towhee
/
vit-image-embedding
copied
3 changed files with 23 additions and 89 deletions
@ -1,24 +0,0 @@ |
|||||
# Copyright 2021 Zilliz. All rights reserved. |
|
||||
# |
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||
# you may not use this file except in compliance with the License. |
|
||||
# You may obtain a copy of the License at |
|
||||
# |
|
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
|
||||
# |
|
||||
# Unless required by applicable law or agreed to in writing, software |
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||
# See the License for the specific language governing permissions and |
|
||||
# limitations under the License. |
|
||||
|
|
||||
import os |
|
||||
|
|
||||
# For requirements. |
|
||||
try: |
|
||||
import timm |
|
||||
except ModuleNotFoundError: |
|
||||
os.system('pip install timm') |
|
||||
|
|
||||
from timm.data import resolve_data_config |
|
||||
from timm.data.transforms_factory import create_transform |
|
@ -1,42 +0,0 @@ |
|||||
# Copyright 2021 Zilliz. All rights reserved. |
|
||||
# |
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||
# you may not use this file except in compliance with the License. |
|
||||
# You may obtain a copy of the License at |
|
||||
# |
|
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
|
||||
# |
|
||||
# Unless required by applicable law or agreed to in writing, software |
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||
# See the License for the specific language governing permissions and |
|
||||
# limitations under the License. |
|
||||
|
|
||||
|
|
||||
import torch |
|
||||
from torch.nn import Linear |
|
||||
from torch import nn |
|
||||
import timm |
|
||||
|
|
||||
|
|
||||
class Model(): |
|
||||
""" |
|
||||
PyTorch model class |
|
||||
""" |
|
||||
def __init__(self, model_name: str, weights_path: str, num_classes=1000): |
|
||||
super().__init__() |
|
||||
if weights_path: |
|
||||
self._model = timm.create_model(model_name, checkpoint_path=weights_path, num_classes=num_classes) |
|
||||
else: |
|
||||
self._model = timm.create_model(model_name, pretrained=True, num_classes=num_classes) |
|
||||
self._model.eval() |
|
||||
|
|
||||
def __call__(self, img_tensor: torch.Tensor): |
|
||||
self._model.eval() |
|
||||
features = self._model.forward_features(img_tensor) |
|
||||
if features.dim() == 4: # if the shape of feature map is [N, C, H, W], where H > 1 and W > 1 |
|
||||
global_pool = nn.AdaptiveAvgPool2d(1) |
|
||||
features = global_pool(features) |
|
||||
return features.flatten().detach().numpy() |
|
||||
|
|
||||
|
|
Loading…
Reference in new issue