ai-agents-for-beginners

ЁЯМН рдорд╛рдЗрдХреНрд░реЛрд╕рдлреНрдЯ рдПрдЬреЗрдиреНрдЯ рдлреНрд░реЗрдорд╡рд░реНрдХ (.NET) рд╕рдВрдЧ AI рдпрд╛рддреНрд░рд╛ рдПрдЬреЗрдиреНрдЯ

ЁЯУЛ рдкрд░рд┐рджреГрд╢реНрдпрдХреЛ рдЕрд╡рд▓реЛрдХрди

рдпреЛ рдЙрджрд╛рд╣рд░рдгрд▓реЗ рдорд╛рдЗрдХреНрд░реЛрд╕рдлреНрдЯ рдПрдЬреЗрдиреНрдЯ рдлреНрд░реЗрдорд╡рд░реНрдХрдХреЛ рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ рдПрдХ рдмреБрджреНрдзрд┐рдорд╛рди рдпрд╛рддреНрд░рд╛ рдпреЛрдЬрдирд╛ рдПрдЬреЗрдиреНрдЯ рдХрд╕рд░реА рдирд┐рд░реНрдорд╛рдг рдЧрд░реНрдиреЗ рднрдиреЗрд░ рджреЗрдЦрд╛рдЙрдБрдЫред рдПрдЬреЗрдиреНрдЯрд▓реЗ рд╡рд┐рд╢реНрд╡рднрд░рдХрд╛ рд╡рд┐рднрд┐рдиреНрди рдЧрдиреНрддрд╡реНрдпрд╣рд░реВрдХреЛ рд▓рд╛рдЧрд┐ рд╡реНрдпрдХреНрддрд┐рдЧрдд рджрд┐рди-рдпрд╛рддреНрд░рд╛ рдпреЛрдЬрдирд╛ рд╕реНрд╡рддрдГ рдЙрддреНрдкрдиреНрди рдЧрд░реНрди рд╕рдХреНрдЫред

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

ЁЯФз рдкреНрд░рд╛рд╡рд┐рдзрд┐рдХ рд╡рд╛рд╕реНрддреБрдХрд▓рд╛

рдореБрдЦреНрдп рдкреНрд░рд╡рд┐рдзрд┐рд╣рд░реВ

рдореБрдЦреНрдп рдШрдЯрдХрд╣рд░реВ

  1. AIAgent: рдореБрдЦреНрдп рдПрдЬреЗрдиреНрдЯ рдЖрдпреЛрдЬрдХ рдЬрд╕рд▓реЗ рд╕рдВрд╡рд╛рдж рдкреНрд░рд╡рд╛рд╣рд▓рд╛рдИ рд╡реНрдпрд╡рд╕реНрдерд╛рдкрди рдЧрд░реНрджрдЫ
  2. рдХрд╕реНрдЯрдо рдЯреВрд▓рд╣рд░реВ: рдПрдЬреЗрдиреНрдЯрд▓рд╛рдИ рдЙрдкрд▓рдмреНрдз GetRandomDestination() рдлрдЩреНрдХреНрд╕рди
  3. рдЪреНрдпрд╛рдЯ рдХреНрд▓рд╛рдЗрдиреНрдЯ: GitHub рдореЛрдбреЗрд▓реНрд╕-рд╕рдорд░реНрдерд┐рдд рд╕рдВрд╡рд╛рдж рдЗрдиреНрдЯрд░рдлреЗрд╕
  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. рдПрдЬреЗрдиреНрдЯ рд╡рд╛рд╕реНрддреБрдХрд▓рд╛: рдорд╛рдЗрдХреНрд░реЛрд╕рдлреНрдЯ рдПрдЬреЗрдиреНрдЯ рдлреНрд░реЗрдорд╡рд░реНрдХрд▓реЗ .NET рдорд╛ AI рдПрдЬреЗрдиреНрдЯ рдирд┐рд░реНрдорд╛рдг рдЧрд░реНрди рд╕рдлрд╛, рдкреНрд░рдХрд╛рд░-рд╕реБрд░рдХреНрд╖рд┐рдд рджреГрд╖реНрдЯрд┐рдХреЛрдг рдкреНрд░рджрд╛рди рдЧрд░реНрджрдЫ
  2. рдЯреВрд▓ рдПрдХреАрдХрд░рдг: [Description] рд╡рд┐рд╢реЗрд╖рддрд╛рд╣рд░реВрд▓реЗ рд╕рдЬрд╛рдЗрдПрдХреЛ рдлрдЩреНрдХреНрд╕рдирд╣рд░реВ рдПрдЬреЗрдиреНрдЯрдХрд╛ рд▓рд╛рдЧрд┐ рдЙрдкрд▓рдмреНрдз рдЯреВрд▓рд╣рд░реВ рдмрдиреНрдЫрдиреН
  3. рдХрдиреНрдлрд┐рдЧрд░реЗрд╕рди рд╡реНрдпрд╡рд╕реНрдерд╛рдкрди: рд╡рд╛рддрд╛рд╡рд░рдг рдЪрд░рд╣рд░реВ рд░ рд╕реБрд░рдХреНрд╖рд┐рдд рдкреНрд░рдорд╛рдгрдкрддреНрд░ рд╣реНрдпрд╛рдиреНрдбрд▓рд┐рдЩ .NET рдХреЛ рдЙрддреНрдХреГрд╖реНрдЯ рдЕрднреНрдпрд╛рд╕рд╣рд░реВ рдЕрдиреБрд╕рд░рдг рдЧрд░реНрджрдЫ
  4. OpenAI рдЕрдиреБрдХреВрд▓рддрд╛: GitHub рдореЛрдбреЗрд▓реНрд╕ рдПрдХреАрдХрд░рдг OpenAI-рд╕рдВрдЧрдд API рд╣рд░реВрд╕рдБрдЧ рд╕рд╣рдЬ рд░реВрдкрдорд╛ рдХрд╛рдо рдЧрд░реНрджрдЫ

ЁЯФЧ рдердк рд╕реНрд░реЛрддрд╣рд░реВ


рдЕрд╕реНрд╡реАрдХрд░рдг:
рдпреЛ рджрд╕реНрддрд╛рд╡реЗрдЬрд╝ AI рдЕрдиреБрд╡рд╛рдж рд╕реЗрд╡рд╛ Co-op Translator рдкреНрд░рдпреЛрдЧ рдЧрд░реА рдЕрдиреБрд╡рд╛рдж рдЧрд░рд┐рдПрдХреЛ рд╣реЛред рд╣рд╛рдореА рдпрдерд╛рд╕рдореНрднрд╡ рд╢реБрджреНрдзрддрд╛рдХреЛ рд▓рд╛рдЧрд┐ рдкреНрд░рдпрд╛рд╕ рдЧрд░реНрдЫреМрдВ, рддрд░ рдХреГрдкрдпрд╛ рдЬрд╛рдирдХрд╛рд░ рд╣реБрдиреБрд╣реЛрд╕реН рдХрд┐ рд╕реНрд╡рдЪрд╛рд▓рд┐рдд рдЕрдиреБрд╡рд╛рджрд╣рд░реВрдорд╛ рддреНрд░реБрдЯрд┐рд╣рд░реВ рд╡рд╛ рдЕрд╢реБрджреНрдзрддрд╛рд╣рд░реВ рд╣реБрди рд╕рдХреНрдЫред рдпрд╕рдХреЛ рдореВрд▓ рднрд╛рд╖рд╛рдорд╛ рд░рд╣реЗрдХреЛ рдореВрд▓ рджрд╕реНрддрд╛рд╡реЗрдЬрд╝рд▓рд╛рдИ рдЖрдзрд┐рдХрд╛рд░рд┐рдХ рд╕реНрд░реЛрдд рдорд╛рдирд┐рдиреБрдкрд░реНрдЫред рдорд╣рддреНрддреНрд╡рдкреВрд░реНрдг рдЬрд╛рдирдХрд╛рд░реАрдХреЛ рд▓рд╛рдЧрд┐, рд╡реНрдпрд╛рд╡рд╕рд╛рдпрд┐рдХ рдорд╛рдирд╡ рдЕрдиреБрд╡рд╛рдж рд╕рд┐рдлрд╛рд░рд┐рд╕ рдЧрд░рд┐рдиреНрдЫред рдпрд╕ рдЕрдиреБрд╡рд╛рджрдХреЛ рдкреНрд░рдпреЛрдЧрдмрд╛рдЯ рдЙрддреНрдкрдиреНрди рд╣реБрдиреЗ рдХреБрдиреИ рдкрдирд┐ рдЧрд▓рддрдлрд╣рдореА рд╡рд╛ рдЧрд▓рдд рд╡реНрдпрд╛рдЦреНрдпрд╛рдХреЛ рд▓рд╛рдЧрд┐ рд╣рд╛рдореА рдЬрд┐рдореНрдореЗрд╡рд╛рд░ рд╣реБрдиреЗрдЫреИрдиреМрдВред