from typing import Union from fastapi import FastAPI,File from PIL import Image from io import BytesIO from transformers import DetrImageProcessor, DetrForObjectDetection import torch import requests app = FastAPI(title="Object Detection", docs_url="/", description="Object detection in Image") processor = DetrImageProcessor.from_pretrained("facebook/detr-resnet-50") model = DetrForObjectDetection.from_pretrained("facebook/detr-resnet-50") @app.post('/image') def read_image(image_file: bytes = File(...)): #image = Image.open(BytesIO(image_file)) url = "http://images.cocodataset.org/val2017/000000039769.jpg" image = Image.open(requests.get(url, stream=True).raw) inputs = processor(images=image, return_tensors="pt") outputs = model(**inputs) target_sizes = torch.tensor([image.size[::-1]]) results = processor.post_process_object_detection(outputs, target_sizes=target_sizes, threshold=0.9)[0] return results