| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 | import pandas as pdimport numpy as npfrom groq import Groqfrom pinecone import Pineconeimport osfrom langchain_community.embeddings.sentence_transformer import SentenceTransformerEmbeddingsfrom langchain_pinecone import PineconeVectorStoredef get_relevant_excerpts(user_question, docsearch):    """    This function retrieves the most relevant excerpts from presidential speeches based on the user's question.    Parameters:    user_question (str): The question asked by the user.    docsearch (PineconeVectorStore): The Pinecone vector store containing the presidential speeches.    Returns:    str: A string containing the most relevant excerpts from presidential speeches.    """    # Perform a similarity search on the Pinecone vector store using the user's question    relevent_docs = docsearch.similarity_search(user_question)    # Extract the page content from the top 3 most relevant documents and join them into a single string    relevant_excerpts = '\n\n------------------------------------------------------\n\n'.join([doc.page_content for doc in relevent_docs[:3]])    return relevant_excerptsdef presidential_speech_chat_completion(client, model, user_question, relevant_excerpts):    """    This function generates a response to the user's question using a pre-trained model.    Parameters:    client (Groq): The Groq client used to interact with the pre-trained model.    model (str): The name of the pre-trained model.    user_question (str): The question asked by the user.    relevant_excerpts (str): A string containing the most relevant excerpts from presidential speeches.    Returns:    str: A string containing the response to the user's question.    """    # Define the system prompt    system_prompt = '''    You are a presidential historian. Given the user's question and relevant excerpts from     presidential speeches, answer the question by including direct quotes from presidential speeches.     When using a quote, site the speech that it was from (ignoring the chunk).    '''    # Generate a response to the user's question using the pre-trained model    chat_completion = client.chat.completions.create(        messages = [            {                "role": "system",                "content":  system_prompt            },            {                "role": "user",                "content": "User Question: " + user_question + "\n\nRelevant Speech Excerpt(s):\n\n" + relevant_excerpts,            }        ],        model = model    )    # Extract the response from the chat completion    response = chat_completion.choices[0].message.content    return responsedef main():    """    This is the main function that runs the application. It initializes the Groq client and the SentenceTransformer model,    gets user input from the Streamlit interface, retrieves relevant excerpts from presidential speeches based on the user's question,    generates a response to the user's question using a pre-trained model, and displays the response.    """    model = 'llama3-8b-8192'    embedding_function = SentenceTransformerEmbeddings(model_name="all-MiniLM-L6-v2")    # Initialize the Groq client    groq_api_key = os.getenv('GROQ_API_KEY')    pinecone_api_key=os.getenv('PINECONE_API_KEY')    pinecone_index_name = "presidential-speeches"    client = Groq(        api_key=groq_api_key    )    pc = Pinecone(api_key = pinecone_api_key)    docsearch = PineconeVectorStore(index_name=pinecone_index_name, embedding=embedding_function)    # Display the title and introduction of the application    print("Presidential Speeches RAG")    multiline_text = """    Welcome! Ask questions about U.S. presidents, like "What were George Washington's views on democracy?" or "What did Abraham Lincoln say about national unity?". The app matches your question to relevant excerpts from presidential speeches and generates a response using a pre-trained model.    """    print(multiline_text)    while True:        # Get the user's question        user_question = input("Ask a question about a US president: ")        if user_question:            pinecone_index_name = "presidential-speeches"            relevant_excerpts = get_relevant_excerpts(user_question, docsearch)            response = presidential_speech_chat_completion(client, model, user_question, relevant_excerpts)            print(response)if __name__ == "__main__":    main()
 |