From 49046125235d11f85ee0dc81f2424f2cde91f1eb Mon Sep 17 00:00:00 2001 From: Yidadaa Date: Mon, 28 Aug 2023 00:50:53 +0800 Subject: [PATCH] feat: close #2430 add a simple user maual --- README.md | 10 ++++ docs/user-manual-cn.md | 101 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 111 insertions(+) create mode 100644 docs/user-manual-cn.md diff --git a/README.md b/README.md index 1662e8c7..5e76e9a7 100644 --- a/README.md +++ b/README.md @@ -257,6 +257,16 @@ If your proxy needs password, use: bash <(curl -s https://raw.githubusercontent.com/Yidadaa/ChatGPT-Next-Web/main/scripts/setup.sh) ``` +## Documentation + +> Please go to the [docs][./docs] directory for more documentation instructions. + +- [Deploy with cloudflare (Deprecated)](./docs/cloudflare-pages-en.md) +- [Frequent Ask Questions](./docs/faq-en.md) +- [How to add a new translation](./docs/translation.md) +- [How to use Vercel (No English)](./docs/vercel-cn.md) +- [User Manual (Only Chinese, WIP)](./docs/user-manual-cn.md) + ## Screenshots ![Settings](./docs/images/settings.png) diff --git a/docs/user-manual-cn.md b/docs/user-manual-cn.md new file mode 100644 index 00000000..883bbc23 --- /dev/null +++ b/docs/user-manual-cn.md @@ -0,0 +1,101 @@ +# 用户手册 User Manual + +> No english version yet, please read this doc with ChatGPT or other translation tools. + +本文档用于解释 ChatGPT Next Web 的部分功能介绍和设计原则。 + +## 面具 (Mask) + +### 什么是面具?它和提示词的区别是什么? + +面具 = 多个预设提示词 + 模型设置 + 对话设置。 + +其中预设提示词(Contextual Prompts)一般用于 In-Context Learning,用于让 ChatGPT 生成更加符合要求的输出,也可以增加系统约束或者输入有限的额外知识。 + +模型设置则顾名思义,使用此面具创建的对话都会默认使用对应的模型参数。 + +对话设置是与对话体验相关的一系列设置,我们会在下方的章节中依次介绍。 + +### 如何添加一个预设面具? + +目前仅能够通过编辑源代码的方式添加预设面具,请根据需要编辑 [mask](../app/masks/) 目录下对应语言的文件即可。 + +编辑步骤如下: + +1. 在 ChatGPT Next Web 中配置好一个面具; +2. 使用面具编辑页面的下载按钮,将面具保存为 JSON 格式; +3. 让 ChatGPT 帮你将 json 文件格式化为对应的 ts 代码; +4. 放入对应的 .ts 文件。 + +后续会增加使用旁加载的方式加载面具。 + +## 对话 (Chat) + +### 对话框上方的按钮的作用 + +在默认状态下,将鼠标移动到按钮上,即可查看按钮的文字说明,我们依次介绍: + +- 对话设置:当前对话的设置,它与全局设置的关系,请查看下一小节的说明; +- 颜色主题:点击即可在自动、暗黑、浅色之间轮换; +- 快捷指令:项目内置的快捷填充预设提示词,也可以在对话框中输入 / 进行搜索; +- 所有面具:进入面具页面; +- 清除聊天:插入一个清除标记,标记上方的聊天将不会发给 GPT,效果相当于清除了当前对话,当然,你也可以再次点击该按钮,可取消清除; +- 模型设置:更改当前对话的模型,注意,此按钮只会修改当前对话的模型,并不会修改全局默认模型。 + +### 对话内设置与全局设置的关系 + +目前有两处设置入口: + +1. 页面左下角的设置按钮,进入后是全局设置页; +2. 对话框上方的设置按钮,进入后是对话设置页。 + +在新建对话后,该对话的设置默认与全局设置保持同步,修改全局设置,则新建对话的对话内设置也会被同步修改。 + +一旦用户手动更改过对话内设置,则对话内设置将与全局设置断开同步,此时更改全局设置,将不会对该对话生效。 + +如果想恢复两者的同步关系,可以将“对话内设置 -> 使用全局设置”选项勾选。 + +### 对话内设置项的含义 + +点开对话框上方的按钮,进入对话内设置,内容从上到下依次为: + +- 预设提示词列表:可以增加、删除、排序预设提示词 +- 角色头像:顾名思义 +- 角色名称:顾名思义 +- 隐藏预设对话:隐藏后,预设提示词不会出现在聊天界面 +- 使用全局设置:用于表示当前对话是否使用全局对话设置 +- 模型设置选项:剩余的选项与全局设置选项含义一致,见下一小节 + +### 全局设置项的含义 + +- model / temperature / top_p / max_tokens / presence_penalty / frequency_penalty 均为 ChatGPT 的设置参数,详情请查阅 OpenAI 官方文档,再次不再赘述; +- 注入系统级提示信息、用户输入预处理:详情请看 [https://github.com/Yidadaa/ChatGPT-Next-Web/issues/2144](https://github.com/Yidadaa/ChatGPT-Next-Web/issues/2144) +- 附带历史消息数:用户每次输入消息并发送时,所携带的最近 n 条消息数量; +- 历史消息长度压缩阈值:当已经产生的聊天字数达到该数值以后,则自动触发历史摘要功能; +- 历史摘要:是否启用历史摘要功能。 + +### 什么是历史摘要? + +历史摘要功能,也是历史消息压缩功能,是保证长对话场景下保持历史记忆的关键,合理使用该功能可以在不丢失历史话题信息的情况下,节省所使用的 token。 + +由于 ChatGPT API 的长度限制,我们以 3.5 模型为例,它只能接受小于 4096 tokens 的对话消息,一旦超出这个数值,就会报错。 + +同时为了让 ChatGPT 理解我们对话的上下文,往往会携带多条历史消息来提供上下文信息,而当对话进行一段时间之后,很容易就会触发长度限制。 + +为了解决此问题,我们增加了历史记录压缩功能,假设阈值为 1000 字符,那么每次用户产生的聊天记录超过 1000 字符时,都会将没有被总结过的消息,发送给 ChatGPT,让其产生一个 100 字所有的摘要。 + +这样,历史信息就从 1000 字压缩到了 100 字,这是一种有损压缩,但已能满足大多数使用场景。 + +### 什么时候应该关闭历史摘要? + +历史摘要可能会影响 ChatGPT 的对话质量,所以如果对话场景是翻译、信息提取等一次性对话场景,请直接关闭历史摘要功能,并将历史消息数设置为 0。 + +### 当用户发送一条消息时,有哪些信息被发送出去了? + +当用户在对话框输入了一条消息后,发送给 ChatGPT 的消息,包含以下几个部分: + +1. 系统级提示词:用于尽可能贴近 ChatGPT 官方 WebUI 的使用体验,可在设置中关闭此信息; +2. 历史摘要:作为长期记忆,提供长久但模糊的上下文信息; +3. 预设提示词:当前对话内设置的预设提示词,用于 In-Context Learning 或者注入系统级限制; +4. 最近 n 条对话记录:作为短期记忆,提供短暂但精确的上下文信息; +5. 用户当前输入的消息。