VLM / app.py
WaysAheadGlobal's picture
Update app.py
48bd4ea verified
import streamlit as st
from transformers import pipeline
from PIL import Image
# Page config
st.set_page_config(page_title="TinyLLaVA Snapshot", layout="centered")
st.title("πŸ“Έ TinyLLaVA β€” Snapshot Q&A (Hugging Face Spaces Safe)")
# Load TinyLLaVA pipeline
st.info("Loading TinyLLaVA... Please wait ⏳")
pipe = pipeline(
task="image-to-text",
model="bczhou/tiny-llava-v1-hf",
trust_remote_code=True,
device_map="cpu"
)
st.success("βœ… Model loaded!")
# Widgets
st.markdown("**1️⃣ Take a snapshot OR upload an image**")
image = st.camera_input("πŸ“· Click 'Take Photo' below:")
if not image:
image = st.file_uploader("πŸ“‚ Or upload an image file", type=["jpg", "png", "jpeg"])
st.markdown("**2️⃣ Enter your question:**")
prompt = st.text_input("πŸ’¬", value="Describe this scene.")
# Debug info
st.write(f"πŸ“Έ Image uploaded: {'Yes' if image else 'No'}")
st.write(f"πŸ’¬ Prompt: {prompt}")
# If both present
if image and prompt:
img = Image.open(image).convert("RGB")
st.image(img, caption="Your Image", use_column_width=True)
query = f"USER: <image>\n{prompt}\nASSISTANT:"
with st.spinner("TinyLLaVA is generating..."):
result = pipe(query, img)
answer = result[0]["generated_text"]
st.subheader("πŸ“ Answer")
st.write(answer)