Project Icon

chatgpt-memory

基于 GPT 和 Redis 的多会话智能对话系统

ChatGPT Memory 项目利用 GPT 和 Redis 技术构建了一个支持多会话的智能对话系统。该系统能够同时处理多个对话,并为每个会话维护连贯的上下文。通过 Redis 存储对话历史,结合嵌入和相似性搜索技术,实现了高效的记忆检索功能。项目提供了完整的代码示例和用户界面,便于开发者快速部署具有长期记忆能力的 AI 对话应用。

本仓库的开发已停止。请查看 OpenAI 的检索插件:https://github.com/openai/chatgpt-retrieval-plugin

ChatGPT 记忆

允许将 ChatGPT API 扩展到多个同时进行的会话,通过 GPT 和 Redis 数据存储提供无限的上下文和自适应记忆。这可以通过以下方式可视化:



入门指南

  1. 这里创建你的免费 Redis 数据存储。
  2. 这里获取你的 OpenAI API 密钥。
  3. 使用 poetry 安装依赖。
poetry install

使用 UI

Screenshot 2023-04-17 at 10 26 59 PM

启动 FastAPI 网络服务器。

poetry run uvicorn rest_api:app --host 0.0.0.0 --port 8000

运行 UI。

poetry run streamlit run ui.py

在终端中使用

该库高度模块化。以下我们将描述每个组件的使用(如上图所示)。

首先,在运行脚本之前设置所需的环境变量。这是可选的,但建议这样做。 你可以使用 .env 文件来完成此操作。请参阅 .env.example 文件作为示例。

from chatgpt_memory.environment import OPENAI_API_KEY, REDIS_HOST, REDIS_PASSWORD, REDIS_PORT

使用 RedisDataStoreConfig 配置创建 RedisDataStore 类的实例。

from chatgpt_memory.datastore import RedisDataStoreConfig, RedisDataStore

redis_datastore_config = RedisDataStoreConfig(
    host=REDIS_HOST,
    port=REDIS_PORT,
    password=REDIS_PASSWORD,
)
redis_datastore = RedisDataStore(config=redis_datastore_config)

使用 EmbeddingConfig 配置创建 EmbeddingClient 类的实例。

from chatgpt_memory.llm_client import EmbeddingConfig, EmbeddingClient

embedding_config = EmbeddingConfig(api_key=OPENAI_API_KEY)
embed_client = EmbeddingClient(config=embedding_config)

使用 Redis 数据存储和 Embedding 客户端实例以及 topk 值创建 MemoryManager 类的实例。

from chatgpt_memory.memory.manager import MemoryManager

memory_manager = MemoryManager(datastore=redis_datastore, embed_client=embed_client, topk=1)

使用 ChatGPTConfig 配置和 MemoryManager 实例创建 ChatGPTClient 类的实例。

from chatgpt_memory.llm_client import ChatGPTClient, ChatGPTConfig

chat_gpt_client = ChatGPTClient(
    config=ChatGPTConfig(api_key=OPENAI_API_KEY, verbose=True), memory_manager=memory_manager
)

通过向 ChatGPTClient 实例的 converse 方法提供用户消息来开始对话。

conversation_id = None
while True:
    user_message = input("\n 请输入您的消息:")
    response = chat_gpt_client.converse(message=user_message, conversation_id=conversation_id)
    conversation_id = response.conversation_id
    print(response.chat_gpt_answer)

这将允许你与 AI 助手交谈,并通过使用外部 Redis 数据存储来扩展其记忆。

整合在一起

以下是上述所有内容的整合。你也可以在 examples/simple_usage.py 中找到它。

## 在运行此脚本之前设置以下环境变量
# 导入必要的模块
from chatgpt_memory.environment import OPENAI_API_KEY, REDIS_HOST, REDIS_PASSWORD, REDIS_PORT
from chatgpt_memory.datastore import RedisDataStoreConfig, RedisDataStore
from chatgpt_memory.llm_client import ChatGPTClient, ChatGPTConfig, EmbeddingConfig, EmbeddingClient
from chatgpt_memory.memory import MemoryManager

# 使用 OpenAI API 密钥实例化 EmbeddingConfig 对象
embedding_config = EmbeddingConfig(api_key=OPENAI_API_KEY)

# 使用 EmbeddingConfig 对象实例化 EmbeddingClient 对象
embed_client = EmbeddingClient(config=embedding_config)

# 使用 Redis 连接详细信息实例化 RedisDataStoreConfig 对象
redis_datastore_config = RedisDataStoreConfig(
    host=REDIS_HOST,
    port=REDIS_PORT,
    password=REDIS_PASSWORD,
)

# 使用 RedisDataStoreConfig 对象实例化 RedisDataStore 对象
redis_datastore = RedisDataStore(config=redis_datastore_config)

# 使用 RedisDataStore 对象和 EmbeddingClient 对象实例化 MemoryManager 对象
memory_manager = MemoryManager(datastore=redis_datastore, embed_client=embed_client, topk=1)

# 使用 OpenAI API 密钥和 verbose 设置为 True 实例化 ChatGPTConfig 对象
chat_gpt_config = ChatGPTConfig(api_key=OPENAI_API_KEY, verbose=True)

# 使用 ChatGPTConfig 对象和 MemoryManager 对象实例化 ChatGPTClient 对象
chat_gpt_client = ChatGPTClient(
    config=chat_gpt_config,
    memory_manager=memory_manager
)

# 将 conversation_id 初始化为 None
conversation_id = None

# 开始聊天机器人循环
while True:
    # 提示用户输入
    user_message = input("\n 请输入您的消息:")

    # 使用 ChatGPTClient 对象生成响应
    response = chat_gpt_client.converse(message=user_message, conversation_id=conversation_id)

    # 使用响应中的 conversation_id 更新 conversation_id
    conversation_id = response.conversation_id

    # 打印聊天机器人生成的响应
    print(response.chat_gpt_answer)

致谢

UI 的添加要感谢 avrabyt/MemoryBot 的出色工作。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号