跳到主要内容
Open on GitHub

聊天历史

聊天记录是用户与聊天模型之间对话的记录。它用于在整个对话中保持上下文和状态。聊天记录是消息的序列,每条消息都与特定的角色相关联,例如“用户”、“助手”、“系统”或“工具”。

对话模式

Conversation patterns

大多数对话以设置对话上下文的系统消息开始。然后是包含用户输入的用户消息,以及包含模型响应的助手消息

助手可以直接回复用户,或者如果配置了工具,则会请求调用工具来执行特定任务。

一个完整的对话通常涉及两种交替消息模式的组合

  1. 用户助手代表来回对话。
  2. 助手工具消息代表一种“代理式”工作流,其中助手正在调用工具来执行特定任务。

管理聊天记录

由于聊天模型对输入大小有最大限制,因此管理聊天记录并根据需要进行裁剪以避免超出上下文窗口非常重要。

在处理聊天记录时,保持正确的对话结构至关重要。

管理聊天记录的关键准则

  • 对话应遵循以下结构之一
    • 第一条消息是“用户”消息或“系统”消息,然后是“用户”消息,再是“助手”消息。
    • 最后一条消息应是“用户”消息或包含工具调用结果的“工具”消息。
  • 当使用工具调用时,“工具”消息只能跟在请求工具调用的“助手”消息之后。
提示

理解正确的对话结构对于在聊天模型中正确实现内存至关重要。