Zulelee commited on
Commit
205a2cd
1 Parent(s): f94c50d

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +6 -199
README.md CHANGED
@@ -1,200 +1,7 @@
1
- ![](img/logo-long-chatchat-trans-v2.png)
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
- * [介绍](README.md#介绍)
17
- * [解决的痛点](README.md#解决的痛点)
18
- * [快速上手](README.md#快速上手)
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
- ![实现原理图](img/langchain+chatglm.png)
48
-
49
- 从文档处理角度来看,实现流程如下:
50
-
51
- ![实现原理图2](img/langchain+chatglm2.png)
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
- ![](img/fastapi_docs_026.png)
152
-
153
- 2. Web UI 启动界面示例:
154
-
155
- - Web UI 对话界面:
156
-
157
- ![img](img/LLM_success.png)
158
-
159
- - Web UI 知识库管理页面:
160
-
161
- ![](img/init_knowledge_base.jpg)
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
- [![Telegram](https://img.shields.io/badge/Telegram-2CA5E0?style=for-the-badge&logo=telegram&logoColor=white "langchain-chatglm")](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
+ ---