from langchain.embeddings.openai import OpenAIEmbeddings from langchain.agents import create_csv_agent from langchain.vectorstores import Chroma from langchain.text_splitter import CharacterTextSplitter from langchain.chains.question_answering import load_qa_chain from langchain.llms import OpenAI from langchain.document_loaders.csv_loader import CSVLoader import os import pandas as pd file_name = 'gpt-generated-food-data.csv' df = pd.read_csv(file_name) agent = create_csv_agent(OpenAI(temperature=0), file_name, verbose=True) loader = CSVLoader(file_path=file_name) data = loader.load() text_splitter = CharacterTextSplitter(chunk_size=100, chunk_overlap=0, separator = "\n") texts = text_splitter.split_text(data) embeddings = OpenAIEmbeddings() docsearch = Chroma.from_texts(texts, embeddings, metadatas=[{"source": str(i)} for i in range(len(texts))]).as_retriever() chain = load_qa_chain(OpenAI(temperature=0), chain_type="stuff") def make_inference(query): docs = docsearch.get_relevant_documents(query) return(chain.run(input_documents=docs, question=query)) if __name__ == "__main__": # make a gradio interface import gradio as gr gr.Interface( make_inference, [ gr.inputs.Textbox(lines=2, label="Query"), ], gr.outputs.Textbox(label="Response"), title="🍲SmartMenuCSV📄", description="🍲SmartMenuCSV📄 is a tool that allows you to ask questions about food menu items.", ).launch()