Spaces:
Running
Running
Update README.md
Browse files
README.md
CHANGED
|
@@ -1,200 +1,7 @@
|
|
| 1 |
-

|
| 2 |
-
|
| 3 |
-
🌍 [READ THIS IN ENGLISH](README_en.md)
|
| 4 |
-
🌍 [日本語で読む](README_ja.md)
|
| 5 |
-
|
| 6 |
-
📃 **LangChain-Chatchat** (原 Langchain-ChatGLM)
|
| 7 |
-
|
| 8 |
-
基于 ChatGLM 等大语言模型与 Langchain 等应用框架实现,开源、可离线部署的检索增强生成(RAG)大模型知识库项目。
|
| 9 |
-
|
| 10 |
-
⚠️`0.2.10`将会是`0.2.x`系列的最后一个版本,`0.2.x`系列版本将会停止更新和技术支持,全力研发具有更强应用性的 `Langchain-Chatchat 0.3.x`。
|
| 11 |
-
|
| 12 |
---
|
| 13 |
-
|
| 14 |
-
|
| 15 |
-
|
| 16 |
-
|
| 17 |
-
|
| 18 |
-
|
| 19 |
-
* [1. 环境配置](README.md#1-环境配置)
|
| 20 |
-
* [2. 模型下载](README.md#2-模型下载)
|
| 21 |
-
* [3. 初始化知识库和配置文件](README.md#3-初始化知识库和配置文件)
|
| 22 |
-
* [4. 一键启动](README.md#4-一键启动)
|
| 23 |
-
* [5. 启动界面示例](README.md#5-启动界面示例)
|
| 24 |
-
* [联系我们](README.md#联系我们)
|
| 25 |
-
|
| 26 |
-
## 介绍
|
| 27 |
-
|
| 28 |
-
🤖️ 一种利用 [langchain](https://github.com/langchain-ai/langchain)
|
| 29 |
-
思想实现的基于本地知识库的问答应用,目标期望建立一套对中文场景与开源模型支持友好、可离线运行的知识库问答解决方案。
|
| 30 |
-
|
| 31 |
-
💡 受 [GanymedeNil](https://github.com/GanymedeNil) 的项目 [document.ai](https://github.com/GanymedeNil/document.ai)
|
| 32 |
-
和 [AlexZhangji](https://github.com/AlexZhangji)
|
| 33 |
-
创建的 [ChatGLM-6B Pull Request](https://github.com/THUDM/ChatGLM-6B/pull/216)
|
| 34 |
-
启发,建立了全流程可使用开源模型实现的本地知识库问答应用。本项目的最新版本中通过使用 [FastChat](https://github.com/lm-sys/FastChat)
|
| 35 |
-
接入 Vicuna, Alpaca, LLaMA, Koala, RWKV 等模型,依托于 [langchain](https://github.com/langchain-ai/langchain)
|
| 36 |
-
框架支持通过基于 [FastAPI](https://github.com/tiangolo/fastapi) 提供的 API
|
| 37 |
-
调用服务,或使用基于 [Streamlit](https://github.com/streamlit/streamlit) 的 WebUI 进行操作。
|
| 38 |
-
|
| 39 |
-
✅ 依托于本项目支持的开源 LLM 与 Embedding 模型,本项目可实现全部使用**开源**模型**离线私有部署**。与此同时,本项目也支持
|
| 40 |
-
OpenAI GPT API 的调用,并将在后续持续扩充对各类模型及模型 API 的接入。
|
| 41 |
-
|
| 42 |
-
⛓️ 本项目实现原理如下图所示,过程包括加载文件 -> 读取文本 -> 文本分割 -> 文本向量化 -> 问句向量化 ->
|
| 43 |
-
在文本向量中匹配出与问句向量最相似的 `top k`个 -> 匹配出的文本作为上下文和问题一起添加到 `prompt`中 -> 提交给 `LLM`生成回答。
|
| 44 |
-
|
| 45 |
-
📺 [原理介绍视频](https://www.bilibili.com/video/BV13M4y1e7cN/?share_source=copy_web&vd_source=e6c5aafe684f30fbe41925d61ca6d514)
|
| 46 |
-
|
| 47 |
-

|
| 48 |
-
|
| 49 |
-
从文档处理角度来看,实现流程如下:
|
| 50 |
-
|
| 51 |
-

|
| 52 |
-
|
| 53 |
-
🚩 本项目未涉及微调、训练过程,但可利用微调或训练对本项目效果进行优化。
|
| 54 |
-
|
| 55 |
-
🌐 [AutoDL 镜像](https://www.codewithgpu.com/i/chatchat-space/Langchain-Chatchat/Langchain-Chatchat) 中 `v0.2.10`
|
| 56 |
-
版本所使用代码已更新至本项目 `v0.2.10` 版本。
|
| 57 |
-
|
| 58 |
-
🐳 [Docker 镜像](registry.cn-beijing.aliyuncs.com/chatchat/chatchat:0.2.6) 已经更新到 ```0.2.7``` 版本。
|
| 59 |
-
|
| 60 |
-
🌲 一行命令运行 Docker :
|
| 61 |
-
|
| 62 |
-
```shell
|
| 63 |
-
docker run -d --gpus all -p 80:8501 registry.cn-beijing.aliyuncs.com/chatchat/chatchat:0.2.7
|
| 64 |
-
```
|
| 65 |
-
|
| 66 |
-
🧩 本项目有一个非常完整的[Wiki](https://github.com/chatchat-space/Langchain-Chatchat/wiki/) , README只是一个简单的介绍,_
|
| 67 |
-
_仅仅是入门教程,能够基础运行__。
|
| 68 |
-
如果你想要更深入的了解本项目,或者想对本项目做出贡献。请移步 [Wiki](https://github.com/chatchat-space/Langchain-Chatchat/wiki/)
|
| 69 |
-
界面
|
| 70 |
-
|
| 71 |
-
## 解决的痛点
|
| 72 |
-
|
| 73 |
-
该项目是一个可以实现 __完全本地化__推理的知识库增强方案, 重点解决数据安全保护,私域化部署的企业痛点。
|
| 74 |
-
本开源方案采用```Apache License```,可以免费商用,无需付费。
|
| 75 |
-
|
| 76 |
-
我们支持市面上主流的本地大语言模型和Embedding模型,支持开源的本地向量数据库。
|
| 77 |
-
支持列表详见[Wiki](https://github.com/chatchat-space/Langchain-Chatchat/wiki/)
|
| 78 |
-
|
| 79 |
-
## 快速上手
|
| 80 |
-
|
| 81 |
-
### 1. 环境配置
|
| 82 |
-
|
| 83 |
-
+ 首先,确保你的机器安装了 Python 3.8 - 3.11 (我们强烈推荐使用 Python3.11)。
|
| 84 |
-
|
| 85 |
-
```
|
| 86 |
-
$ python --version
|
| 87 |
-
Python 3.11.7
|
| 88 |
-
```
|
| 89 |
-
|
| 90 |
-
接着,创建一个虚拟环境,并在虚拟环境内安装项目的依赖
|
| 91 |
-
|
| 92 |
-
```shell
|
| 93 |
-
|
| 94 |
-
# 拉取仓库
|
| 95 |
-
$ git clone https://github.com/chatchat-space/Langchain-Chatchat.git
|
| 96 |
-
|
| 97 |
-
# 进入目录
|
| 98 |
-
$ cd Langchain-Chatchat
|
| 99 |
-
|
| 100 |
-
# 安装全部依赖
|
| 101 |
-
$ pip install -r requirements.txt
|
| 102 |
-
$ pip install -r requirements_api.txt
|
| 103 |
-
$ pip install -r requirements_webui.txt
|
| 104 |
-
|
| 105 |
-
# 默认依赖包括基本运行环境(FAISS向量库)。如果要使用 milvus/pg_vector 等向量库,请将 requirements.txt 中相应依赖取消注释再安装。
|
| 106 |
-
```
|
| 107 |
-
|
| 108 |
-
请注意,LangChain-Chatchat `0.2.x` 系列是针对 Langchain `0.0.x` 系列版本的,如果你使用的是 Langchain `0.1.x`
|
| 109 |
-
系列版本,需要降级您的`Langchain`版本。
|
| 110 |
-
|
| 111 |
-
### 2, 模型下载
|
| 112 |
-
|
| 113 |
-
如需在本地或离线环境下运行本项目,需要首先将项目所需的模型下载至本地,通常开源 LLM 与 Embedding
|
| 114 |
-
模型可以从 [HuggingFace](https://huggingface.co/models) 下载。
|
| 115 |
-
|
| 116 |
-
以本项目中默认使用的 LLM 模型 [THUDM/ChatGLM3-6B](https://huggingface.co/THUDM/chatglm3-6b) 与 Embedding
|
| 117 |
-
模型 [BAAI/bge-large-zh](https://huggingface.co/BAAI/bge-large-zh) 为例:
|
| 118 |
-
|
| 119 |
-
下载模型需要先[安装 Git LFS](https://docs.github.com/zh/repositories/working-with-files/managing-large-files/installing-git-large-file-storage)
|
| 120 |
-
,然后运行
|
| 121 |
-
|
| 122 |
-
```Shell
|
| 123 |
-
$ git lfs install
|
| 124 |
-
$ git clone https://huggingface.co/THUDM/chatglm3-6b
|
| 125 |
-
$ git clone https://huggingface.co/BAAI/bge-large-zh
|
| 126 |
-
```
|
| 127 |
-
|
| 128 |
-
### 3. 初始化知识库和配置文件
|
| 129 |
-
|
| 130 |
-
按照下列方式初始化自己的知识库和简单的复制配置文件
|
| 131 |
-
|
| 132 |
-
```shell
|
| 133 |
-
$ python copy_config_example.py
|
| 134 |
-
$ python init_database.py --recreate-vs
|
| 135 |
-
```
|
| 136 |
-
|
| 137 |
-
### 4. 一键启动
|
| 138 |
-
|
| 139 |
-
按照以下命令启动项目
|
| 140 |
-
|
| 141 |
-
```shell
|
| 142 |
-
$ python startup.py -a
|
| 143 |
-
```
|
| 144 |
-
|
| 145 |
-
### 5. 启动界面示例
|
| 146 |
-
|
| 147 |
-
如果正常启动,你将能看到以下界面
|
| 148 |
-
|
| 149 |
-
1. FastAPI Docs 界面
|
| 150 |
-
|
| 151 |
-

|
| 152 |
-
|
| 153 |
-
2. Web UI 启动界面示例:
|
| 154 |
-
|
| 155 |
-
- Web UI 对话界面:
|
| 156 |
-
|
| 157 |
-

|
| 158 |
-
|
| 159 |
-
- Web UI 知识库管理页面:
|
| 160 |
-
|
| 161 |
-

|
| 162 |
-
|
| 163 |
-
### 注意
|
| 164 |
-
|
| 165 |
-
以上方式只是为了快速上手,如果需要更多的功能和自定义启动方式
|
| 166 |
-
,请参考[Wiki](https://github.com/chatchat-space/Langchain-Chatchat/wiki/)
|
| 167 |
-
|
| 168 |
-
|
| 169 |
-
---
|
| 170 |
-
|
| 171 |
-
## 项目里程碑
|
| 172 |
-
|
| 173 |
-
+ `2023年4月`: `Langchain-ChatGLM 0.1.0` 发布,支持基于 ChatGLM-6B 模型的本地知识库问答。
|
| 174 |
-
+ `2023年8月`: `Langchain-ChatGLM` 改名为 `Langchain-Chatchat`,`0.2.0` 发布,使用 `fastchat` 作为模型加载方案,支持更多的模型和数据库。
|
| 175 |
-
+ `2023年10月`: `Langchain-Chatchat 0.2.5` 发布,推出 Agent 内容,开源项目在`Founder Park & Zhipu AI & Zilliz`
|
| 176 |
-
举办的黑客马拉松获得三等奖。
|
| 177 |
-
+ `2023年12月`: `Langchain-Chatchat` 开源项目获得超过 **20K** stars.
|
| 178 |
-
+ `2024年1月`: `LangChain 0.1.x` 推出,`Langchain-Chatchat 0.2.x` 发布稳定版本`0.2.10`
|
| 179 |
-
后将停止更新和技术支持,全力研发具有更强应用性的 `Langchain-Chatchat 0.3.x`。
|
| 180 |
-
|
| 181 |
-
+ 🔥 让我们一起期待未来 Chatchat 的故事 ···
|
| 182 |
-
|
| 183 |
-
---
|
| 184 |
-
|
| 185 |
-
## 联系我们
|
| 186 |
-
|
| 187 |
-
### Telegram
|
| 188 |
-
|
| 189 |
-
[](https://t.me/+RjliQ3jnJ1YyN2E9)
|
| 190 |
-
|
| 191 |
-
### 项目交流群
|
| 192 |
-
<img src="img/qr_code_88.jpg" alt="二维码" width="300" />
|
| 193 |
-
|
| 194 |
-
🎉 Langchain-Chatchat 项目微信交流群,如果你也对本项目感兴趣,欢迎加入群聊参与讨论交流。
|
| 195 |
-
|
| 196 |
-
### 公众号
|
| 197 |
-
|
| 198 |
-
<img src="img/official_wechat_mp_account.png" alt="二维码" width="300" />
|
| 199 |
-
|
| 200 |
-
🎉 Langchain-Chatchat 项目官方公众号,欢迎扫码关注。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
---
|
| 2 |
+
sdk: streamlit
|
| 3 |
+
title: chathchat
|
| 4 |
+
emoji: 🐨
|
| 5 |
+
colorFrom: blue
|
| 6 |
+
colorTo: purple
|
| 7 |
+
---
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|