File size: 871 Bytes
1b5a4cf
82cc87e
e8710db
 
228a778
e8710db
228a778
 
 
e8710db
 
 
 
228a778
e8710db
228a778
 
 
 
 
 
e8710db
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import gradio as gr
from transformers import VisionEncoderDecoderModel, AutoTokenizer
from PIL import Image
import io
import torch

# Load model and tokenizer
model = VisionEncoderDecoderModel.from_pretrained("liuhaotian/LLaVA-1.5-7b")
tokenizer = AutoTokenizer.from_pretrained("liuhaotian/LLaVA-1.5-7b")

# Function to analyze the image
def analyze_image(image_blob):
    image = Image.open(io.BytesIO(image_blob))
    pixel_values = torch.tensor(image).unsqueeze(0)  # Add batch dimension
    inputs = tokenizer("Analyze the emotions in this image", return_tensors="pt")
    
    # Run the model
    outputs = model.generate(**inputs, pixel_values=pixel_values)
    result = tokenizer.decode(outputs[0], skip_special_tokens=True)
    
    return result

# Set up the Gradio interface
iface = gr.Interface(fn=analyze_image, inputs="file", outputs="text")
iface.launch()