Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qiangsiwei/bert_distill
BERT distillation(基于BERT的蒸馏实验 )
https://github.com/qiangsiwei/bert_distill
bert classification distillation nlp
Last synced: 2 months ago
JSON representation
BERT distillation(基于BERT的蒸馏实验 )
- Host: GitHub
- URL: https://github.com/qiangsiwei/bert_distill
- Owner: qiangsiwei
- Created: 2019-08-14T04:13:27.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-07-30T02:21:43.000Z (over 4 years ago)
- Last Synced: 2024-08-02T08:09:51.755Z (5 months ago)
- Topics: bert, classification, distillation, nlp
- Language: Python
- Homepage:
- Size: 28.9 MB
- Stars: 308
- Watchers: 5
- Forks: 87
- Open Issues: 7
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
- awesome-bert - qiangsiwei/bert_distill
README
基于BERT的蒸馏实验
================参考论文《Distilling Task-Specific Knowledge from BERT into Simple Neural Networks》
分别采用keras和pytorch基于textcnn和bilstm(gru)进行了实验
实验数据分割成 1(有标签训练):8(无标签训练):1(测试)
在情感2分类clothing的数据集上初步结果如下:
- 小模型(textcnn & bilstm)准确率在 0.80 ~ 0.81
- BERT模型 准确率在 0.90 ~ 0.91
- 蒸馏模型 准确率在 0.87 ~ 0.88
实验结果与论文结论基本一致,与预期相符
后续将尝试其他更有效的蒸馏方案
## 使用方法
首先finetune BERT
```bash
python ptbert.py
```然后把BERT的知识蒸馏到小模型里
需要先解压`data/cache/word2vec.gz`
然后
```bash
python distill.py
```调整文件中的`use_aug`及以下的参数可以使用论文中提到的其中两种数据增强方式(masking, n-gram sampling)