2022-02-08 16:29:25 -08:00
|
|
|
# fmt: off
|
2020-04-28 22:24:55 -07:00
|
|
|
# __doc_import_begin__
|
|
|
|
from ray import serve
|
|
|
|
|
|
|
|
from io import BytesIO
|
|
|
|
from PIL import Image
|
|
|
|
|
|
|
|
import torch
|
|
|
|
from torchvision import transforms
|
|
|
|
from torchvision.models import resnet18
|
|
|
|
# __doc_import_end__
|
2022-02-08 16:29:25 -08:00
|
|
|
# fmt: on
|
2020-04-28 22:24:55 -07:00
|
|
|
|
|
|
|
|
|
|
|
# __doc_define_servable_begin__
|
2021-05-03 13:19:34 -05:00
|
|
|
@serve.deployment(route_prefix="/image_predict")
|
2020-04-28 22:24:55 -07:00
|
|
|
class ImageModel:
|
|
|
|
def __init__(self):
|
2020-06-18 15:41:43 -07:00
|
|
|
self.model = resnet18(pretrained=True).eval()
|
2020-04-28 22:24:55 -07:00
|
|
|
self.preprocessor = transforms.Compose(
|
|
|
|
[
|
|
|
|
transforms.Resize(224),
|
|
|
|
transforms.CenterCrop(224),
|
|
|
|
transforms.ToTensor(),
|
|
|
|
transforms.Lambda(lambda t: t[:3, ...]), # remove alpha channel
|
2020-06-18 15:41:43 -07:00
|
|
|
transforms.Normalize(
|
|
|
|
mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]
|
|
|
|
),
|
2020-04-28 22:24:55 -07:00
|
|
|
]
|
|
|
|
)
|
|
|
|
|
2020-12-21 13:34:15 -08:00
|
|
|
async def __call__(self, starlette_request):
|
|
|
|
image_payload_bytes = await starlette_request.body()
|
2020-04-28 22:24:55 -07:00
|
|
|
pil_image = Image.open(BytesIO(image_payload_bytes))
|
|
|
|
print("[1/3] Parsed image data: {}".format(pil_image))
|
|
|
|
|
|
|
|
pil_images = [pil_image] # Our current batch size is one
|
|
|
|
input_tensor = torch.cat(
|
|
|
|
[self.preprocessor(i).unsqueeze(0) for i in pil_images]
|
|
|
|
)
|
|
|
|
print("[2/3] Images transformed, tensor shape {}".format(input_tensor.shape))
|
|
|
|
|
|
|
|
with torch.no_grad():
|
|
|
|
output_tensor = self.model(input_tensor)
|
|
|
|
print("[3/3] Inference done!")
|
|
|
|
return {"class_index": int(torch.argmax(output_tensor[0]))}
|
2022-08-05 09:55:31 -07:00
|
|
|
# __doc_define_servable_end__
|
2020-04-28 22:24:55 -07:00
|
|
|
|
|
|
|
|
|
|
|
# __doc_deploy_begin__
|
2022-08-05 09:55:31 -07:00
|
|
|
app = ImageModel.bind()
|
2020-04-28 22:24:55 -07:00
|
|
|
# __doc_deploy_end__
|