import os import gradio as gr from langchain_openai import ChatOpenAI from langchain_community.embeddings import HuggingFaceEmbeddings from langchain.text_splitter import RecursiveCharacterTextSplitter from langchain_community.vectorstores import Chroma from langchain_community.document_loaders import PyPDFLoader from langchain.chains import ConversationalRetrievalChain from langchain_community.chat_message_histories import ChatMessageHistory from langchain.memory import ConversationBufferMemory from langchain_core.prompts import PromptTemplate # Access the OpenAI API key from the environment open_ai_key = os.getenv("OPENAI_API_KEY") llm = ChatOpenAI(api_key=open_ai_key) template = """Use the following pieces of information to answer the user's question. If you don't know the answer, just say that you don't know, don't try to make up an answer. Context: {context} Question: {question} Only return the helpful answer below and nothing else. Helpful answer: """ prompt = PromptTemplate(template=template, input_variables=["context", "question"]) def process_pdf_and_answer(pdf_file, question): # Load and process the PDF loader = PyPDFLoader(pdf_file.name) pdf_data = loader.load() # Split the text into chunks text_splitter = RecursiveCharacterTextSplitter(chunk_size=1000, chunk_overlap=200) docs = text_splitter.split_documents(pdf_data) # Create a Chroma vector store embeddings = HuggingFaceEmbeddings(model_name="embaas/sentence-transformers-multilingual-e5-base") db = Chroma.from_documents(docs, embeddings) # Initialize message history for conversation message_history = ChatMessageHistory() # Memory for conversational context memory = ConversationBufferMemory( memory_key="chat_history", output_key="answer", chat_memory=message_history, return_messages=True, ) # Create a chain that uses the Chroma vector store chain = ConversationalRetrievalChain.from_llm( llm=llm, chain_type="stuff", retriever=db.as_retriever(), memory=memory, return_source_documents=False, combine_docs_chain_kwargs={'prompt': prompt} ) # Process the question res = chain({"question": question}) return res["answer"] gr.Interface( fn=process_pdf_and_answer, inputs=[gr.File(file_count="single", type="filepath"), gr.Textbox(lines=2, placeholder="Ask a question...")], outputs="text", title="PDF Q&A", description="Upload a pdf and ask questions about it" ).launch()