LangGraph基础理解

2024-02-04 07:12
文章标签 基础 理解 langgraph

本文主要是介绍LangGraph基础理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 动机
  • 功能
    • StateGraph
    • Nodes
    • Edges
      • 起始边
      • 正常边
      • 条件边
  • Agent Executor
  • Chat Agent Executor
  • Modifications

本文对LangGraph博客内容做下简单总结,详细内容请查看langchain博客
https://blog.langchain.dev/langgraph/

动机

Agent的实现基本上有两个步骤:

  • 调用LLM来决定(a)采取什么行动,或(b)向用户提供什么响应
  • 采取给定的行动,然后回到步骤1

重复这些步骤,直到生成最终响应。

langchain中AgentExecutor本质上就是实现了这样一个循环,但当我们实际使用时会发现,当前langchain Agent的实现属于黑盒状态,缺乏扩展性。在实践中通常需要更多的控制。可能希望始终强制代理首先调用特定工具。可能希望更好地控制工具的调用方式。可能希望代理有不同的提示等等。

状态机

功能

以实现最简单的react Agent逻辑介绍langGraph的相关功能。

StateGraph

StateGraph是一个表示图形的类。通过传入状态定义来初始化该类。此状态定义表示随时间更新的中心状态对象。此状态由图中的节点更新,这些节点将操作返回到此状态的属性(以键值存储的形式)。

此状态的属性可以通过两种方式更新。首先,可以完全重写属性。如果希望节点返回属性的新值,这将非常有用。其次,可以通过添加属性的值来更新属性。如果属性是所采取的操作列表(或类似的东西),并且您希望节点返回所采取的新操作(并将这些操作自动添加到属性中),则这很有用。

Nodes

创建StateGraph之后,您可以使用graph.add_node(name, value)添加节点。name参数应该是一个字符串,我们将在添加边时使用它来引用节点。value参数应该是一个函数或将被调用的LCEL可运行程序。这个函数/LCEL应该接受与State对象相同形式的字典作为输入,并输出一个包含要更新的State对象的键的字典。

还有一个特殊的END节点,用于表示图的结束。重要的是你的周期最终能够结束!

graph.add_node("model", model)
graph.add_node("tools", tool_executor)
from langgraph.graph import END

Edges

起始边

这是将图的起点连接到特定节点的边。这将使该节点成为输入传递到图形时第一个调用的节点。伪代码是:

graph.set_entry_point("model")

正常边

在这些边上,一个节点应该始终在另一个节点之后被调用。这方面的一个例子可能是在基本代理运行时中,我们总是希望在调用工具之后调用模型。

graph.add_edge("tools", "model")

条件边

在这些节点中,使用一个函数(通常由LLM提供支持)来确定首先转到哪个节点。要创建这条边,你需要传入三样东西:

上游节点:将查看该节点的输出,以确定下一步要做什么
函数:将调用该函数以确定下一步调用哪个节点。它应该返回一个字符串
映射:此映射将用于将(2)中的函数的输出映射到另一个节点。键应该是(2)中的函数可能返回的值。这些值应该是返回该值时要转到的节点的名称。

一个例子是,在调用模型后,我们要么退出图表并返回给用户,要么调用一个工具 - 取决于用户的决定!请参阅下面的伪代码示例:

graph.add_conditional_edge("model",should_continue,{"end": END,"continue": "tools"}
)

Agent Executor

我们用LangGraph重新创建了标准的LangChain AgentExecutor。这将允许您使用现有的LangChain代理,但允许您更容易地修改AgentExecutor的内部。默认情况下,此图的状态包含您应该熟悉的概念(如果您使用过LangChain代理):input、chat_history、intermediate_steps(以及表示最新代理结果的agent_outcome)

from typing import TypedDict, Annotated, List, Union
from langchain_core.agents import AgentAction, AgentFinish
from langchain_core.messages import BaseMessage
import operatorclass AgentState(TypedDict):input: strchat_history: list[BaseMessage]agent_outcome: Union[AgentAction, AgentFinish, None]intermediate_steps: Annotated[list[tuple[AgentAction, str]], operator.add]

Chat Agent Executor

我们看到的一个共同趋势是,越来越多的模型是“聊天”模型,它对消息列表进行操作。这种模型通常配备了函数调用之类的功能,这使得类代理体验更加可行。在使用这些类型的模型时,通常直观地将代理的状态表示为消息列表。

因此,我们创建了一个处理这种状态的代理运行时。输入是一个消息列表,节点只是随着时间的推移向该消息列表添加信息。

from typing import TypedDict, Annotated, Sequence
import operator
from langchain_core.messages import BaseMessageclass AgentState(TypedDict):messages: Annotated[Sequence[BaseMessage], operator.add]

Modifications

LangGraph 的一大好处是它以更加自然和可修改的方式公开 AgentExecutor 的逻辑。

我们提供了一些我们收到的修改请求的示例:

  • 强制调用工具
  • 如何在调用工具之前添加人机交互步骤。
  • 用于添加有关如何处理代理可能采取的中间步骤的自定义逻辑(对于有很多步骤时很有用)。
  • 以特定格式返回输出 直接动态返回工具的输出

这篇关于LangGraph基础理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/676715

相关文章

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键