当前位置: 首页 > news >正文

Microsoft Agent Framework/C#:了解Workflows的几种不同模式

前言

最近有空的时候在学习Microsoft Agent Framework,在这个框架中目前Workflows分为了Sequential、Concurrent、Handoffs以及Groupchat四种模式,今天让我们来了解一下这四种不同的模式。

首先需要以下两个包:

Sequential 模式

在开始介绍之前,先看下它的效果:

首先需要先构建一个IChatClient:

 var apiKey = Environment.GetEnvironmentVariable("OPENAI_API_KEY") ?? throw new InvalidOperationException("未设置环境变量:OPENAI_API_KEY");//var model = Environment.GetEnvironmentVariable("OPENAI_MODEL") ?? "gpt-4o-mini";var model = "moonshotai/Kimi-K2-Instruct-0905";var baseUrl = Environment.GetEnvironmentVariable("OPENAI_BASEURL") ?? throw new InvalidOperationException("未设置环境变量:OPENAI_BASEURL");ApiKeyCredential apiKeyCredential = new ApiKeyCredential(apiKey);OpenAIClientOptions openAIClientOptions = new OpenAIClientOptions();openAIClientOptions.Endpoint = new Uri(baseUrl);var client = new OpenAIClient(apiKeyCredential, openAIClientOptions).GetChatClient(model).AsIChatClient();

现在通过这个函数方便构建不同的翻译代理:

 /// <summary>为指定目标语言创建翻译代理。</summary>private static ChatClientAgent GetTranslationAgent(string targetLanguage, IChatClient chatClient) =>new(chatClient,$"你是一个翻译助手,只使用{targetLanguage}回应。对于任何输入," +$"首先输出输入语言的名称,然后将输入翻译成{targetLanguage}。");

构建顺序工作流:

  // 创建顺序工作流var workflow = AgentWorkflowBuilder.BuildSequential(from lang in (string[])["French", "Spanish", "English"] select GetTranslationAgent(lang, client));

参数就是一组AIAgent,然后工作流会将这些AIAgent按顺序组合起来。

运行这个工作流:

  List<ChatMessage> messages = [new(ChatRole.User, InputText)];await RunWorkflowAsync(workflow, messages);private async Task<List<ChatMessage>> RunWorkflowAsync(Workflow workflow, List<ChatMessage> messages)
{string? lastExecutorId = null;await using StreamingRun run = await InProcessExecution.StreamAsync(workflow, messages);await run.TrySendMessageAsync(new TurnToken(emitEvents: true));await foreach (WorkflowEvent evt in run.WatchStreamAsync()){if (evt is AgentRunUpdateEvent e){if (e.ExecutorId != lastExecutorId){OutputText += "\n";lastExecutorId = e.ExecutorId;OutputText += $"{e.ExecutorId}:\n";}OutputText += e.Update.Text;if (e.Update.Contents.OfType<FunctionCallContent>().FirstOrDefault() is FunctionCallContent call){OutputText += "\n";OutputText += $"[调用函数 '{call.Name}',参数: {JsonSerializer.Serialize(call.Arguments)}]";}}else if (evt is WorkflowOutputEvent output){OutputText += "\n\n工作流完成!";return output.As<List<ChatMessage>>()!;}}return [];
}

与直觉不一样的地方是只有在传入TurnToken的时候才会开始运行:

await run.TrySendMessageAsync(new TurnToken(emitEvents: true));

然后通过WorkflowEvent来进行不同操作。

这个例子看最后的输入就是这样的:

Concurrent 模式

还是先来看下效果:

Concurrent就是并发工作流,对同一个输入,不同的AI Agent同时响应。

看一下怎么构建:

 // 创建并发工作流var workflow = AgentWorkflowBuilder.BuildConcurrent(from lang in (string[])["French", "Spanish", "English"] select GetTranslationAgent(lang, client));

Handoffs 模式

Handoffs就是交接模式,跟之前的不太一样,首先我们先创建3个不同的AI Agent:

// 创建专门的代理
ChatClientAgent historyTutor = new(client,"你提供历史查询方面的帮助。清晰地解释重要事件和背景。只回应历史相关内容。","history_tutor","历史问题的专业代理");ChatClientAgent mathTutor = new(client,"你提供数学问题方面的帮助。在每一步解释你的推理过程并包含示例。只回应数学相关内容。","math_tutor","数学问题的专业代理");ChatClientAgent triageAgent = new(client,"你根据用户的作业问题确定使用哪个代理。总是将任务交接给另一个代理。","triage_agent","将消息路由到适当的专业代理");

看下如何构建:

 // 创建交接工作流var workflow = AgentWorkflowBuilder.CreateHandoffBuilderWith(triageAgent).WithHandoffs(triageAgent, [mathTutor, historyTutor]).WithHandoffs([mathTutor, historyTutor], triageAgent).Build();

来看下效果:

这次会到这个地方:

内部有一个FunctionCall交接给了对应的代理。

看一下最终的结果:

再问一个数学相关的问题看看效果:

看一下最终的结果:

Groupchat 模式

Groupchat模式就是开启一个AI群聊,我拿辩论举个例子。

 ChatClientAgent chatClientAgent1 = new(client, "你是辩论正方");ChatClientAgent chatClientAgent2 = new(client, "你是辩论反方");// 创建群聊工作流var workflow = AgentWorkflowBuilder.CreateGroupChatBuilderWith(agents => new RoundRobinGroupChatManager(agents) { MaximumIterationCount = 5 }).AddParticipants([chatClientAgent1, chatClientAgent2]).Build();

效果:

http://www.rkmt.cn/news/28471.html

相关文章:

  • CodeForces-374D Inna and Sequence
  • 字符串过长导致编译报错的问题及解决办法 - 详解
  • 厨房电秤方案:介绍一款电子秤芯片sic8632
  • CF981F Round Marriage
  • macOS直接使用pip安装报错
  • 《借力JBoltAI框架,Java技术开发公司开启高效开发新范式》
  • Wireshark抓包教程:JSON和HTTPS抓取
  • SMARTFORMS去掉数值后面的小数点
  • 数字征程,逐级而上;生态协同,智绘新篇—— 艾拓琪威灏 与 哲讯顺维 数字化战略合作签署暨CRMMES项目启动会隆重举行
  • 2025 年唐山油漆生产厂家最新推荐榜单:精选优质企业,解析专业品牌选购指南唐山油漆批发/唐山油漆生产公司推荐
  • 做题笔记21
  • 权威调研榜单:重庆旧房加层改造公司TOP3榜单好评深度解析
  • 2025 年 MVR 蒸发器源头厂家最新推荐排行榜:聚焦食品医药化工环保领域优质设备,助力企业精准选型
  • Tailwind CSS 使用入门
  • 实用指南:Calico 网络插件在 K8s 集群的作用
  • godot + Avalonia 渲染第三方UI
  • 2025-10-23 cocos安装
  • 用EasyPlayer播国标GB28181算法算力平台EasyGBS视频流,居然比点外卖还简单
  • 测试美化效果
  • idea错误解决记录
  • 2025 年连接器厂家最新推荐榜单:覆盖多领域优质产品,为企业选购提供权威参考的国内制造商精选汽车/高速/板载/航空连接器公司推荐
  • 2025年护栏厂家权威推荐榜单:不锈钢栏杆、桥梁防撞护栏、河道景观护栏等全品类生产供应商精选
  • Windows 10 version 22H2 中文版、英文版下载 (2025 年 10 月更新)
  • CF1140E Palindrome-less Arrays
  • foobar2000下载安装教程:从入门到配置的完整指南(2025最新版)
  • 编织袋定制生产厂家:基于专业测评的技术、工艺及市场优势深度分析
  • 可视化图解算法65:有效的字母异位词
  • 2025 年传感器厂家最新推荐排行榜:磁致伸缩 / 防爆 / 防水 / 隔爆 / 线性等类型传感器企业实力与产品优势解析
  • 2025 年加热线圈厂家最新推荐排行榜:聚焦行业头部企业,深度解析优质品牌核心优势与选购价值轴承外感应加热线圈 / 轴承座内圈加热线圈 / 感应加热线圈公司推荐
  • 互动问答直播版双端小程序管理系统:开启直播变现新蓝海