ai-agents-for-beginners

ЁЯМН Microsoft Agent Framework (.NET) рд╕рд╣ AI рдкреНрд░рд╡рд╛рд╕ рдПрдЬрдВрдЯ

ЁЯУЛ рдкрд░рд┐рд╕реНрдерд┐рддреАрдЪрд╛ рдЖрдврд╛рд╡рд╛

рд╣реА рдЙрджрд╛рд╣рд░рдгреЗ Microsoft Agent Framework for .NET рд╡рд╛рдкрд░реВрди рдмреБрджреНрдзрд┐рдорд╛рди рдкреНрд░рд╡рд╛рд╕ рдирд┐рдпреЛрдЬрди рдПрдЬрдВрдЯ рдХрд╕рд╛ рддрдпрд╛рд░ рдХрд░рд╛рдпрдЪрд╛ рд╣реЗ рджрд░реНрд╢рд╡рддреЗ. рд╣рд╛ рдПрдЬрдВрдЯ рдЬрдЧрднрд░рд╛рддреАрд▓ рдпрд╛рджреГрдЪреНрдЫрд┐рдХ рд╕реНрдерд│рд╛рдВрд╕рд╛рдареА рд╡реИрдпрдХреНрддрд┐рдХреГрдд рджрд┐рд╡рд╕-рдпрд╛рддреНрд░рд╛ рдХрд╛рд░реНрдпрдХреНрд░рдо рд╕реНрд╡рдпрдВрдЪрд▓рд┐рддрдкрдгреЗ рддрдпрд╛рд░ рдХрд░реВ рд╢рдХрддреЛ.

рдореБрдЦреНрдп рдХреНрд╖рдорддрд╛:

ЁЯФз рддрд╛рдВрддреНрд░рд┐рдХ рдЖрд░реНрдХрд┐рдЯреЗрдХреНрдЪрд░

рдореБрдЦреНрдп рддрдВрддреНрд░рдЬреНрдЮрд╛рди

рдореБрдЦреНрдп рдШрдЯрдХ

  1. AIAgent: рдореБрдЦреНрдп рдПрдЬрдВрдЯ рдСрд░реНрдХреЗрд╕реНрдЯреНрд░реЗрдЯрд░ рдЬреЛ рд╕рдВрднрд╛рд╖рдг рдкреНрд░рд╡рд╛рд╣ рд╣рд╛рддрд╛рд│рддреЛ
  2. рд╕рд╛рдиреБрдХреВрд▓ рд╕рд╛рдзрдиреЗ: рдПрдЬрдВрдЯрд╕рд╛рдареА рдЙрдкрд▓рдмреНрдз GetRandomDestination() рдлрдВрдХреНрд╢рди
  3. рдЪреЕрдЯ рдХреНрд▓рд╛рдпрдВрдЯ: GitHub Models-рд╕рдорд░реНрдерд┐рдд рд╕рдВрднрд╛рд╖рдг рдЗрдВрдЯрд░рдлреЗрд╕
  4. рд╕реНрдЯреНрд░реАрдорд┐рдВрдЧ рд╕рдорд░реНрдерди: рд░рд┐рдЕрд▓-рдЯрд╛рдЗрдо рдкреНрд░рддрд┐рд╕рд╛рдж рдирд┐рд░реНрдорд┐рддреА рдХреНрд╖рдорддрд╛

рдПрдХрддреНрд░реАрдХрд░рдг рдирдореБрдирд╛

graph LR
    A[User Request] --> B[AI Agent]
    B --> C[GitHub Models API]
    B --> D[GetRandomDestination Tool]
    C --> E[Travel Itinerary]
    D --> E

ЁЯЪА рд╕реБрд░реБрд╡рд╛рдд рдХрд╢реА рдХрд░рд╛рд╡реА

рдкреВрд░реНрд╡рд╛рдкреЗрдХреНрд╖рд┐рдд

рдЖрд╡рд╢реНрдпрдХ рдкрд░реНрдпрд╛рд╡рд░рдгреАрдп рд╡реНрд╣реЗрд░рд┐рдПрдмрд▓реНрд╕

# zsh/bash
export GH_TOKEN=<your_github_token>
export GH_ENDPOINT=https://models.github.ai/inference
export GH_MODEL_ID=openai/gpt-5-mini
# PowerShell
$env:GH_TOKEN = "<your_github_token>"
$env:GH_ENDPOINT = "https://models.github.ai/inference"
$env:GH_MODEL_ID = "openai/gpt-5-mini"

рдирдореБрдирд╛ рдХреЛрдб

рдХреЛрдб рдЙрджрд╛рд╣рд░рдг рдЪрд╛рд▓рд╡рдгреНрдпрд╛рд╕рд╛рдареА,

# zsh/bash
chmod +x ./01-dotnet-agent-framework.cs
./01-dotnet-agent-framework.cs

рдХрд┐рдВрд╡рд╛ dotnet CLI рд╡рд╛рдкрд░реВрди:

dotnet run ./01-dotnet-agent-framework.cs

рд╕рдВрдкреВрд░реНрдг рдХреЛрдбрд╕рд╛рдареА 01-dotnet-agent-framework.cs рдкрд╣рд╛.

#!/usr/bin/dotnet run

#:package Microsoft.Extensions.AI@9.*
#:package Microsoft.Agents.AI.OpenAI@1.*-*

using System.ClientModel;
using System.ComponentModel;

using Microsoft.Agents.AI;
using Microsoft.Extensions.AI;

using OpenAI;

// Tool Function: Random Destination Generator
// This static method will be available to the agent as a callable tool
// The [Description] attribute helps the AI understand when to use this function
// This demonstrates how to create custom tools for AI agents
[Description("Provides a random vacation destination.")]
static string GetRandomDestination()
{
    // List of popular vacation destinations around the world
    // The agent will randomly select from these options
    var destinations = new List<string>
    {
        "Paris, France",
        "Tokyo, Japan",
        "New York City, USA",
        "Sydney, Australia",
        "Rome, Italy",
        "Barcelona, Spain",
        "Cape Town, South Africa",
        "Rio de Janeiro, Brazil",
        "Bangkok, Thailand",
        "Vancouver, Canada"
    };

    // Generate random index and return selected destination
    // Uses System.Random for simple random selection
    var random = new Random();
    int index = random.Next(destinations.Count);
    return destinations[index];
}

// Extract configuration from environment variables
// Retrieve the GitHub Models API endpoint, defaults to https://models.github.ai/inference if not specified
// Retrieve the model ID, defaults to openai/gpt-5-mini if not specified
// Retrieve the GitHub token for authentication, throws exception if not specified
var github_endpoint = Environment.GetEnvironmentVariable("GH_ENDPOINT") ?? "https://models.github.ai/inference";
var github_model_id = Environment.GetEnvironmentVariable("GH_MODEL_ID") ?? "openai/gpt-5-mini";
var github_token = Environment.GetEnvironmentVariable("GH_TOKEN") ?? throw new InvalidOperationException("GH_TOKEN is not set.");

// Configure OpenAI Client Options
// Create configuration options to point to GitHub Models endpoint
// This redirects OpenAI client calls to GitHub's model inference service
var openAIOptions = new OpenAIClientOptions()
{
    Endpoint = new Uri(github_endpoint)
};

// Initialize OpenAI Client with GitHub Models Configuration
// Create OpenAI client using GitHub token for authentication
// Configure it to use GitHub Models endpoint instead of OpenAI directly
var openAIClient = new OpenAIClient(new ApiKeyCredential(github_token), openAIOptions);

// Create AI Agent with Travel Planning Capabilities
// Initialize OpenAI client, get chat client for specified model, and create AI agent
// Configure agent with travel planning instructions and random destination tool
// The agent can now plan trips using the GetRandomDestination function
AIAgent agent = openAIClient
    .GetChatClient(github_model_id)
    .CreateAIAgent(
        instructions: "You are a helpful AI Agent that can help plan vacations for customers at random destinations",
        tools: [AIFunctionFactory.Create(GetRandomDestination)]
    );

// Execute Agent: Plan a Day Trip
// Run the agent with streaming enabled for real-time response display
// Shows the agent's thinking and response as it generates the content
// Provides better user experience with immediate feedback
await foreach (var update in agent.RunStreamingAsync("Plan me a day trip"))
{
    await Task.Delay(10);
    Console.Write(update);
}

ЁЯОУ рдореБрдЦреНрдп рд╢рд┐рдХрд╡рдгреНрдпрд╛

  1. рдПрдЬрдВрдЯ рдЖрд░реНрдХрд┐рдЯреЗрдХреНрдЪрд░: Microsoft Agent Framework .NET рдордзреНрдпреЗ AI рдПрдЬрдВрдЯ рддрдпрд╛рд░ рдХрд░рдгреНрдпрд╛рд╕рд╛рдареА рд╕реНрд╡рдЪреНрдЫ, рдкреНрд░рдХрд╛рд░-рд╕реБрд░рдХреНрд╖рд┐рдд рджреГрд╖реНрдЯрд┐рдХреЛрди рдкреНрд░рджрд╛рди рдХрд░рддреЗ
  2. рд╕рд╛рдзрди рдПрдХрддреНрд░реАрдХрд░рдг: [Description] рдЧреБрдгрдзрд░реНрдорд╛рдВрд╕рд╣ рд╕рдЬрд╡рд▓реЗрд▓реЗ рдлрдВрдХреНрд╢рдиреНрд╕ рдПрдЬрдВрдЯрд╕рд╛рдареА рдЙрдкрд▓рдмреНрдз рд╕рд╛рдзрдиреЗ рдмрдирддрд╛рдд
  3. рдХреЙрдиреНрдлрд┐рдЧрд░реЗрд╢рди рд╡реНрдпрд╡рд╕реНрдерд╛рдкрди: рдкрд░реНрдпрд╛рд╡рд░рдгреАрдп рд╡реНрд╣реЗрд░рд┐рдПрдмрд▓реНрд╕ рдЖрдгрд┐ рд╕реБрд░рдХреНрд╖рд┐рдд рдХреНрд░реЗрдбреЗрдиреНрд╢рд┐рдпрд▓ рд╣рд╛рддрд╛рд│рдгреА .NET рд╕рд░реНрд╡реЛрддреНрддрдо рдкрджреНрдзрддреАрдВрдЪреЗ рдЕрдиреБрд╕рд░рдг рдХрд░рддреЗ
  4. OpenAI рд╕реБрд╕рдВрдЧрддрддрд╛: GitHub Models рдПрдХрддреНрд░реАрдХрд░рдг OpenAI-рд╕реБрд╕рдВрдЧрдд API рджреНрд╡рд╛рд░реЗ рд╕рд╣рдЬрдкрдгреЗ рдХрд╛рд░реНрдп рдХрд░рддреЗ

ЁЯФЧ рдЕрддрд┐рд░рд┐рдХреНрдд рд╕рдВрд╕рд╛рдзрдиреЗ


рдЕрд╕реНрд╡реАрдХрд░рдг:
рд╣рд╛ рджрд╕реНрддрдРрд╡рдЬ AI рднрд╛рд╖рд╛рдВрддрд░ рд╕реЗрд╡рд╛ Co-op Translator рд╡рд╛рдкрд░реВрди рднрд╛рд╖рд╛рдВрддрд░рд┐рдд рдХреЗрд▓рд╛ рдЧреЗрд▓рд╛ рдЖрд╣реЗ. рдЖрдореНрд╣реА рдЕрдЪреВрдХрддреЗрд╕рд╛рдареА рдкреНрд░рдпрддреНрдирд╢реАрд▓ рдЕрд╕рд▓реЛ рддрд░реА, рдХреГрдкрдпрд╛ рд▓рдХреНрд╖рд╛рдд рдШреНрдпрд╛ рдХреА рд╕реНрд╡рдпрдВрдЪрд▓рд┐рдд рднрд╛рд╖рд╛рдВрддрд░рд╛рдВрдордзреНрдпреЗ рдЪреБрдХрд╛ рдХрд┐рдВрд╡рд╛ рдЕрдЪреВрдХрддреЗрдЪрд╛ рдЕрднрд╛рд╡ рдЕрд╕реВ рд╢рдХрддреЛ. рдореВрд│ рднрд╛рд╖реЗрддреАрд▓ рдореВрд│ рджрд╕реНрддрдРрд╡рдЬ рд╣рд╛ рдЕрдзрд┐рдХреГрдд рд╕реНрд░реЛрдд рдорд╛рдирд▓рд╛ рдЬрд╛рд╡рд╛. рдорд╣рддреНрддреНрд╡рд╛рдЪреНрдпрд╛ рдорд╛рд╣рд┐рддреАрд╕рд╛рдареА, рд╡реНрдпрд╛рд╡рд╕рд╛рдпрд┐рдХ рдорд╛рдирд╡реА рднрд╛рд╖рд╛рдВрддрд░рд╛рдЪреА рд╢рд┐рдлрд╛рд░рд╕ рдХреЗрд▓реА рдЬрд╛рддреЗ. рдпрд╛ рднрд╛рд╖рд╛рдВрддрд░рд╛рдЪрд╛ рд╡рд╛рдкрд░ рдХреЗрд▓реНрдпрд╛рдореБрд│реЗ рдЙрджреНрднрд╡рдгрд╛рд▒реНрдпрд╛ рдХреЛрдгрддреНрдпрд╛рд╣реА рдЧреИрд░рд╕рдордЬ рдХрд┐рдВрд╡рд╛ рдЪреБрдХреАрдЪреНрдпрд╛ рдЕрд░реНрдерд╛рд╕рд╛рдареА рдЖрдореНрд╣реА рдЬрдмрд╛рдмрджрд╛рд░ рд░рд╛рд╣рдгрд╛рд░ рдирд╛рд╣реА.