diff --git a/10-API-Search.ipynb b/10-API-Search.ipynb index 2452110a..b2e98a18 100644 --- a/10-API-Search.ipynb +++ b/10-API-Search.ipynb @@ -29,7 +29,7 @@ }, { "cell_type": "code", - "execution_count": 2, + "execution_count": 1, "id": "c1fb79a3-4856-4721-988c-112813690a90", "metadata": {}, "outputs": [], @@ -64,7 +64,7 @@ }, { "cell_type": "code", - "execution_count": 3, + "execution_count": 2, "id": "258a6e99-2d4f-4147-b8ee-c64c85296181", "metadata": {}, "outputs": [], @@ -75,7 +75,7 @@ }, { "cell_type": "code", - "execution_count": 4, + "execution_count": 3, "id": "9d3daf03-77e2-466e-a255-2f06bee3561b", "metadata": {}, "outputs": [], @@ -85,6 +85,8 @@ "\n", "COMPLETION_TOKENS = 2000\n", "\n", + "\n", + "# This notebook needs GPT-4-Turbo (context size of 128k tokens)\n", "llm = AzureChatOpenAI(deployment_name=os.environ[\"GPT4_DEPLOYMENT_NAME\"], \n", " temperature=0.5, max_tokens=COMPLETION_TOKENS, \n", " streaming=True, callback_manager=cb_manager)" @@ -137,7 +139,7 @@ }, { "cell_type": "code", - "execution_count": 9, + "execution_count": 4, "id": "8efd8698-aea1-4de3-b810-e9c4782f04c4", "metadata": {}, "outputs": [], @@ -163,7 +165,7 @@ }, { "cell_type": "code", - "execution_count": 10, + "execution_count": 5, "id": "94503afc-c398-458a-b369-610c5dbe682d", "metadata": {}, "outputs": [], @@ -174,7 +176,7 @@ }, { "cell_type": "code", - "execution_count": 11, + "execution_count": 6, "id": "57d77e9b-6f3f-4ec4-bc01-baac18984937", "metadata": {}, "outputs": [ @@ -202,6 +204,14 @@ "Sometimes it makes sense to reduce the size of the API Specs by using the `reduce_openapi_spec` function. It's optional." ] }, + { + "cell_type": "markdown", + "id": "cd8c3b3e-959e-4b19-b34d-66de3501b1b1", + "metadata": {}, + "source": [ + "#### NOTE: As you can see, a large context LLM is needed. `GPT4-turbo` is necessary for this notebook to run succesfully." + ] + }, { "cell_type": "markdown", "id": "9a945386-39eb-405d-9310-3b67c9af77bb", @@ -213,7 +223,7 @@ }, { "cell_type": "code", - "execution_count": 21, + "execution_count": 7, "id": "d020b5de-7ebe-4fb9-9b71-f6c71956149d", "metadata": {}, "outputs": [], @@ -242,7 +252,7 @@ }, { "cell_type": "code", - "execution_count": 13, + "execution_count": 8, "id": "96731b5f-988b-49ec-a5c3-3a344b7085da", "metadata": {}, "outputs": [], @@ -253,17 +263,9 @@ "requests_wrapper = RequestsWrapper(headers=headers)" ] }, - { - "cell_type": "markdown", - "id": "1fd6a140-f675-40db-98ad-b5c955a4f7b6", - "metadata": {}, - "source": [ - "**Note**: Notice that we are using GPT-3.5 (llm_2) below for this chain since it doesn't need too many instructions or reasoning" - ] - }, { "cell_type": "code", - "execution_count": 14, + "execution_count": 9, "id": "426fab6f-ea04-4c07-8211-d9cc5c70ac8e", "metadata": {}, "outputs": [], @@ -283,12 +285,12 @@ "id": "1707e590-809b-4391-bdcd-c7d285ec8fb1", "metadata": {}, "source": [ - "These are the prompts on the APIChain class (on to create the URL endpoint and the other one to use it and get the answer):" + "These are the prompts on the APIChain class (one to create the URL endpoint and the other one to use it and get the answer):" ] }, { "cell_type": "code", - "execution_count": 15, + "execution_count": 10, "id": "9f80d2bb-e285-4d30-88c8-5677e86cebe2", "metadata": {}, "outputs": [ @@ -298,7 +300,7 @@ "'You are given the below API Documentation:\\n{api_docs}\\nUsing this documentation, generate the full API url to call for answering the user question.\\nYou should build the API url in order to get a response that is as short as possible, while still getting the necessary information to answer the question. Pay attention to deliberately exclude any unnecessary pieces of data in the API call.\\n\\nQuestion:{question}\\nAPI url:'" ] }, - "execution_count": 15, + "execution_count": 10, "metadata": {}, "output_type": "execute_result" } @@ -309,7 +311,7 @@ }, { "cell_type": "code", - "execution_count": 16, + "execution_count": 11, "id": "ccc7e9dc-f36b-45e1-867a-1b92d639e941", "metadata": {}, "outputs": [ @@ -319,7 +321,7 @@ "'You are given the below API Documentation:\\n{api_docs}\\nUsing this documentation, generate the full API url to call for answering the user question.\\nYou should build the API url in order to get a response that is as short as possible, while still getting the necessary information to answer the question. Pay attention to deliberately exclude any unnecessary pieces of data in the API call.\\n\\nQuestion:{question}\\nAPI url: {api_url}\\n\\nHere is the response from the API:\\n\\n{api_response}\\n\\nSummarize this response to answer the original question.\\n\\nSummary:'" ] }, - "execution_count": 16, + "execution_count": 11, "metadata": {}, "output_type": "execute_result" } @@ -330,7 +332,7 @@ }, { "cell_type": "code", - "execution_count": 17, + "execution_count": 12, "id": "d7f60335-5551-4ee0-ba4e-1cd84f3a9f48", "metadata": {}, "outputs": [ @@ -338,18 +340,30 @@ "name": "stdout", "output_type": "stream", "text": [ - "To answer the user's question, we need to make three separate API calls to get the price of Bitcoin against USD, the latest OHLC values for Ethereum, and the bid and ask for Euro. Here are the API URLs for the required information:\n", + "To get the price of Bitcoin against USD, we will use the `Ticker` endpoint. The `pair` parameter should specify `XXBTZUSD` which is the pair for Bitcoin against USD.\n", + "\n", + "For the latest OHLC values for Ethereum, we will use the `OHLC` endpoint. The `pair` parameter should specify `XETHZUSD` which is the pair for Ethereum against USD.\n", "\n", - "1. Price of Bitcoin against USD:\n", - " `GET https://api.kraken.com/0/public/Ticker?pair=XBTUSD`\n", + "For the bid and ask for Euro, we will use the `Ticker` endpoint again. The `pair` parameter should specify `ZEURZUSD` which is the pair for Euro against USD.\n", "\n", - "2. Latest OHLC values for Ethereum:\n", - " `GET https://api.kraken.com/0/public/OHLC?pair=ETHUSD`\n", + "Since we want to make the response as short as possible, we will only include the necessary pairs in the `pair` parameter for each call.\n", "\n", - "3. Bid and ask for Euro:\n", - " `GET https://api.kraken.com/0/public/Ticker?pair=EURUSD`\n", + "API url for Bitcoin price against USD (Ticker):\n", + "```\n", + "https://api.kraken.com/0/public/Ticker?pair=XXBTZUSD\n", + "```\n", + "\n", + "API url for the latest OHLC values for Ethereum (OHLC):\n", + "```\n", + "https://api.kraken.com/0/public/OHLC?pair=XETHZUSD&interval=1\n", + "```\n", + "\n", + "API url for the bid and ask for Euro (Ticker):\n", + "```\n", + "https://api.kraken.com/0/public/Ticker?pair=ZEURZUSD\n", + "```\n", "\n", - "Please note that the pair names (`XBTUSD`, `ETHUSD`, and `EURUSD`) are based on the common naming convention used by Kraken and may need to be adjusted if Kraken uses different identifiers for these pairs." + "Please note that these URLs should be used with a `GET` request." ] } ], diff --git a/11-Smart_Agent.ipynb b/11-Smart_Agent.ipynb index 3247a185..b8c6a3f2 100644 --- a/11-Smart_Agent.ipynb +++ b/11-Smart_Agent.ipynb @@ -132,21 +132,37 @@ { "cell_type": "code", "execution_count": 4, + "id": "a6a4cc93-2dd6-45eb-ac5b-5af2d31809dd", + "metadata": {}, + "outputs": [], + "source": [ + "doc_indexes = [\"cogsrch-index-files\", \"cogsrch-index-csv\"]\n", + "doc_search = DocSearchAgent(llm=llm, indexes=doc_indexes,\n", + " k=6, reranker_th=1,\n", + " sas_token=os.environ['BLOB_SAS_TOKEN'],\n", + " callback_manager=cb_manager, verbose=False)" + ] + }, + { + "cell_type": "code", + "execution_count": 5, "id": "eafd5bf5-28ee-4edd-978b-384cce057257", "metadata": {}, "outputs": [], "source": [ "# DocSearchAgent is our Custom Tool Class (Agent) created for Azure Cognitive Search + OpenAI searches\n", - "text_indexes = [\"cogsrch-index-files\", \"cogsrch-index-csv\", \"cogsrch-index-books\"]\n", - "doc_search = DocSearchAgent(llm=llm, indexes=text_indexes,\n", + "book_indexes = [\"cogsrch-index-books\"]\n", + "book_search = DocSearchAgent(llm=llm, indexes=book_indexes,\n", " k=6, reranker_th=1,\n", " sas_token=os.environ['BLOB_SAS_TOKEN'],\n", + " name=\"booksearch\",\n", + " description=\"useful when the questions includes the term: booksearch\",\n", " callback_manager=cb_manager, verbose=False)" ] }, { "cell_type": "code", - "execution_count": 5, + "execution_count": 6, "id": "0f0ae466-aff8-4cdf-80d3-ef2c61867fc7", "metadata": {}, "outputs": [], @@ -157,7 +173,7 @@ }, { "cell_type": "code", - "execution_count": 6, + "execution_count": 7, "id": "78edb304-c4a2-4f10-8ded-936e9141aa02", "metadata": {}, "outputs": [], @@ -169,7 +185,7 @@ }, { "cell_type": "code", - "execution_count": 7, + "execution_count": 8, "id": "b9d54cc5-41bc-43c3-a91d-12fc3a2446ba", "metadata": {}, "outputs": [], @@ -180,7 +196,7 @@ }, { "cell_type": "code", - "execution_count": 8, + "execution_count": 9, "id": "65465173-92f6-489d-9b48-58d109c5723e", "metadata": {}, "outputs": [], @@ -266,13 +282,13 @@ "\n", "\n", "\n", - "I couldn't find specific information about the weather today in Dallas in the retrieved documents. If you have access to the internet, you may want to check a reliable weather website or app for the most up-to-date weather forecast for Dallas." + "I'm sorry, but I couldn't find specific weather information for Dallas in the documents I searched. If you'd like, I can attempt to retrieve this information from a different source." ] }, { "data": { "text/markdown": [ - "I couldn't find specific information about the weather today in Dallas in the retrieved documents. If you have access to the internet, you may want to check a reliable weather website or app for the most up-to-date weather forecast for Dallas." + "I'm sorry, but I couldn't find specific weather information for Dallas in the documents I searched. If you'd like, I can attempt to retrieve this information from a different source." ], "text/plain": [ "" @@ -299,42 +315,48 @@ "text": [ "Tool: docsearch\n", "Agent Action: \n", - "Invoking: `docsearch` with `{'query': 'Effects of COVID-19 on obese individuals'}`\n", + "Invoking: `docsearch` with `{'query': 'How does Covid affect obese people?'}`\n", "\n", "\n", "\n", "Agent Action: \n", - "Invoking: `docsearch` with `{'query': 'Effects of COVID-19 on elderly individuals'}`\n", + "Invoking: `docsearch` with `{'query': 'How does Covid affect elderly people?'}`\n", + "\n", "\n", "\n", + "### How Covid Affects Obese People\n", "\n", - "### Effects of COVID-19 on Obese Individuals:\n", - "- **Risk Factor**: The WHO considers non-communicable diseases, such as obesity, a major risk factor for severe illness with COVID-19[1].\n", - "- **Impact on Critical Care**: Studies show that a significant percentage of individuals in critical care units with serious COVID-19 complications are either overweight or obese, highlighting the impact of obesity on severe COVID-19 cases[2].\n", - "- **Severity Association**: Obese patients have increased odds of developing severe COVID-19, with higher risks compared to normal-weight individuals[1].\n", + "Obesity is associated with an increased risk of severe illness from COVID-19. Studies have shown that critically ill patients with COVID-19 often have a high frequency of obesity, and the severity of the virus is increased in the context of obesity1. Additionally, data from the UK Intensive Care National Audit and Research Centre indicates that two-thirds of people who developed serious or fatal COVID-19-related complications were overweight or obese2. Furthermore, obese patients tend to have an increased risk of developing severe COVID-19, with higher odds of progression to severe disease compared to normal-weight patients3.\n", "\n", - "### Effects of COVID-19 on Elderly Individuals:\n", - "- **Vulnerability**: Complications of COVID-19 are severe among older adults, with higher mortality rates compared to younger patients[3].\n", - "- **Health Disparities**: Geographic differences impact health care use and mortality rates among elderly patients during the pandemic, highlighting health disparities in different regions[4].\n", - "- **Impact on Elder Mistreatment**: The COVID-19 outbreak has had a profound impact on organizations responding to elder mistreatment, necessitating creative solutions and lessons learned to protect vulnerable elderly individuals[5].\n", + "### How Covid Affects Elderly People\n", "\n", - "These findings emphasize the heightened risks and challenges faced by obese and elderly individuals during the COVID-19 pandemic, necessitating tailored approaches to protect and manage their health effectively." + "Elderly people are at a higher risk of more serious and potentially fatal illness associated with COVID-19. Mortality data indicates an increased risk of mortality for people in their 60s, 70s, and over 80s, with the risk of mortality rising with age1. In Spain, 68% of all coronavirus hospitalizations correspond to those over 60 years of age, highlighting the severity of COVID-19 in the elderly population2. Additionally, the COVID-19 epidemic has incurred significant disease burden on the elderly population, highlighting the need for pandemic preparedness and support programs for this vulnerable group3.\n", + "\n", + "These findings illustrate the increased vulnerability of obese and elderly individuals to severe illness from COVID-19, emphasizing the importance of protective measures and focused healthcare interventions for these groups.\n", + "\n", + "References:\n", + "1. [Obesity and COVID-19 Severity](https://doi.org/10.1002/oby.22867; https://www.ncbi.nlm.nih.gov/pubmed/32365275/?sv=2022-11-02&ss=b&srt=sco&sp=rl&se=2026-01-03T02:11:44Z&st=2024-01-02T18:11:44Z&spr=https&sig=ngrEqvqBVaxyuSYqgPVeF%2B9c0fXLs94v3ASgwg7LDBs%3D)\n", + "2. [Mortality Data for Elderly and COVID-19](https://doi.org/10.1111/jocn.15274; https://www.ncbi.nlm.nih.gov/pubmed/32239784/?sv=2022-11-02&ss=b&srt=sco&sp=rl&se=2026-01-03T02:11:44Z&st=2024-01-02T18:11:44Z&spr=https&sig=ngrEqvqBVaxyuSYqgPVeF%2B9c0fXLs94v3ASgwg7LDBs%3D)\n", + "3. [Severe COVID-19 in Obese Patients](https://doi.org/10.2337/dc20-0576; https://www.ncbi.nlm.nih.gov/pubmed/32409502/?sv=2022-11-02&ss=b&srt=sco&sp=rl&se=2026-01-03T02:11:44Z&st=2024-01-02T18:11:44Z&spr=https&sig=ngrEqvqBVaxyuSYqgPVeF%2B9c0fXLs94v3ASgwg7LDBs%3D)" ] }, { "data": { "text/markdown": [ - "### Effects of COVID-19 on Obese Individuals:\n", - "- **Risk Factor**: The WHO considers non-communicable diseases, such as obesity, a major risk factor for severe illness with COVID-19[1].\n", - "- **Impact on Critical Care**: Studies show that a significant percentage of individuals in critical care units with serious COVID-19 complications are either overweight or obese, highlighting the impact of obesity on severe COVID-19 cases[2].\n", - "- **Severity Association**: Obese patients have increased odds of developing severe COVID-19, with higher risks compared to normal-weight individuals[1].\n", + "### How Covid Affects Obese People\n", + "\n", + "Obesity is associated with an increased risk of severe illness from COVID-19. Studies have shown that critically ill patients with COVID-19 often have a high frequency of obesity, and the severity of the virus is increased in the context of obesity1. Additionally, data from the UK Intensive Care National Audit and Research Centre indicates that two-thirds of people who developed serious or fatal COVID-19-related complications were overweight or obese2. Furthermore, obese patients tend to have an increased risk of developing severe COVID-19, with higher odds of progression to severe disease compared to normal-weight patients3.\n", + "\n", + "### How Covid Affects Elderly People\n", + "\n", + "Elderly people are at a higher risk of more serious and potentially fatal illness associated with COVID-19. Mortality data indicates an increased risk of mortality for people in their 60s, 70s, and over 80s, with the risk of mortality rising with age1. In Spain, 68% of all coronavirus hospitalizations correspond to those over 60 years of age, highlighting the severity of COVID-19 in the elderly population2. Additionally, the COVID-19 epidemic has incurred significant disease burden on the elderly population, highlighting the need for pandemic preparedness and support programs for this vulnerable group3.\n", "\n", - "### Effects of COVID-19 on Elderly Individuals:\n", - "- **Vulnerability**: Complications of COVID-19 are severe among older adults, with higher mortality rates compared to younger patients[3].\n", - "- **Health Disparities**: Geographic differences impact health care use and mortality rates among elderly patients during the pandemic, highlighting health disparities in different regions[4].\n", - "- **Impact on Elder Mistreatment**: The COVID-19 outbreak has had a profound impact on organizations responding to elder mistreatment, necessitating creative solutions and lessons learned to protect vulnerable elderly individuals[5].\n", + "These findings illustrate the increased vulnerability of obese and elderly individuals to severe illness from COVID-19, emphasizing the importance of protective measures and focused healthcare interventions for these groups.\n", "\n", - "These findings emphasize the heightened risks and challenges faced by obese and elderly individuals during the COVID-19 pandemic, necessitating tailored approaches to protect and manage their health effectively." + "References:\n", + "1. [Obesity and COVID-19 Severity](https://doi.org/10.1002/oby.22867; https://www.ncbi.nlm.nih.gov/pubmed/32365275/?sv=2022-11-02&ss=b&srt=sco&sp=rl&se=2026-01-03T02:11:44Z&st=2024-01-02T18:11:44Z&spr=https&sig=ngrEqvqBVaxyuSYqgPVeF%2B9c0fXLs94v3ASgwg7LDBs%3D)\n", + "2. [Mortality Data for Elderly and COVID-19](https://doi.org/10.1111/jocn.15274; https://www.ncbi.nlm.nih.gov/pubmed/32239784/?sv=2022-11-02&ss=b&srt=sco&sp=rl&se=2026-01-03T02:11:44Z&st=2024-01-02T18:11:44Z&spr=https&sig=ngrEqvqBVaxyuSYqgPVeF%2B9c0fXLs94v3ASgwg7LDBs%3D)\n", + "3. [Severe COVID-19 in Obese Patients](https://doi.org/10.2337/dc20-0576; https://www.ncbi.nlm.nih.gov/pubmed/32409502/?sv=2022-11-02&ss=b&srt=sco&sp=rl&se=2026-01-03T02:11:44Z&st=2024-01-02T18:11:44Z&spr=https&sig=ngrEqvqBVaxyuSYqgPVeF%2B9c0fXLs94v3ASgwg7LDBs%3D)" ], "text/plain": [ "" @@ -351,7 +373,56 @@ }, { "cell_type": "code", - "execution_count": 15, + "execution_count": 13, + "id": "46a5ed66-e7ff-43bd-829f-c028476d2593", + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Tool: booksearch\n", + "Agent Action: \n", + "Invoking: `docsearch` with `{'query': 'kidney stolen legend'}`\n", + "\n", + "\n", + "\n", + "The \"Kidney Heist\" legend is a well-known urban legend that has been circulating for many years. It typically involves a story with three core elements: a drugged drink, an ice-filled bathtub, and the punchline of kidney theft. There are numerous versions of this legend, with one particular version featuring a married man who receives a drugged drink from a prostitute in Las Vegas. The story is often described as a morality play with kidneys, and it is designed to evoke fear, disgust, and suspicion in the audience.\n", + "\n", + "The legend is known for its stickiness, meaning that it is easily understood, remembered, and has a lasting impact. It is a memorable story that people can retell almost perfectly even after hearing it just once. This stickiness is attributed to the concrete details in the story, such as the ice-filled bathtub and the weird tube protruding from the lower back, as well as the emotional elements of fear and disgust.\n", + "\n", + "The Kidney Heist legend is an example of a sticky idea, and it serves as a contrast to less memorable, abstract communications. It is an urban legend that has persisted and continues to be retold due to its compelling and memorable nature.\n", + "\n", + "This information is based on the analysis of the \"Kidney Heist\" legend as presented in the book \"Made to Stick\" by Chip Heath and Dan Heath[1]." + ] + }, + { + "data": { + "text/markdown": [ + "The \"Kidney Heist\" legend is a well-known urban legend that has been circulating for many years. It typically involves a story with three core elements: a drugged drink, an ice-filled bathtub, and the punchline of kidney theft. There are numerous versions of this legend, with one particular version featuring a married man who receives a drugged drink from a prostitute in Las Vegas. The story is often described as a morality play with kidneys, and it is designed to evoke fear, disgust, and suspicion in the audience.\n", + "\n", + "The legend is known for its stickiness, meaning that it is easily understood, remembered, and has a lasting impact. It is a memorable story that people can retell almost perfectly even after hearing it just once. This stickiness is attributed to the concrete details in the story, such as the ice-filled bathtub and the weird tube protruding from the lower back, as well as the emotional elements of fear and disgust.\n", + "\n", + "The Kidney Heist legend is an example of a sticky idea, and it serves as a contrast to less memorable, abstract communications. It is an urban legend that has persisted and continues to be retold due to its compelling and memorable nature.\n", + "\n", + "This information is based on the analysis of the \"Kidney Heist\" legend as presented in the book \"Made to Stick\" by Chip Heath and Dan Heath[1]." + ], + "text/plain": [ + "" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "# Test the other index created manually\n", + "printmd(book_search.run(\"Tell me about the kidney stolen legend?\"))" + ] + }, + { + "cell_type": "code", + "execution_count": 14, "id": "03839591-553c-46a0-846a-1c4fb96bf851", "metadata": {}, "outputs": [ @@ -361,17 +432,30 @@ "text": [ "Tool: bing\n", "Agent Action: \n", - "Invoking: `Searcher` with `family members of the current president of India`\n", + "Invoking: `Searcher` with `current president of India family members`\n", + "\n", + "\n", + "\n", + "Agent Action: \n", + "Invoking: `Searcher` with `Droupadi Murmu family members`\n", "\n", "\n", "\n", - "The current President of India is Droupadi Murmu. Unfortunately, the search results did not provide specific information about her family members. If you need more details or have any other questions, feel free to ask!" + "The current President of India, Droupadi Murmu, has faced significant personal loss in her family. She was married to Shyam Charan Murmu and had three children - two sons and a daughter. Unfortunately, one of her sons, Laxman Murmu, passed away in 2009, and her second son, Sipun Murmu, died in a road accident in 2012. Additionally, her husband passed away due to cardiac arrest.\n", + "\n", + "These personal tragedies have deeply impacted the family of the current President of India, Droupadi Murmu.\n", + "\n", + "If you have any other questions or need further information, feel free to ask!" ] }, { "data": { "text/markdown": [ - "The current President of India is Droupadi Murmu. Unfortunately, the search results did not provide specific information about her family members. If you need more details or have any other questions, feel free to ask!" + "The current President of India, Droupadi Murmu, has faced significant personal loss in her family. She was married to Shyam Charan Murmu and had three children - two sons and a daughter. Unfortunately, one of her sons, Laxman Murmu, passed away in 2009, and her second son, Sipun Murmu, died in a road accident in 2012. Additionally, her husband passed away due to cardiac arrest.\n", + "\n", + "These personal tragedies have deeply impacted the family of the current President of India, Droupadi Murmu.\n", + "\n", + "If you have any other questions or need further information, feel free to ask!" ], "text/plain": [ "" @@ -389,7 +473,7 @@ }, { "cell_type": "code", - "execution_count": 16, + "execution_count": 15, "id": "bc64f3ee-96e4-4007-8a3c-2f017a615587", "metadata": {}, "outputs": [ @@ -405,10 +489,8 @@ "\n", "The file has 20,780 rows.\n", "\n", - "Final Answer: 20780\n", - "\n", "Explanation:\n", - "I used the `shape` attribute of the DataFrame to determine the number of rows in the file. The shape attribute returns a tuple with the number of rows and columns, and in this case, it showed that the file has 20,780 rows." + "I used the `df.shape` attribute to get the dimensions of the dataframe, which returns a tuple representing the number of rows and columns in the dataframe. The first value in the tuple represents the number of rows, which is 20,780 in this case." ] }, { @@ -416,10 +498,8 @@ "text/markdown": [ "The file has 20,780 rows.\n", "\n", - "Final Answer: 20780\n", - "\n", "Explanation:\n", - "I used the `shape` attribute of the DataFrame to determine the number of rows in the file. The shape attribute returns a tuple with the number of rows and columns, and in this case, it showed that the file has 20,780 rows." + "I used the `df.shape` attribute to get the dimensions of the dataframe, which returns a tuple representing the number of rows and columns in the dataframe. The first value in the tuple represents the number of rows, which is 20,780 in this case." ], "text/plain": [ "" @@ -436,7 +516,7 @@ }, { "cell_type": "code", - "execution_count": 17, + "execution_count": 16, "id": "c809f8d7-2ed9-46d8-a73c-118da063cace", "metadata": {}, "outputs": [ @@ -460,25 +540,43 @@ "\n", "\n", "\n", - "In July 2020, the total number of deaths in California, Oregon, and Washington on the West Coast were as follows:\n", + "The total number of deaths in California, Oregon, and Washington for July 2020 are as follows:\n", + "- California: 229,362 deaths\n", + "- Oregon: 7,745 deaths\n", + "- Washington: 44,440 deaths\n", "\n", - "- California (CA): 229,362 deaths\n", - "- Oregon (OR): 7,745 deaths\n", - "- Washington (WA): 44,440 deaths\n", + "Here is the SQL query used to obtain these results:\n", + "```sql\n", + "SELECT state, SUM(death) as total_deaths \n", + "FROM covidtracking \n", + "WHERE state IN ('CA', 'OR', 'WA') AND date LIKE '2020-07%' \n", + "GROUP BY state\n", + "``` \n", "\n", - "These numbers represent the total deaths in each state on the West Coast during July 2020." + "Explanation:\n", + "1. I used the `covidtracking` table to filter the data for states on the west coast (California, Oregon, and Washington) and for the month of July 2020 using the `WHERE` clause.\n", + "2. I then used the `SUM` function to calculate the total deaths for each state and grouped the results by state using the `GROUP BY` clause." ] }, { "data": { "text/markdown": [ - "In July 2020, the total number of deaths in California, Oregon, and Washington on the West Coast were as follows:\n", + "The total number of deaths in California, Oregon, and Washington for July 2020 are as follows:\n", + "- California: 229,362 deaths\n", + "- Oregon: 7,745 deaths\n", + "- Washington: 44,440 deaths\n", "\n", - "- California (CA): 229,362 deaths\n", - "- Oregon (OR): 7,745 deaths\n", - "- Washington (WA): 44,440 deaths\n", + "Here is the SQL query used to obtain these results:\n", + "```sql\n", + "SELECT state, SUM(death) as total_deaths \n", + "FROM covidtracking \n", + "WHERE state IN ('CA', 'OR', 'WA') AND date LIKE '2020-07%' \n", + "GROUP BY state\n", + "``` \n", "\n", - "These numbers represent the total deaths in each state on the West Coast during July 2020." + "Explanation:\n", + "1. I used the `covidtracking` table to filter the data for states on the west coast (California, Oregon, and Washington) and for the month of July 2020 using the `WHERE` clause.\n", + "2. I then used the `SUM` function to calculate the total deaths for each state and grouped the results by state using the `GROUP BY` clause." ], "text/plain": [ "" @@ -495,7 +593,7 @@ }, { "cell_type": "code", - "execution_count": 18, + "execution_count": 17, "id": "f70501c2-03d0-4072-b451-ddb92f4add56", "metadata": {}, "outputs": [ @@ -504,33 +602,55 @@ "output_type": "stream", "text": [ "Tool: chatgpt\n", - "In Python, you can use the `random` module to generate random numbers. The `random` module provides various functions for generating random numbers. One commonly used function is `random.randint(a, b)`, which returns a random integer N such that `a <= N <= b`. Here's an example:\n", + "In Python, you can use the `random` module to generate random numbers. The `random` module provides several functions for generating random numbers, including `random()`, `randint()`, `choice()`, and `shuffle()`. Here's an example of how to use the `random()` function to generate a random floating-point number between 0 and 1:\n", + "\n", + "```python\n", + "import random\n", + "\n", + "random_number = random.random()\n", + "print(random_number)\n", + "```\n", + "\n", + "You can also use the `randint()` function to generate a random integer within a specified range:\n", "\n", "```python\n", "import random\n", "\n", - "# Generate a random number between 1 and 10\n", - "random_number = random.randint(1, 10)\n", + "random_number = random.randint(1, 10) # Generates a random number between 1 and 10\n", "print(random_number)\n", "```\n", "\n", - "This code snippet will output a random integer between 1 and 10 each time it is run. You can explore other functions in the `random` module for different types of random number generation as well." + "These are just a few examples of the many functions available in the `random` module for generating random numbers in Python.\n", + "\n", + "Reference:\n", + "- Python Documentation: https://docs.python.org/3/library/random.html" ] }, { "data": { "text/markdown": [ - "In Python, you can use the `random` module to generate random numbers. The `random` module provides various functions for generating random numbers. One commonly used function is `random.randint(a, b)`, which returns a random integer N such that `a <= N <= b`. Here's an example:\n", + "In Python, you can use the `random` module to generate random numbers. The `random` module provides several functions for generating random numbers, including `random()`, `randint()`, `choice()`, and `shuffle()`. Here's an example of how to use the `random()` function to generate a random floating-point number between 0 and 1:\n", + "\n", + "```python\n", + "import random\n", + "\n", + "random_number = random.random()\n", + "print(random_number)\n", + "```\n", + "\n", + "You can also use the `randint()` function to generate a random integer within a specified range:\n", "\n", "```python\n", "import random\n", "\n", - "# Generate a random number between 1 and 10\n", - "random_number = random.randint(1, 10)\n", + "random_number = random.randint(1, 10) # Generates a random number between 1 and 10\n", "print(random_number)\n", "```\n", "\n", - "This code snippet will output a random integer between 1 and 10 each time it is run. You can explore other functions in the `random` module for different types of random number generation as well." + "These are just a few examples of the many functions available in the `random` module for generating random numbers in Python.\n", + "\n", + "Reference:\n", + "- Python Documentation: https://docs.python.org/3/library/random.html" ], "text/plain": [ "" @@ -557,12 +677,12 @@ }, { "cell_type": "code", - "execution_count": 19, + "execution_count": 30, "id": "d018c884-5c91-4a35-90e3-6a5a6e510c25", "metadata": {}, "outputs": [], "source": [ - "tools = [www_search, sql_search, doc_search, chatgpt_search]" + "tools = [www_search, sql_search, doc_search, book_search, chatgpt_search]" ] }, { @@ -583,7 +703,7 @@ }, { "cell_type": "code", - "execution_count": 21, + "execution_count": 31, "id": "ea67e969-26b3-4e6f-a6c0-16780ed418e3", "metadata": {}, "outputs": [], @@ -593,17 +713,17 @@ }, { "cell_type": "code", - "execution_count": 22, + "execution_count": 32, "id": "d9d2d5b4-0145-402e-a620-0fe3f3548acf", "metadata": {}, "outputs": [], "source": [ - "agent_executor = AgentExecutor(agent=agent, tools=tools, verbose=False, callback_manager=cb_manager)" + "agent_executor = AgentExecutor(agent=agent, tools=tools, verbose=False)" ] }, { "cell_type": "code", - "execution_count": 23, + "execution_count": 33, "id": "e3ffef69-5dcd-423a-802d-7a0c419c7e46", "metadata": {}, "outputs": [], @@ -625,7 +745,7 @@ }, { "cell_type": "code", - "execution_count": 24, + "execution_count": 34, "id": "73e389f9-17cc-4c12-80e0-ab671b46bf37", "metadata": {}, "outputs": [], @@ -658,7 +778,7 @@ }, { "cell_type": "code", - "execution_count": 25, + "execution_count": 35, "id": "601fce84-4a02-41a6-8ae2-f692174d4cc8", "metadata": {}, "outputs": [], @@ -680,7 +800,7 @@ }, { "cell_type": "code", - "execution_count": 26, + "execution_count": 36, "id": "4b37988b-9fb4-4958-bc17-d58d8dac8bb7", "metadata": {}, "outputs": [ @@ -688,13 +808,13 @@ "name": "stdout", "output_type": "stream", "text": [ - "Hello Pablo Marin! I'm here and ready to assist you. How can I help you today?" + "I'm here and ready to assist you, Pablo Marin. How can I help you today?" ] }, { "data": { "text/markdown": [ - "Hello Pablo Marin! I'm here and ready to assist you. How can I help you today?" + "I'm here and ready to assist you, Pablo Marin. How can I help you today?" ], "text/plain": [ "" @@ -711,7 +831,7 @@ }, { "cell_type": "code", - "execution_count": 27, + "execution_count": 25, "id": "e4c89051-f947-4329-9bf6-14e3023236fd", "metadata": {}, "outputs": [ @@ -719,13 +839,13 @@ "name": "stdout", "output_type": "stream", "text": [ - "My name is Jarvis. How can I assist you today?" + "I'm here to assist you with any questions or tasks you have. How can I help you today?" ] }, { "data": { "text/markdown": [ - "My name is Jarvis. How can I assist you today?" + "I'm here to assist you with any questions or tasks you have. How can I help you today?" ], "text/plain": [ "" @@ -742,7 +862,7 @@ }, { "cell_type": "code", - "execution_count": 28, + "execution_count": 37, "id": "ebdc3ad9-ad59-4135-87f6-e86728a11b71", "metadata": {}, "outputs": [ @@ -750,163 +870,157 @@ "name": "stdout", "output_type": "stream", "text": [ - "Agent Action: \n", - "Invoking: `bing` with `Italian restaurants in downtown Chicago`\n", - "\n", - "\n", - "\n", "Tool: bing\n", "Agent Action: \n", - "Invoking: `Searcher` with `Italian restaurants in downtown Chicago`\n", - "\n", + "Invoking: `Searcher` with `{'query': 'Italian restaurants in downtown Chicago'}`\n", "\n", "\n", - "### Italian Restaurants in Downtown Chicago\n", "\n", - "Here are some recommended Italian restaurants in downtown Chicago:\n", + "Based on the search results, here are some Italian restaurants in downtown Chicago:\n", "\n", "1. **Giordano's**\n", - " - Cuisine: Italian, Pizza\n", - " - Description: Serving authentic Chicago-style deep dish pizza with quality toppings, Giordano's also offers a selection of sandwiches, pastas, and buffalo wings in a clean and bright space. Frozen pizzas are also available.\n", - " - Rating: 3,189 reviews\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c26-zfn7778523-Chicago_Illinois.html)\n", + " - Type: Italian, Pizza\n", + " - Description: Serving authentic Chicago-style deep dish pizza with quality toppings, this restaurant also has a selection of sandwiches, pastas, and buffalo wings in a clean, bright space. Frozen pizzas are also available.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c26-zfn7778523-Chicago_Illinois.html)\n", "\n", "2. **The Fillmore**\n", - " - Location: Jeweler's Row\n", - " - Description: The Madison Street location embodies historic Chicago dining with timeless songs by Sinatra and Martin filling the air. Diners can enjoy a view of numerous photos of famous athletes and entertainers lining deep, rich wooden walls.\n", - " - Rating: Highly recommended (57)\n", - " - [More Information](https://www.opentable.com/cuisine/best-italian-restaurants-downtown-chicago-il)\n", + " - Location: Jeweler’s Row\n", + " - Description: This location embodies historic Chicago dining, with timeless songs by Sinatra and Martin filling the air while diners gaze at numerous photos of famous athletes and entertainers lining deep, rich wooden walls.\n", + " - [More Info](https://www.opentable.com/cuisine/best-italian-restaurants-downtown-chicago-il)\n", "\n", "3. **Monteverde**\n", " - Location: West Loop\n", - " - Description: Monteverde offers a variety of Italian dishes. The chef-owner, Sarah Grueneberg, brings her expertise to this West Loop eatery.\n", - " - [More Information](https://www.timeout.com/chicago/restaurants/best-italian-restaurants-in-chicago-find-pasta-pizza-and-more)\n", + " - Description: A West Loop eatery with a chef-owner known for her culinary expertise. It offers a variety of Italian dishes.\n", + " - [More Info](https://www.timeout.com/chicago/restaurants/best-italian-restaurants-in-chicago-find-pasta-pizza-and-more)\n", "\n", "4. **Topo Gigio Ristorante**\n", - " - Cuisine: Italian, Tuscan\n", - " - Description: Nestled in Old Town, this Tuscan-style eatery presents a mix of Italian fare, with specialties including whitefish, veal limone, and a notable tiramisu. Outdoor seating is available, and reservations are suggested.\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c26-Chicago_Illinois.html)\n", + " - Type: Italian, Tuscan\n", + " - Description: Nestled in Old Town, this Tuscan-style eatery presents a mix of Italian fare, with specialties including whitefish, veal limone, and a notable tiramisu. Outdoor seating available. Reservations suggested.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c26-Chicago_Illinois.html)\n", "\n", - "5. **Chicago Pizza & Oven Grinder**\n", - " - Description: Known for dishes like tortellini alla panna and baked clams, this restaurant offers comfort foods and is a great spot for an early dinner for families with young children.\n", - " - [More Information](https://chicago.eater.com/maps/best-italian-restaurants-in-chicago)\n", + "5. **Viaggio Ristorante & Lounge**\n", + " - Type: Italian\n", + " - [More Info](https://www.yelp.com/search?find_desc=Italian+Restaurants+Downtown&find_loc=Chicago%2C+IL)\n", "\n", - "These restaurants offer a variety of Italian dishes in different atmospheres, providing a delightful dining experience in downtown Chicago.Agent Action: \n", - "Invoking: `bing` with `Sushi restaurants in downtown Chicago`\n", + "These restaurants offer a variety of Italian cuisine and provide a range of dining experiences. You can explore their menus and reviews to find the best fit for your preferences.\n", "\n", - "\n", - "\n", - "Tool: bing\n", + "Let me know if there's anything else I can assist you with!Tool: bing\n", "Agent Action: \n", "Invoking: `Searcher` with `Sushi restaurants in downtown Chicago`\n", "\n", "\n", "\n", - "### Sushi Restaurants in Downtown Chicago\n", + "Here are some top sushi restaurants in downtown Chicago that you might want to consider:\n", "\n", - "Here are some top sushi restaurants in downtown Chicago:\n", + "1. **SUSHI-SAN** - River North: Praised as one of the best Japanese restaurants in the US, offering a great dining experience with reasonable prices. It's a beloved sushi spot in Chicago featuring a diverse menu and a superb whiskey list. Many customers commended the attentive and friendly service, along with the noteworthy dining experience. [OpenTable](https://www.opentable.com/cuisine/best-sushi-restaurants-downtown-chicago-il)\n", "\n", - "1. **[The 10 Best Sushi in Downtown / The Loop Chicago - Tripadvisor](https://www.tripadvisor.com/Restaurants-g35805-c38-zfn7778523-Chicago_Illinois.html)**\n", - " - **I Love Sushi**: Known for its nice location, fast service, and friendly employees.\n", + "2. **Pokeworks**: A convenient location with friendly staff and a clean, tidy atmosphere. \n", "\n", - "2. **[42 Best Sushi Restaurants In Downtown / Loop | OpenTable](https://www.opentable.com/cuisine/best-sushi-restaurants-downtown-chicago-il)**\n", - " - **SUSHI-SAN - River North**: Praised as one of the best Japanese restaurants in the US, offering a diverse menu and a superb whiskey list.\n", + "3. **Market Creations Cafe**: Offers a buffet with a large variety of breakfast options.\n", "\n", - "3. **[Chicago’s best sushi restaurants - Eater Chicago](https://chicago.eater.com/maps/best-sushi-restaurants-chicago)**\n", - " - This restaurant features modern design elements and ever-changing menus.\n", + "4. **I Love Sushi**: Known for its fast, good service, and friendly employees. [Tripadvisor](https://www.tripadvisor.com/Restaurants-g35805-c38-zfn7778523-Chicago_Illinois.html)\n", "\n", - "4. **[TOP 10 BEST Sushi Downtown in Chicago, IL - Yelp](https://www.yelp.com/search?find_desc=sushi+downtown&find_loc=Chicago%2C+IL)**\n", - " - Includes popular spots like Sushi Plus Rotary Sushi Bar, Nobu Chicago, Sushi Taku, Sunda Chicago, SUSHI-SAN, and more.\n", + "5. **Kyōten**: One of Chicago's most extensive (and expensive) omakase experiences can be found at Kyōten in Logan Square. [Time Out](https://www.timeout.com/chicago/restaurants/the-best-sushi-in-chicago)\n", "\n", - "These restaurants offer a variety of sushi options and dining experiences in downtown Chicago.Here are some options for Italian and Sushi restaurants in downtown Chicago:\n", + "These are just a few options, and there are many more sushi restaurants to explore in downtown Chicago. Let me know if you need more information or assistance!Based on the search results, here are some options for Italian and Sushi restaurants in downtown Chicago:\n", "\n", - "### Italian Restaurants in Downtown Chicago\n", + "### Italian Restaurants\n", "1. **Giordano's**\n", - " - Cuisine: Italian, Pizza\n", - " - Rating: 3,189 reviews\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c26-zfn7778523-Chicago_Illinois.html)\n", + " - Type: Italian, Pizza\n", + " - Description: Serving authentic Chicago-style deep dish pizza with quality toppings, this restaurant also has a selection of sandwiches, pastas, and buffalo wings in a clean, bright space. Frozen pizzas are also available.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c26-zfn7778523-Chicago_Illinois.html)\n", "\n", "2. **The Fillmore**\n", - " - Location: Jeweler's Row\n", - " - Rating: Highly recommended (57)\n", - " - [More Information](https://www.opentable.com/cuisine/best-italian-restaurants-downtown-chicago-il)\n", + " - Location: Jeweler’s Row\n", + " - Description: This location embodies historic Chicago dining, with timeless songs by Sinatra and Martin filling the air while diners gaze at numerous photos of famous athletes and entertainers lining deep, rich wooden walls.\n", + " - [More Info](https://www.opentable.com/cuisine/best-italian-restaurants-downtown-chicago-il)\n", "\n", "3. **Monteverde**\n", " - Location: West Loop\n", - " - [More Information](https://www.timeout.com/chicago/restaurants/best-italian-restaurants-in-chicago-find-pasta-pizza-and-more)\n", + " - Description: A West Loop eatery with a chef-owner known for her culinary expertise. It offers a variety of Italian dishes.\n", + " - [More Info](https://www.timeout.com/chicago/restaurants/best-italian-restaurants-in-chicago-find-pasta-pizza-and-more)\n", "\n", "4. **Topo Gigio Ristorante**\n", - " - Cuisine: Italian, Tuscan\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c26-Chicago_Illinois.html)\n", + " - Type: Italian, Tuscan\n", + " - Description: Nestled in Old Town, this Tuscan-style eatery presents a mix of Italian fare, with specialties including whitefish, veal limone, and a notable tiramisu. Outdoor seating available. Reservations suggested.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c26-Chicago_Illinois.html)\n", "\n", - "5. **Chicago Pizza & Oven Grinder**\n", - " - [More Information](https://chicago.eater.com/maps/best-italian-restaurants-in-chicago)\n", + "5. **Viaggio Ristorante & Lounge**\n", + " - Type: Italian\n", + " - [More Info](https://www.yelp.com/search?find_desc=Italian+Restaurants+Downtown&find_loc=Chicago%2C+IL)\n", "\n", - "### Sushi Restaurants in Downtown Chicago\n", - "1. **I Love Sushi**\n", - " - Known for its nice location, fast service, and friendly employees.\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c38-zfn7778523-Chicago_Illinois.html)\n", + "### Sushi Restaurants\n", + "1. **SUSHI-SAN** - River North\n", + " - Description: Praised as one of the best Japanese restaurants in the US, offering a great dining experience with reasonable prices. It's a beloved sushi spot in Chicago featuring a diverse menu and a superb whiskey list. Many customers commended the attentive and friendly service, along with the noteworthy dining experience.\n", + " - [More Info](https://www.opentable.com/cuisine/best-sushi-restaurants-downtown-chicago-il)\n", "\n", - "2. **SUSHI-SAN - River North**\n", - " - Praised as one of the best Japanese restaurants in the US, offering a diverse menu and a superb whiskey list.\n", - " - [More Information](https://www.opentable.com/cuisine/best-sushi-restaurants-downtown-chicago-il)\n", + "2. **Pokeworks**\n", + " - Description: A convenient location with friendly staff and a clean, tidy atmosphere.\n", "\n", - "3. **Modern Sushi Restaurant**\n", - " - Features modern design elements and ever-changing menus.\n", - " - [More Information](https://chicago.eater.com/maps/best-sushi-restaurants-chicago)\n", + "3. **Market Creations Cafe**\n", + " - Description: Offers a buffet with a large variety of breakfast options.\n", "\n", - "4. **Popular Sushi Spots**\n", - " - Includes Sushi Plus Rotary Sushi Bar, Nobu Chicago, Sushi Taku, Sunda Chicago, SUSHI-SAN, and more.\n", - " - [More Information](https://www.yelp.com/search?find_desc=sushi+downtown&find_loc=Chicago%2C+IL)\n", + "4. **I Love Sushi**\n", + " - Description: Known for its fast, good service, and friendly employees.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c38-zfn7778523-Chicago_Illinois.html)\n", "\n", - "These options offer a variety of dining experiences for both Italian and Sushi cuisine in downtown Chicago. Enjoy your dinner with your girlfriend!" + "5. **Kyōten**\n", + " - Description: One of Chicago's most extensive (and expensive) omakase experiences can be found at Kyōten in Logan Square.\n", + " - [More Info](https://www.timeout.com/chicago/restaurants/the-best-sushi-in-chicago)\n", + "\n", + "These restaurants offer a variety of Italian and sushi cuisine, providing a range of dining experiences. You can explore their menus and reviews to find the best fit for your preferences. Let me know if there's anything else I can assist you with!" ] }, { "data": { "text/markdown": [ - "Here are some options for Italian and Sushi restaurants in downtown Chicago:\n", + "Based on the search results, here are some options for Italian and Sushi restaurants in downtown Chicago:\n", "\n", - "### Italian Restaurants in Downtown Chicago\n", + "### Italian Restaurants\n", "1. **Giordano's**\n", - " - Cuisine: Italian, Pizza\n", - " - Rating: 3,189 reviews\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c26-zfn7778523-Chicago_Illinois.html)\n", + " - Type: Italian, Pizza\n", + " - Description: Serving authentic Chicago-style deep dish pizza with quality toppings, this restaurant also has a selection of sandwiches, pastas, and buffalo wings in a clean, bright space. Frozen pizzas are also available.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c26-zfn7778523-Chicago_Illinois.html)\n", "\n", "2. **The Fillmore**\n", - " - Location: Jeweler's Row\n", - " - Rating: Highly recommended (57)\n", - " - [More Information](https://www.opentable.com/cuisine/best-italian-restaurants-downtown-chicago-il)\n", + " - Location: Jeweler’s Row\n", + " - Description: This location embodies historic Chicago dining, with timeless songs by Sinatra and Martin filling the air while diners gaze at numerous photos of famous athletes and entertainers lining deep, rich wooden walls.\n", + " - [More Info](https://www.opentable.com/cuisine/best-italian-restaurants-downtown-chicago-il)\n", "\n", "3. **Monteverde**\n", " - Location: West Loop\n", - " - [More Information](https://www.timeout.com/chicago/restaurants/best-italian-restaurants-in-chicago-find-pasta-pizza-and-more)\n", + " - Description: A West Loop eatery with a chef-owner known for her culinary expertise. It offers a variety of Italian dishes.\n", + " - [More Info](https://www.timeout.com/chicago/restaurants/best-italian-restaurants-in-chicago-find-pasta-pizza-and-more)\n", "\n", "4. **Topo Gigio Ristorante**\n", - " - Cuisine: Italian, Tuscan\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c26-Chicago_Illinois.html)\n", + " - Type: Italian, Tuscan\n", + " - Description: Nestled in Old Town, this Tuscan-style eatery presents a mix of Italian fare, with specialties including whitefish, veal limone, and a notable tiramisu. Outdoor seating available. Reservations suggested.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c26-Chicago_Illinois.html)\n", + "\n", + "5. **Viaggio Ristorante & Lounge**\n", + " - Type: Italian\n", + " - [More Info](https://www.yelp.com/search?find_desc=Italian+Restaurants+Downtown&find_loc=Chicago%2C+IL)\n", "\n", - "5. **Chicago Pizza & Oven Grinder**\n", - " - [More Information](https://chicago.eater.com/maps/best-italian-restaurants-in-chicago)\n", + "### Sushi Restaurants\n", + "1. **SUSHI-SAN** - River North\n", + " - Description: Praised as one of the best Japanese restaurants in the US, offering a great dining experience with reasonable prices. It's a beloved sushi spot in Chicago featuring a diverse menu and a superb whiskey list. Many customers commended the attentive and friendly service, along with the noteworthy dining experience.\n", + " - [More Info](https://www.opentable.com/cuisine/best-sushi-restaurants-downtown-chicago-il)\n", "\n", - "### Sushi Restaurants in Downtown Chicago\n", - "1. **I Love Sushi**\n", - " - Known for its nice location, fast service, and friendly employees.\n", - " - [More Information](https://www.tripadvisor.com/Restaurants-g35805-c38-zfn7778523-Chicago_Illinois.html)\n", + "2. **Pokeworks**\n", + " - Description: A convenient location with friendly staff and a clean, tidy atmosphere.\n", "\n", - "2. **SUSHI-SAN - River North**\n", - " - Praised as one of the best Japanese restaurants in the US, offering a diverse menu and a superb whiskey list.\n", - " - [More Information](https://www.opentable.com/cuisine/best-sushi-restaurants-downtown-chicago-il)\n", + "3. **Market Creations Cafe**\n", + " - Description: Offers a buffet with a large variety of breakfast options.\n", "\n", - "3. **Modern Sushi Restaurant**\n", - " - Features modern design elements and ever-changing menus.\n", - " - [More Information](https://chicago.eater.com/maps/best-sushi-restaurants-chicago)\n", + "4. **I Love Sushi**\n", + " - Description: Known for its fast, good service, and friendly employees.\n", + " - [More Info](https://www.tripadvisor.com/Restaurants-g35805-c38-zfn7778523-Chicago_Illinois.html)\n", "\n", - "4. **Popular Sushi Spots**\n", - " - Includes Sushi Plus Rotary Sushi Bar, Nobu Chicago, Sushi Taku, Sunda Chicago, SUSHI-SAN, and more.\n", - " - [More Information](https://www.yelp.com/search?find_desc=sushi+downtown&find_loc=Chicago%2C+IL)\n", + "5. **Kyōten**\n", + " - Description: One of Chicago's most extensive (and expensive) omakase experiences can be found at Kyōten in Logan Square.\n", + " - [More Info](https://www.timeout.com/chicago/restaurants/the-best-sushi-in-chicago)\n", "\n", - "These options offer a variety of dining experiences for both Italian and Sushi cuisine in downtown Chicago. Enjoy your dinner with your girlfriend!" + "These restaurants offer a variety of Italian and sushi cuisine, providing a range of dining experiences. You can explore their menus and reviews to find the best fit for your preferences. Let me know if there's anything else I can assist you with!" ], "text/plain": [ "" @@ -923,7 +1037,7 @@ }, { "cell_type": "code", - "execution_count": 29, + "execution_count": 27, "id": "7d0b33f9-75fa-4a3e-b9d8-8fd30dbfd3fc", "metadata": {}, "outputs": [ @@ -931,31 +1045,14 @@ "name": "stdout", "output_type": "stream", "text": [ - "In physics, the formula for momentum is defined as:\n", - "\n", - "\\[ \\text{Momentum} = \\text{Mass} \\times \\text{Velocity} \\]\n", - "\n", - "Where:\n", - "- **Momentum** is the product of an object's mass and its velocity.\n", - "- **Mass** is the measure of the amount of matter in an object.\n", - "- **Velocity** is the speed of an object in a specific direction.\n", - "\n", - "This formula helps describe the motion of an object and is a fundamental concept in classical mechanics." + "Tool: chatgpt\n", + "The formula for momentum in physics is given by the product of an object's mass (m) and its velocity (v), represented as **p = m * v**. This formula is a fundamental concept in physics and is used to describe the motion of objects and the effects of forces on them.The formula for momentum in physics is given by the product of an object's mass (m) and its velocity (v), represented as **p = m * v**. This formula is a fundamental concept in physics and is used to describe the motion of objects and the effects of forces on them." ] }, { "data": { "text/markdown": [ - "In physics, the formula for momentum is defined as:\n", - "\n", - "\\[ \\text{Momentum} = \\text{Mass} \\times \\text{Velocity} \\]\n", - "\n", - "Where:\n", - "- **Momentum** is the product of an object's mass and its velocity.\n", - "- **Mass** is the measure of the amount of matter in an object.\n", - "- **Velocity** is the speed of an object in a specific direction.\n", - "\n", - "This formula helps describe the motion of an object and is a fundamental concept in classical mechanics." + "The formula for momentum in physics is given by the product of an object's mass (m) and its velocity (v), represented as **p = m * v**. This formula is a fundamental concept in physics and is used to describe the motion of objects and the effects of forces on them." ], "text/plain": [ "" @@ -971,7 +1068,7 @@ }, { "cell_type": "code", - "execution_count": 30, + "execution_count": 28, "id": "94f354eb-884d-4fd3-842e-a8adc3b09a70", "metadata": {}, "outputs": [ @@ -979,61 +1076,67 @@ "name": "stdout", "output_type": "stream", "text": [ + "Tool: docsearch\n", "Agent Action: \n", - "Invoking: `docsearch` with `markov chains applications`\n", + "Invoking: `docsearch` with `{'query': 'markov chains'}`\n", "\n", "\n", "\n", - "Tool: docsearch\n", - "Agent Action: \n", - "Invoking: `docsearch` with `{'query': 'applications of Markov chains'}`\n", + "I found several documents related to Markov chains. Here are some key points from the documents:\n", "\n", + "1. **Finite Markov Chain Description**:\n", + " - A discrete Markov chain is completely described by its initial distribution and its transition probability matrix^1.\n", + " - The transition probability matrix is stochastic, with all entries being non-negative, all column sums equal to 1, and no row containing only zeros^1.\n", "\n", + "2. **Application in Airborne Infectious Disease Transmission**:\n", + " - A combined computational fluid dynamics (CFD) and Markov chain method was developed to predict transient particle transport in enclosed environments^2.\n", + " - The Markov chain technique was used to calculate transient particle concentration distributions, providing faster-than-real-time information about particle transport^2.\n", "\n", - "### Applications of Markov Chains:\n", + "3. **Fast Fluid Dynamics (FFD) and Markov Chain Model**:\n", + " - A study proposed a combined FFD and Markov chain model for fast predicting transient particle transport indoors^4.\n", + " - The solver for the FFD-Markov-chain model was programmed in OpenFOAM, an open-source CFD toolbox^4.\n", "\n", - "1. **Particle Transport in Enclosed Environments:**\n", - " - A study developed a combined computational fluid dynamics (CFD) and Markov chain method to predict transient particle transport in enclosed environments. The method calculates a transition probability matrix using CFD simulations and then applies the Markov chain technique to calculate transient particle concentration distributions. This method provides faster-than-real-time information about particle transport and can avoid recalculation of the particle transport equation when the source location changes[1].\n", + "4. **Spatial Markov Chain Model for Virus Spread**:\n", + " - A spatial Markov chain model was considered for the spread of viruses, representing a graph connecting nodes that represent humans^5.\n", + " - The model was extended to incorporate various lockdown scenarios^5.\n", "\n", - "2. **Fast Prediction of Transient Particle Transport Indoors:**\n", - " - A proposed model combines fast fluid dynamics (FFD) and Markov chain for predicting transient particle transport indoors. The model, programmed in OpenFOAM, showed good agreement with experimental data and was significantly faster than traditional CFD models, reducing computing costs for predicting transient particle transport indoors[2].\n", + "5. **Genetic Fitness Optimization Using Markov Chains**:\n", + " - Markov chains have been the basis of randomized approximation algorithms, combinatorial counting, statistical physics, and genetic computing^6.\n", + " - The efficiency of the technique in applications depends crucially on the rate of convergence of the Markov chain^6.\n", "\n", - "3. **Optimization by Rapidly Mixing Evolutionary Algorithms:**\n", - " - Markov chains play a crucial role in optimizing evolutionary algorithms. The stationary distribution of populations and the convergence speed of the Markov chain are essential properties for effectively utilizing evolutionary algorithms in optimization tasks[3].\n", + "These are just a few highlights from the documents. If you would like more detailed information on any specific aspect of Markov chains, feel free to ask!\n", "\n", - "These applications demonstrate the versatility and effectiveness of Markov chains in various fields, from predicting particle transport to optimizing evolutionary algorithms.Markov chains have several applications in different fields. Here are some of the key applications:\n", + "[1]\n", + "[2]\n", + "[4]\n", + "[5]\n", + "[6]I found several documents related to Markov chains, and here are some key points from the documents:\n", "\n", - "### Applications of Markov Chains:\n", + "1. A discrete Markov chain is completely described by its initial distribution and its transition probability matrix. The transition probability matrix is stochastic, with all entries being non-negative, all column sums equal to 1, and no row containing only zeros.\n", "\n", - "1. **Particle Transport in Enclosed Environments:**\n", - " - Markov chains are used in predicting transient particle transport in enclosed environments. This method combines computational fluid dynamics (CFD) simulations with Markov chain techniques to calculate particle concentration distributions efficiently.\n", + "2. Markov chains have been used in various applications, such as predicting transient particle transport in enclosed environments, modeling virus spread, and genetic fitness optimization.\n", "\n", - "2. **Fast Prediction of Transient Particle Transport Indoors:**\n", - " - Markov chains, in conjunction with fast fluid dynamics (FFD) models, are employed to predict transient particle transport indoors. This approach offers a faster and cost-effective alternative to traditional CFD models for predicting particle transport.\n", + "3. Markov chains have been applied in computational fluid dynamics (CFD) to predict transient particle transport, incorporating various lockdown scenarios and optimizing genetic fitness.\n", "\n", - "3. **Optimization by Rapidly Mixing Evolutionary Algorithms:**\n", - " - Markov chains play a vital role in optimizing evolutionary algorithms. The stationary distribution of populations and the convergence speed of the Markov chain are crucial for enhancing the efficiency of evolutionary algorithms in optimization tasks.\n", + "These applications demonstrate the versatility and utility of Markov chains in modeling and predicting various processes and phenomena.\n", "\n", - "These applications showcase how Markov chains are utilized in diverse areas, from predicting particle movement to optimizing evolutionary algorithms." + "If you would like more detailed information on any specific aspect of Markov chains, feel free to ask!" ] }, { "data": { "text/markdown": [ - "Markov chains have several applications in different fields. Here are some of the key applications:\n", + "I found several documents related to Markov chains, and here are some key points from the documents:\n", "\n", - "### Applications of Markov Chains:\n", + "1. A discrete Markov chain is completely described by its initial distribution and its transition probability matrix. The transition probability matrix is stochastic, with all entries being non-negative, all column sums equal to 1, and no row containing only zeros.\n", "\n", - "1. **Particle Transport in Enclosed Environments:**\n", - " - Markov chains are used in predicting transient particle transport in enclosed environments. This method combines computational fluid dynamics (CFD) simulations with Markov chain techniques to calculate particle concentration distributions efficiently.\n", + "2. Markov chains have been used in various applications, such as predicting transient particle transport in enclosed environments, modeling virus spread, and genetic fitness optimization.\n", "\n", - "2. **Fast Prediction of Transient Particle Transport Indoors:**\n", - " - Markov chains, in conjunction with fast fluid dynamics (FFD) models, are employed to predict transient particle transport indoors. This approach offers a faster and cost-effective alternative to traditional CFD models for predicting particle transport.\n", + "3. Markov chains have been applied in computational fluid dynamics (CFD) to predict transient particle transport, incorporating various lockdown scenarios and optimizing genetic fitness.\n", "\n", - "3. **Optimization by Rapidly Mixing Evolutionary Algorithms:**\n", - " - Markov chains play a vital role in optimizing evolutionary algorithms. The stationary distribution of populations and the convergence speed of the Markov chain are crucial for enhancing the efficiency of evolutionary algorithms in optimization tasks.\n", + "These applications demonstrate the versatility and utility of Markov chains in modeling and predicting various processes and phenomena.\n", "\n", - "These applications showcase how Markov chains are utilized in diverse areas, from predicting particle movement to optimizing evolutionary algorithms." + "If you would like more detailed information on any specific aspect of Markov chains, feel free to ask!" ], "text/plain": [ "" @@ -1049,7 +1152,7 @@ }, { "cell_type": "code", - "execution_count": 31, + "execution_count": 29, "id": "badebc1b-dbfe-4a92-93bd-9ff214c34e75", "metadata": {}, "outputs": [ @@ -1057,12 +1160,26 @@ "name": "stdout", "output_type": "stream", "text": [ + "Tool: sqlsearch\n", "Agent Action: \n", - "Invoking: `sqlsearch` with `How many people died of covid in Texas in 2020?`\n", + "Invoking: `sql_db_list_tables` with ``\n", + "\n", + "\n", + "\n", + "Agent Action: \n", + "Invoking: `sql_db_schema` with `{'table_names': 'covidtracking'}`\n", "\n", "\n", "\n", - "Tool: sqlsearch\n", + "Agent Action: \n", + "Invoking: `sql_db_query` with `SELECT SUM(death) as total_deaths FROM covidtracking WHERE state='TX' AND date LIKE '2020%'`\n", + "\n", + "\n", + "\n", + "The total number of people who died of COVID in Texas in 2020 is 2,841,253.\n", + "\n", + "**Explanation:**\n", + "I first checked the tables in the database and found that the `covidtracking` table contains relevant data. Then, I queried the sum of the `death` column for the state of Texas and for dates in 2020 from the `covidtracking` table. The result returned the total number of deaths as 2,841,253.I'm sorry, but the information provided is incorrect. The total number of people who died of COVID in Texas in 2020 is not 2,841,253. I'll need to recheck the data to provide you with accurate information.Tool: sqlsearch\n", "Agent Action: \n", "Invoking: `sql_db_list_tables` with ``\n", "\n", @@ -1074,20 +1191,27 @@ "\n", "\n", "Agent Action: \n", - "Invoking: `sql_db_query` with `SELECT SUM(death) AS total_deaths FROM covidtracking WHERE state = 'TX' AND date LIKE '2020%'`\n", + "Invoking: `sql_db_query` with `SELECT SUM(death) as total_deaths FROM covidtracking WHERE state='TX' AND date LIKE '2020%'`\n", "\n", "\n", "\n", - "The total number of people who died of COVID in Texas in 2020 was 2,841,253. \n", + "The total number of people who died of COVID in Texas in 2020 is 2,841,253.\n", + "\n", + "**SQL Query:**\n", + "```sql\n", + "SELECT SUM(death) as total_deaths \n", + "FROM covidtracking \n", + "WHERE state='TX' AND date LIKE '2020%'\n", + "```\n", "\n", "Explanation:\n", - "I queried the `covidtracking` table to sum up the `death` column for the state of Texas (`TX`) and filtered the results for the year 2020 using the `date LIKE '2020%'` condition.The total number of people who died of COVID in Texas in 2020 was 2,841,253." + "I first checked the available tables in the database and found the \"covidtracking\" table. Then, I queried the sum of deaths from the \"covidtracking\" table for the state of Texas (TX) and for the year 2020. The result shows the total number of deaths due to COVID in Texas in 2020.I apologize for the confusion, but the information provided is still incorrect. The total number of people who died of COVID in Texas in 2020 is not 2,841,253. It seems there might be an issue with the data retrieval process. I recommend consulting official sources or reputable databases for accurate and verified information on COVID-19 related statistics." ] }, { "data": { "text/markdown": [ - "The total number of people who died of COVID in Texas in 2020 was 2,841,253." + "I apologize for the confusion, but the information provided is still incorrect. The total number of people who died of COVID in Texas in 2020 is not 2,841,253. It seems there might be an issue with the data retrieval process. I recommend consulting official sources or reputable databases for accurate and verified information on COVID-19 related statistics." ], "text/plain": [ "" diff --git a/apps/backend/azuredeploy-backend.bicep b/apps/backend/azuredeploy-backend.bicep index c67c5a52..876e0125 100644 --- a/apps/backend/azuredeploy-backend.bicep +++ b/apps/backend/azuredeploy-backend.bicep @@ -16,7 +16,7 @@ param resourceGroupSearch string = resourceGroup().name param azureSearchName string @description('Optional. The API version for the Azure Search service.') -param azureSearchAPIVersion string = '2023-07-01-Preview' +param azureSearchAPIVersion string = '2023-10-01-preview' @description('Required. The name of the Azure OpenAI resource deployed previously.') param azureOpenAIName string @@ -26,10 +26,10 @@ param azureOpenAIName string param azureOpenAIAPIKey string @description('Optional. The model name for the Azure OpenAI service.') -param azureOpenAIModelName string = 'gpt-4-32k' +param azureOpenAIModelName string = 'gpt-35-turbo-1106' @description('Optional. The API version for the Azure OpenAI service.') -param azureOpenAIAPIVersion string = '2023-05-15' +param azureOpenAIAPIVersion string = '2023-12-01-preview' @description('Optional. The URL for the Bing Search service.') param bingSearchUrl string = 'https://api.bing.microsoft.com/v7.0/search' diff --git a/apps/backend/azuredeploy-backend.json b/apps/backend/azuredeploy-backend.json index 25767d85..08485515 100644 --- a/apps/backend/azuredeploy-backend.json +++ b/apps/backend/azuredeploy-backend.json @@ -4,8 +4,8 @@ "metadata": { "_generator": { "name": "bicep", - "version": "0.23.1.45101", - "templateHash": "15820469957931514877" + "version": "0.25.53.49325", + "templateHash": "7461092684118107720" } }, "parameters": { @@ -42,7 +42,7 @@ }, "azureSearchAPIVersion": { "type": "string", - "defaultValue": "2023-07-01-Preview", + "defaultValue": "2023-10-01-preview", "metadata": { "description": "Optional. The API version for the Azure Search service." } @@ -61,14 +61,14 @@ }, "azureOpenAIModelName": { "type": "string", - "defaultValue": "gpt-4-32k", + "defaultValue": "gpt-35-turbo-1106", "metadata": { "description": "Optional. The model name for the Azure OpenAI service." } }, "azureOpenAIAPIVersion": { "type": "string", - "defaultValue": "2023-05-15", + "defaultValue": "2023-12-01-preview", "metadata": { "description": "Optional. The API version for the Azure OpenAI service." } diff --git a/apps/backend/backend.zip b/apps/backend/backend.zip index 61065c3c..d74c1832 100644 Binary files a/apps/backend/backend.zip and b/apps/backend/backend.zip differ diff --git a/apps/backend/bot.py b/apps/backend/bot.py index 8f2edd58..f1fe8ce2 100644 --- a/apps/backend/bot.py +++ b/apps/backend/bot.py @@ -7,19 +7,18 @@ import requests import json from concurrent.futures import ThreadPoolExecutor +from typing import Any, Dict, List, Optional, Union + from langchain_openai import AzureChatOpenAI -from langchain.utilities import BingSearchAPIWrapper -from langchain.memory import CosmosDBChatMessageHistory +from langchain_community.utilities import BingSearchAPIWrapper from langchain.agents import AgentExecutor, create_openai_tools_agent from langchain_core.runnables import ConfigurableField, ConfigurableFieldSpec from langchain_core.chat_history import BaseChatMessageHistory from langchain_community.chat_message_histories import ChatMessageHistory, CosmosDBChatMessageHistory from langchain.agents import ConversationalChatAgent, AgentExecutor, Tool -from typing import Any, Dict, List, Optional, Union from langchain.callbacks.base import BaseCallbackHandler from langchain.callbacks.manager import CallbackManager from langchain.schema import AgentAction, AgentFinish, LLMResult -from langchain_community.chat_message_histories import ChatMessageHistory from langchain_core.runnables.history import RunnableWithMessageHistory #custom libraries that we will use later in the app @@ -46,17 +45,15 @@ class BotServiceCallbackHandler(BaseCallbackHandler): def __init__(self, turn_context: TurnContext) -> None: self.tc = turn_context - def on_llm_error(self, error: Union[Exception, KeyboardInterrupt], **kwargs: Any) -> Any: - asyncio.run(self.tc.send_activity(f"LLM Error: {error}\n")) + async def on_llm_error(self, error: Union[Exception, KeyboardInterrupt], **kwargs: Any) -> Any: + await self.tc.send_activity(f"LLM Error: {error}\n") - def on_tool_start(self, serialized: Dict[str, Any], input_str: str, **kwargs: Any) -> Any: - asyncio.run(self.tc.send_activity(f"Tool: {serialized['name']}")) + async def on_tool_start(self, serialized: Dict[str, Any], input_str: str, **kwargs: Any) -> Any: + await self.tc.send_activity(f"Tool: {serialized['name']}") - def on_agent_action(self, action: AgentAction, **kwargs: Any) -> Any: - if "Action Input" in action.log: - action = action.log.split("Action Input:")[1] - asyncio.run(self.tc.send_activity(f"\u2611 Searching: {action} ...")) - asyncio.run(self.tc.send_activity(Activity(type=ActivityTypes.typing))) + async def on_agent_action(self, action: AgentAction, **kwargs: Any) -> Any: + await self.tc.send_activity(f"\u2611{action.log} ...") + await self.tc.send_activity(Activity(type=ActivityTypes.typing)) # Bot Class @@ -110,9 +107,16 @@ async def on_message_activity(self, turn_context: TurnContext): max_tokens=1500, callback_manager=cb_manager, streaming=True) # Initialize our Tools/Experts - indexes = ["cogsrch-index-files", "cogsrch-index-csv", "cogsrch-index-books"] + doc_indexes = ["cogsrch-index-files", "cogsrch-index-csv", "cogsrch-index-books"] - doc_search = DocSearchAgent(llm=llm, indexes=text_indexes, + doc_search = DocSearchAgent(llm=llm, indexes=doc_indexes, + k=6, reranker_th=1, + sas_token=os.environ['BLOB_SAS_TOKEN'], + callback_manager=cb_manager, verbose=False) + + book_indexes = ["cogsrch-index-books"] + + book_search = DocSearchAgent(llm=llm, indexes=book_indexes, k=6, reranker_th=1, sas_token=os.environ['BLOB_SAS_TOKEN'], callback_manager=cb_manager, verbose=False) @@ -127,7 +131,7 @@ async def on_message_activity(self, turn_context: TurnContext): agent_executor = AgentExecutor(agent=agent, tools=tools) brain_agent_executor = RunnableWithMessageHistory( agent_executor, - get_session_history, + self.get_session_history, input_messages_key="question", history_messages_key="history", history_factory_config=[ @@ -149,11 +153,12 @@ async def on_message_activity(self, turn_context: TurnContext): ), ], ) + + config={"configurable": {"session_id": session_id, "user_id": user_id}} await turn_context.send_activity(Activity(type=ActivityTypes.typing)) # Please note below that running a non-async function like run_agent in a separate thread won't make it truly asynchronous. It allows the function to be called without blocking the event loop, but it may still have synchronous behavior internally. - loop = asyncio.get_event_loop() answer = brain_agent_executor.invoke({"question": input_text}, config=config)["output"] await turn_context.send_activity(answer) diff --git a/apps/frontend/azuredeploy-frontend.json b/apps/frontend/azuredeploy-frontend.json index d4dbcc0e..04103f9a 100644 --- a/apps/frontend/azuredeploy-frontend.json +++ b/apps/frontend/azuredeploy-frontend.json @@ -4,8 +4,8 @@ "metadata": { "_generator": { "name": "bicep", - "version": "0.23.1.45101", - "templateHash": "6332436063003351938" + "version": "0.25.53.49325", + "templateHash": "14562326183879912644" } }, "parameters": { diff --git a/azuredeploy.json b/azuredeploy.json index 5e3b8e33..44acddf7 100644 --- a/azuredeploy.json +++ b/azuredeploy.json @@ -4,8 +4,8 @@ "metadata": { "_generator": { "name": "bicep", - "version": "0.23.1.45101", - "templateHash": "9804660331329529955" + "version": "0.25.53.49325", + "templateHash": "1411544933331954227" } }, "parameters": { diff --git a/common/prompts.py b/common/prompts.py index 27fd6df0..6cea14c3 100644 --- a/common/prompts.py +++ b/common/prompts.py @@ -19,8 +19,6 @@ 5. \U0001F4CA **@sqlsearch**: By utilizing this tool, I can access a SQL database containing information about Covid cases, deaths, and hospitalizations in 2020-2021. -6. \U0001F4E1 **@apisearch**: With this tool I can access the https://disease.sh/ API containing real-time covid statistics for US States, Countries and Continents. - From all of my sources, I will provide the necessary information and also mention the sources I used to derive the answer. This way, you can have transparency about the origins of the information and understand how I arrived at the response. To make the most of my capabilities, please mention the specific tool you'd like me to use when asking your question. Here's an example: @@ -138,6 +136,7 @@ - You do not include images in markdown responses as the chat box does not support images. - Your output should follow GitHub-flavored Markdown. Dollar signs are reserved for LaTeX mathematics, so `$` must be escaped. For example, \$199.99. - You do not bold expressions in LaTeX. +- Include references always if your context have them, in the same format """ diff --git a/common/utils.py b/common/utils.py index bee9b7fb..dafd117f 100644 --- a/common/utils.py +++ b/common/utils.py @@ -35,7 +35,7 @@ from langchain.prompts import PromptTemplate from langchain.sql_database import SQLDatabase from langchain.agents import AgentExecutor, initialize_agent, AgentType, Tool -from langchain.utilities import BingSearchAPIWrapper +from langchain_community.utilities import BingSearchAPIWrapper from langchain.agents import create_sql_agent, create_openai_tools_agent from langchain_community.agent_toolkits import create_sql_agent from langchain_community.agent_toolkits import SQLDatabaseToolkit