From 5f87b2802f9f336338ace444cf895b54e83b6b61 Mon Sep 17 00:00:00 2001 From: siddharth Sambharia Date: Mon, 9 Sep 2024 11:06:48 +0530 Subject: [PATCH] Portkey Integration with Autogen (#3395) * Portkey Integration with Autogen * Update website/docs/ecosystem/portkey.md Co-authored-by: gagb * Update website/docs/ecosystem/portkey.md Co-authored-by: gagb * Update website/docs/ecosystem/portkey.md Co-authored-by: gagb * Update website/docs/ecosystem/portkey.md * Update website/docs/ecosystem/portkey.md * Update website/docs/ecosystem/portkey.md * Update website/docs/ecosystem/portkey.md * Update website/docs/ecosystem/portkey.md * Update portkey.md with changes * Update website/docs/ecosystem/portkey.md Co-authored-by: Mark Sze <66362098+marklysze@users.noreply.github.com> * Remove trailing white spaces * Update portkey.md with mark's note * remove trailing white spaces line 15 and empty line at end --------- Co-authored-by: Li Jiang Co-authored-by: gagb Co-authored-by: Mark Sze <66362098+marklysze@users.noreply.github.com> --- website/docs/ecosystem/portkey.md | 209 ++++++++++++++++++++++++++++++ 1 file changed, 209 insertions(+) create mode 100644 website/docs/ecosystem/portkey.md diff --git a/website/docs/ecosystem/portkey.md b/website/docs/ecosystem/portkey.md new file mode 100644 index 000000000000..4825cf78d9a7 --- /dev/null +++ b/website/docs/ecosystem/portkey.md @@ -0,0 +1,209 @@ +# Portkey Integration with AutoGen + Portkey Metrics Visualization + +[Portkey](https://portkey.ai) is a 2-line upgrade to make your AutoGen agents reliable, cost-efficient, and fast. + +Portkey adds 4 core production capabilities to any AutoGen agent: +1. Routing to 200+ LLMs +2. Making each LLM call more robust +3. Full-stack tracing & cost, performance analytics +4. Real-time guardrails to enforce behavior + +## Getting Started + +1. **Install Required Packages:** +2. ```bash + pip install -qU pyautogen portkey-ai + ``` + **Configure AutoGen with Portkey:** + + ```python + from autogen import AssistantAgent, UserProxyAgent, config_list_from_json + from portkey_ai import PORTKEY_GATEWAY_URL, createHeaders + + config = [ + { + "api_key": "OPENAI_API_KEY", + "model": "gpt-3.5-turbo", + "base_url": PORTKEY_GATEWAY_URL, + "api_type": "openai", + "default_headers": createHeaders( + api_key="YOUR_PORTKEY_API_KEY", + provider="openai", + ) + } + ] + ``` + + Generate your API key in the [Portkey Dashboard](https://app.portkey.ai/). + +And, that's it! With just this, you can start logging all of your AutoGen requests and make them reliable. + +3. **Let's Run your Agent** + +``` python +import autogen + +# Create user proxy agent, coder, product manager + + +user_proxy = autogen.UserProxyAgent( + name="User_proxy", + system_message="A human admin who will give the idea and run the code provided by Coder.", + code_execution_config={"last_n_messages": 2, "work_dir": "groupchat"}, + human_input_mode="ALWAYS", +) + + +coder = autogen.AssistantAgent( + name="Coder", + system_message = "You are a Python developer who is good at developing games. You work with Product Manager.", + llm_config={"config_list": config}, +) + +# Create groupchat +groupchat = autogen.GroupChat( + agents=[user_proxy, coder], messages=[]) +manager = autogen.GroupChatManager(groupchat=groupchat, llm_config={"config_list": config}) + + + +# Start the conversation +user_proxy.initiate_chat( + manager, message="Build a classic & basic pong game with 2 players in python") +``` +
+Here’s the output from your Agent’s run on Portkey's dashboard
+Portkey Dashboard + +## Key Features +Portkey offers a range of advanced features to enhance your AutoGen agents. Here’s an overview + +| Feature | Description | +|---------|-------------| +| 🌐 [Multi-LLM Integration](#interoperability) | Access 200+ LLMs with simple configuration changes | +| πŸ›‘οΈ [Enhanced Reliability](#reliability) | Implement fallbacks, load balancing, retries, and much more | +| πŸ“Š [Advanced Metrics](#metrics) | Track costs, tokens, latency, and 40+ custom metrics effortlessly | +| πŸ” [Detailed Traces and Logs](#comprehensive-logging) | Gain insights into every agent action and decision | +| 🚧 [Guardrails](#guardrails) | Enforce agent behavior with real-time checks on inputs and outputs | +| πŸ”„ [Continuous Optimization](#continuous-improvement) | Capture user feedback for ongoing agent improvements | +| πŸ’Ύ [Smart Caching](#caching) | Reduce costs and latency with built-in caching mechanisms | +| πŸ” [Enterprise-Grade Security](#security-and-compliance) | Set budget limits and implement fine-grained access controls | + + +## Colab Notebook + +For a hands-on example of integrating Portkey with Autogen, check out our notebook

[![Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://git.new/Portkey-Autogen) . + + + +## Advanced Features + +### Interoperability + +Easily switch between **200+ LLMs** by changing the `provider` and API key in your configuration. + +#### Example: Switching from OpenAI to Azure OpenAI + +```python +config = [ + { + "api_key": "api-key", + "model": "gpt-3.5-turbo", + "base_url": PORTKEY_GATEWAY_URL, + "api_type": "openai", + "default_headers": createHeaders( + api_key="YOUR_PORTKEY_API_KEY", + provider="azure-openai", + virtual_key="AZURE_VIRTUAL_KEY" + ) + } +] +``` +Note: AutoGen messages will go through Portkey's AI Gateway following OpenAI's API signature. Some language models may not work properly because messages need to be in a specific role order. + +### Reliability + +Implement fallbacks, load balancing, and automatic retries to make your agents more resilient. + +```python +{ + "strategy": { + "mode": "fallback" # Options: "loadbalance" or "fallback" + }, + "targets": [ + { + "provider": "openai", + "api_key": "openai-api-key", + "override_params": { + "top_k": "0.4", + "max_tokens": "100" + } + }, + { + "provider": "anthropic", + "api_key": "anthropic-api-key", + "override_params": { + "top_p": "0.6", + "model": "claude-3-5-sonnet-20240620" + } + } + ] +} +``` +Learn more about [Portkey Config object here](https://docs.portkey.ai/docs/product/ai-gateway-streamline-llm-integrations/configs). +Be Careful to Load-Balance/Fallback to providers that don't support tool calling when the request contains a function call. +### Metrics + +Agent runs are complex. Portkey automatically logs **40+ comprehensive metrics** for your AI agents, including cost, tokens used, latency, etc. Whether you need a broad overview or granular insights into your agent runs, Portkey's customizable filters provide the metrics you need. + +
+ Portkey's Observability Dashboard +Portkey Dashboard +
+ +### Comprehensive Logging + +Access detailed logs and traces of agent activities, function calls, and errors. Filter logs based on multiple parameters for in-depth analysis. + +
+ Traces + Portkey Logging Interface +
+ +
+ Logs + Portkey Metrics Visualization +
+ +### Guardrails +AutoGen agents, while powerful, can sometimes produce unexpected or undesired outputs. Portkey's Guardrails feature helps enforce agent behavior in real-time, ensuring your AutoGen agents operate within specified parameters. Verify both the **inputs** to and *outputs* from your agents to ensure they adhere to specified formats and content guidelines. Learn more about Portkey's Guardrails [here](https://docs.portkey.ai/product/guardrails) + +### Continuous Improvement + +Capture qualitative and quantitative user feedback on your requests to continuously enhance your agent performance. + +### Caching + +Reduce costs and latency with Portkey's built-in caching system. + +```python +portkey_config = { + "cache": { + "mode": "semantic" # Options: "simple" or "semantic" + } +} +``` + +### Security and Compliance + +Set budget limits on provider API keys and implement fine-grained user roles and permissions for both your application and the Portkey APIs. + +## Additional Resources + +- [πŸ“˜ Portkey Documentation](https://docs.portkey.ai) +- [🐦 Twitter](https://twitter.com/portkeyai) +- [πŸ’¬ Discord Community](https://discord.gg/JHPt4C7r) +- [πŸ“Š Portkey App](https://app.portkey.ai) + +For more information on using these features and setting up your Config, please refer to the [Portkey documentation](https://docs.portkey.ai).