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

别再吹牛了,% Vibe Coding 存在无法自洽的逻辑漏洞!醇

简介

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

相关文章:

  • 在银河麒麟V10上,用linuxdeployqt打包Qt5.14.2应用的保姆级避坑指南
  • 乘 AI 教育东风 筑育人强国根基——赶考集团深耕 “人工智能 + 教育” 打造行业标杆 - 速递信息
  • Allegro PCB设计避坑指南:引脚交换后必须做的3项检查(以差分对为例)
  • 招剪辑师没用了!电商视频进入“AI智能体”时代,易元AI让素材生产实现“无人驾驶”
  • Ostrakon-VL 终端 Java 面试题精讲:高并发场景下模型服务调优策略
  • 如何在2025年完美访问Flash内容:CefFlashBrowser完整使用指南
  • 别再傻傻分不清!手把手教你根据引脚丝印识别12864液晶驱动芯片(KS0108/RA6963/RA8816)
  • 不懂时序图?手把手教你用UML画出清晰的系统交互流程(附常见错误避坑指南)
  • 5个高效RAG部署教程:BGE-Reranker-v2-m3免配置一键启动
  • SuperYOLO实战:融合超分与多模态的遥感小目标检测新范式
  • Cursor Pro自动化注册:TempMailPlus智能验证码获取技术深度解析
  • MediaCreationTool.bat:Windows系统部署的自动化解决方案
  • 如何在Linux系统上免费安装Photoshop CC 2022:终极完整指南
  • # 眼动追踪在Python中的实战应用:从数据采集到交互式可视化在现代人机交
  • Claude Code 源码解读 07:插件、Skills 与 MCP——三层扩展体系
  • 为什么你的AI原生项目3年未见正向ROI?SITS2026圆桌深度复盘:从立项到上线的6个ROI漏损黑洞及实时拦截方案
  • Wan2.2-I2V-A14B部署教程:Linux系统下端口映射与远程访问配置
  • DAMO-YOLO TinyNAS模型蒸馏教程:小模型训练指南
  • AMD Ryzen系统调试实战:3大高级策略解决硬件性能瓶颈
  • 用ESP32S3+Arduino搭建智能家居控制中心:从WIFI配置到网页控制全流程
  • 【C】隐式类型转换
  • 通义千问1.5-1.8B-Chat-GPTQ-Int4入门实操:STM32开发基础概念问答
  • Pretext:值得关注的文本排版引擎皆
  • Rust的#[inline(always)]强制内联属性与编译器优化决策的覆盖
  • Waydroid终极加速指南:10倍速度部署Linux上的Android容器
  • 软件竞争管理中的差异化策略
  • Anolis OS 8.6公有云仓库源配置与常见故障排查指南
  • DsHidMini:Windows平台下的虚拟HID驱动架构解析
  • SpaceNet 6 MSAW数据集解析:多传感器融合在建筑足迹提取中的创新应用
  • Java的java.lang.foreign