logo
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Readme
Files and versions

63 lines
2.3 KiB

# 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.
from typing import NamedTuple, Union
import torch
import numpy as np
from PIL import Image
from torchvision import transforms
from towhee.operator import Operator
class TransformImage(Operator):
"""
Use PyTorch to transform an image (resize, crop, normalize, etc...)
Args:
size (`int`):
Image size to use. A resize to `size x size` followed by center crop and
image normalization will be done.
"""
def __init__(self, size: int) -> None:
super().__init__()
# user defined transform
self.tfms = transforms.Compose(
[
transforms.Resize(size),
transforms.CenterCrop(224),
transforms.ToTensor(),
transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225]),
]
)
def __call__(self, img_tensor: Union[np.ndarray, Image.Image, torch.Tensor, str]) -> NamedTuple('Outputs', [('img_transformed', torch.Tensor)]):
"""
Call it when use this class.
Args:
img_tensor (`Union[np.ndarray, Image.Image, torch.Tensor, str]`):
The image data to be normalized, you can try one of the
four formats: np.ndarray, Image.Image, torch.Tensor and str.
Returns:
(`torch.Tensor`)
The normalized image tensor.
"""
if isinstance(img_tensor, str):
img_tensor = Image.open(img_tensor)
if isinstance(img_tensor, Image.Image):
img_tensor = img_tensor.convert('RGB')
Outputs = NamedTuple('Outputs', [('img_transformed', torch.Tensor)])
return Outputs(self.tfms(img_tensor).unsqueeze(0))