在基础示例中,我们使用了一个messages
列表(第二行代码),来作为“提示”,去传递给大模型处理。
可以看出,这个列表中包括SystemMessage
和HumanMessage
两个元素。实际上这两个元素其实是对一个完整的提示进行的一种分解,体现出了类似于基于不同的身份所提出的不同要求:
SystemMessage
是站在对模型进行设定的角度,告诉模型需要它完成一个什么样的任务。
HumanMessage
是站在用户使用的角度,告诉模型用户输入了什么与完成这个任务相关的补充内容。
但总的来说,上述方式是直接手工将具体的指令写好,然后传给模型处理。
事实上,如果需要模型完成的任务非常标准化,或者说指令的大部分要素都是固定的,只需要根据需要调整其中的小部分要求。
比如,“翻译”是一个标准的任务,翻成意大利语还是汉语,这个可以调整。
那么,我们就可以考虑设计一个提示模板(Prompt Templates),把常规的指令固定下来,把灵活的部分留空待填即可。
接下来,我们就来看看如何在LangChain中,用构造好的,标准化的提示模板,来向模型下达指令,具体步骤如下:
1.引入模块
from langchain_core.prompts import ChatPromptTemplate
ChatPromptTemplate
是一个提示模板类,用于构建对话模型的输入结构。我们可以用它来定义对话中不同角色的对话模式。
2.创建提示模板的主要内容
首先,对原来的SystemMessage
进行标准化、格式化,即使用一个system_template
变量来储存与任务设定相关的字符串信息。(即示例中的翻译任务)
注意,{language}
为占位符形式,意味着后续可以对该部分进行调整。
然后,第二行代码通过from_messages
方法来创建提示模板实例并赋值给prompt_template
。可以看出,我们向from_messages
传入的参数也是一个列表,这个列表包括多个元组,每个元组表示一个角色和对应的消息模板。
至此,一个提示模板prompt_template
就创建完成了。
3.使用提示模板
result = prompt_template.invoke({"language": "italian", "text": "hi"})
result.to_messages()
那么如何使用提示模板呢?
首先,仍然是用invoke
方法去处理模板信息,这时需传入一个字典结构的参数,可以看出,这个字典的键,就是我们在模版中用占位符设定的内容,而键值,就是我们根据需要输入的内容。
然后,利用to_messages
方法,我们就可以把大模型处理提示模板后的信息,转化成类似本文开篇部分我们直接输入提示的样子。
也就是说,如果把result.to_messages()
打印出来,我们就可以获得一个内容为这样的列表对象。
[SystemMessage(content='Translate the following into italian:'),
HumanMessage(content='hi')]
可以看出,这个对象的内容跟本文开篇部分的messages
列表,是一模一样的。
4.Chain起来
同样的,我们也可以用|
操作符把prompt_template
加到chain中,通过调用chain来指挥模型,具体代码如下:
chain = prompt_template | model | parser
chain.invoke({"language": "italian", "text": "hi"})
如何学习AI大模型?
作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。
这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
一、全套AGI大模型学习路线
AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!
二、640套AI大模型报告合集
这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。
三、AI大模型经典PDF籍
随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。
四、AI大模型商业化落地方案
作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量。