README.md 2.58 KB
Newer Older
liangjing's avatar
v1  
liangjing committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
# 内容
- [内容](#内容)
- [环境配置](#环境配置)
- [下载词汇文件](#下载词汇文件)
- [下载训练数据](#下载训练数据)
- [训练](#训练)
  - [数据预处理](#数据预处理)
  - [GPT预训练](#gpt预训练)
    - [分布式多卡训练](#分布式多卡训练)
- [GPT文本生成](#gpt文本生成)
- [参考](#参考)

# 环境配置
1. 安装基础依赖包
Neel Kant's avatar
Neel Kant committed
15
<pre>
liangjing's avatar
v1  
liangjing committed
16
pip install -r requirements.txt
Neel Kant's avatar
Neel Kant committed
17
</pre>
liangjing's avatar
v1  
liangjing committed
18
2. 安装DCU相关whl包
liangjing's avatar
liangjing committed
19

liangjing's avatar
v1  
liangjing committed
20
DCU相关包下载目录:[https://cancon.hpccube.com:65024/4/main](https://cancon.hpccube.com:65024/4/main)
Neel Kant's avatar
Neel Kant committed
21

liangjing's avatar
liangjing committed
22
pytorch whl包:pytorch ---> dtk-24.04.1
liangjing's avatar
v1  
liangjing committed
23
根据python版本,下载对应pytorch的whl包
Neel Kant's avatar
Neel Kant committed
24
25

<pre>
liangjing's avatar
v1  
liangjing committed
26
pip install torch* (下载的torch的whl包)
Neel Kant's avatar
Neel Kant committed
27
</pre>
liangjing's avatar
liangjing committed
28
torchvision whl包:vision ---> dtk-24.04.1
liangjing's avatar
v1  
liangjing committed
29
根据python版本,下载对应torchvision的whl包
Mohammad's avatar
Mohammad committed
30
31

<pre>
liangjing's avatar
v1  
liangjing committed
32
pip install torchvision* (下载的torchvision的whl包)
Mohammad's avatar
Mohammad committed
33
</pre>
liangjing's avatar
liangjing committed
34
apex whl包:apex ---> dtk-24.04.1
liangjing's avatar
v1  
liangjing committed
35
根据python版本,下载对应apex的whl包
Mohammad's avatar
Mohammad committed
36
37

<pre>
liangjing's avatar
v1  
liangjing committed
38
pip install apex* (下载的apex的whl包)
39
</pre>
liangjing's avatar
v1  
liangjing committed
40
若使用 pip install 下载安装过慢,可添加源:-i https://pypi.tuna.tsinghua.edu.cn/simple/
Mohammad's avatar
Mohammad committed
41

liangjing's avatar
liangjing committed
42
43
44
45
46
47
48
3. 安装unsloth

<pre>
cd ./unsloth
pip3 install -e .
</pre>

liangjing's avatar
v1  
liangjing committed
49
# 下载词汇文件
50

Mohammad's avatar
Mohammad committed
51
<pre>
liangjing's avatar
v1  
liangjing committed
52
53
wget https://s3.amazonaws.com/models.huggingface.co/bert/gpt2-vocab.json
wget https://s3.amazonaws.com/models.huggingface.co/bert/gpt2-merges.txt
Mohammad's avatar
Mohammad committed
54
</pre>
55
56


liangjing's avatar
v1  
liangjing committed
57
58
# 下载训练数据
使用1GB 79K jsonl数据集
Mohammad's avatar
Mohammad committed
59
<pre>
liangjing's avatar
v1  
liangjing committed
60
61
wget https://huggingface.co/bigscience/misc-test-data/resolve/main/stas/oscar-1GB.jsonl.xz
xz -d oscar-1GB.jsonl.xz
Mohammad's avatar
Mohammad committed
62
63
</pre>

liangjing's avatar
v1  
liangjing committed
64
# 训练
Mohammad's avatar
Mohammad committed
65

liangjing's avatar
v1  
liangjing committed
66
## 数据预处理
Mohammad's avatar
Mohammad committed
67
68

<pre>
liangjing's avatar
v1  
liangjing committed
69
70
71
python tools/preprocess_data.py \
    --input oscar-1GB.jsonl \ 
    --output-prefix ./dataset/my-gpt2 \
liangjing's avatar
liangjing committed
72
    --vocab-file gpt2-vocab.json \
liangjing's avatar
v1  
liangjing committed
73
74
75
76
    --tokenizer-type GPT2BPETokenizer \
    --merge-file gpt2-merges.txt \
    --append-eod \
    --workers 8
Mohammad's avatar
Mohammad committed
77
78
</pre>

liangjing's avatar
v1  
liangjing committed
79
80
81
参数说明
--input				输入数据集路径,即oscar-1GB.jsonl.xz解压后的文件路径
--output-prefix		输出数据路径,处理后会自动加上_text_document后缀
liangjing's avatar
liangjing committed
82
--vocab-file				下载的gpt2-vocab.json词表文件路径
liangjing's avatar
v1  
liangjing committed
83
84
85
86
--tokenizer-type 	tokenizer类型
--merge-file		下载的gpt2-merges.txt文件路径		
--append-eod		添加结束标志符		
--workers			进程数
Mohammad's avatar
Mohammad committed
87

liangjing's avatar
v1  
liangjing committed
88
## GPT预训练
Mohammad's avatar
Mohammad committed
89

liangjing's avatar
v1  
liangjing committed
90
91
### 分布式训练
- 修改DATA_PATH路径
Mohammad's avatar
Mohammad committed
92

liangjing's avatar
v1  
liangjing committed
93
94
95
  ```bash
  VOCAB_FILE=gpt2-vocab.json
  MERGE_FILE=gpt2-merges.txt
liangjing's avatar
liangjing committed
96
  DATA_PATH="./dataset/my-gpt2_text_document"
liangjing's avatar
v1  
liangjing committed
97
  ```
Raul Puri's avatar
Raul Puri committed
98

liangjing's avatar
v1  
liangjing committed
99
- 执行多卡训练
100

liangjing's avatar
v1  
liangjing committed
101
102
  ```
  #np为起的进程数,np\hostfile均需按实际填写
liangjing's avatar
liangjing committed
103
  mpirun -np 4 --hostfile hostfile single.sh localhost(基于单节点四卡)
liangjing's avatar
v1  
liangjing committed
104
  ```
105

liangjing's avatar
v1  
liangjing committed
106
# 参考
107

liangjing's avatar
liangjing committed
108
- [README_ORIGIN](README_ORIGIN.md)