|
|
@ -24,6 +24,7 @@ import os |
|
|
|
from towhee.operator import Operator |
|
|
|
from timm.data import resolve_data_config |
|
|
|
from timm.data.transforms_factory import create_transform |
|
|
|
from towhee.utils.pil_utils import to_pil |
|
|
|
|
|
|
|
import warnings |
|
|
|
warnings.filterwarnings("ignore") |
|
|
@ -52,8 +53,8 @@ class VitImageEmbedding(Operator): |
|
|
|
config = resolve_data_config({}, model=self.model._model) |
|
|
|
self.tfms = create_transform(**config) |
|
|
|
|
|
|
|
def __call__(self, img_path: str) -> NamedTuple('Outputs', [('feature_vector', numpy.ndarray)]): |
|
|
|
def __call__(self, image: 'towhee.types.Image') -> NamedTuple('Outputs', [('feature_vector', numpy.ndarray)]): |
|
|
|
img = self.tfms(to_pil(image)).unsqueeze(0) |
|
|
|
Outputs = NamedTuple('Outputs', [('feature_vector', numpy.ndarray)]) |
|
|
|
img = self.tfms(Image.open(img_path)).unsqueeze(0) |
|
|
|
features = self.model(img) |
|
|
|
return Outputs(features.flatten().detach().numpy()) |
|
|
|