andresgtn's picture
Update app.py
c478e88
import datasets
from transformers import AutoFeatureExtractor, AutoModelForImageClassification
import numpy as np
import gradio as gr
import torch
dataset = datasets.load_dataset("beans") # This should be the same as the first line of Python code in this Colab notebook
extractor = AutoFeatureExtractor.from_pretrained("andresgtn/vit-base-bean-health-classifier")
model = AutoModelForImageClassification.from_pretrained("andresgtn/vit-base-bean-health-classifier")
# add to cuda?
#model.eval()
#model.to(device)
labels = dataset['train'].features['labels'].names
def classify(im):
features = extractor(im, return_tensors='pt')
#features.to(device) # move to gpu as model, if available
with torch.no_grad():
logits = model(**features).logits
probability = torch.nn.functional.softmax(logits, dim=-1)
#probs = probability[0].to('cpu').detach().numpy()
probs = probability[0].detach().numpy()
confidences = {label: float(probs[i]) for i, label in enumerate(labels)}
return confidences
#interface = gr.Interface(classify, gr.Image(shape=(200, 200)), 'text')
sample_images=[['https://s3.amazonaws.com/moonup/production/uploads/1663933284359-611f9702593efbee33a4f7c9.png'],
['https://s3.amazonaws.com/moonup/production/uploads/1663933284374-611f9702593efbee33a4f7c9.png'],
['https://s3.amazonaws.com/moonup/production/uploads/1663933284412-611f9702593efbee33a4f7c9.png']]
title = "Bean leaf disease classifier"
description = "Upload an image of a bean leaf to find out if it is diseased"
interface = gr.Interface(classify, gr.Image(shape=(200, 200)), 'label',
examples=sample_images, title=title, description=description)
#demo.launch()
interface.launch(debug=False)