Spaces:
Runtime error
Runtime error
from dotenv import load_dotenv | |
import os | |
import streamlit as st | |
from PIL import Image | |
from transformers import ViltProcessor, ViltForQuestionAnswering | |
from langchain.prompts import PromptTemplate | |
from langchain.chains import LLMChain | |
from streamlit_extras.add_vertical_space import add_vertical_space | |
from langchain.llms import OpenAI | |
load_dotenv() | |
processor = ViltProcessor.from_pretrained("dandelin/vilt-b32-finetuned-vqa") | |
model = ViltForQuestionAnswering.from_pretrained("dandelin/vilt-b32-finetuned-vqa") | |
llm = OpenAI(temperature=0.2) | |
prompt = PromptTemplate( | |
input_variables=["question", "elements"], | |
template="""Please generate a structured response using the following information: | |
\n\n | |
#Question: {question} | |
#Response: {elements} | |
\n\n | |
Your structured response:""", | |
) | |
def process_query(image, query): | |
encoding = processor(image, query, return_tensors="pt") | |
outputs = model(**encoding) | |
logits = outputs.logits | |
idx = logits.argmax(-1).item() | |
chain = LLMChain(llm=llm, prompt=prompt) | |
response = chain.run(question=query, elements=model.config.id2label[idx]) | |
return response | |
st.set_page_config(page_title="Insightly") | |
# Sidebar contents | |
with st.sidebar: | |
st.sidebar.image("https://i.ibb.co/bX6GdqG/insightly-wbg.png", use_column_width=True) | |
st.sidebar.markdown("<p class='sidebar-link'>π <a href='https://insightly-csv-bot.hf.space/'> CSV Bot</a></p>", unsafe_allow_html=True) | |
st.sidebar.markdown("<p class='sidebar-link'>π <a href='https://chandrakalagowda-demo2.hf.space/'> PDF Bot </a></p>", unsafe_allow_html=True) | |
st.sidebar.markdown("<p class='sidebar-link'>πΈ <a href='https://insightly-frame-capturer.hf.space/'> Frame Capturer</a></p>", unsafe_allow_html=True) | |
st.sidebar.markdown("<div class='vertical-space'></div>", unsafe_allow_html=True) | |
# Custom CSS to style the link and create vertical space | |
st.markdown( | |
""" | |
<style> | |
.image-container { | |
margin-bottom: 60px; | |
} | |
.sidebar-link { | |
display: flex; | |
justify-content: left; | |
font-size: 28px; | |
margin-top: 20px; | |
margin-left: 10px; | |
} | |
.vertical-space { | |
height: 20px; | |
} | |
</style> | |
""", | |
unsafe_allow_html=True, | |
) | |
def main(): | |
st.title("Chat With Images πΌοΈ") | |
uploaded_file = st.file_uploader('Upload your Image', type=['png', 'jpeg', 'jpg']) | |
if uploaded_file is not None: | |
image = Image.open(uploaded_file) | |
st.image(image, caption='Uploaded Image.', width=300) | |
cancel_button = st.button('Remove this image') | |
if cancel_button: | |
st.markdown( | |
"""<style> | |
.css-2trqyj:focus, | |
.css-2trqyj:active, | |
.css-2trqyj:hover { | |
outline: 2px solid red; | |
outline-offset: 2px; | |
} | |
</style>""", | |
unsafe_allow_html=True | |
) | |
query = st.text_input('Type your question here') | |
if query: | |
with st.spinner('Processing...'): | |
answer = process_query(image, query) | |
st.write(answer) | |
if cancel_button: | |
st.stop() | |
if __name__ == "__main__": | |
main() | |