# 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, Foundry, Anthropic, 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 Foundry integration pip install agent-framework-foundry --pre # Optional: Add OpenAI integration pip install agent-framework-openai --pre ``` Supported Platforms: - Python: 3.10+ - OS: Windows, macOS, Linux ## 1. Setup API Keys Depending on the client you want to use, there are various environment variables you can set to configure the chat clients. This can be done in the environment itself, or with a `.env` file in your project root, some examples of environment variables include: ```bash FOUNDRY_PROJECT_ENDPOINT=... FOUNDRY_MODEL=... ... OPENAI_API_KEY=sk-... OPENAI_CHAT_COMPLETION_MODEL=... OPENAI_CHAT_MODEL=... ... AZURE_OPENAI_API_KEY=... AZURE_OPENAI_ENDPOINT=... AZURE_OPENAI_MODEL=... ``` You can also override environment variables by explicitly passing configuration parameters to the chat client constructor: ```python from agent_framework.openai import OpenAIChatClient client = OpenAIChatClient( api_key="", model="", ) ``` See the following [getting started samples](https://github.com/microsoft/agent-framework/tree/main/python/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 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 = asyncio.run(agent.run("Summarize the Three Laws of Robotics")) print(result) # 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() response = await client.get_response([ Message("system", ["You are a helpful assistant."]), Message("user", ["Write a haiku about Agent Framework."]) ]) 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 agent_framework import Agent from agent_framework.openai import OpenAIChatClient def get_weather( location: Annotated[str, "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](https://github.com/microsoft/agent-framework/tree/main/python/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](https://github.com/microsoft/agent-framework/tree/main/python/samples/03-workflows/orchestrations). ## More Examples & Samples - [Getting Started with Agents](https://github.com/microsoft/agent-framework/tree/main/python/samples/02-agents): Basic agent creation and tool usage - [Chat Client Examples](https://github.com/microsoft/agent-framework/tree/main/python/samples/02-agents/chat_client): Direct chat client usage patterns - [Foundry Integration](https://github.com/microsoft/agent-framework/tree/main/python/packages/foundry): Foundry integration - [Workflows Samples](https://github.com/microsoft/agent-framework/tree/main/python/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/agent-framework/)