Spaces:
Running
Running
import pickle | |
import gradio as gr | |
from datasets import load_dataset | |
from transformers import AutoModel, AutoFeatureExtractor | |
seed = 42 | |
# Only runs once when the script is first run. | |
with open("index.pickle", "rb") as handle: | |
index = pickle.load(handle) | |
# Load model for computing embeddings. | |
feature_extractor = AutoFeatureExtractor.from_pretrained("abhishek/autotrain-butterflies-new-17716425") | |
model = AutoModel.from_pretrained("abhishek/autotrain-butterflies-new-17716425") | |
# Candidate images. | |
dataset = load_dataset("sasha/butterflies_names_multiple") | |
ds = dataset["train"] | |
def query(image, top_k): | |
inputs = feature_extractor(image, return_tensors="pt") | |
model_output = model(**inputs) | |
embedding = model_output.pooler_output.detach() | |
results = index.query(embedding) | |
images=[] | |
for i in results[0].tolist(): | |
print(i) | |
print(type(i)) | |
images.append(ds.select(i)["image"]) | |
return images | |
title = "Find my Butterfly 🦋" | |
description = "This Space demos an image similarity system. You can refer to [this notebook](TODO) to know the details of the system. You can pick any image from the available samples below. On the right hand side, you'll find the similar images returned by the system. The example images have been named with their corresponding integer class labels for easier identification. The fetched images will also have their integer labels tagged so that you can validate the correctness of the results." | |
# You can set the type of gr.Image to be PIL, numpy or str (filepath) | |
# Not sure what the best for this demo is. | |
gr.Interface( | |
query, | |
inputs=[gr.Image(type="pil"), gr.Slider(value=5, minimum=1, maximum=10, step=1)], | |
outputs=gr.Gallery().style(grid=[3], height="auto"), | |
# Filenames denote the integer labels. Know here: https://hf.co/datasets/beans | |
title=title, | |
description=description, | |
#examples=[["0.png", 5], ["1.png", 5], ["2.png", 5]], | |
).launch() | |