# Get Started with Microsoft Agent Framework Highlights - Flexible Agent Framework: build, orchestrate, and deploy AI agents and multi-agent systems - Multi-Agent Orchestration: Group chat, sequential, concurrent, and handoff patterns - Plugin Ecosystem: Extend with native functions, OpenAPI, Model Context Protocol (MCP), and more - LLM Support: OpenAI, Azure OpenAI, Azure AI, and more - Runtime Support: In-process and distributed agent execution - Multimodal: Text, vision, and function calling - Cross-Platform: .NET and Python implementations ## Quick Install ```bash pip install agent-framework-core --pre # Optional: Add Azure AI integration pip install agent-framework-azure-ai --pre ``` Supported Platforms: - Python: 3.10+ - OS: Windows, macOS, Linux ## 1. Setup API Keys Set as environment variables, or create a .env file at your project root: ```bash OPENAI_API_KEY=sk-... OPENAI_CHAT_MODEL_ID=... OPENAI_RESPONSES_MODEL_ID=... ... AZURE_OPENAI_API_KEY=... AZURE_OPENAI_ENDPOINT=... AZURE_OPENAI_CHAT_DEPLOYMENT_NAME=... ... AZURE_AI_PROJECT_ENDPOINT=... AZURE_AI_MODEL_DEPLOYMENT_NAME=... ``` You can also override environment variables by explicitly passing configuration parameters to the chat client constructor: ```python from agent_framework.azure import AzureOpenAIChatClient client = AzureOpenAIChatClient( api_key="", endpoint="", deployment_name="", api_version="", ) ``` See the following [setup guide](../../samples/01-get-started) for more information. ## 2. Create a Simple Agent Create agents and invoke them directly: ```python import asyncio from agent_framework import Agent from agent_framework.openai import OpenAIChatClient async def main(): agent = Agent( client=OpenAIChatClient(), instructions=""" 1) A robot may not injure a human being... 2) A robot must obey orders given it by human beings... 3) A robot must protect its own existence... Give me the TLDR in exactly 5 words. """ ) result = await agent.run("Summarize the Three Laws of Robotics") print(result) asyncio.run(main()) # Output: Protect humans, obey, self-preserve, prioritized. ``` ## 3. Directly Use Chat Clients (No Agent Required) You can use the chat client classes directly for advanced workflows: ```python import asyncio from agent_framework.openai import OpenAIChatClient from agent_framework import Message, Role async def main(): client = OpenAIChatClient() messages = [ Message("system", ["You are a helpful assistant."]), Message("user", ["Write a haiku about Agent Framework."]) ] response = await client.get_response(messages) print(response.messages[0].text) """ Output: Agents work in sync, Framework threads through each task— Code sparks collaboration. """ asyncio.run(main()) ``` ## 4. Build an Agent with Tools and Functions Enhance your agent with custom tools and function calling: ```python import asyncio from typing import Annotated from random import randint from pydantic import Field from agent_framework import Agent from agent_framework.openai import OpenAIChatClient def get_weather( location: Annotated[str, Field(description="The location to get the weather for.")], ) -> str: """Get the weather for a given location.""" conditions = ["sunny", "cloudy", "rainy", "stormy"] return f"The weather in {location} is {conditions[randint(0, 3)]} with a high of {randint(10, 30)}°C." def get_menu_specials() -> str: """Get today's menu specials.""" return """ Special Soup: Clam Chowder Special Salad: Cobb Salad Special Drink: Chai Tea """ async def main(): agent = Agent( client=OpenAIChatClient(), instructions="You are a helpful assistant that can provide weather and restaurant information.", tools=[get_weather, get_menu_specials] ) response = await agent.run("What's the weather in Amsterdam and what are today's specials?") print(response) # Output: # The weather in Amsterdam is sunny with a high of 22°C. Today's specials include # Clam Chowder soup, Cobb Salad, and Chai Tea as the special drink. asyncio.run(main()) ``` You can explore additional agent samples [here](../../samples/02-agents). ## 5. Multi-Agent Orchestration Coordinate multiple agents to collaborate on complex tasks using orchestration patterns: ```python import asyncio from agent_framework import Agent from agent_framework.openai import OpenAIChatClient async def main(): # Create specialized agents writer = Agent( client=OpenAIChatClient(), name="Writer", instructions="You are a creative content writer. Generate and refine slogans based on feedback." ) reviewer = Agent( client=OpenAIChatClient(), name="Reviewer", instructions="You are a critical reviewer. Provide detailed feedback on proposed slogans." ) # Sequential workflow: Writer creates, Reviewer provides feedback task = "Create a slogan for a new electric SUV that is affordable and fun to drive." # Step 1: Writer creates initial slogan initial_result = await writer.run(task) print(f"Writer: {initial_result}") # Step 2: Reviewer provides feedback feedback_request = f"Please review this slogan: {initial_result}" feedback = await reviewer.run(feedback_request) print(f"Reviewer: {feedback}") # Step 3: Writer refines based on feedback refinement_request = f"Please refine this slogan based on the feedback: {initial_result}\nFeedback: {feedback}" final_result = await writer.run(refinement_request) print(f"Final Slogan: {final_result}") # Example Output: # Writer: "Charge Forward: Affordable Adventure Awaits!" # Reviewer: "Good energy, but 'Charge Forward' is overused in EV marketing..." # Final Slogan: "Power Up Your Adventure: Premium Feel, Smart Price!" if __name__ == "__main__": asyncio.run(main()) ``` **Note**: Sequential, Concurrent, Group Chat, Handoff, and Magentic orchestrations are available. See examples in [orchestration samples](../../samples/03-workflows/orchestrations). ## More Examples & Samples - [Getting Started with Agents](../../samples/02-agents): Basic agent creation and tool usage - [Chat Client Examples](../../samples/02-agents/chat_client): Direct chat client usage patterns - [Azure AI Integration](https://github.com/microsoft/agent-framework/tree/main/python/packages/azure-ai): Azure AI integration - [Workflows Samples](../../samples/03-workflows): Advanced multi-agent patterns ## Agent Framework Documentation - [Agent Framework Repository](https://github.com/microsoft/agent-framework) - [Python Package Documentation](https://github.com/microsoft/agent-framework/tree/main/python) - [.NET Package Documentation](https://github.com/microsoft/agent-framework/tree/main/dotnet) - [Design Documents](https://github.com/microsoft/agent-framework/tree/main/docs/design) - [Learn Documentation](https://learn.microsoft.com/en-us/agent-framework/user-guide/workflows/orchestrations/overview)