Sandhya
change app
9f77617
import gradio as gr
import os
import torch
from model import create_model
from timeit import default_timer as timer
class_names=["Pizza","Steak","Sushi"]
effnetb2,effnetb2_transform=create_model(num_class=3)
effnetb2.load_state_dict(torch.load(f="effnetb2_pizza_steak_sushi (1).pt",map_location=torch.device('cpu')))
def predict(img):
start_time=timer()
img=effnetb2_transform(img).unsqueeze(0)
effnetb2.eval()
with torch.inference_mode():
predict_logit=effnetb2(img)
predict_prob=torch.softmax(predict_logit,dim=1)
predict_label=torch.argmax(predict_prob,dim=1)
pred_label_prob={class_names[i]:float(predict_prob[0][i]) for i in range(len(class_names))}
end_time=timer()
pred_time=round(end_time-start_time,4)
return pred_label_prob,pred_time
title="Food Vision Mini 🍕🥩🍣"
description="An EfficientNetB2 feature extractor computer vision model to classify images of food as pizza, steak or sushi."
example_list=[['examples/'+example] for example in os.listdir("examples")]
demo=gr.Interface(fn=predict,inputs=gr.Image(type="pil"),outputs=[gr.Label(num_top_classes=3,label="Prediction"),gr.Number(label="Prediction time")],examples=example_list,title=title,description=description)
demo.launch()