聊天记录
聊天记录是用户和聊天模型之间对话的记录。它用于在整个对话过程中保持上下文和状态。聊天记录是消息的序列,每条消息都与特定的角色相关联,例如“用户”、“助手”、“系统”或“工具”。
对话模式
大多数对话都以设置对话上下文的系统消息开始。然后是包含用户输入的用户消息,然后是包含模型响应的助手消息。
助手可以直接回复用户,或者如果配置了工具,则请求调用工具来执行特定任务。
完整的对话通常涉及两种交替消息模式的组合
- 用户和助手表示来回对话。
- 助手和工具消息表示“代理式”工作流程,其中助手调用工具来执行特定任务。
管理聊天记录
由于聊天模型对输入大小有最大限制,因此管理聊天记录并在需要时修剪它以避免超出上下文窗口非常重要。
在处理聊天记录时,必须保留正确的对话结构。
管理聊天记录的关键准则
- 对话应遵循以下结构之一
- 第一条消息必须是“user”消息或“system”消息,之后紧跟着一条“user”消息,然后再是一条“assistant”消息。
- 最后一条消息应该是“user”消息或包含工具调用结果的“tool”消息。
- 当使用工具调用时,“tool”消息只能紧跟请求工具调用的“assistant”消息之后。
提示
理解正确的对话结构对于在聊天模型中正确实现记忆至关重要。