from turtle import title import gradio as gr from transformers import pipeline import numpy as np from PIL import Image pipes = { "chinese-clip-vit-base-patch16": pipeline("zero-shot-image-classification", model="OFA-Sys/chinese-clip-vit-base-patch16"), "chinese-clip-vit-large-patch14": pipeline("zero-shot-image-classification", model="OFA-Sys/chinese-clip-vit-large-patch14"), "chinese-clip-vit-large-patch14-336px": pipeline("zero-shot-image-classification", model="OFA-Sys/chinese-clip-vit-large-patch14-336px"), "chinese-clip-vit-huge-patch14": pipeline("zero-shot-image-classification", model="OFA-Sys/chinese-clip-vit-huge-patch14"), } images="festival.jpg" def shot(image, labels_text): PIL_image = Image.fromarray(np.uint8(image)).convert('RGB') labels = labels_text.split(",") res = pipes['chinese-clip-vit-base-patch16'](images=PIL_image, candidate_labels=labels, hypothesis_template= "一张{}的图片。") return {dic["label"]: dic["score"] for dic in res} iface = gr.Interface(shot, ["image", "text"], "label", examples=[["festival.jpg", "灯笼, 鞭炮, 对联"], ["cat-dog-music.png", "音乐表演, 体育运动"], ["football-match.jpg", "梅西, C罗, 马奎尔"]], description="Add a picture and a list of labels separated by commas", title="Zero-shot Image Classification") iface.launch()