import os from typing import List, Tuple, Dict, Any import openai import streamlit as st from langchain.agents import AgentType, initialize_agent, load_tools from langchain.llms import OpenAI as l_OpenAI import requests OPENAI_API_KEY = os.environ["OPENAI_API_KEY"] SERPAPI_API_KEY = os.environ["SERPAPI_API_KEY"] openai_client = openai.OpenAI(api_key=OPENAI_API_KEY) def call_chatgpt(query: str, model: str = "gpt-3.5-turbo") -> str: """ Generates a response to a query using the specified language model. Args: query (str): The user's query that needs to be processed. model (str, optional): The language model to be used. Defaults to "gpt-3.5-turbo". Returns: str: The generated response to the query. """ # Prepare the conversation context with system and user messages. messages = [ {"role": "system", "content": "You are a helpful assistant."}, {"role": "user", "content": f"Question: {query}."}, ] # Use the OpenAI client to generate a response based on the model and the conversation context. response = openai_client.chat.completions.create( model=model, messages=messages, ) # Extract the content of the response from the first choice. content: str = response.choices[0].message.content # Return the generated content. return content def call_langchain(prompt: str) -> str: """ Initializes a language model with specific settings, loads additional tools, initializes an agent with these tools, and then runs the agent with a given prompt to produce a text response. Args: prompt (str): The input text prompt that the agent will process. Returns: str: The text output produced by the agent after processing the input prompt. """ # Initialize the OpenAI language model with a specified temperature # and the OpenAI API key. It's assumed that `l_OpenAI` is a class or function # that is responsible for setting up the language model with the given parameters. llm = l_OpenAI(temperature=0, openai_api_key=OPENAI_API_KEY) # Type: ignore # Load additional tools needed for the agent. Here, 'serpapi' for search engine results # and 'llm-math' for math capabilities are loaded, along with their respective API keys. # The `load_tools` function is assumed to return a dictionary of initialized tools, # with the tools being ready for use by the agent. tools = load_tools( # Type: ignore ["serpapi", "llm-math"], llm=llm, serpapi_api_key=SERPAPI_API_KEY ) # Initialize the agent with the provided tools, the language model, and specific agent settings. # The agent is set to a ZERO_SHOT_REACT_DESCRIPTION type, which likely defines its behavior # or capabilities, with verbosity enabled for detailed logs. # The `initialize_agent` function presumably returns an instance of an agent configured # with the specified tools and settings, ready to process prompts. agent = initialize_agent( # Type: ignore tools, llm, agent_type=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True ) # Execute the agent with the given prompt and capture the output. # The `run` method of the agent is assumed to process the prompt and return a string response, # which is then returned by this function to the caller. output: str = agent.run(prompt) return output def query(payload: Dict[str, Any]) -> Dict[str, Any]: """ Sends a JSON payload to a predefined API URL and returns the JSON response. Args: payload (Dict[str, Any]): The JSON payload to be sent to the API. Returns: Dict[str, Any]: The JSON response received from the API. """ # API endpoint URL API_URL = "https://sks7h7h5qkhoxwxo.us-east-1.aws.endpoints.huggingface.cloud" # Headers to indicate both the request and response formats are JSON headers = { "Accept": "application/json", "Content-Type": "application/json" } # Sending a POST request with the JSON payload and headers response = requests.post(API_URL, headers=headers, json=payload) # Returning the JSON response return response.json() def llama2_7b_ysa(prompt: str) -> str: """ Queries a model and retrieves the generated text based on the given prompt. This function sends a prompt to a model (presumably named 'llama2_7b') and extracts the generated text from the model's response. It's tailored for handling responses from a specific API or model query structure where the response is expected to be a list of dictionaries, with at least one dictionary containing a key 'generated_text'. Parameters: - prompt (str): The text prompt to send to the model. Returns: - str: The generated text response from the model. Note: - The function assumes that the 'query' function is previously defined and accessible within the same scope or module. It should send a request to the model and return the response in a structured format. - The 'parameters' dictionary is passed empty but can be customized to include specific request parameters as needed by the model API. """ # Define the query payload with the prompt and any additional parameters query_payload: Dict[str, Any] = { "inputs": prompt, "parameters": {} } # Send the query to the model and store the output response output = query(query_payload) # Extract the 'generated_text' from the first item in the response list response: str = output[0]['generated_text'] return response def llama2_7b_brk_letters(prompt: str) -> str: """ Queries the LLaMA 2 7B model hosted on a specific Hugging Face endpoint with a given prompt, and returns the generated text as a response. Args: prompt (str): The input text prompt to be sent to the LLaMA 2 7B model for generating text. Returns: str: The text generated by the LLaMA 2 7B model in response to the input prompt. """ # Endpoint URL of the LLaMA 2 7B model hosted on Hugging Face. API_URL = "https://fjnshtq0d24uia40.us-east-1.aws.endpoints.huggingface.cloud" # Headers to include in the HTTP request. Specifies the expected format of the response and request. headers = { "Accept": "application/json", "Content-Type": "application/json" } def query_llama2_7b_brk_letters(payload: dict) -> dict: """ Sends a POST request to the LLaMA 2 7B API endpoint with a given payload. Args: payload (dict): The data to be sent in the POST request, including the input prompt and any parameters for the model. Returns: dict: The JSON response from the API, parsed into a dictionary. """ response = requests.post(API_URL, headers=headers, json=payload) return response.json() # The payload for the POST request, including the prompt and any model parameters. output = query_llama2_7b_brk_letters({ "inputs": prompt, "parameters": {} }) # Extracts the generated text from the API's response. response = output[0]['generated_text'] return response