From 9ea339f46e6e79f6e10aad173331c9c8dc507579 Mon Sep 17 00:00:00 2001 From: Ian Zhai Date: Wed, 1 May 2024 19:27:38 +0800 Subject: [PATCH 1/6] add a oai assistant agent guide --- .../topics/gpt-assistant/gpt_assistant.ipynb | 34 +++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 website/docs/topics/gpt-assistant/gpt_assistant.ipynb diff --git a/website/docs/topics/gpt-assistant/gpt_assistant.ipynb b/website/docs/topics/gpt-assistant/gpt_assistant.ipynb new file mode 100644 index 000000000000..97953e503f6b --- /dev/null +++ b/website/docs/topics/gpt-assistant/gpt_assistant.ipynb @@ -0,0 +1,34 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# GPTAssistantAgent\n", + "\n", + "The GPTAssistantAgent lets you to leverage the power of OpenAI's Assistant API within the AutoGen framework. This enables you to incorporate various functionalities into your agents, including:\n", + "\n", + "\n", + "Multi-Tool Mastery: Agents can leverage a combination of OpenAI's built-in tools, like [Code Interpreter](https://platform.openai.com/docs/assistants/tools/code-interpreter) and [File Search](https://platform.openai.com/docs/assistants/tools/file-search), alongside custom tools you create or integrate via [Function Calling](https://platform.openai.com/docs/assistants/tools/function-calling).\n", + "\n", + "Streamlined Conversation Management: Benefit from persistent threads that automatically store message history and adjust based on the model's context length. This simplifies development by allowing you to focus on adding new messages rather than managing conversation flow.\n", + "\n", + "File Access and Integration: Enable agents to access and utilize files in various formats. Files can be incorporated during agent creation or throughout conversations via threads. Additionally, agents can generate files (e.g., images, spreadsheets) and cite referenced files within their responses." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [] + } + ], + "metadata": { + "language_info": { + "name": "python" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} From 96850bfa1f9f41678c2925d802e0cecb0b9b9ddd Mon Sep 17 00:00:00 2001 From: Ian Zhai Date: Wed, 1 May 2024 19:31:13 +0800 Subject: [PATCH 2/6] add a oai assistant agent guide --- .../topics/gpt-assistant/gpt_assistant.ipynb | 177 +++++++++++++++++- 1 file changed, 175 insertions(+), 2 deletions(-) diff --git a/website/docs/topics/gpt-assistant/gpt_assistant.ipynb b/website/docs/topics/gpt-assistant/gpt_assistant.ipynb index 97953e503f6b..729d49be8db5 100644 --- a/website/docs/topics/gpt-assistant/gpt_assistant.ipynb +++ b/website/docs/topics/gpt-assistant/gpt_assistant.ipynb @@ -13,7 +13,9 @@ "\n", "Streamlined Conversation Management: Benefit from persistent threads that automatically store message history and adjust based on the model's context length. This simplifies development by allowing you to focus on adding new messages rather than managing conversation flow.\n", "\n", - "File Access and Integration: Enable agents to access and utilize files in various formats. Files can be incorporated during agent creation or throughout conversations via threads. Additionally, agents can generate files (e.g., images, spreadsheets) and cite referenced files within their responses." + "File Access and Integration: Enable agents to access and utilize files in various formats. Files can be incorporated during agent creation or throughout conversations via threads. Additionally, agents can generate files (e.g., images, spreadsheets) and cite referenced files within their responses.\n", + "\n", + "## How to create a OpenAI Assistant in Autogen\n" ] }, { @@ -21,7 +23,178 @@ "execution_count": null, "metadata": {}, "outputs": [], - "source": [] + "source": [ + "import os\n", + "\n", + "from autogen import config_list_from_json\n", + "from autogen.agentchat.contrib.gpt_assistant_agent import GPTAssistantAgent\n", + "\n", + "assistant_id = os.environ.get(\"ASSISTANT_ID\", None)\n", + "config_list = config_list_from_json(\"OAI_CONFIG_LIST\")\n", + "llm_config = {\n", + " \"config_list\": config_list,\n", + "}\n", + "assistant_config = {\n", + " # define the openai assistant behavior as you need\n", + "}\n", + "oai_agent = GPTAssistantAgent(\n", + " name=\"oai_agent\",\n", + " instructions=\"I'm an openai assistant running in autogen\",\n", + " llm_config=llm_config,\n", + " assistant_config=assistant_config,\n", + ")" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## How to OpenAI Assistant Built-in Tools and Function Calling\n", + "\n", + "### Code Interpreter\n", + "\n", + "The [Code Interpreter](https://platform.openai.com/docs/assistants/tools/code-interpreter) empowers your agents to write and execute Python code in a secure environment provide by OpenAI. This unlocks several capabilities, including but not limited to:\n", + "\n", + "- Process data: Handle various data formats and manipulate data on the fly.\n", + "- Generate outputs: Create new data files or even visualizations like graphs.\n", + "- ...\n", + "\n", + "Using the Code Interpreter with the following configuration." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "assistant_config = {\n", + " \"tools\": [\n", + " {\"type\": \"code_interpreter\"},\n", + " ],\n", + " \"tool_resources\": {\n", + " \"code_interpreter\": {\n", + " \"file_ids\": [\"$file.id\"] # optional. Files that are passed at the Assistant level are accessible by all Runs with this Assistant.\n", + " }\n", + " }\n", + "}" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "To get the `file.id`, you can employ two methods:\n", + "\n", + "1. OpenAI Playground: Leverage the OpenAI Playground, an interactive platform accessible at https://platform.openai.com/playground, to upload your files and obtain the corresponding file IDs.\n", + "\n", + "2. Code-Based Uploading: Alternatively, you can upload files and retrieve their file IDs programmatically using the following code snippet:\n", + "\n", + " ```python\n", + " from openai import OpenAI\n", + " client = OpenAI(\n", + " # Defaults to os.environ.get(\"OPENAI_API_KEY\")\n", + " )\n", + " # Upload a file with an \"assistants\" purpose\n", + " file = client.files.create(\n", + " file=open(\"mydata.csv\", \"rb\"),\n", + " purpose='assistants'\n", + " )\n", + " ```" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### File Search\n", + "\n", + "The [File Search](https://platform.openai.com/docs/assistants/tools/file-search) tool empowers your agents to tap into knowledge beyond its pre-trained model. This allows you to incorporate your own documents and data, such as product information or code files, into your agent's capabilities.\n", + "\n", + "Using the File Search with the following configuration." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "assistant_config = {\n", + " \"tools\": [\n", + " {\"type\": \"file_search\"},\n", + " ],\n", + " \"tool_resources\": {\n", + " \"file_search\": {\n", + " \"vector_store_ids\": [\"$vector_store.id\"]\n", + " }\n", + " }\n", + "}" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Here's how to obtain the vector_store.id using two methods:\n", + "\n", + "1. OpenAI Playground: Leverage the OpenAI Playground, an interactive platform accessible at https://platform.openai.com/playground, to create a vector store, upload your files, and add it into your vector store. Once complete, you'll be able to retrieve the associated `vector_store.id`.\n", + "\n", + "2. Code-Based Uploading:Alternatively, you can upload files and retrieve their file IDs programmatically using the following code snippet:\n", + "\n", + " ```python\n", + " from openai import OpenAI\n", + " client = OpenAI(\n", + " # Defaults to os.environ.get(\"OPENAI_API_KEY\")\n", + " )\n", + "\n", + " # Step 1: Create a Vector Store\n", + " vector_store = client.beta.vector_stores.create(name=\"Financial Statements\")\n", + " print(\"Vector Store created:\", vector_store.id) # This is your vector_store.id\n", + "\n", + " # Step 2: Prepare Files for Upload\n", + " file_paths = [\"edgar/goog-10k.pdf\", \"edgar/brka-10k.txt\"]\n", + " file_streams = [open(path, \"rb\") for path in file_paths]\n", + "\n", + " # Step 3: Upload Files and Add to Vector Store (with status polling)\n", + " file_batch = client.beta.vector_stores.file_batches.upload_and_poll(\n", + " vector_store_id=vector_store.id, files=file_streams\n", + " )\n", + "\n", + " # Step 4: Verify Completion (Optional)\n", + " print(\"File batch status:\", file_batch.status)\n", + " print(\"Uploaded file count:\", file_batch.file_counts.processed)\n", + " ```" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Function calling\n", + "\n", + "Function Calling empowers you to extend the capabilities of your agents with your pre-defined functionalities, which allows you to describe custom functions to the Assistant, enabling intelligent function selection and argument generation.\n", + "\n", + "Using the Function calling with the following configuration." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# learn more from https://platform.openai.com/docs/guides/function-calling/function-calling\n", + "api_schema = \"define your function schema here\"\n", + "assistant_config = {\n", + " \"tools\": [\n", + " {\n", + " \"type\": \"function\",\n", + " \"function\": api_schema,\n", + " }\n", + " ],\n", + "}" + ] } ], "metadata": { From 76cdcf09827d370a57d2ee73b6088b2757ee6996 Mon Sep 17 00:00:00 2001 From: IANTHEREAL Date: Wed, 1 May 2024 19:56:09 +0800 Subject: [PATCH 3/6] polish --- .../topics/gpt-assistant/gpt_assistant.ipynb | 207 ------------------ .../topics/gpt-assistant/gpt_assistant.md | 151 +++++++++++++ 2 files changed, 151 insertions(+), 207 deletions(-) delete mode 100644 website/docs/topics/gpt-assistant/gpt_assistant.ipynb create mode 100644 website/docs/topics/gpt-assistant/gpt_assistant.md diff --git a/website/docs/topics/gpt-assistant/gpt_assistant.ipynb b/website/docs/topics/gpt-assistant/gpt_assistant.ipynb deleted file mode 100644 index 729d49be8db5..000000000000 --- a/website/docs/topics/gpt-assistant/gpt_assistant.ipynb +++ /dev/null @@ -1,207 +0,0 @@ -{ - "cells": [ - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "# GPTAssistantAgent\n", - "\n", - "The GPTAssistantAgent lets you to leverage the power of OpenAI's Assistant API within the AutoGen framework. This enables you to incorporate various functionalities into your agents, including:\n", - "\n", - "\n", - "Multi-Tool Mastery: Agents can leverage a combination of OpenAI's built-in tools, like [Code Interpreter](https://platform.openai.com/docs/assistants/tools/code-interpreter) and [File Search](https://platform.openai.com/docs/assistants/tools/file-search), alongside custom tools you create or integrate via [Function Calling](https://platform.openai.com/docs/assistants/tools/function-calling).\n", - "\n", - "Streamlined Conversation Management: Benefit from persistent threads that automatically store message history and adjust based on the model's context length. This simplifies development by allowing you to focus on adding new messages rather than managing conversation flow.\n", - "\n", - "File Access and Integration: Enable agents to access and utilize files in various formats. Files can be incorporated during agent creation or throughout conversations via threads. Additionally, agents can generate files (e.g., images, spreadsheets) and cite referenced files within their responses.\n", - "\n", - "## How to create a OpenAI Assistant in Autogen\n" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "import os\n", - "\n", - "from autogen import config_list_from_json\n", - "from autogen.agentchat.contrib.gpt_assistant_agent import GPTAssistantAgent\n", - "\n", - "assistant_id = os.environ.get(\"ASSISTANT_ID\", None)\n", - "config_list = config_list_from_json(\"OAI_CONFIG_LIST\")\n", - "llm_config = {\n", - " \"config_list\": config_list,\n", - "}\n", - "assistant_config = {\n", - " # define the openai assistant behavior as you need\n", - "}\n", - "oai_agent = GPTAssistantAgent(\n", - " name=\"oai_agent\",\n", - " instructions=\"I'm an openai assistant running in autogen\",\n", - " llm_config=llm_config,\n", - " assistant_config=assistant_config,\n", - ")" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "## How to OpenAI Assistant Built-in Tools and Function Calling\n", - "\n", - "### Code Interpreter\n", - "\n", - "The [Code Interpreter](https://platform.openai.com/docs/assistants/tools/code-interpreter) empowers your agents to write and execute Python code in a secure environment provide by OpenAI. This unlocks several capabilities, including but not limited to:\n", - "\n", - "- Process data: Handle various data formats and manipulate data on the fly.\n", - "- Generate outputs: Create new data files or even visualizations like graphs.\n", - "- ...\n", - "\n", - "Using the Code Interpreter with the following configuration." - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "assistant_config = {\n", - " \"tools\": [\n", - " {\"type\": \"code_interpreter\"},\n", - " ],\n", - " \"tool_resources\": {\n", - " \"code_interpreter\": {\n", - " \"file_ids\": [\"$file.id\"] # optional. Files that are passed at the Assistant level are accessible by all Runs with this Assistant.\n", - " }\n", - " }\n", - "}" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "To get the `file.id`, you can employ two methods:\n", - "\n", - "1. OpenAI Playground: Leverage the OpenAI Playground, an interactive platform accessible at https://platform.openai.com/playground, to upload your files and obtain the corresponding file IDs.\n", - "\n", - "2. Code-Based Uploading: Alternatively, you can upload files and retrieve their file IDs programmatically using the following code snippet:\n", - "\n", - " ```python\n", - " from openai import OpenAI\n", - " client = OpenAI(\n", - " # Defaults to os.environ.get(\"OPENAI_API_KEY\")\n", - " )\n", - " # Upload a file with an \"assistants\" purpose\n", - " file = client.files.create(\n", - " file=open(\"mydata.csv\", \"rb\"),\n", - " purpose='assistants'\n", - " )\n", - " ```" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "### File Search\n", - "\n", - "The [File Search](https://platform.openai.com/docs/assistants/tools/file-search) tool empowers your agents to tap into knowledge beyond its pre-trained model. This allows you to incorporate your own documents and data, such as product information or code files, into your agent's capabilities.\n", - "\n", - "Using the File Search with the following configuration." - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "assistant_config = {\n", - " \"tools\": [\n", - " {\"type\": \"file_search\"},\n", - " ],\n", - " \"tool_resources\": {\n", - " \"file_search\": {\n", - " \"vector_store_ids\": [\"$vector_store.id\"]\n", - " }\n", - " }\n", - "}" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "Here's how to obtain the vector_store.id using two methods:\n", - "\n", - "1. OpenAI Playground: Leverage the OpenAI Playground, an interactive platform accessible at https://platform.openai.com/playground, to create a vector store, upload your files, and add it into your vector store. Once complete, you'll be able to retrieve the associated `vector_store.id`.\n", - "\n", - "2. Code-Based Uploading:Alternatively, you can upload files and retrieve their file IDs programmatically using the following code snippet:\n", - "\n", - " ```python\n", - " from openai import OpenAI\n", - " client = OpenAI(\n", - " # Defaults to os.environ.get(\"OPENAI_API_KEY\")\n", - " )\n", - "\n", - " # Step 1: Create a Vector Store\n", - " vector_store = client.beta.vector_stores.create(name=\"Financial Statements\")\n", - " print(\"Vector Store created:\", vector_store.id) # This is your vector_store.id\n", - "\n", - " # Step 2: Prepare Files for Upload\n", - " file_paths = [\"edgar/goog-10k.pdf\", \"edgar/brka-10k.txt\"]\n", - " file_streams = [open(path, \"rb\") for path in file_paths]\n", - "\n", - " # Step 3: Upload Files and Add to Vector Store (with status polling)\n", - " file_batch = client.beta.vector_stores.file_batches.upload_and_poll(\n", - " vector_store_id=vector_store.id, files=file_streams\n", - " )\n", - "\n", - " # Step 4: Verify Completion (Optional)\n", - " print(\"File batch status:\", file_batch.status)\n", - " print(\"Uploaded file count:\", file_batch.file_counts.processed)\n", - " ```" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "### Function calling\n", - "\n", - "Function Calling empowers you to extend the capabilities of your agents with your pre-defined functionalities, which allows you to describe custom functions to the Assistant, enabling intelligent function selection and argument generation.\n", - "\n", - "Using the Function calling with the following configuration." - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# learn more from https://platform.openai.com/docs/guides/function-calling/function-calling\n", - "api_schema = \"define your function schema here\"\n", - "assistant_config = {\n", - " \"tools\": [\n", - " {\n", - " \"type\": \"function\",\n", - " \"function\": api_schema,\n", - " }\n", - " ],\n", - "}" - ] - } - ], - "metadata": { - "language_info": { - "name": "python" - } - }, - "nbformat": 4, - "nbformat_minor": 2 -} diff --git a/website/docs/topics/gpt-assistant/gpt_assistant.md b/website/docs/topics/gpt-assistant/gpt_assistant.md new file mode 100644 index 000000000000..dc7b6139b03e --- /dev/null +++ b/website/docs/topics/gpt-assistant/gpt_assistant.md @@ -0,0 +1,151 @@ +# GPTAssistantAgent + +The GPTAssistantAgent is a powerful component of the AutoGen framework, utilizing OpenAI's Assistant API to enhance agents with advanced capabilities. This agent enables the integration of multiple tools such as the Code Interpreter, File Search, and Function Calling, allowing for a highly customizable and dynamic interaction model. + +Key Features of the GPTAssistantAgent: + +- Multi-Tool Mastery: Agents can leverage a combination of OpenAI's built-in tools, like [Code Interpreter](https://platform.openai.com/docs/assistants/tools/code-interpreter) and [File Search](https://platform.openai.com/docs/assistants/tools/file-search), alongside custom tools you create or integrate via [Function Calling](https://platform.openai.com/docs/assistants/tools/function-calling). + +- Streamlined Conversation Management: Benefit from persistent threads that automatically store message history and adjust based on the model's context length. This simplifies development by allowing you to focus on adding new messages rather than managing conversation flow. + +- File Access and Integration: Enable agents to access and utilize files in various formats. Files can be incorporated during agent creation or throughout conversations via threads. Additionally, agents can generate files (e.g., images, spreadsheets) and cite referenced files within their responses. + +For a practical illustration, here are some examples: + +- [Chat with OpenAI Assistant using function call](/notebook/agentchat_oai_assistant_function_call.ipynb) demonstrates how to leverage function calling to enable intelligent function selection. +- [GPTAssistant with Code Interpreter](/notebook/agentchat_oai_code_interpreter.ipynb) showcases the integration of the Code Interpreter tool which executes Python code dynamically within applications. +- [Group Chat with GPTAssistantAgent](/notebook/agentchat_oai_assistant_groupchat.ipynb) demonstrates how to use the GPTAssistantAgent in AutoGen's group chat mode, enabling collaborative task performance through automated chat with agents powered by LLMs, tools, or humans. + +## Create a OpenAI Assistant in Autogen + +```python +import os + +from autogen import config_list_from_json +from autogen.agentchat.contrib.gpt_assistant_agent import GPTAssistantAgent + +assistant_id = os.environ.get("ASSISTANT_ID", None) +config_list = config_list_from_json("OAI_CONFIG_LIST") +llm_config = { + "config_list": config_list, +} +assistant_config = { + # define the openai assistant behavior as you need +} +oai_agent = GPTAssistantAgent( + name="oai_agent", + instructions="I'm an openai assistant running in autogen", + llm_config=llm_config, + assistant_config=assistant_config, +) +``` + +## Use OpenAI Assistant Built-in Tools and Function Calling + +### Code Interpreter + +The [Code Interpreter](https://platform.openai.com/docs/assistants/tools/code-interpreter) empowers your agents to write and execute Python code in a secure environment provide by OpenAI. This unlocks several capabilities, including but not limited to: + +- Process data: Handle various data formats and manipulate data on the fly. +- Generate outputs: Create new data files or even visualizations like graphs. +- ... + +Using the Code Interpreter with the following configuration. +```python +assistant_config = { + "tools": [ + {"type": "code_interpreter"}, + ], + "tool_resources": { + "code_interpreter": { + "file_ids": ["$file.id"] # optional. Files that are passed at the Assistant level are accessible by all Runs with this Assistant. + } + } +} +``` + +To get the `file.id`, you can employ two methods: + +1. OpenAI Playground: Leverage the OpenAI Playground, an interactive platform accessible at https://platform.openai.com/playground, to upload your files and obtain the corresponding file IDs. + +2. Code-Based Uploading: Alternatively, you can upload files and retrieve their file IDs programmatically using the following code snippet: + + ```python + from openai import OpenAI + client = OpenAI( + # Defaults to os.environ.get("OPENAI_API_KEY") + ) + # Upload a file with an "assistants" purpose + file = client.files.create( + file=open("mydata.csv", "rb"), + purpose='assistants' + ) + ``` + +### File Search + +The [File Search](https://platform.openai.com/docs/assistants/tools/file-search) tool empowers your agents to tap into knowledge beyond its pre-trained model. This allows you to incorporate your own documents and data, such as product information or code files, into your agent's capabilities. + +Using the File Search with the following configuration. + +```python +assistant_config = { + "tools": [ + {"type": "file_search"}, + ], + "tool_resources": { + "file_search": { + "vector_store_ids": ["$vector_store.id"] + } + } +} +``` + +Here's how to obtain the vector_store.id using two methods: + +1. OpenAI Playground: Leverage the OpenAI Playground, an interactive platform accessible at https://platform.openai.com/playground, to create a vector store, upload your files, and add it into your vector store. Once complete, you'll be able to retrieve the associated `vector_store.id`. + +2. Code-Based Uploading:Alternatively, you can upload files and retrieve their file IDs programmatically using the following code snippet: + + ```python + from openai import OpenAI + client = OpenAI( + # Defaults to os.environ.get("OPENAI_API_KEY") + ) + + # Step 1: Create a Vector Store + vector_store = client.beta.vector_stores.create(name="Financial Statements") + print("Vector Store created:", vector_store.id) # This is your vector_store.id + + # Step 2: Prepare Files for Upload + file_paths = ["edgar/goog-10k.pdf", "edgar/brka-10k.txt"] + file_streams = [open(path, "rb") for path in file_paths] + + # Step 3: Upload Files and Add to Vector Store (with status polling) + file_batch = client.beta.vector_stores.file_batches.upload_and_poll( + vector_store_id=vector_store.id, files=file_streams + ) + + # Step 4: Verify Completion (Optional) + print("File batch status:", file_batch.status) + print("Uploaded file count:", file_batch.file_counts.processed) + ``` + +### Function calling + +Function Calling empowers you to extend the capabilities of your agents with your pre-defined functionalities, which allows you to describe custom functions to the Assistant, enabling intelligent function selection and argument generation. + +Using the Function calling with the following configuration. + +```python +# learn more from https://platform.openai.com/docs/guides/function-calling/function-calling +api_schema = "define your function schema here" +assistant_config = { + "tools": [ + { + "type": "function", + "function": api_schema, + } + ], +} +``` From 85d64ca7a46c220f5c89ad7104b9ec4b49509be5 Mon Sep 17 00:00:00 2001 From: IANTHEREAL Date: Thu, 2 May 2024 18:51:04 +0800 Subject: [PATCH 4/6] address comments --- autogen/oai/openai_utils.py | 6 ++-- ...gentchat_oai_assistant_function_call.ipynb | 27 +++++++++++++- .../agentchat_oai_assistant_groupchat.ipynb | 36 +++++++++++-------- notebook/agentchat_oai_code_interpreter.ipynb | 34 ++++++++++-------- .../topics/openai-assistant/_category_.json | 5 +++ .../openai_assistant.md} | 34 +++++++++++++++--- 6 files changed, 105 insertions(+), 37 deletions(-) create mode 100644 website/docs/topics/openai-assistant/_category_.json rename website/docs/topics/{gpt-assistant/gpt_assistant.md => openai-assistant/openai_assistant.md} (85%) diff --git a/autogen/oai/openai_utils.py b/autogen/oai/openai_utils.py index 7e738b7bd61e..9d52179b8dad 100644 --- a/autogen/oai/openai_utils.py +++ b/autogen/oai/openai_utils.py @@ -693,17 +693,17 @@ def create_gpt_vector_store(client: OpenAI, name: str, fild_ids: List[str]) -> A """Create a openai vector store for gpt assistant""" try: - vector_store = client.beta.vector_stores.create(name=name) + vector_store = client.beta.vector_stores.create(name=name) # type: ignore except Exception as e: raise AttributeError(f"Failed to create vector store, please install the latest OpenAI python package: {e}") # poll the status of the file batch for completion. - batch = client.beta.vector_stores.file_batches.create_and_poll(vector_store_id=vector_store.id, file_ids=fild_ids) + batch = client.beta.vector_stores.file_batches.create_and_poll(vector_store_id=vector_store.id, file_ids=fild_ids) # type: ignore if batch.status == "in_progress": time.sleep(1) logging.debug(f"file batch status: {batch.file_counts}") - batch = client.beta.vector_stores.file_batches.poll(vector_store_id=vector_store.id, batch_id=batch.id) + batch = client.beta.vector_stores.file_batches.poll(vector_store_id=vector_store.id, batch_id=batch.id) # type: ignore if batch.status == "completed": return vector_store diff --git a/notebook/agentchat_oai_assistant_function_call.ipynb b/notebook/agentchat_oai_assistant_function_call.ipynb index 878175420c6c..9dcd6221e849 100644 --- a/notebook/agentchat_oai_assistant_function_call.ipynb +++ b/notebook/agentchat_oai_assistant_function_call.ipynb @@ -17,9 +17,16 @@ "### Requirements\n", "\n", "AutoGen requires `Python>=3.8`. To run this notebook example, please install:\n", + "````{=mdx}\n", + ":::info Requirements\n", + "Install `pyautogen`:\n", "```bash\n", "pip install pyautogen\n", - "```" + "```\n", + "\n", + "For more information, please refer to the [installation guide](/docs/installation/).\n", + ":::\n", + "````" ] }, { @@ -155,6 +162,17 @@ ")" ] }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "````{=mdx}\n", + ":::tip\n", + "Learn more about configuring LLMs for agents [here](/docs/topics/llm_configuration).\n", + ":::\n", + "````\n" + ] + }, { "cell_type": "markdown", "metadata": {}, @@ -256,6 +274,13 @@ } ], "metadata": { + "front_matter": { + "description": "This Jupyter Notebook demonstrates how to leverage OSS Insight (Open Source Software Insight) for advanced GitHub data analysis by defining `Function calls` in AutoGen for the OpenAI Assistant.", + "tags": [ + "OpenAI Assistant", + "function call" + ] + }, "kernelspec": { "display_name": "autogen", "language": "python", diff --git a/notebook/agentchat_oai_assistant_groupchat.ipynb b/notebook/agentchat_oai_assistant_groupchat.ipynb index 603d2cf71d99..d38fed4cdaee 100644 --- a/notebook/agentchat_oai_assistant_groupchat.ipynb +++ b/notebook/agentchat_oai_assistant_groupchat.ipynb @@ -14,9 +14,16 @@ "## Requirements\n", "\n", "AutoGen requires `Python>=3.8`. To run this notebook example, please install:\n", + "````{=mdx}\n", + ":::info Requirements\n", + "Install `pyautogen`:\n", "```bash\n", - "pip install \"pyautogen>=0.2.3\"\n", - "```" + "pip install pyautogen\n", + "```\n", + "\n", + "For more information, please refer to the [installation guide](/docs/installation/).\n", + ":::\n", + "````" ] }, { @@ -50,19 +57,11 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "It first looks for environment variable \"OAI_CONFIG_LIST\" which needs to be a valid json string. If that variable is not found, it then looks for a json file named \"OAI_CONFIG_LIST\". It filters the configs by models (you can filter by other keys as well).\n", - "\n", - "The config list looks like the following:\n", - "```python\n", - "config_list = [\n", - " {\n", - " \"model\": \"gpt-4\",\n", - " \"api_key\": \"\",\n", - " }, # OpenAI API endpoint for gpt-4\n", - "]\n", - "```\n", - "\n", - "Currently Azure OpenAI does not support assistant api. You can set the value of config_list in any way you prefer. Please refer to this [notebook](https://github.com/microsoft/autogen/blob/main/website/docs/topics/llm_configuration.ipynb) for full code examples of the different methods." + "````{=mdx}\n", + ":::tip\n", + "Learn more about configuring LLMs for agents [here](/docs/topics/llm_configuration).\n", + ":::\n", + "````" ] }, { @@ -482,6 +481,13 @@ } ], "metadata": { + "front_matter": { + "description": "This Jupyter Notebook demonstrates how to use the GPTAssistantAgent in AutoGen's group chat mode, enabling collaborative task performance through automated chat with agents powered by LLMs, tools, or humans.", + "tags": [ + "OpenAI Assistant", + "group chat" + ] + }, "kernelspec": { "display_name": "Python 3", "language": "python", diff --git a/notebook/agentchat_oai_code_interpreter.ipynb b/notebook/agentchat_oai_code_interpreter.ipynb index 921165fdd6b3..a8aeb6147896 100644 --- a/notebook/agentchat_oai_code_interpreter.ipynb +++ b/notebook/agentchat_oai_code_interpreter.ipynb @@ -10,9 +10,16 @@ "## Requirements\n", "\n", "AutoGen requires `Python>=3.8`. To run this notebook example, please install:\n", + "````{=mdx}\n", + ":::info Requirements\n", + "Install `pyautogen`:\n", "```bash\n", "pip install pyautogen\n", - "```" + "```\n", + "\n", + "For more information, please refer to the [installation guide](/docs/installation/).\n", + ":::\n", + "````" ] }, { @@ -52,19 +59,11 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "It first looks for environment variable \"OAI_CONFIG_LIST\" which needs to be a valid json string. If that variable is not found, it then looks for a json file named \"OAI_CONFIG_LIST\". It filters the configs by models (you can filter by other keys as well).\n", - "\n", - "The config list looks like the following:\n", - "```python\n", - "config_list = [\n", - " {\n", - " \"model\": \"gpt-4\",\n", - " \"api_key\": \"\",\n", - " }, # OpenAI API endpoint for gpt-4\n", - "]\n", - "```\n", - "\n", - "Currently Azure OpenAi does not support assistant api. You can set the value of config_list in any way you prefer. Please refer to this [notebook](https://github.com/microsoft/autogen/blob/main/website/docs/llm_endpoint_configuration.ipynb) for full code examples of the different methods." + "````{=mdx}\n", + ":::tip\n", + "Learn more about configuring LLMs for agents [here](/docs/topics/llm_configuration).\n", + ":::\n", + "````" ] }, { @@ -297,6 +296,13 @@ } ], "metadata": { + "front_matter": { + "description": "This Jupyter Notebook showcases the integration of the Code Interpreter tool which executes Python code dynamically within applications.", + "tags": [ + "OpenAI Assistant", + "code interpreter" + ] + }, "kernelspec": { "display_name": "Python 3", "language": "python", diff --git a/website/docs/topics/openai-assistant/_category_.json b/website/docs/topics/openai-assistant/_category_.json new file mode 100644 index 000000000000..146faedf94c3 --- /dev/null +++ b/website/docs/topics/openai-assistant/_category_.json @@ -0,0 +1,5 @@ +{ + "position": 2, + "label": "OpenAI Assistant", + "collapsible": true +} diff --git a/website/docs/topics/gpt-assistant/gpt_assistant.md b/website/docs/topics/openai-assistant/openai_assistant.md similarity index 85% rename from website/docs/topics/gpt-assistant/gpt_assistant.md rename to website/docs/topics/openai-assistant/openai_assistant.md index dc7b6139b03e..fc16893dec14 100644 --- a/website/docs/topics/gpt-assistant/gpt_assistant.md +++ b/website/docs/topics/openai-assistant/openai_assistant.md @@ -1,4 +1,4 @@ -# GPTAssistantAgent +# Agent Backed by OpenAI Assistant API The GPTAssistantAgent is a powerful component of the AutoGen framework, utilizing OpenAI's Assistant API to enhance agents with advanced capabilities. This agent enables the integration of multiple tools such as the Code Interpreter, File Search, and Function Calling, allowing for a highly customizable and dynamic interaction model. @@ -12,9 +12,9 @@ Key Features of the GPTAssistantAgent: For a practical illustration, here are some examples: -- [Chat with OpenAI Assistant using function call](/notebook/agentchat_oai_assistant_function_call.ipynb) demonstrates how to leverage function calling to enable intelligent function selection. -- [GPTAssistant with Code Interpreter](/notebook/agentchat_oai_code_interpreter.ipynb) showcases the integration of the Code Interpreter tool which executes Python code dynamically within applications. -- [Group Chat with GPTAssistantAgent](/notebook/agentchat_oai_assistant_groupchat.ipynb) demonstrates how to use the GPTAssistantAgent in AutoGen's group chat mode, enabling collaborative task performance through automated chat with agents powered by LLMs, tools, or humans. +- [Chat with OpenAI Assistant using function call](/docs/notebooks/agentchat_oai_assistant_function_call) demonstrates how to leverage function calling to enable intelligent function selection. +- [GPTAssistant with Code Interpreter](/docs/notebooks/agentchat_oai_code_interpreter) showcases the integration of the Code Interpreter tool which executes Python code dynamically within applications. +- [Group Chat with GPTAssistantAgent](/docs/notebooks/agentchat_oai_assistant_groupchat) demonstrates how to use the GPTAssistantAgent in AutoGen's group chat mode, enabling collaborative task performance through automated chat with agents powered by LLMs, tools, or humans. ## Create a OpenAI Assistant in Autogen @@ -139,6 +139,32 @@ Using the Function calling with the following configuration. ```python # learn more from https://platform.openai.com/docs/guides/function-calling/function-calling +from autogen.function_utils import get_function_schema + +def get_current_weather(location: str) -> dict: + """ + Retrieves the current weather for a specified location. + + Args: + location (str): The location to get the weather for. + + Returns: + Union[str, dict]: A dictionary with weather details.. + """ + + # Simulated response + return { + "location": location, + "temperature": 22.5, + "description": "Partly cloudy" + } + +api_schema = get_function_schema( + get_current_weather, + name=get_current_weather.__name__, + description="Returns the current weather data for a specified location." +) + api_schema = "define your function schema here" assistant_config = { "tools": [ From a215c63802bee9af2d41b8e3a8183476c87ae653 Mon Sep 17 00:00:00 2001 From: IANTHEREAL Date: Thu, 2 May 2024 19:04:04 +0800 Subject: [PATCH 5/6] remove useless type ingnore comments --- autogen/oai/openai_utils.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/autogen/oai/openai_utils.py b/autogen/oai/openai_utils.py index 9d52179b8dad..7e738b7bd61e 100644 --- a/autogen/oai/openai_utils.py +++ b/autogen/oai/openai_utils.py @@ -693,17 +693,17 @@ def create_gpt_vector_store(client: OpenAI, name: str, fild_ids: List[str]) -> A """Create a openai vector store for gpt assistant""" try: - vector_store = client.beta.vector_stores.create(name=name) # type: ignore + vector_store = client.beta.vector_stores.create(name=name) except Exception as e: raise AttributeError(f"Failed to create vector store, please install the latest OpenAI python package: {e}") # poll the status of the file batch for completion. - batch = client.beta.vector_stores.file_batches.create_and_poll(vector_store_id=vector_store.id, file_ids=fild_ids) # type: ignore + batch = client.beta.vector_stores.file_batches.create_and_poll(vector_store_id=vector_store.id, file_ids=fild_ids) if batch.status == "in_progress": time.sleep(1) logging.debug(f"file batch status: {batch.file_counts}") - batch = client.beta.vector_stores.file_batches.poll(vector_store_id=vector_store.id, batch_id=batch.id) # type: ignore + batch = client.beta.vector_stores.file_batches.poll(vector_store_id=vector_store.id, batch_id=batch.id) if batch.status == "completed": return vector_store From bf1fc9120f71ce907d585081b86efc89b54d37cd Mon Sep 17 00:00:00 2001 From: IANTHEREAL Date: Fri, 3 May 2024 09:14:41 +0800 Subject: [PATCH 6/6] fix ci --- notebook/agentchat_oai_assistant_function_call.ipynb | 10 +++++----- .../{openai_assistant.md => gpt_assistant_agent.md} | 0 2 files changed, 5 insertions(+), 5 deletions(-) rename website/docs/topics/openai-assistant/{openai_assistant.md => gpt_assistant_agent.md} (100%) diff --git a/notebook/agentchat_oai_assistant_function_call.ipynb b/notebook/agentchat_oai_assistant_function_call.ipynb index 9dcd6221e849..bc78819fb198 100644 --- a/notebook/agentchat_oai_assistant_function_call.ipynb +++ b/notebook/agentchat_oai_assistant_function_call.ipynb @@ -4,7 +4,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "## Chat with OpenAI Assistant using function call in AutoGen: OSS Insights for Advanced GitHub Data Analysis\n", + "# Chat with OpenAI Assistant using function call in AutoGen: OSS Insights for Advanced GitHub Data Analysis\n", "\n", "This Jupyter Notebook demonstrates how to leverage OSS Insight (Open Source Software Insight) for advanced GitHub data analysis by defining `Function calls` in AutoGen for the OpenAI Assistant. \n", "\n", @@ -14,7 +14,7 @@ "2. Defining an OpenAI Assistant Agent in AutoGen\n", "3. Fetching GitHub Insight Data using Function Call\n", "\n", - "### Requirements\n", + "## Requirements\n", "\n", "AutoGen requires `Python>=3.8`. To run this notebook example, please install:\n", "````{=mdx}\n", @@ -43,7 +43,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "### Function Schema and Implementation\n", + "## Function Schema and Implementation\n", "\n", "This section provides the function schema definition and their implementation details. These functions are tailored to fetch and process data from GitHub, utilizing OSS Insight's capabilities." ] @@ -108,7 +108,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "### Defining an OpenAI Assistant Agent in AutoGen\n", + "## Defining an OpenAI Assistant Agent in AutoGen\n", "\n", "Here, we explore how to define an OpenAI Assistant Agent within the AutoGen. This includes setting up the agent to make use of the previously defined function calls for data retrieval and analysis." ] @@ -177,7 +177,7 @@ "cell_type": "markdown", "metadata": {}, "source": [ - "### Fetching GitHub Insight Data using Function Call\n", + "## Fetching GitHub Insight Data using Function Call\n", "\n", "This part of the notebook demonstrates the practical application of the defined functions and the OpenAI Assistant Agent in fetching and interpreting GitHub Insight data." ] diff --git a/website/docs/topics/openai-assistant/openai_assistant.md b/website/docs/topics/openai-assistant/gpt_assistant_agent.md similarity index 100% rename from website/docs/topics/openai-assistant/openai_assistant.md rename to website/docs/topics/openai-assistant/gpt_assistant_agent.md