Julien Simon
- Add apple/mobilevit-small
f9ccbb5
import gradio as gr
from transformers import pipeline
model_names = [
"apple/mobilevit-small",
"facebook/deit-base-patch16-224",
"facebook/convnext-base-224",
"google/vit-base-patch16-224",
"google/mobilenet_v2_1.4_224",
"microsoft/resnet-50",
"microsoft/swin-base-patch4-window7-224",
"microsoft/beit-base-patch16-224",
"nvidia/mit-b0",
"shi-labs/nat-base-in1k-224",
"shi-labs/dinat-base-in1k-224",
]
def process(image_file, top_k):
labels = []
for m in model_names:
p = pipeline("image-classification", model=m)
pred = p(image_file)
labels.append({x["label"]: x["score"] for x in pred[:top_k]})
return labels
# Inputs
image = gr.Image(type="filepath", label="Upload an image")
top_k = gr.Slider(minimum=1, maximum=5, step=1, value=5, label="Top k classes")
# Output
labels = [gr.Label(label=m) for m in model_names]
description = "This Space lets you quickly compare the most popular image classifiers available on the hub, including the recent NAT and DINAT models. All of them have been fine-tuned on the ImageNet-1k dataset. Anecdotally, the three sample images have been generated with a Stable Diffusion model :)"
iface = gr.Interface(
theme="huggingface",
description=description,
layout="horizontal",
fn=process,
inputs=[image, top_k],
outputs=labels,
examples=[
["bike.jpg", 5],
["car.jpg", 5],
["food.jpg", 5],
],
allow_flagging="never",
)
iface.launch()