FoodVision / app.py
Th3BossC's picture
first commit
15935e0
raw
history blame
1.32 kB
# creating app.py
########## imports ############
import torch
import torch.nn as nn
from torchvision import models, transforms
import gradio as gr
from model import create_model
import PIL
from PIL import Image
import os
from pathlib import Path
###############################
def predict(img):
effnetb2, transform = create_model()
class_names = []
with open('classes.txt', 'r') as f:
class_names = [foodname.strip() for foodname in f.readlines()]
effnetb2.load_state_dict(torch.load(f = 'effnet_b2_food101.pth', map_location = torch.device('cpu')))
img = transform(img).unsqueeze(0)
model.eval()
with torch.inference_mode():
pred_label = class_names[model(img).softmax(dim = 1).argmax(dim = 1)]
print(pred_label)
return pred_label
###############################
title = 'FoodVision Project'
description = 'FoodVision is an image classification model based on EfficientNet_B2 which has been trained on a 101 different classes using the Food101 dataset'
###############################
example_list = [['examples/' + example] for example in os.listdir('examples')] ##############
demo = gr.Interface(
fn = predict,
inputs = gr.Image(type = 'pil'),
outputs = [gr.Textbox()],
title = title,
description = description
)
demo.launch()