fb700 commited on
Commit
2323c39
1 Parent(s): 5b7eb6b

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +129 -73
README.md CHANGED
@@ -3,87 +3,143 @@ language:
3
  - zh
4
  - en
5
  tags:
6
- - glm
7
- - chatglm
8
- - thudm
 
 
 
 
 
 
 
 
9
  ---
10
- # ChatGLM-6B
11
- <p align="center">
12
- 🌐 <a href="https://chatglm.cn/blog" target="_blank">Blog</a> • 💻 <a href="https://github.com/THUDM/ChatGLM-6B" target="_blank">Github Repo</a> • 🐦 <a href="https://twitter.com/thukeg" target="_blank">Twitter</a> • 📃 <a href="https://arxiv.org/abs/2103.10360" target="_blank">[GLM@ACL 22]</a> <a href="https://github.com/THUDM/GLM" target="_blank">[GitHub]</a> • 📃 <a href="https://arxiv.org/abs/2210.02414" target="_blank">[GLM-130B@ICLR 23]</a> <a href="https://github.com/THUDM/GLM-130B" target="_blank">[GitHub]</a> <br>
13
- </p>
14
 
15
- <p align="center">
16
- 👋 Join our <a href="https://join.slack.com/t/chatglm/shared_invite/zt-1udqapmrr-ocT1DS_mxWe6dDY8ahRWzg" target="_blank">Slack</a> and <a href="https://github.com/THUDM/ChatGLM-6B/blob/main/resources/WECHAT.md" target="_blank">WeChat</a>
17
- </p>
18
-
19
- ## 介绍
20
- ChatGLM-6B 是一个开源的、支持中英双语问答的对话语言模型,基于 [General Language Model (GLM)](https://github.com/THUDM/GLM) 架构,具有 62 亿参数。结合模型量化技术,用户可以在消费级的显卡上进行本地部署(INT4 量化级别下最低只需 6GB 显存)。ChatGLM-6B 使用了和 [ChatGLM](https://chatglm.cn) 相同的技术,针对中文问答和对话进行了优化。经过约 1T 标识符的中英双语训练,辅以监督微调、反馈自助、人类反馈强化学习等技术的加持,62 亿参数的 ChatGLM-6B 已经能生成相当符合人类偏好的回答。
21
-
22
- ChatGLM-6B is an open bilingual language model based on [General Language Model (GLM)](https://github.com/THUDM/GLM) framework, with 6.2 billion parameters. With the quantization technique, users can deploy locally on consumer-grade graphics cards (only 6GB of GPU memory is required at the INT4 quantization level). ChatGLM-6B uses technology similar to ChatGPT, optimized for Chinese QA and dialogue. The model is trained for about 1T tokens of Chinese and English corpus, supplemented by supervised fine-tuning, feedback bootstrap, and reinforcement learning wit human feedback. With only about 6.2 billion parameters, the model is able to generate answers that are in line with human preference.
23
-
24
- ## 软件依赖
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
25
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
26
  ```shell
27
- pip install protobuf==3.20.0 transformers==4.27.1 icetk cpm_kernels
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
28
  ```
29
 
30
- ## 代码调用
31
-
32
- 可以通过如下代码调用 ChatGLM-6B 模型来生成对话:
33
-
34
- ```ipython
35
- >>> from transformers import AutoTokenizer, AutoModel
36
- >>> tokenizer = AutoTokenizer.from_pretrained("THUDM/chatglm-6b", trust_remote_code=True)
37
- >>> model = AutoModel.from_pretrained("THUDM/chatglm-6b", trust_remote_code=True).half().cuda()
38
- >>> response, history = model.chat(tokenizer, "你好", history=[])
39
- >>> print(response)
40
- 你好👋!我是人工智能助手 ChatGLM-6B,很高兴见到你,欢迎问我任何问题。
41
- >>> response, history = model.chat(tokenizer, "晚上睡不着应该怎么办", history=history)
42
- >>> print(response)
43
- 晚上睡不着可能会让你感到焦虑或不舒服,但以下是一些可以帮助你入睡的方法:
44
-
45
- 1. 制定规律的睡眠时间表:保持规律的睡眠时间表可以帮助你建立健康的睡眠习惯,使你更容易入睡。尽量在每天的相同时间上床,并在同一时间起床。
46
- 2. 创造一个舒适的睡眠环境:确保睡眠环境舒适,安静,黑暗且温度适宜。可以使用舒适的床上用品,并保持房间通风。
47
- 3. 放松身心:在睡前做些放松的活动,例如泡个热水澡,听些轻柔的音乐,阅读一些有趣的书籍等,有助于缓解紧张和焦虑,使你更容易入睡。
48
- 4. 避免饮用含有咖啡因的饮料:咖啡因是一种刺激性物质,会影响你的睡眠质量。尽量避免在睡前饮用含有咖啡因的饮料,例如咖啡,茶和可乐。
49
- 5. 避免在床上做与睡眠无关的事情:在床上做些与睡眠无关的事情,例如看电影,玩游戏或工作等,可能会干扰你的睡眠。
50
- 6. 尝试呼吸技巧:深呼吸是一种放松技巧,可以帮助你缓解紧张和焦虑,使你更容易入睡。试着慢慢吸气,保持几秒钟,然后缓慢呼气。
51
-
52
- 如果这些方法无法帮助你入睡,你可以考虑咨询医生或睡眠专家,寻求进一步的建议。
53
  ```
54
-
55
- 关于更多的使用说明,包括如何运行命令行和网页版本的 DEMO,以及使用模型量化以节省显存,请参考我们的 [Github Repo](https://github.com/THUDM/ChatGLM-6B)。
56
-
57
- For more instructions, including how to run CLI and web demos, and model quantization, please refer to our [Github Repo](https://github.com/THUDM/ChatGLM-6B).
58
-
59
- ## Change Log
60
- * v1.1.0 ([942945d](https://huggingface.co/THUDM/chatglm-6b/commit/942945df047dee66f653c68ae0e56655045f1741)): 更新 v1.1 版本 checkpoint
61
- * v0.1.0 ([f831824](https://huggingface.co/THUDM/chatglm-6b/commit/f83182484538e663a03d3f73647f10f89878f438))
62
-
63
- ## 协议
64
-
65
- 本仓库的代码依照 [Apache-2.0](LICENSE) 协议开源,ChatGLM-6B 模型的权重的使用则需要遵循 [Model License](MODEL_LICENSE)。
66
-
67
- ## 引用
68
-
69
- 如果你觉得我们的工作有帮助的话,请考虑引用下列论文:
70
-
71
  ```
72
- @inproceedings{
73
- zeng2023glm-130b,
74
- title={{GLM}-130B: An Open Bilingual Pre-trained Model},
75
- author={Aohan Zeng and Xiao Liu and Zhengxiao Du and Zihan Wang and Hanyu Lai and Ming Ding and Zhuoyi Yang and Yifan Xu and Wendi Zheng and Xiao Xia and Weng Lam Tam and Zixuan Ma and Yufei Xue and Jidong Zhai and Wenguang Chen and Zhiyuan Liu and Peng Zhang and Yuxiao Dong and Jie Tang},
76
- booktitle={The Eleventh International Conference on Learning Representations (ICLR)},
77
- year={2023},
78
- url={https://openreview.net/forum?id=-Aw0rrrPUF}
79
- }
80
  ```
 
 
81
  ```
82
- @inproceedings{du2022glm,
83
- title={GLM: General Language Model Pretraining with Autoregressive Blank Infilling},
84
- author={Du, Zhengxiao and Qian, Yujie and Liu, Xiao and Ding, Ming and Qiu, Jiezhong and Yang, Zhilin and Tang, Jie},
85
- booktitle={Proceedings of the 60th Annual Meeting of the Association for Computational Linguistics (Volume 1: Long Papers)},
86
- pages={320--335},
87
- year={2022}
88
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
89
  ```
 
3
  - zh
4
  - en
5
  tags:
6
+ - chatglm-6b
7
+ - chatglm2-6b
8
+ - pytorch
9
+ - peft
10
+ - ft
11
+ - sft
12
+ - PPO
13
+ - RLHF
14
+ - RM
15
+ - Transformers
16
+ license: "apache-2.0"
17
  ---
 
 
 
 
18
 
19
+ # 重磅消息
20
+ - 本项目经过多位网友实测,中文总结能力超越了GPT3.5各版本,健康咨询水平在同参数规模模型也出类拔萃,可能是任何个人和中下企业首选模型。
21
+ # 重大突破
22
+ - 经优化目前可以支持无限context,远大于4k、8K、16K......
23
+ # ChatGLM-6B RLHF & LoRA Model
24
+
25
+ ChatGLM-6B 是开源中英双语对话模型,本次训练基于ChatGLM-6B 的第一代版本,在保留了初代模型对话流畅、部署门槛较低等众多优秀特性的基础之上开展训练。通过训练我们对模型有了更深刻的认知,LLM在一直在进化,好的方法和数据可以挖掘出模型的更大潜能。
26
+ ## 本次训练使用的方法
27
+
28
+ - 首先,用40万条高质量数据进行强化训练,以提高模型的基础能力;
29
+ - 第二,使用30万条人类反馈数据,构建一个表达方式规范优雅的语言模式(RM模型);
30
+ - 第三,在保留SFT阶段三分之一训练数据的同时,增加了30万条fitness数据,叠加RM模型,对ChatGLM-6B进行强化训练。
31
+ - 成果,训练后在健康咨询,文档总结能力上不但强于chatglm-6b,而且部分能力上更是强于chatglm2-6b,配合“闻达”和“langchain-chatglm”等知识库项目,应用体验上对比chatglm-6b、chatglm2-6b和百川-7b均匀显著提升。
32
+ - 性能,fp16运行时速度上比原模型提升20%.可以代替原有官方模型,大家可以fp16、int4、int8使用。
33
+ - 兼容性,本项目全模型的运行方式与原模型一致。lora文件运行方式,建议在原模型chatglm-6b上运行,在chatglm2-6b上可以正常加载但不推荐,只有当上下文大于4k时在chatglm2-6b上运行有一定价值,经(网友:大笨熊)测试有一定效果,但是效果不能完全发挥。
34
+ - 特性,基于模型对自然对话的超强理解力和总结能力,连续会话不受tokens限制,支持无限轮次的智能对话。
35
+ - 协议
36
+ - 本仓库的代码依照 Apache-2.0 协议开源,ChatGLM2-6B 模型的权重的使用则需要遵循 Model License。
37
+ - 授权方式,与原项目一致,未经过chatglm-6b原开发方允许,不得用于商业用途。详细见原项目相关规定,模型地址https://huggingface.co/THUDM/chatglm-6b
38
+ - 本次训练由智能AI用户[帛凡]于2023年基于ChatGLM-6b进行独立完成。(严禁售卖或者商业项目,任何通过此项目产生的知识仅用于参考,作者不承担任何责任)。
39
+ - 百度网盘 https://pan.baidu.com/s/1l9q_7h8nGdelIwYlCbllMg?pwd=klhu (感谢网友 :宋小猫 提供分享)
40
+ - 夸克网盘 https://pan.quark.cn/s/d947c6dbf592
41
+
42
+ - 原模型量化评测
43
+ ![原模型量化评测](glm_eval.jpg)
44
+ - 训练后量化评测
45
+ ![训练后量化评测](lora_eva.jpg)
46
+ ## Usage1 16G及以上显存用下载压缩包即lora文件使用,可支持ChatGLM原生模型和LoRA微调后的模型
47
+ 16G及以上显存用下载压缩包即lora文件使用,可支持ChatGLM原生模型和LoRA微调后的模型
48
+ (HuggingFace Transformers)
49
+ First, you pass your input through the transformer model, then you get the generated sentence.
50
+ Install package:
51
+ ```
52
+ pip install transformers
53
+ ```
54
 
55
+ ```python
56
+
57
+ import sys
58
+ from peft import PeftModel
59
+ from transformers import AutoModel, AutoTokenizer
60
+ sys.path.append('..')
61
+ model = AutoModel.from_pretrained("THUDM/chatglm-6b", trust_remote_code=True, device_map='auto')
62
+ model = PeftModel.from_pretrained(model, "model/chatglm_fitness_lora")
63
+ model = model.half().cuda() # fp16
64
+ tokenizer = AutoTokenizer.from_pretrained("THUDM/chatglm-6b", trust_remote_code=True)
65
+ sents = ['新冠肺炎怎么预防。\n答:']
66
+ for s in sents:
67
+ response = model.chat(tokenizer, s, max_length=128, eos_token_id=tokenizer.eos_token_id)
68
+ print(response)
69
+ ```
70
+ output:
71
  ```shell
72
+ 例一:常识综合问答
73
+ 问: 新冠肺炎怎么预防
74
+ 答:新冠肺炎是一种由新型冠状病毒引起的疾病,可以通过飞沫传播和接触传播。以下是一些预防新冠肺炎的建议:
75
+ 戴口罩:佩戴口罩可以防止呼吸道飞沫传播,减少感染风险。在公共场合、公共交通工具上、与他人交往时,应佩戴医用口罩或N95口罩。
76
+ 勤洗手:经常用肥皂和温水洗手,尤其在接触公共场所、物品或与他人交往后,或咳嗽、打喷嚏、擤鼻涕后等。
77
+ 保持社交距离:尽量避免近距离接触他人,保持至少1米的社交距离。
78
+ 避免聚集:尽量避免参加人员密集的聚会、活动或旅行。
79
+ 加强室内通风:在室内保持良好的通风可以降低病毒在空气中的浓度。
80
+ 健康生活方式:保持充足的睡眠、均衡的饮食、适量的运动等健康生活方式可以增强身体免疫力,预防感染。
81
+ 接种疫苗:疫苗接种是预防新冠肺炎最有效的方法之一。如果有机会,应接种疫苗。
82
+ 预防新冠肺炎需要个人和社会的共同努力,遵守公共卫生规定,加强个人防护,减少接触风险。
83
+ 例二:较为专业的医疗和心理学问答
84
+ 问:系统性红斑狼疮的危害和治疗方法是什么?
85
+ 答:系统性红斑狼疮(Systemic Lupus Erythematosus,SLE)是一种自身免疫性疾病,可以影响身体的多个器官和组织。SLE的危害包括:
86
+ 1. 心血管疾病:SLE可以引起高血压、心脏病和中风等心血管疾病。
87
+ 2. 肾脏疾病:SLE可以引起肾小球肾炎和肾衰竭等肾脏疾病。
88
+ 3. 口腔溃疡:SLE可以引起口腔和舌头溃疡等口腔疾病。
89
+ 4. 皮肤疾病:SLE可以引起皮疹、红斑狼疮面容和光敏感等皮肤疾病。
90
+
91
+ 治疗方法包括:
92
+ 1. 药物治疗:SLE可以使用非甾体抗炎药、激素类药物和免疫抑制剂等药物治疗。
93
+ 2. 支持性治疗:SLE可以使用营养支持、心理治疗和支持性护理等支持性治疗。
94
+ 3. 手术治疗:在一些情况下,SLE可能需要手术治疗,如肾脏移植等。
95
+
96
+ SLE是一种严重的疾病,需要患者及时接受专业治疗。患者需要积极配合医生的治疗,保持良好的生活习惯和饮食习惯,定期进行检查和监测。
97
+ 例三:无限多轮次的智能对话(第一轮见例二)
98
+ 问:早期激素和免疫抑制剂用药建议是什么?
99
+ 答:系统性红斑狼疮的早期治疗非常重要,因为病情的严重程度和进展速度可能会影响患者的生活质量和生命安全。对于系统性红斑狼疮的早期治疗,激素和免疫抑制剂的使用是非常重要的。以下是一些早期激素和免疫抑制剂用药的建议:
100
+ 1. 激素类药物:激素类药物是系统性红斑狼疮的主要治疗方法之一。在使用激素类药物时,需要遵循医生的建议,根据病情和身体状况进行剂量和用药时间的调整。一般来说,激素类药物需要长期使用,以避免药物副作用和病情的复发。
101
+ 2. 免疫抑制剂:免疫抑制剂是系统性红斑狼疮另一种重要的治疗方法。在使用免疫抑制剂时,需要遵循医生的建议,根据病情和身体状况进行用药时间和剂量的调整。免疫抑制剂可以用于治疗系统性红斑狼疮的各种症状和并发症,如肾脏疾病、口腔溃疡、皮肤疾病等。
102
+ 3. 其他治疗:除了激素和免疫抑制剂之外,系统性红斑狼疮的治疗还包括其他治疗方法,如支持性治疗、手术治疗等。在使用这些治疗方法时,需要遵循医生的建议,根据病情和身体状况进行用药和治疗。
103
+
104
+ 早期激素和免疫抑制剂的使用非常重要,需要患者积极配合医生的治疗,遵循医生的建议,定期进行检查和监测,以确保病情得到有效控制和生活质量得到保障。
105
  ```
106
 
107
+ 模型文件组成:
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
108
  ```
109
+ chatglm_fitness_lora
110
+ ├── adapter_config.json
111
+ └── adapter_model.bin
 
 
 
 
 
 
 
 
 
 
 
 
 
 
112
  ```
113
+ --------------------------------------------------------------------------------
114
+ ## Usage2 16G及以下显存用户下载整个模型,可支持fp16、int8、int4
115
+ First, you pass your input through the transformer model, then you get the generated sentence.
 
 
 
 
 
116
  ```
117
+ pip install transformers
118
+
119
  ```
120
+
121
+ ```python
122
+
123
+ import sys
124
+ from peft import PeftModel
125
+ from transformers import AutoModel, AutoTokenizer
126
+ sys.path.append('..')
127
+ model = AutoModel.from_pretrained("THUDM/chatglm-6b", trust_remote_code=True, device_map='auto')
128
+ model = PeftModel.from_pretrained(model, "model/chatglm_fitness_lora") # lora文件保存目录
129
+ model = model.half().quantize(4).cuda() # int4
130
+ #model = model.half().quantize(8).cuda() # int8
131
+ #model = model.half().cuda() # fp16
132
+ tokenizer = AutoTokenizer.from_pretrained("THUDM/chatglm-6b", trust_remote_code=True)
133
+ sents = ['新冠肺炎怎么预防。\n答:']
134
+ for s in sents:
135
+ response = model.chat(tokenizer, s, max_length=128, eos_token_id=tokenizer.eos_token_id)
136
+ print(response)
137
+ ```
138
+ output:
139
+ ```shell
140
+ 例四:优于chatglm-6b、chatglm2-6b和百川-7b等类似参数量模型的总结归纳能力
141
+ 问:请用简短的语言总��下面的文字:
142
+ 大语言模型是指能够生成、理解和处理自然语言的高度智能化的计算机模型。这些模型使用深度学习技术,尤其是循环神经网络(RNN)或变种,如长短期记忆(LSTM)或注意力机制(attention mechanism),从大规模文本语料库中进行训练。
143
+ 大语言模型的训练过程通常基于预测下一个单词或字符的任务。通过对大量文本数据进行训练,模型能够学习到语言的潜在��式、结构和语义含义。这使得大语言模型能够产生流畅、连贯的文本,回答问题,完成翻译任务,生成代码等。
144
+ 答:大语言模型是一种使用深度学习技术训练的计算机模型,能够生成、理解和处理自然语言。通过训练大量文本数据,大语言模型能够产生流畅、连贯的文本,回答问题,完成翻译任务,生成代码等。
145
  ```