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

学习LangChain-基础篇-认识LangChain

认识LangChainLangChain 由 Harrison Chase 创建于 2022年10月是用于开发智能体工程 Agent Engineering的平台。1.1 架构体系LangChain 并不仅仅是一个框架而是一整个智能体开发平台包含很多不同的组件。其中包含一系列开源的智能体Agent开发框架而且兼容 Python和 TypeScript 两种语言LangChain用于快速构建智能体可兼容任何模型提供商。LangGraph从底层一步步控制智能体的构建包括记忆Memory、人机协同HITL等Deep Agents用于构建复杂的、处理多步骤的任务的智能体另外LangChain 还包含一套帮助人工智能团队利用实时生产数据进行持续测试和改进的平台叫做LangSmith。总结LangChain是智能体开发平台包含一套各种帮助开发、测试、评估智能体的框架。核心包括LangChain用于快速构建智能体可兼容任何模型提供商。LangGraph从底层一步步控制智能体的构建包括记忆Memory、人机协同HITL等Deep Agents用于构建复杂的、处理多步骤的任务的智能体LangSmith用于测试、观察、评估、部署智能体可以看到LangChain平台的所有框架都是围绕着构建智能体Agent这一目标的那么问题来了什么是智能体Agent呢1.2 什么是Agent什么是 Agent这其实没有一个标准的答案每个人都有自己的理解。对于这个问题LangChain 创始人 Harrison Chase 有一个偏向技术性的答案Agent 是一种使用大语言模型LLM来决定应用程序控制流的系统。在人工智能领域Agent通常翻译为智能体或代理是指一种能感知环境、进行推理、自主决策并采取行动以实现特定目标的智能系统。特性传统聊天机器人/LLMAI Agent交互模式被动响应问一句答一句主动规划以目标为导向执行力停留在文本生成层面能操作软件、发送邮件、分析数据自主性需要人类给出详细步骤只需给定最终目标自主寻找路径如果说大模型LLM是“大脑”那么 Agent 就是“拥有手脚和思维逻辑的独立个体”。它不再只是被动地回答问题而是能主动拆解任务并调用各种工具来完成工作。例如要开发一个《AI旅游助手》的应用。如果是传统LLM应用程序流程是这样的用户提出需求例如帮我计划一个5天的北京之旅预算8000元我喜欢历史。调用LLM分析用户需求直接由LLM生成一个简单旅游计划这个计划基于它训练数据中的通用知识可能没有考虑当前的天气、景点是否关闭、门票是否可预订等实时信息。如果是Agent应用Agent可以自主规划程序流程用户提出需求例如帮我计划一个5天的北京之旅预算8000元我喜欢历史。Agent分析用户需求分步执行规划 将大目标分解为查询机票酒店价格 - 查询天气和景点信息 - 设计每日行程 - 计算总预算。调用工具调用机票/酒店API查询用户指定日期范围内的价格和可选酒店。调用天气预报API查询未来5天北京的天气建议携带的衣物。调用搜索引擎/景点API查询故宫、国博等热门景点的最新开放时间、预约政策和当前展览。感知与反馈 综合感知所有查询到的实时信息生成一个动态的、可执行的计划。例如“根据预算和您对历史的兴趣我推荐入住胡同里的XX酒店。第一天去故宫但请注意下周一故宫闭馆所以调整到第二天……总花费预计7500元还在预算内。需要我现在帮您预订酒店和机票吗”Agent通过主动规划任务流程主动使用工具整合了实时信息并进行了动态调整最终产出的是一个真正可落地的方案。总结如下LLM 聪明的大脑Agent 聪明的大脑 手脚当然Agent的模式也是在不断演进的阶段一ReAct Tool Calling阶段二Reflection Long Memory阶段三Multi Agent SystemMAS接下来我们会从最简单的Agent开始学习逐渐升级到更复杂的Agent结构。1.3 快速入门1.3.1 准备工作uv add langchainLangChain支持各种不同的模型而且提供了对应的兼容SDK不过也都需要安装对应依赖你可以按需添加# 集成 DeepSeek uv add langchain-deepseek ​ # 集成 OpenAI uv add langchain-openai ​ # 集成 Anthropic uv add langchain-anthropic1.3.2 代码示例开发Agent了基本步骤如下加载环境变量定义工具定义Agent调用AgentLangchain提供了create_agent方法用来快速创建Agent我们只需要提供好Agent所需的模型Models、工具Tools即可。示例代码如下# 1.加载环境变量 from dotenv import load_dotenv ​ load_dotenv() ​ # 2.定义工具基础版通过注释描述工具 tool def getWeather(location: str) - str: Get the weather in a given location. Args: location: city name or coordinates return fCurrent weather in {location} is sunny ​ # 3.定义Agent agent create_agent( deepseek-chat, # 模型名称必须是LangChain支持的模型 tools[getWeather] # 工具集 ) ​ # 4.调用模型 print( 正在调用大模型...) response agent.invoke({ messages: [ {role: user, content: 杭州今天天气如何?} ] }) ​ # 5.打印结果 print(response)运行结果如下 正在调用大模型... {messages: [HumanMessage(content杭州今天天气如何?, additional_kwargs{}, response_metadata{}, id216c9cd1-8ebc-4365-a192-6b1a30ae788c), AIMessage(content我来帮您查询杭州今天的天气情况。, additional_kwargs{refusal: None}, response_metadata{token_usage: {completion_tokens: 51, prompt_tokens: 313, total_tokens: 364, completion_tokens_details: None, prompt_tokens_details: {audio_tokens: None, cached_tokens: 256}, prompt_cache_hit_tokens: 256, prompt_cache_miss_tokens: 57}, model_provider: deepseek, model_name: deepseek-chat, system_fingerprint: fp_eaab8d114b_prod0820_fp8_kvcache, id: bbeda11e-7653-4c3d-9cc5-9a58491f63f0, finish_reason: tool_calls, logprobs: None}, idlc_run--019c92f4-8395-7852-8e36-d4645f86d443-0, tool_calls[{name: getWeather, args: {location: 杭州}, id: call_00_H7Yklbf4osnSeFOj3k4TP33N, type: tool_call}], invalid_tool_calls[], usage_metadata{input_tokens: 313, output_tokens: 51, total_tokens: 364, input_token_details: {cache_read: 256}, output_token_details: {}}), ToolMessage(contentCurrent weather in 杭州 is sunny, namegetWeather, id911eda0e-a5a8-4375-909d-b8707b3a08a9, tool_call_idcall_00_H7Yklbf4osnSeFOj3k4TP33N), AIMessage(content根据查询结果杭州今天的天气是**晴朗**的。, additional_kwargs{refusal: None}, response_metadata{token_usage: {completion_tokens: 13, prompt_tokens: 388, total_tokens: 401, completion_tokens_details: None, prompt_tokens_details: {audio_tokens: None, cached_tokens: 320}, prompt_cache_hit_tokens: 320, prompt_cache_miss_tokens: 68}, model_provider: deepseek, model_name: deepseek-chat, system_fingerprint: fp_eaab8d114b_prod0820_fp8_kvcache, id: 692c1420-4a06-4080-adf7-54250207e86a, finish_reason: stop, logprobs: None}, idlc_run--019c92f4-8d74-7770-89fd-da1e9d67efca-0, tool_calls[], invalid_tool_calls[], usage_metadata{input_tokens: 388, output_tokens: 13, total_tokens: 401, input_token_details: {cache_read: 320}, output_token_details: {}})]}原本大模型不具备查询天气的能力所以无法回答天气问题。但是当我们提供了一个查询添加的Tool以后它就能自动查询天气来回答问题是不是很神奇。那么Agent是如何做到的呢传统的LLM应用都是一问一答的形式模型只能根据自己的训练数据来回答流程非常简单而智能体则可以调用工具与外界交互获取实时信息工作流程则要复杂很多是这样的流程如下用户提问Input杭州今天天气如何模型分析Reasoning用户询问杭州天气我不知道需要调用查询天气的工具get_weather调用工具Action调用工具get_weather传入城市杭州分析结果Observation工具返回结果模型分析结果判断是否足以回答用户问题是整理生成响应结果否重复前面步骤生成结果Output根据工具的结果生成响应给用户那么模型是如何知道工具的信息的呢其实在大模型提供的API接口中有一个tools参数描述了工具的详细信息所以LangChain会帮助我们把tool的信息封装为此tool参数与message一起发送给大模型大模型就了解tool的详细信息根据用户需求判断是否需要调用tool需要调用哪个tool.那么问题来了当大模型决定调用某个tool时该如何调用呢毕竟tool是我们定义的模型是没有调用能力的。模型确实不能直接调用tool只能返回字符串。但是它可以把要调用的tool信息、参数信息都以Json格式返回这样一来LangChain就会帮我们解析响应结果中的Function信息也就是tool信息就知道了要调用哪个函数以及参数是什么了。LangChain就会执行该函数再把得到的结果再次发送给大模型。具体的工作流程如图OK弄明白了Agent的原理我们不难发现Agent中最重要的两个部分就是Model负责推理分析、思考相当于Agent的大脑Tools负责执行任务相当于Agent与外界交互的手脚当然Agent中肯定不止这两个部分接下来我们就逐一解析Agent创建的各个细节。

相关文章:

学习LangChain-基础篇-认识LangChain

认识LangChainLangChain 由 Harrison Chase 创建于 2022年10月,是用于开发智能体工程 (Agent Engineering)的平台。1.1 架构体系LangChain 并不仅仅是一个框架,而是一整个智能体开发平台,包含很多不同的组件。其中&…...

Dev Containers 为什么越用越卡?揭秘90%开发者忽略的5个Dockerfile反模式及3步修复法

更多请点击: https://intelliparadigm.com 第一章:Dev Containers 性能退化现象的系统性归因 Dev Containers 在提供环境一致性的同时,常在实际开发中表现出显著的性能退化——包括启动延迟增加、文件监听响应迟缓、调试器连接超时及 CPU/内…...

Phi-3.5-Mini-Instruct部署案例:高校AI教学实验平台轻量化部署方案

Phi-3.5-Mini-Instruct部署案例:高校AI教学实验平台轻量化部署方案 1. 项目背景与价值 在高校AI教学实验场景中,传统大模型部署面临三大痛点: 硬件门槛高:动辄需要数十GB显存的专业显卡部署复杂度高:需要专业IT人员…...

用 Python 批量制造表情包,从此聊天斗图没输过

再也不怕群聊斗图了——写个脚本,一键生成 100 张自定义表情包,还能自动配上沙雕文字。 技术不一定改变世界,但一定能让你成为表情包之王。 一个尴尬的故事 有次我在群里和人斗图,对方连续甩出 5 张精准打击的表情包,…...

大模型内部的数学世界

从文字到数字,从数字到理解 引言:当你对大模型说"你好" 想象你走进一座巨大的图书馆。这座图书馆里有数十亿本书,每本书都记录着人类的知识。当你走向前台,对管理员说:"你好,请问什么是量子力学?"——管理员听到了你的问题,然后在她的大脑中开始…...

ofa_image-caption步骤详解:临时文件管理、Pipeline超参设置与结果缓存机制

ofa_image-caption步骤详解:临时文件管理、Pipeline超参设置与结果缓存机制 1. 工具概述 ofa_image-caption是一款基于OFA(ofa_image-caption_coco_distilled_en)模型开发的本地图像描述生成工具。这个工具通过ModelScope Pipeline接口调用…...

Wasserstein距离在GAN中的原理与实践

1. Wasserstein距离在GAN中的核心价值生成对抗网络(GAN)训练过程中最棘手的难题莫过于模式崩溃(Mode Collapse)和梯度消失。传统GAN采用的JS散度(Jensen-Shannon Divergence)在判别器最优时,生成…...

为什么你的 devcontainer.json 总被面试官打叉?11个被忽略的 spec v2.0 兼容性细节,资深工程师私藏笔记

更多请点击: https://intelliparadigm.com 第一章:Dev Containers 面试高频误区与 spec v2.0 兼容性认知盲区 常见误解:Dev Container 就是 Docker Compose 的别名 许多候选人误将 devcontainer.json 视为 Docker Compose 的简化配置&…...

北京通州比较好的学画画画画班推荐

在北京通州,为孩子选择一家优质的画画班是很多家长关心的话题。今天,我将为大家推荐一家备受好评的少儿美术机构——甲乙果美术书法,并通过具体数据和案例来展示其优势。一、科学进阶课程体系1.1 课程设计内容:甲乙果美术书法针对…...

Vulkan GPU图像处理之幂律(伽马)变换:Kompute框架实战与性能分析

一、定义 章节:第3章 灰度变换与空间滤波 → 3.2 基本灰度变换 → 3.2.3 幂律(伽马)变换别名:幂律变换(Power‑Law Transformation)、伽马变换(Gamma Transformation) 公式 [scrγ] …...

3步掌握ChanlunX缠论插件:通达信技术分析终极指南

3步掌握ChanlunX缠论插件:通达信技术分析终极指南 【免费下载链接】ChanlunX 缠中说禅炒股缠论可视化插件 项目地址: https://gitcode.com/gh_mirrors/ch/ChanlunX ChanlunX缠论可视化插件是专为通达信软件设计的开源缠论分析工具,它将复杂的缠论…...

C/C++程序设计的基本概念详解

学C语言有很长一段时间了,想做做笔记,把C和C相关的比较容易忽视的地方记下来,也希望可以给需要的同学一些帮助。我的这些文章不想对C和C的语法进行讲解和罗列,这些东西随便找一本书就讲的比我清楚,我只是想把一般人忽视…...

Docker原生WASM运行时落地实践:从零搭建低延迟边缘AI推理节点(含性能压测数据)

更多请点击: https://intelliparadigm.com 第一章:Docker原生WASM运行时落地实践:从零搭建低延迟边缘AI推理节点(含性能压测数据) WebAssembly(WASM)正突破浏览器边界,成为边缘计算…...

神经网络在NLP中的应用与Transformer实现详解

1. 神经网络模型在自然语言处理中的核心价值 第一次接触自然语言处理(NLP)时,我被传统基于规则的方法折磨得够呛——那些复杂的语法解析树和手工设计的特征模板,就像试图用乐高积木搭建一座摩天大楼。直到2013年Mikolov提出word2vec,神经网络…...

MCP 2026国产化配置实战:从零搭建符合等保2.0三级+信创名录要求的高可用集群(含OpenEuler 24.03 LTS完整脚本)

更多请点击: https://intelliparadigm.com 第一章:MCP 2026国产化部署概述与合规基线解析 MCP(Mission-Critical Platform)2026 是面向关键信息基础设施的国产化高可靠平台,其部署需严格遵循《信创产品适配目录&#…...

阿里云国际站服务器DNS服务器设置成什么?服务器dns怎么填写?

阿里云国际站服务器DNS服务器设置成什么?服务器dns怎么填写?针对阿里云国际站(Alibaba Cloud International)的 ECS 服务器,设置 DNS 分为两种常见场景:使用阿里云内网 DNS(推荐)或使…...

Learning to AutoFocus:深度学习驱动的自动对焦实战

文章目录 Learning to AutoFocus:深度学习驱动的自动对焦实战 一、问题背景 二、技术方案 三、数据准备 四、模型 五、训练 六、推理与对焦控制 七、部署考虑 八、实验结果 九、总结 代码链接与详细流程 购买即可解锁1000+YOLO优化文章,并且还有海量深度学习复现项目,价格仅…...

香港工地火灾的警示:边缘AI如何让“监控”真正变成“安全”

引言近期香港某在建工地发生严重火灾,造成多人伤亡。事故原因指向违规动火、疏散通道堵塞、监控预警不及时。这让我不禁思考:在AI和边缘计算足够成熟的今天,我们能不能用技术提前掐灭火灾的苗头?本文不讲产品,只讲技术…...

Nixtla时间序列预测生态:统一接口、高速统计与深度学习模型实战

1. 项目概述:时间序列预测的“瑞士军刀”如果你正在处理时间序列数据,无论是销售预测、服务器监控还是能源消耗分析,那么“Nixtla/nixtla”这个名字很可能已经出现在你的雷达上。这不是一个单一的工具,而是一个由Nixtla团队维护的…...

助贷CRM系统比较是什么?其主要特点应关注哪些方面?

在探讨助贷CRM系统比较时,有几个关键方面需要我们重点关注。首先是获客能力,优秀的系统能够帮助金融机构有效获取和管理客户资源。其次,合规性是确保业务稳定发展的基础,务必符合相关法规,以避免不必要的法律风险。再者…...

hyperf 微服务架构方案大全

---1. 服务拆分原则 大白话: 什么时候该拆、怎么拆、拆多细。 拆分原则…...

scikit-learn预测建模全流程解析与实战技巧

1. 预测建模基础与scikit-learn概览 机器学习预测建模的核心在于从历史数据中发现规律,并将这些规律应用于新数据。scikit-learn作为Python最流行的机器学习库,提供了统一的API设计,使得从数据预处理到模型评估的整个流程变得异常简单。我初次…...

C/C++:类型转换

最近复盘C基础,发现类型转换看着简单,实际细碎考点非常多。很多代码写法平时随手就能写,但一深挖底层编译逻辑就容易混乱。我把整套知识点按步骤拆解、条理化整理,配上完整可运行代码,全程条目化讲解,适合自…...

AI模型部署效率提升210%,Docker AI Toolkit 2026到底重构了哪4层编排协议?

更多请点击: https://intelliparadigm.com 第一章:AI模型部署效率跃升210%:Docker AI Toolkit 2026的范式革命 Docker AI Toolkit 2026(DAIT-2026)正式终结了传统模型容器化部署中“构建慢、启动卡、调试难”的三重瓶…...

基于向量数据库的视频语义检索:从多模态特征提取到工程实践

1. 项目概述:当视频遇见向量数据库最近在折腾一个挺有意思的项目,叫video-db/bloom。光看这个名字,你可能觉得它和视频数据库或者某种“绽放”效果有关。实际上,它解决的是一个更底层、更核心的问题:如何让机器像人一样…...

DemoGPT:从自然语言描述到完整Web应用的AI智能体编程实践

1. 项目概述:当大模型学会自己写代码最近在GitHub上看到一个项目,叫DemoGPT。初看标题,你可能会觉得这又是一个基于GPT的代码生成工具,没什么新意。但当我深入使用和拆解后,发现它的设计理念和实现方式,完全…...

机器学习超参数调优:从原理到工程实践

1. 机器学习超参数调优的本质理解超参数调优是每个机器学习工程师的必修课,但很多人把它简单理解为"试参数"。我在金融风控和推荐系统领域摸爬滚打八年,发现优秀的调参师和普通使用者的本质区别在于:前者把调参视为对问题空间的系统…...

Real-ESRGAN-ncnn-vulkan:3分钟让模糊图像焕然新生的AI超分辨率神器

Real-ESRGAN-ncnn-vulkan:3分钟让模糊图像焕然新生的AI超分辨率神器 【免费下载链接】Real-ESRGAN-ncnn-vulkan NCNN implementation of Real-ESRGAN. Real-ESRGAN aims at developing Practical Algorithms for General Image Restoration. 项目地址: https://gi…...

神经形态视觉传感器与3D堆叠计算架构解析

1. 神经形态视觉与事件相机的技术演进神经形态视觉传感器(Neuromorphic Vision Sensors)正彻底改变传统计算机视觉的范式。这类受生物视觉启发的传感器采用完全异步的工作机制,每个像素独立检测亮度变化并触发事件(Event&#xff…...

京东大屏AI手机+东东APP:银发智能,诚意够!

4月25日,京东举办了大屏AI手机生态发布会。说实话,一开始我对“银发青年”这个定位的产品没抱太高期待——毕竟市面上不少所谓的“长辈机”,要么是简单减配、贴个标签,要么是功能堆砌,根本没真正懂中老年用户的需求。但…...