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

关于 MicroPython + ESP-S 的使用流程

简介

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/746236/

相关文章:

  • B站视频下载终极指南:3步获取无水印高清视频的完整方案
  • 独立开发者如何借助 Taotoken 的透明计费系统精准掌控 AI 项目月度支出
  • SOGo ActiveSync配置指南:让移动设备随时随地同步工作数据
  • 终极指南:如何使用theHarvester构建高效分布式扫描系统
  • 2025届最火的五大AI学术工具推荐
  • Ollama模型老被卸载?试试这个keep_alive参数,让LLaMA2在内存里多待会儿
  • 解锁3大创新功能:League Director《英雄联盟》专业视频创作完全指南
  • PKHeX自动合法性插件完整指南:5分钟掌握宝可梦合规性检查
  • 从Spring Boot 2.7到3.2,Java中间件国产化适配的5个断代式兼容节点(附JDK17+OpenJ9+统信UOS压测对比数据)
  • R3nzSkin国服特供版:基于内存注入的LOL皮肤修改技术深度解析
  • 网页自定义光标实战指南:从CC协议到CSS集成与性能优化
  • Roaring Bitmaps:高性能位图压缩库完全指南 - 被InfluxDB、Bleve、DataDog广泛采用
  • cube-composer游戏状态管理:Storage模块完整解析
  • Krypton Palette系统详解:轻松实现统一主题化设计
  • 告别模组混乱:BG3 Mod Manager如何用3步解决《博德之门3》模组管理难题
  • Cursor Pro访问优化工具完整解决方案:AI编程助手解锁终极指南
  • OpenAI代理网关部署指南:构建安全可控的AI应用中间层
  • Feroxbuster终极配置指南:快速打造高效内容发现工作流
  • 量子计算来了,运维会失业?还是直接“开挂”?
  • 从源码到桌面:Breeze Shell构建与部署的终极指南
  • 八大网盘直链下载助手完整指南:告别限速烦恼,轻松获取高速下载地址
  • 别再折腾虚拟机了!Windows 10本地搞定Hadoop 3.1.3开发环境(附winutils下载)
  • Vue.js 自定义指令
  • svg-sprite-loader服务器端渲染实践:SSR环境下的SVG精灵处理
  • 日志不输出、断点不命中、变量全为None——Python低代码插件调试困局全解析,深度穿透沙箱隔离层
  • 别再死记硬背了!用RabbitMQ Web管理界面5分钟搞懂Topic通配符(附实战截图)
  • 2026年4月口碑好的网带螺旋塔供应商推荐,斗式提升机/食品紫外线杀菌炉/网带烘干机/乙型网带,网带螺旋塔直销厂家有哪些 - 品牌推荐师
  • 终极dnSpy性能分析指南:快速找出代码生成瓶颈的10个技巧
  • 【仅限头部金融/政务系统内部流出】:Java多租户数据隔离最小可行配置矩阵(含Oracle/PostgreSQL/MySQL三端差异表)
  • Python跨端项目上线前必须完成的9项合规审计,少1项即遭App Store拒审