# Import required libraries - packages import gradio as gr import torch from PIL import Image from transformers import AutoModel, AutoTokenizer import spaces from googletrans import Translator translator = Translator() def translate_to_english(text): return translator.translate(text, src='zh-cn', dest='en').text device="cuda" # Load the model and tokenizer model = AutoModel.from_pretrained('openbmb/MiniCPM-Llama3-V-2_5', trust_remote_code=True, torch_dtype=torch.float16) model = model.to(device='cuda') tokenizer = AutoTokenizer.from_pretrained('openbmb/MiniCPM-Llama3-V-2_5', trust_remote_code=True) model.eval() # Define a function to generate a response @spaces.GPU def generate_response(image, question): msgs = [{'role': 'user', 'content': question}] res = model.chat( image=image, msgs=msgs, tokenizer=tokenizer, sampling=True, temperature=0.7, stream=True ) generated_text = "".join(res) # Translate to English translated_text = translate_to_english(generated_text) return translated_text def generate_response_old(image, question): msgs = [{'role': 'user', 'content': question}] res = model.chat( image=image, msgs=msgs, tokenizer=tokenizer, sampling=True, temperature=0.7, stream=True ) generated_text = "" for new_text in res: generated_text += new_text return generated_text # Create the footer with links footer = """