jonas's picture
mh
71952de
raw
history blame
1.46 kB
import gradio as gr
import cv2
import requests
import os
from PIL import Image
import torch
import ultralytics
model = torch.hub.load("ultralytics/yolov5", "custom", path="yolov5_0.65map_exp7_best.pt",
force_reload=False)
model.conf = 0.20 # NMS confidence threshold
path = [['img/test-image.jpg'], ['img/test-image-2.jpg']]
# def show_preds_image(image_path):
# image = cv2.imread(image_path)
# outputs = model.predict(source=image_path)
# results = outputs[0].cpu().numpy()
# for i, det in enumerate(results.boxes.xyxy):
# cv2.rectangle(
# image,
# (int(det[0]), int(det[1])),
# (int(det[2]), int(det[3])),
# color=(0, 0, 255),
# thickness=2,
# lineType=cv2.LINE_AA
# )
# return cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
def show_preds_image(im):
#g = (size / max(im.size)) # gain
#im = im.resize((int(x * g) for x in im.size), Image.ANTIALIAS) # resize
results = model(im) # inference
return results.render()[0]
inputs_image = [
gr.components.Image(type="filepath", label="Input Image"),
]
outputs_image = [
gr.components.Image(type="filepath", label="Output Image"),
]
interface_image = gr.Interface(
fn=show_preds_image,
inputs=inputs_image,
outputs=outputs_image,
title="Cashew Disease Detection",
examples=path,
cache_examples=False,
)
interface_image.launch()