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

DeerFlow多智能体系统实战:基于LangGraph的自动化研究流程搭建

DeerFlow多智能体系统实战基于LangGraph的自动化研究流程搭建本文详细介绍了如何使用DeerFlow的多智能体架构进行自动化研究包括LangGraph框架的配置、智能体节点定义、状态管理以及工作流设计。适合希望快速构建复杂AI研究流程的开发者提供从环境搭建到实际部署的完整指南。1. 引言为什么选择DeerFlow进行深度研究如果你曾经尝试过让AI模型帮你做深度研究可能会遇到这样的问题简单的问答还能应付但涉及到需要多步骤、多来源信息的复杂研究任务时单个模型往往力不从心。要么是信息收集不全面要么是分析深度不够或者根本无法处理需要代码执行的技术性问题。DeerFlow的出现正好解决了这个痛点。它是一个基于LangGraph构建的多智能体系统通过分工协作的方式让不同的智能体各司其职共同完成复杂的深度研究任务。想象一下你有了一支专业的研究团队有人负责规划研究方案有人负责搜集资料有人负责技术分析还有人负责撰写最终报告。最吸引人的是DeerFlow完全开源代码结构清晰即使你是多智能体系统的新手也能相对容易地上手和理解。接下来我将带你一步步搭建这个强大的自动化研究系统。2. 环境准备与快速部署2.1 系统要求与工具准备在开始之前确保你的系统满足以下最低要求Python 3.12Node.js 22用于Web UI至少8GB内存复杂任务建议16GB推荐使用以下工具来简化环境管理# 安装uv用于Python环境管理 curl -LsSf https://astral.sh/uv/install.sh | sh # 安装nvm用于Node.js版本管理 curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash # 安装pnpm用于前端依赖管理 npm install -g pnpm2.2 一键部署DeerFlow部署DeerFlow非常简单只需要几个命令# 克隆仓库 git clone https://github.com/bytedance/deer-flow.git cd deer-flow # 使用uv自动创建虚拟环境并安装依赖 uv sync # 复制配置文件模板 cp .env.example .env cp conf.yaml.example conf.yaml # 安装Marp用于PPT生成可选 brew install marp-cli # macOS # 或使用其他包管理器安装2.3 关键配置说明安装完成后需要配置一些关键信息.env文件配置示例# 选择搜索引擎tavily, duckduckgo, brave_search, arxiv SEARCH_APItavily TAVILY_API_KEYyour_tavily_api_key # 文本转语音配置可选 TTS_PROVIDERvolcengine VOLCENGINE_TTS_ACCESS_KEYyour_access_key VOLCENGINE_TTS_SECRET_KEYyour_secret_keyconf.yaml配置示例BASIC_MODEL: base_url: https://api.openai.com/v1 model: gpt-4o api_key: your_openai_api_key # 其他模型配置reasoning, vision等 REASONING_MODEL: base_url: https://api.openai.com/v1 model: gpt-4o api_key: your_openai_api_key3. LangGraph核心概念与工作流设计3.1 理解DeerFlow的多智能体架构DeerFlow的核心是一个基于LangGraph的多智能体系统主要包括四个核心组件协调器Coordinator负责接收用户输入和管理工作流生命周期规划器Planner分析研究目标并制定详细的执行计划研究团队Research Team包含研究员和编码员执行具体任务报告员Reporter汇总研究成果并生成最终报告这种架构的好处是每个智能体都可以专注于自己最擅长的任务通过协作产生112的效果。3.2 状态管理工作流的核心在LangGraph中状态State是整个工作流的核心。它就像一个共享的白板所有智能体都可以在上面读取和写入信息。DeerFlow的状态对象通常包含以下信息from typing import TypedDict, List, Optional from langchain_core.messages import BaseMessage class ResearchState(TypedDict): messages: List[BaseMessage] # 对话消息历史 user_input: str # 用户输入的研究主题 research_plan: Optional[dict] # 研究计划 observations: List[str] # 研究过程中的观察结果 final_report: Optional[str] # 最终报告3.3 定义智能体节点每个智能体都是一个独立的函数接收状态并返回更新后的状态和下一步指令def researcher_node(state: ResearchState): 研究员节点负责信息搜集 # 创建研究员智能体 researcher_agent create_agent( llmget_llm_by_type(basic), tools[web_search_tool, crawler_tool], system_message你是一个专业的研究员擅长从网络搜集信息... ) # 执行研究任务 response researcher_agent.invoke({ messages: state[messages], current_plan: state[research_plan] }) # 更新状态 new_state { **state, messages: state[messages] [response[messages][-1]], observations: state[observations] [extract_observations(response)] } return new_state4. 构建完整的研究工作流4.1 初始化LangGraph工作流首先需要创建一个StateGraph实例并定义节点和边from langgraph.graph import StateGraph, END # 创建工作流构建器 workflow_builder StateGraph(ResearchState) # 添加所有节点 workflow_builder.add_node(coordinator, coordinator_node) workflow_builder.add_node(planner, planner_node) workflow_builder.add_node(researcher, researcher_node) workflow_builder.add_node(coder, coder_node) workflow_builder.add_node(reporter, reporter_node) # 设置入口点 workflow_builder.set_entry_point(coordinator)4.2 定义节点之间的流转逻辑节点之间的流转通过条件边来控制根据当前状态决定下一步执行哪个节点def decide_next_step(state: ResearchState): 决定下一步执行哪个节点 last_message state[messages][-1] if 需要规划 in last_message.content: return planner elif 需要研究 in last_message.content: return researcher elif 需要编码 in last_message.content: return coder elif 需要报告 in last_message.content: return reporter else: return END # 添加条件边 workflow_builder.add_conditional_edges( coordinator, decide_next_step ) # 添加其他边 workflow_builder.add_edge(planner, researcher) workflow_builder.add_edge(researcher, coder) workflow_builder.add_edge(coder, reporter) workflow_builder.add_edge(reporter, END)4.3 编译和执行工作流完成工作流定义后需要编译成可执行的对象# 编译工作流 research_workflow workflow_builder.compile() # 执行工作流 initial_state { messages: [HumanMessage(content我想研究人工智能在医疗诊断中的应用)], user_input: 人工智能在医疗诊断中的应用, research_plan: None, observations: [], final_report: None } result research_workflow.invoke(initial_state) print(result[final_report])5. 实战示例自动化研究流程5.1 简单研究任务示例让我们看一个简单的例子研究气候变化对农业的影响# 初始化工作流 workflow create_research_workflow() # 执行研究 result workflow.invoke({ messages: [HumanMessage(content研究气候变化对农业的影响)], user_input: 气候变化对农业的影响, research_plan: None, observations: [], final_report: None }) # 输出结果 print(研究完成) print(f最终报告长度{len(result[final_report])}字符) print(f收集到的观察数量{len(result[observations])})5.2 复杂技术研究示例对于更复杂的技术研究比如比较PyTorch和TensorFlow在深度学习中的性能编码员智能体会发挥重要作用# 这种任务会自动触发编码员节点执行性能测试代码 result workflow.invoke({ messages: [HumanMessage(content比较PyTorch和TensorFlow在深度学习中的性能)], user_input: 比较PyTorch和TensorFlow在深度学习中的性能, research_plan: None, observations: [], final_report: None })在这个过程中编码员智能体会自动编写和执行测试代码比如# 自动生成的性能测试代码示例 import torch import tensorflow as tf import time # 测试矩阵乘法性能 def test_performance(): # PyTorch测试 start time.time() a torch.randn(1000, 1000) b torch.randn(1000, 1000) torch.mm(a, b) pytorch_time time.time() - start # TensorFlow测试 start time.time() a tf.random.normal((1000, 1000)) b tf.random.normal((1000, 1000)) tf.matmul(a, b) tensorflow_time time.time() - start return { pytorch_time: pytorch_time, tensorflow_time: tensorflow_time }6. 高级功能与调试技巧6.1 使用LangGraph Studio进行可视化调试DeerFlow支持使用LangGraph Studio进行可视化调试这是一个非常强大的功能# 启动LangGraph Studio uvx --refresh --from langgraph-cli[inmem] --with-editable . --python 3.12 langgraph dev --allow-blocking启动后你可以在浏览器中访问Studio界面实时查看工作流的执行过程包括每个节点的输入输出、状态变化等。6.2 自定义智能体和工具你可以很容易地添加自定义智能体和工具# 添加自定义研究工具 tool def academic_paper_search(query: str) - str: 学术论文搜索工具 # 实现具体的论文搜索逻辑 return f关于{query}的学术论文结果... # 创建自定义智能体 def custom_researcher_node(state: ResearchState): custom_tools [academic_paper_search, web_search_tool] researcher create_agent(llmget_llm_by_type(basic), toolscustom_tools) # ...其余实现6.3 性能优化建议对于生产环境部署考虑以下优化措施智能体并行化让多个研究任务可以并行执行结果缓存对常见研究主题的结果进行缓存资源限制为每个智能体设置超时和资源限制错误处理添加重试机制和优雅降级# 示例添加重试机制 from tenacity import retry, stop_after_attempt, wait_exponential retry(stopstop_after_attempt(3), waitwait_exponential(multiplier1, min4, max10)) def robust_researcher_node(state: ResearchState): # 实现带重试的研究逻辑7. 总结通过本文的介绍你应该对DeerFlow的多智能体系统有了全面的了解。从环境搭建到工作流设计从基础使用到高级定制这个基于LangGraph的框架为自动化研究提供了强大的基础设施。实际使用下来DeerFlow的模块化设计确实让复杂研究任务的自动化变得可行。每个智能体各司其职通过LangGraph的状态管理机制协同工作产生的效果比单一模型要强大得多。特别是在处理需要多步骤、多来源信息的复杂研究任务时这种多智能体协作的优势更加明显。如果你刚开始接触多智能体系统建议先从简单的任务开始逐步深入了解每个组件的工作原理。等到熟悉基本用法后再尝试自定义智能体和工具打造适合自己需求的研究流水线。获取更多AI镜像想探索更多AI镜像和应用场景访问 CSDN星图镜像广场提供丰富的预置镜像覆盖大模型推理、图像生成、视频生成、模型微调等多个领域支持一键部署。

相关文章:

DeerFlow多智能体系统实战:基于LangGraph的自动化研究流程搭建

DeerFlow多智能体系统实战:基于LangGraph的自动化研究流程搭建 本文详细介绍了如何使用DeerFlow的多智能体架构进行自动化研究,包括LangGraph框架的配置、智能体节点定义、状态管理以及工作流设计。适合希望快速构建复杂AI研究流程的开发者,提…...

Qwen3-0.6B-FP8模型监控:性能指标与日志分析

Qwen3-0.6B-FP8模型监控:性能指标与日志分析 1. 为什么需要模型监控 当你把Qwen3-0.6B-FP8模型部署到生产环境后,最怕的就是半夜收到报警说服务挂了,或者用户反馈响应变慢了。这时候如果没有完善的监控体系,排查问题就像大海捞针…...

二极管伏安特性实测:用Arduino+Python绘制曲线(附完整代码)

二极管伏安特性实测:用ArduinoPython绘制曲线(附完整代码) 在电子工程实践中,理解元器件的真实特性往往比理论推导更具价值。当我们翻开任何一本电子学教材,二极管伏安特性曲线总是以理想化的折线形式呈现——0.7V导通…...

51单片机学习记录

1.流水灯#include "reg51.h"// 定义LED灯的位选数组 unsigned char led0[] {0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};// 延时函数 void delay(unsigned int n){unsigned int i0,j0;for(i 0;i<n;i){for(j 0;j<120;j);} } // LED流水灯函数 void led(){int…...

终极Evernote备份方案:evernote-backup完整指南,让笔记数据永不丢失![特殊字符]

终极Evernote备份方案&#xff1a;evernote-backup完整指南&#xff0c;让笔记数据永不丢失&#xff01;&#x1f4da; 【免费下载链接】evernote-backup Backup & export all Evernote notes and notebooks 项目地址: https://gitcode.com/gh_mirrors/ev/evernote-backu…...

AIGlasses OS Pro实战:用本地视觉系统实现文档扫描与实时翻译场景

AIGlasses OS Pro实战&#xff1a;用本地视觉系统实现文档扫描与实时翻译场景 1. 智能眼镜视觉系统的独特价值 在移动计算设备快速发展的今天&#xff0c;智能眼镜正逐渐成为增强现实和视觉辅助的重要载体。AIGlasses OS Pro作为一款专为智能眼镜设计的本地视觉系统&#xff…...

Youtu-VL-4B-Instruct源码部署:智能家居设备界面理解与操作指引生成

Youtu-VL-4B-Instruct源码部署&#xff1a;智能家居设备界面理解与操作指引生成 1. 引言 想象一下这个场景&#xff1a;你刚买了一个新的智能空气净化器&#xff0c;面对面板上密密麻麻的按钮和指示灯&#xff0c;说明书又不知所云。这时候&#xff0c;你只需要拿起手机拍张照…...

lychee-rerank-mm快速部署教程:单机GPU适配,显存占用<2GB

lychee-rerank-mm快速部署教程&#xff1a;单机GPU适配&#xff0c;显存占用<2GB 1. 什么是lychee-rerank-mm&#xff1f; lychee-rerank-mm是一个轻量级的多模态重排序模型&#xff0c;专门用来给文本或图像内容按照与查询的匹配度进行打分排序。简单来说&#xff0c;它就…...

黑群晖Docker新手避坑:aria2-pro挂载路径错误导致容器启动失败的完整解决流程

黑群晖Docker新手避坑指南&#xff1a;彻底解决aria2-pro路径映射问题 刚接触黑群晖和Docker的新手&#xff0c;在搭建下载工具时总会遇到各种"坑"。其中最常见的就是容器启动失败&#xff0c;而错误原因往往指向一个看似简单却令人困惑的问题——路径映射错误。本文…...

Python爬虫实战:手把手教你如何搭建文档站点快照与长图归档器!

㊗️本期内容已收录至专栏《Python爬虫实战》&#xff0c;持续完善知识体系与项目实战&#xff0c;建议先订阅收藏&#xff0c;后续查阅更方便&#xff5e; ㊙️本期爬虫难度指数&#xff1a;⭐⭐⭐ (进阶) &#x1f250;福利&#xff1a; 一次订阅后&#xff0c;专栏内的所有文…...

Python 快速上手:从零构建你的第一个 Telegram 机器人

1. 为什么选择Telegram机器人开发 最近两年&#xff0c;我身边越来越多的开发者开始尝试Telegram机器人开发。作为一个长期使用Python的开发者&#xff0c;我发现用Python构建Telegram机器人简直是绝配。相比其他即时通讯平台&#xff0c;Telegram的机器人API设计得非常友好&am…...

OpenClaw+GLM-4.7-Flash智能监控:服务器日志异常检测与告警推送

OpenClawGLM-4.7-Flash智能监控&#xff1a;服务器日志异常检测与告警推送 1. 为什么需要本地化的日志监控方案 去年处理线上事故时&#xff0c;我发现团队严重依赖第三方日志监控服务。当服务器出现权限拒绝错误时&#xff0c;敏感路径信息已经被传输到云端。这件事让我开始…...

告别第三方内网穿透服务:用DDNS-Go+华为云自建动态域名解析,飞牛OS实测

自建动态域名解析全攻略&#xff1a;DDNS-Go与华为云的深度整合实践 在数字化生活日益普及的今天&#xff0c;远程访问家庭或办公室网络资源已成为许多技术爱好者和专业人士的刚需。传统的内网穿透解决方案如花生壳、Ngrok等虽然方便&#xff0c;但往往伴随着高昂的费用、带宽限…...

硬件密码引擎(CE)技术解析:嵌入式安全加速核心

1. 硬件密码引擎&#xff08;CE&#xff09;模块技术解析 1.1 模块定位与工程价值 硬件密码引擎&#xff08;Crypto Engine&#xff0c;简称 CE&#xff09;并非通用计算单元&#xff0c;而是面向嵌入式系统安全需求深度定制的专用协处理器。其核心价值在于将原本由主控 CPU 承…...

不用困在局域网!XiuXianGame修仙游戏,外网访问就这么简单

XiuXianGame 是一款以文字为核心的修仙休闲游戏&#xff0c;核心功能涵盖修为提升、灵石积累、休闲小游戏闯关等&#xff0c;玩家可通过手动操作或自动挂机的方式推进修仙进度&#xff0c;整体玩法轻松不耗时&#xff0c;主打碎片化的休闲体验&#xff0c;无需高强度投入就能感…...

当后轮也开始玩转向:4WS4WD的横摆稳定黑科技

4WS4WD无人车横摆稳定性控制 通过滑模控制理论对后轮转角和直接横摆力矩进行集成控制&#xff0c;考虑前后轴荷及路面附着系数实现转矩分配&#xff0c;提高车身稳定性。 carsim&#xff0f;simulink联合仿真 方向打死油门到底&#xff0c;车尾突然开始画龙——这种惊悚场面在…...

dir命令详解:查看文件与文件夹

Windows命令提示符中dir命令的完整使用指南 dir命令是Windows命令提示符中最基础且最重要的命令之一&#xff0c;主要用于查看当前目录下的文件和子文件夹信息。下面我将详细介绍该命令的各种用法和参数。 1. dir命令的基本用法 基本查看操作 在命令提示符中直接输入dir命令…...

Step3-VL-10B-Base系统资源优化:C盘清理与模型存储空间管理

Step3-VL-10B-Base系统资源优化&#xff1a;C盘清理与模型存储空间管理 你是不是也遇到过这种情况&#xff1f;兴致勃勃地准备部署一个像Step3-VL-10B-Base这样的大模型&#xff0c;结果刚跑起来&#xff0c;C盘空间就“告急”了。看着那个红色的磁盘空间不足提示&#xff0c;…...

华为ENSP实战:旁挂AC的Web界面快速部署多SSID无线网络

1. 为什么选择旁挂AC部署多SSID无线网络&#xff1f; 在企业无线网络部署中&#xff0c;旁挂式AC&#xff08;接入控制器&#xff09;架构因其灵活性和易维护性&#xff0c;成为中小型企业的首选方案。相比直连式部署&#xff0c;旁挂AC不需要改变现有网络拓扑结构&#xff0c;…...

5.OpenGL之uniform

在OpenGL中&#xff0c;uniform 是一种着色器程序中的变量类型&#xff08;存储限定符&#xff09;。简单来说&#xff0c;可以把 uniform 理解为&#xff1a;从CPU端&#xff08;你的C/Qt代码&#xff09;向GPU端&#xff08;着色器程序&#xff09;发送的一个“全局只读”参数…...

保姆级教程:用GParted Live USB无损调整Windows磁盘分区(含安全操作指南)

零风险实战&#xff1a;用GParted Live USB拯救你的Windows磁盘空间 每次打开电脑看到C盘飘红的剩余空间&#xff0c;是不是有种窒息感&#xff1f;系统运行越来越慢&#xff0c;新软件装不下&#xff0c;临时文件不敢删——这种困境我太熟悉了。三年前我的开发机C盘只剩500MB时…...

从x86架构到接口技术:微机原理实战笔记(含汇编语言编程示例)

从x86架构到接口技术&#xff1a;微机原理实战笔记&#xff08;含汇编语言编程示例&#xff09; 1. 理解计算机的"心脏"&#xff1a;x86微处理器架构解析 在计算机科学领域&#xff0c;x86架构就像一座精密的瑞士钟表&#xff0c;每一个齿轮的转动都遵循着严格的物理…...

常见的8个Jmeter压测问题及解决方法

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 为什么在JMeter中执行压力测试时&#xff0c;出现连接异常或连接重置错误&#xff1f;答案&#xff1a;连接异常或连接重置错误通常是由于服务器在处理请求时出现问…...

嵌入式系统开发知识体系:从硬件抽象到RTOS与Linux驱动

1. 嵌入式系统开发知识体系构建&#xff1a;从硬件底层到软件架构的工程实践指南嵌入式系统开发并非零散技术点的简单堆砌&#xff0c;而是一个需要系统性思维与工程化方法支撑的知识体系。本文基于多年一线嵌入式项目实践&#xff0c;对涵盖微控制器底层驱动、实时操作系统内核…...

Qwen3.5-9B开源大模型部署指南:9B参数量+CUDA加速+Gradio开箱即用

Qwen3.5-9B开源大模型部署指南&#xff1a;9B参数量CUDA加速Gradio开箱即用 1. 引言&#xff1a;为什么选择Qwen3.5-9B 想快速部署一个强大又高效的开源大模型吗&#xff1f;Qwen3.5-9B可能是你当前最理想的选择。这个拥有90亿参数的模型在保持轻量级的同时&#xff0c;通过C…...

JBoltAI智教小工坊:AI赋能教育的技术落地与价值体现

在AI技术向各行业深度渗透的当下&#xff0c;教育领域的数字化转型亟需技术与场景的深度融合&#xff0c;Java生态作为企业级开发的核心支撑&#xff0c;为教育AI应用落地筑牢了技术底座。JBoltAI以企业级Java AI应用开发框架为核心&#xff0c;构建起AIGS&#xff08;人工智能…...

VirtualBox安装CachyOS避坑指南:EFI设置与GRUB修复全流程

VirtualBox安装CachyOS实战指南&#xff1a;从EFI配置到系统调优 在开源社区中&#xff0c;CachyOS凭借其基于Arch Linux的轻量级设计和性能优化&#xff0c;正吸引着越来越多的技术爱好者。而VirtualBox作为最受欢迎的虚拟化解决方案之一&#xff0c;为体验各种Linux发行版提供…...

ESP32异步MQTT客户端:QoS2/SSL/WSS全协议支持

1. PsychicMqttClient&#xff1a;面向ESP32全功能异步MQTT客户端深度解析1.1 项目定位与工程价值PsychicMqttClient并非又一个轻量级MQTT封装&#xff0c;而是在ESP-IDF原生MQTT客户端基础上构建的工业级异步通信中间件。其核心价值在于填补了ESP32生态中长期存在的三大技术空…...

YOLOv11网络结构拆解:从Anchor生成到损失计算的保姆级图解

YOLOv11架构深度解析&#xff1a;从Anchor机制到损失函数的全链路实现 在计算机视觉领域&#xff0c;目标检测算法的发展日新月异。作为YOLO系列的最新成员&#xff0c;YOLOv11凭借其卓越的性能和工程友好性&#xff0c;正在成为工业界和学术界的热门选择。本文将带您深入YOLOv…...

Emgu CV实战:用VideoCapture类快速实现摄像头监控(附常见报错解决)

Emgu CV实战&#xff1a;从零搭建智能摄像头监控系统 最近在帮朋友改造他的小型工作室安防系统时&#xff0c;我重新审视了Emgu CV这个强大的.NET图像处理库。作为OpenCV的.NET封装&#xff0c;Emgu CV让C#开发者也能轻松实现复杂的计算机视觉应用。本文将分享如何用VideoCaptu…...