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

哥本哈士奇(aspnetx)涝

简介

langchain中提供的chain链组件,能够帮助我门快速的实现各个组件的流水线式的调用,和模型的问答

Chain链的组成

根据查阅的资料,langchain的chain链结构如下:

$$Input \rightarrow Prompt \rightarrow Model \rightarrow Output$$

其中langchain框架提供了几个常用构建chain链的工具:

工具名称 作用 流程

RunnablePassthrough 传递原本的数据或添加新的字段 $$A->B$$

RunnableParallel 并发输出结果并将结果同时传递 $$A,B->C$$

RunnableLambda 自定义传递工具

乍一看很疑惑,我接下来用案例来解释各种用法。

构建较为复杂的chain链

这个案例几乎用了上面所有工具,用于演示用法

案例

案例描述:输入论文的话题,写一篇950字的高中论文。

import os

from langchain_community.chat_models.tongyi import ChatTongyi

from langchain_core.prompts import ChatPromptTemplate

from langchain_core.output_parsers import StrOutputParser

from langchain_core.runnables import RunnablePassthrough, RunnableParallel

#你的qwen模型apikey

os.environ["DASHSCOPE_API_KEY"] = "apikey"

model = ChatTongyi(model="qwen-max")

outline_prompt = ChatPromptTemplate.from_template(

"请给主题为 {topic} 的议论文写一个 总-递进-总 的简短大纲,一共分为5段。"

)

outline_chain = outline_prompt | model | StrOutputParser()

def mock_search(input_data):

return """

1. 利:Google Health AI 筛查乳腺癌准确率超人类。

2. 利:AlphaFold 预测蛋白质结构,缩短科研周期。

3. 弊:GPT-4 普及导致初级文案、原画设计岗位萎缩。

4. 弊:Deepfake 技术被用于电信诈骗和虚假视频。

"""

output_prompt = ChatPromptTemplate.from_template(

"你是一位高考作文专家。请基于大纲:\n{outline}\n并结合以下案例素材:\n{data}\n"

"就主题【{topic}】写一篇高考论文。要求:950字左右,论证严密,文采斐然。"

)

output_chain = output_prompt | model | StrOutputParser()

complex_chain = (

RunnableParallel({

"outline": outline_chain,

"data": mock_search,

"topic": RunnablePassthrough()

})

| output_chain

)

topic_input = "AI 进步的利与弊:在智能时代保持人类的温度"

print(f"正在为您撰写关于《{topic_input}》的论文...\n")

final_essay = complex_chain.invoke({"topic": topic_input})

print(final_essay)

代码解释

其他的代码我上期解释了,这里就不废话了,我着重讲chain链的构建,总体chain链的流程如下:

输入话题->获取写作的大纲 ──╮

├─? 根据大纲和示例写一篇论文

查询相关的示例 ──╯

根据输入流程图流程,我们个以分解成一个个相关的链,再将各个链串起来。

构建各部分的链

1.获取写作大纲

outline_prompt = ChatPromptTemplate.from_template(

"请给主题为 {topic} 的议论文写一个 总-递进-总 的简短大纲,一共分为5段。"

)

outline_chain = outline_prompt | model | StrOutputParser()

流程描述:构建prompt->喂给ai->将返回解析成文本

这里用的ChatPromptTemplate.from_template和上的ChatPromptTemplate.from_messages不同,区别在于前者比较简单,相当于后者直接用user字典的形式,后者from_messages有langchain框架提供的prompt模板

2.查询相关的示例

这里就直接用Gemini,mock一些模拟数据(不保证真),用于完成案例,实际情况可以自己完善搜索逻辑。

def mock_search(input_data):

return """

1. 利:Google Health AI 筛查乳腺癌准确率超人类。

2. 利:AlphaFold 预测蛋白质结构,缩短科研周期。

3. 弊:GPT-4 普及导致初级文案、原画设计岗位萎缩。

4. 弊:Deepfake 技术被用于电信诈骗和虚假视频。

"""

这个相当于RanableLamda,后面可以不用显示调用RanableLamda(mock_search)

3. 根据大纲和示例写一篇论文

output_prompt = ChatPromptTemplate.from_template(

"你是一位高考作文专家。请基于大纲:\n{outline}\n并结合以下案例素材:\n{data}\n"

"就主题【{topic}】写一篇高考论文。要求:950字左右,论证严密,文采斐然。"

)

output_chain = output_prompt | model | StrOutputParser()

流程描述:构建prompt->喂给ai->将返回解析成文本

将各个链连起来

complex_chain = (

RunnableParallel({

"outline": outline_chain,

"data": mock_search,

"topic": RunnablePassthrough()

})

| output_chain

)

这里利用RunnableParallel将获取写作的大纲和查询相关的示例两个流程并列运行后一起输出到后面,传递给output_chain继续处理。

问题

我不想利用RunnableParallel行不行? 当然可以,可以用线性来代替,先查资料,后写大纲,然后再进行文章输出,但是效率可能会比较慢。

我希望看到输出的data和outline字段怎么办? ,可以利用RunnablePassthrough().assign将生成的文本保存在新的字段中,调用时根据字典的方式定位各个文本,如下:

complex_chain = (

RunnableParallel({

"outline": outline_chain,

"data": mock_search,

"topic": RunnablePassthrough()

})

| RunnablePassthrough().assign(essay=output_chain)

)

print(response['essay'])

print(response['data'])

......们障盎橇

http://www.jsqmd.com/news/630226/

相关文章:

  • VidCoder:解决视频转码与苹果设备兼容问题的免费工具
  • Qwen2.5-VL-7B-Instruct应用案例:一键生成网页截图对应HTML代码
  • HagiCode Soul 平台技术解析:从需求萌发到独立平台的演进之路奶
  • AICoverGen实战指南:基于RVC v2的AI翻唱生成深度解析
  • 15分钟完成黑苹果配置:OpCore-Simplify自动化工具终极指南
  • 从离群值到平坦线:FlatQuant 如何重塑 LLM 的 4-bit 量化格局
  • 遥感图像分割太耗时?Geo-SAM如何让地理空间AI在毫秒间完成复杂任务?
  • 5分钟快速上手:暗黑破坏神2存档编辑器d2s-editor终极使用指南
  • 信创集成项目管理师证书到底值不值得考?5年IT老兵亲测避坑指南
  • YOLO26涨点改进| ICME 2026 | 独家创新首发、注意力改进篇| 引入SFC显著特征校准模块,通过双分支门控与全局统计信息引导实现特征精细校准,助力遥感目标检测、图像分割、图像分类任务涨点
  • 2026奇点智能技术大会核心洞察(工具链调用能力已成大模型商用分水岭)
  • MouseJiggler终极指南:3分钟告别电脑锁屏烦恼,提升工作效率300%
  • 隶属函数配置
  • Pixel Epic实战案例:高校科研组用贤者模式3小时产出行业白皮书
  • Input Leap:一套键鼠控制多台电脑的终极解决方案
  • 【SITS2026独家解密】:联邦大模型安全水印机制、梯度泄露防御阈值、合规审计日志模板——仅限本届参会者获取的3份白皮书级资料
  • 为什么你的vLLM集群总在凌晨3点失联?揭秘服务注册TTL策略缺失引发的级联雪崩(附7行修复代码)
  • 用Zotero+BibTeX实现参考文献全自动管理:从文献收集到LaTeX引用的完整工作流
  • BilibiliDown:打造个人B站视频库的全能开源工具
  • 【Claude Code 源码解析教程】 - 附录
  • Audio Slicer深度解析:基于静默识别的智能音频切分实战方案
  • SpringBoot邮件发送进阶:除了163/QQ,如何优雅集成企业邮箱(如阿里云、腾讯企业邮)?
  • PvZ Toolkit:如何通过开源工具深度定制您的植物大战僵尸游戏体验
  • YOLO26涨点改进| ICME 2026 | 独家创新首发、注意力改进篇| 引入SFD显著特征判别模块,通过通道关系建模和图结构推理实现全局语义增强,助力遥感目标检测、图像分割、图像分类任务涨点
  • 基于VideoAgentTrek-ScreenFilter构建智能教室系统:过滤学生端无关屏幕活动
  • 从百亿到零噪声:工业级大模型数据清洗SOP(含MinHash+LSH+Embedding聚类三阶验证)
  • 别再到处找了!手把手教你用BigMap+geojson.io搞定ECharts镇级地图数据(附完整避坑指南)
  • .NET 诊断技巧 | 日志框架原理、手写日志框架学习颜
  • 3个场景告诉你:如何零成本破解Altium电路设计文件查看难题
  • Agent Client Protocol 全景解析释