langchain入门系列之四 链结构的使用

2024-08-26 14:12

本文主要是介绍langchain入门系列之四 链结构的使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

所谓的链结构,就是在相同的标准下,不同模块组成一条处理任务的流水线。优点是链提高了模块的标准化和复用性,缺点是增加了工程的复杂度和冗余。

本文着重介绍三种链接,langchain的链结构不止本文所介绍的,感兴趣的同学可以查看官方文档解惑,本文前提在于,读者已经阅读过我前面写的文章,若还没有,可能会有阅读上的障碍。

单链结构

定义prompt →定义llm→定义chain→运行predict

# LLM  chain
import os
from langchain_community.chat_models import QianfanChatEndpoint
from langchain.prompts import PromptTemplate# 设置API
os.environ["QIANFAN_AK"] = ""
os.environ["QIANFAN_SK"] = ""llm = QianfanChatEndpoint(model="ERNIE-Bot-turbo")prompt = PromptTemplate.from_template("给我讲一个关于{对象}的黑色幽默笑话")
# prompt.format(对象="猫")from langchain.chains import LLMChain
chain = LLMChain(llm=llm, prompt=prompt)
print(chain.run("狗"))

多链结构

定义prompt →定义llms/embeddings→定义chain(多链并行,选择其中一条链进行处理)→运行predict

import os
from langchain_community.llms import QianfanLLMEndpoint# 设置API
os.environ["QIANFAN_AK"] = ""
os.environ["QIANFAN_SK"] = ""# 实例化(大模型)
llm = QianfanLLMEndpoint()geography_template = "你将扮演一位地理知识丰富的地理学家,你尤其对中国的地理人文知识了解透彻,你将回答用户提出的关于地理方面的问题,这里是问题{input}"
math_template = "你将扮演一位经验丰富的数学老师,你尤其擅长中小学方面的数学知识,你将回答用户提出的数学问题,这里是问题{input}"
prompt_infos = [{"name":"地理","description":"擅长地理","prompt_template":geography_template},{"name":"数学","description":"擅长数学","prompt_template":math_template},
]from langchain.chains import ConversationChain
from langchain.chains.router import MultiPromptChain
from langchain.prompts import PromptTemplate
from langchain.chains import LLMChaindestination_chains = {}
# 对每一条单链进行初始化
for p in prompt_infos:name = p['name']prompt_template = p['prompt_template']prompt = PromptTemplate(template=prompt_template, input_variables=["input"])chain = LLMChain(llm=llm, prompt=prompt)destination_chains[name] = chain
default_chain = ConversationChain(llm=llm, output_key="text")from langchain.chains.router.llm_router import LLMRouterChain, RouterOutputParser
from langchain.chains.router.multi_prompt_prompt import MULTI_PROMPT_ROUTER_TEMPLATE
# 配置router
destinations = [f"{p['name']}:{p['description']}" for p in prompt_infos]
destinations_str = '\n'.join(destinations)
router_template = MULTI_PROMPT_ROUTER_TEMPLATE.format(destinations=destinations_str)
router_prompt = PromptTemplate(template=router_template,input_variables=['input'],output_parser=RouterOutputParser(),
)
router_chain = LLMRouterChain.from_llm(llm=llm, prompt=router_prompt)from langchain.chains.router import MultiPromptChain
chain = MultiPromptChain(router_chain=router_chain,destination_chains=destination_chains,default_chain=default_chain,verbose=True,
)
print(chain.run("敦煌在中国哪个省?"))
------------------------------------
> Entering new MultiPromptChain chain...
None: {'input': '敦煌在中国哪个省份?'}
> Finished chain.
敦煌位于中国甘肃省。

由上面代码可以知道,多链结构至少会调两次llm。

多链顺序结构

定义prompt →定义llms/embeddings→定义chain(多链串行,按顺序执行)→运行predict

import os
from langchain_community.llms import QianfanLLMEndpoint# 设置API
os.environ["QIANFAN_AK"] = ""
os.environ["QIANFAN_SK"] = ""# 实例化(大模型)
llm = QianfanLLMEndpoint()from langchain.prompts import PromptTemplate
from langchain.chains import LLMChaintemplate = """你将扮演一位成语出题人,你将从你丰富的成语知识库里,给出三个关于{input}相关的成语"""
prompt_template = PromptTemplate(input_variables=["input"], template=template)
synopsis_chain = LLMChain(llm=llm, prompt=prompt_template)from langchain.prompts import PromptTemplate
from langchain.chains import LLMChaintemplate = """你将扮演一位成语分析者,擅长从多个维度分析成语,并且从中挑选出寓意最好的成语,成语分析:{synopsis},对上面的成语进行分析,挑选出寓意最好的成语"""
prompt_template = PromptTemplate(input_variables=["input"], template=template)
select_chain = LLMChain(llm=llm, prompt=prompt_template)from langchain.chains import SimpleSequentialChain
overall_chain = SimpleSequentialChain(chains=[synopsis_chain, select_chain], verbose=True)select = overall_chain.run("结婚")
-------------------------------------------Entering new SimpleSequentialChain chain...
以下是三个与结婚相关的成语:1. 喜结连理:这个成语形容两个人之间美好的姻缘和因缘关系。它常用来祝贺两人成婚的场景,传达着美满、幸福和长久的祝愿。
2. 百年好合:这个成语常用于祝福新婚夫妇的婚姻美满、幸福长久。它强调了婚姻的持久和美好,是表达祝福和喜悦的常用成语。
3. 共结连理枝:这个成语比喻两个人结为夫妻,是美好的结合,与“喜结连理”意思相近,但表达上略显浪漫。这些成语在汉语中经常被用来描述和祝福美满的婚姻,都充满了喜庆和幸福的色彩。
在分析这三个与结婚相关的成语后,我认为寓意最好的成语是“百年好合”。首先,“喜结连理”和“共结连理枝”两个成语都强调了两个人因缘际会、结为夫妻的美好关系,寓意着美满和幸福。然而,“百年好合”在这个基础上更进一步,它不仅表达了夫妻关系的和谐与美满,还特别强调了婚姻的持久性。在中国文化中,百年被视为一个很长的时间跨度,象征着长久的承诺和持续的幸福。因此,“百年好合”寓意着夫妻之间的长久美满和永恒的幸福,这是一个对婚姻最深切的祝福和期许。综上所述,我认为“百年好合”是这三个成语中寓意最好的一个。> Finished chain.

这篇关于langchain入门系列之四 链结构的使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl