fclong's picture
Upload 396 files
8ebda9e
# Bert预训练
## 背景
我们有持续收集了一部分语料,有一套自建的数据处理流程。位了验证数据处理的效果,从零开始预训练了2个base级别的Bert模型,一个是基于自建数据,一个是基于同行们开源的数据。总体来说数据效果差别不大,下面只介绍一下本次预训练的流程。
## 数据处理
我们的原始语料主要源自common crawl以及一些开源的高质量语料,经过一些列的数据清洗之后,我们的数据格式为jsonline。例如(摘自内部数据):
```json
{"text":"据悉,河南博物馆成立于1927年,目前拥有超过170000件(套)的文物收藏,包括Jiahu骨笛,雌性猫头鹰雕像,cloud-patterned铜禁,Duling Fangding,莲花和起重机广场,和玉柄剑,黄金从武则天滑落,四神云雾壁画和汝窑天蓝釉雕鹅颈瓶是九大镇厅的珍品。院中的藏品以史前文物、商周青铜器、陶瓷、玉器和石雕等为特色。高质量文物数量多、品种齐全、品位高、价值高。它们是见证中国文明发展、展示中国历史发展的文化艺术宝库。"}
{"text": "功夫不负有心人,1925年,万氏兄弟试制动画片初获成果,并获得了商务印书馆的大力支持。其后兄弟们再接再厉,直到1927年,一部黑白无声动画片《大闹画室》诞生了爱尔兰风笛。据《申报》记载,“该片内容画人与真人合作锁梦楼,滑稽处甚多,令人观后,捧腹不止。”此片曾远销美国放映,并大受赞誉。1930年夏俊娜,万古蟾到大中华百合影片公司工作,万氏兄弟采用了同样的手法拍摄了第二部动画短片《纸人捣乱记》,并于1931年上映。"}
```
处理脚本路径:`/cognitive_comp/wuziwei/codes/Fengshenbang-LM/fengshen/data/bert_dataloader`
该路径下面有3个文件,`auto_split.sh``preprocessing.py`是原始数据预处理的脚本,`load.py是fs_data`的处理脚本,执行顺序如下:
#### step 1
执行`auto_split.sh`文件,作用是分割大文件,超过1GB的文件,会自动分割未300M的小文件。使用方法如下:
`sh auto_split.sh 你的数据文件路径`
#### step 2
执行`preprocessing.py`文件,该文件的作用主要是分句,为什么不嵌入到collate_fn中做,是发现那样效率会慢一些,所以单独拿出来做了。
执行`python preprocessing.py`即可,注意修改脚本内的文件路径。
#### step 3
`load.py`文件是用fsdata的方式加载数据集,也是执行即可。执行一遍,后续的加载可以实现180GB的数据秒入~
前面两步是为了提高load.py文件生成缓存文件的速度。经过这几步的处理以及collate_fn函数(bert mask 策略的实现),最终变成bert的输入。如下:
*ps: collate_fn在`Fengshenbang-LM\fengshen\examples\pretrain_bert\pretrain_bert.py`脚本下,由DataCollate类实现。*
```json
{
"input_ids": torch.tensor(input_ids),
"labels": torch.tensor(batch_labels),
"attention_mask": torch.tensor(attention_mask),
"token_type_ids": torch.tensor(token_type_ids)
}
```
## 模型结构
模型结构即为标准的bert-base,即:
| 配置 | 参数 |
| :---------: | :---: |
| nlayers | 12 |
| nheaders | 12 |
| hidden-size | 768 |
| seq-length | 512 |
| vocab-size | 21128 |
## 任务以及Mask策略
*mask策略的实现在`Fengshenbang-LM\fengshen\examples\pretrain_bert\pretrain_bert.py`的**DataCollate**类中*
本次预训练取消了NSP任务,只做mask任务,具体mask策略如下:
- 15%随机mask
- 80% mask
- 10% 随机替换
- 10% 保持不变
- 全词mask (wwm)
- n-gram mask
由于加入了全词mask和n-gram mask 总体的mask token数量会比英文原始论文的mask比例略高
## 预训练执行流程
- 训练框架:[Fengshenbang-LM](https://github.com/IDEA-CCNL/Fengshenbang-LM)
- 脚本执行:`sh Fengshenbang-LM\fengshen\examples\pretrain_bert\pretrain_bert.sh`
*具体配置见`Fengshenbang-LM\fengshen\examples\pretrain_bert\pretrain_bert.sh`*