Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ymcui/pert

PERT: Pre-training BERT with Permuted Language Model
https://github.com/ymcui/pert

bert nlp plm pre-trained-model pytorch tensorflow transformers

Last synced: 15 days ago
JSON representation

PERT: Pre-training BERT with Permuted Language Model

Awesome Lists containing this project

README

        

[**中文**](https://github.com/ymcui/PERT) | [**English**](https://github.com/ymcui/PERT/blob/main/README_EN.md)










GitHub

在自然语言处理领域中,预训练语言模型(Pre-trained Language Models,PLMs)已成为非常重要的基础技术。在近两年,哈工大讯飞联合实验室发布了多种中文预训练模型资源以及相关配套工具。作为相关工作的延续,在本项目中,我们提出了一种基于乱序语言模型的预训练模型(PERT),在不引入掩码标记[MASK]的情况下自监督地学习文本语义信息。PERT在部分中英文NLU任务上获得性能提升,但也在部分任务上效果较差,请酌情使用。目前提供了中文和英文的PERT模型,包含两种模型大小(base、large)。

- [**PERT: Pre-Training BERT with Permuted Language Model**](https://arxiv.org/abs/2203.06906)
- *Yiming Cui, Ziqing Yang, Ting Liu*

----

[中文LERT](https://github.com/ymcui/LERT) | [中英文PERT](https://github.com/ymcui/PERT) | [中文MacBERT](https://github.com/ymcui/MacBERT) | [中文ELECTRA](https://github.com/ymcui/Chinese-ELECTRA) | [中文XLNet](https://github.com/ymcui/Chinese-XLNet) | [中文BERT](https://github.com/ymcui/Chinese-BERT-wwm) | [知识蒸馏工具TextBrewer](https://github.com/airaria/TextBrewer) | [模型裁剪工具TextPruner](https://github.com/airaria/TextPruner)

查看更多哈工大讯飞联合实验室(HFL)发布的资源:https://github.com/ymcui/HFL-Anthology

## 新闻
**2023/3/28 开源了中文LLaMA&Alpaca大模型,可快速在PC上部署体验,查看:https://github.com/ymcui/Chinese-LLaMA-Alpaca**

2022/10/29 我们提出了一种融合语言学信息的预训练模型LERT。查看:https://github.com/ymcui/LERT

2022/5/7 更新了在多个阅读理解数据集上精调的阅读理解专用PERT,并提供了huggingface在线交互Demo,check:[模型下载](#模型下载)

2022/3/15 技术报告已发布,请参考:https://arxiv.org/abs/2203.06906

2022/2/24 中文、英文的PERT-base和PERT-large已发布。可直接使用BERT结构加载并进行下游任务精调。技术报告待完善后发出,时间预计在3月中旬,感谢耐心等待。

2022/2/17 感谢对本项目的关注,预计下周发出模型,技术报告待完善后发出。

## 内容导引
| 章节 | 描述 |
| ------------------------------------- | ------------------------------------------------------------ |
| [简介](#简介) | PERT预训练模型的基本原理 |
| [模型下载](#模型下载) | PERT预训练模型的下载地址 |
| [快速加载](#快速加载) | 如何使用[🤗Transformers](https://github.com/huggingface/transformers)快速加载模型 |
| [基线系统效果](#基线系统效果) | 在部分中英文NLU任务上的基线系统效果 |
| [FAQ](#FAQ) | 常见问题答疑 |
| [引用](#引用) | 本项目的技术报告 |

## 简介
面向自然语言理解(NLU)的预训练模型的学习大致分为两类:使用和不使用带掩码标记[MASK]的输入文本。

算法启发:一定程度的乱序文本不影响理解。那么能否从乱序文本中学习语义知识?

大体思想:PERT对原始输入文本进行一定的词序调换,从而形成乱序文本(因此不会引入额外的[MASK]标记)。PERT的学习目标是预测原token所在的位置,具体见下例。

| 说明 | 输入文本 | 输出目标 |
| :-------------- | :----------------------------------------------------------- | ------------------------------------------------------------ |
| 原始文本 | 研究表明这一句话的顺序并不影响阅读。 | - |
| WordPiece分词后 | 研 究 表 明 这 一 句 话 的 顺 序 并 不 影 响 阅 读 。 | - |
| BERT | 研 究 表 明 这 一 句 **[MASK]** 的 顺 **[MASK]** 并 不 **[MASK]** 响 阅 读 。 | 位置7 → 话
位置10 → 序
位置13 → 影 |
| PERT | 研 究 **明** **表** 这 一 句 话 的 顺 序 并 不 **响** **影** 阅 读 。 | 位置2(明)→位置3(表)
位置3(表)→位置2(明)
位置13(响)→位置14(影)
位置14(影)→位置13(响) |

以下是PERT模型**在预训练阶段**的基本结构和输入输出格式(注意:目前arXiv技术报告中的图片有误,请以下图为准。下次更新论文时会替换为正确图片。)。

![pert](https://github.com/ymcui/PERT/blob/main/pics/pert.png)

## 模型下载

### 原版下载地址

这里主要提供TensorFlow 1.15版本的模型权重。如需PyTorch或者TensorFlow2版本的模型,请看下一小节。

**开源版本仅包含Transformer部分的权重,可直接用于下游任务精调,或者其他预训练模型二次预训练的初始权重,更多说明见FAQ。**

* **`PERT-large`**:24-layer, 1024-hidden, 16-heads, 330M parameters
* **`PERT-base`** 12-layer, 768-hidden, 12-heads, 110M parameters

| 模型简称 | 语种 | 语料 | Google下载 | 百度盘下载 |
| :--------------------------------- | :--: | :---------------------: | :--------: | :----------------------------------------------------------: |
| **Chinese-PERT-large** | 中文 | EXT数据[1] | [TensorFlow](https://drive.google.com/file/d/1jAV2IbJEHErVpl6mPceLjSEQl6osQ0uk/view?usp=sharing) | [TensorFlow(密码:e9hs)](https://pan.baidu.com/s/1MG44TRIgqV6m_StfB_yBqQ?pwd=e9hs) |
| **Chinese-PERT-base** | 中文 | EXT数据[1] | [TensorFlow](https://drive.google.com/file/d/1_3TYwubupTfL-pgb2seqvF1qgD5SRGrz/view?usp=sharing) | [TensorFlow(密码:rcsw)](https://pan.baidu.com/s/1yDHkYKmdaJkliTGHWQtdFA?pwd=rcsw) |
| **English-PERT-large** (uncased) | 英文 | WikiBooks[2] | [TensorFlow](https://drive.google.com/file/d/1WXpMTCqB9Cf0jXQPiNAsyssTRDtPCHjU/view?usp=sharing) | [TensorFlow(密码:wxwi)](https://pan.baidu.com/s/1h62V5y_XH6VqlD820KnkFw?pwd=wxwi) |
| **English-PERT-base** (uncased) | 英文 | WikiBooks[2] | [TensorFlow](https://drive.google.com/file/d/1rJng61FlRveqXyHKXlxu1g9YTYi24N55/view?usp=sharing) | [TensorFlow(密码:8jgq)](https://pan.baidu.com/s/1fX4Epbgk8rR49A0xIAEWDw?pwd=8jgq) |

> [1] EXT数据包括:中文维基百科,其他百科、新闻、问答等数据,总词数达5.4B,约占用20G磁盘空间,与MacBERT相同。
> [2] Wikipedia + BookCorpus

以TensorFlow版`Chinese-PERT-base`为例,下载完毕后对zip文件进行解压得到:

```
chinese_pert_base_L-12_H-768_A-12.zip
|- pert_model.ckpt # 模型权重
|- pert_model.meta # 模型meta信息
|- pert_model.index # 模型index信息
|- pert_config.json # 模型参数
|- vocab.txt # 词表(与谷歌原版一致)
```

其中`bert_config.json`和`vocab.txt`与谷歌原版`BERT-base, Chinese`完全一致(英文版与BERT-uncased版本一致)。

### PyTorch以及TensorFlow 2版本

通过🤗transformers模型库可以下载TensorFlow (v2)和PyTorch版本模型。

下载方法:点击任意需要下载的模型 → 选择"Files and versions"选项卡 → 下载对应的模型文件。

| 模型简称 | 模型文件大小 | transformers模型库地址 |
| :------- | :---------: | :---------- |
| **Chinese-PERT-large** | 1.2G | https://huggingface.co/hfl/chinese-pert-large |
| **Chinese-PERT-base** | 0.4G | https://huggingface.co/hfl/chinese-pert-base |
| **Chinese-PERT-large-MRC** | 1.2G | https://huggingface.co/hfl/chinese-pert-large-mrc |
| **Chinese-PERT-base-MRC** | 0.4G | https://huggingface.co/hfl/chinese-pert-base-mrc |
| **English-PERT-large** | 1.2G | https://huggingface.co/hfl/english-pert-large |
| **English-PERT-base** | 0.4G | https://huggingface.co/hfl/english-pert-base |

## 快速加载
由于PERT主体部分仍然是BERT结构,用户可以使用[transformers库](https://github.com/huggingface/transformers)轻松调用PERT模型。

**注意:本目录中的所有模型均使用BertTokenizer以及BertModel加载(MRC模型使用BertForQuestionAnswering)。**

```python
from transformers import BertTokenizer, BertModel

tokenizer = BertTokenizer.from_pretrained("MODEL_NAME")
model = BertModel.from_pretrained("MODEL_NAME")
```
其中`MODEL_NAME`对应列表如下:

| 模型名 | MODEL_NAME |
| ---------------------- | -------------------------- |
| Chinese-PERT-large | hfl/chinese-pert-large |
| Chinese-PERT-base | hfl/chinese-pert-base |
| Chinese-PERT-large-MRC | hfl/chinese-pert-large-mrc |
| Chinese-PERT-base-MRC | hfl/chinese-pert-base-mrc |
| English-PERT-large | hfl/english-pert-large |
| English-PERT-base | hfl/english-pert-base |

## 基线系统效果
以下仅列举部分实验结果。详细结果和分析见论文。实验结果表格中,括号外为最大值,括号内为平均值。

### 中文任务

在以下10个任务上进行了效果测试。

- **抽取式阅读理解**(2):[CMRC 2018(简体中文)](https://github.com/ymcui/cmrc2018)、[DRCD(繁体中文)](https://github.com/DRCKnowledgeTeam/DRCD)
- **文本分类**(6):
- **单句**(2):[ChnSentiCorp](https://github.com/pengming617/bert_classification)、[TNEWS](https://github.com/CLUEbenchmark/CLUE)
- **句对**(4):[XNLI](https://github.com/google-research/bert/blob/master/multilingual.md)、[LCQMC](http://icrc.hitsz.edu.cn/info/1037/1146.htm)、[BQ Corpus](http://icrc.hitsz.edu.cn/Article/show/175.html)、[OCNLI](https://github.com/CLUEbenchmark/OCNLI)
- **命名实体识别**(2):[MSRA-NER]()、[People's Daily(人民日报)]()

#### 阅读理解

![chinese-mrc](./pics/chinese-mrc.png)

#### 文本分类

![chinese-tc](./pics/chinese-tc.png)

#### 命名实体识别

![chinese-ner](./pics/chinese-ner.png)

#### 文本纠错(乱序)

除了上述任务之外,我们还在文本纠错中的乱序任务上进行了测试,效果如下。

![chinese-wor](./pics/chinese-wor.png)

### 英文任务

在以下6个任务上进行了效果测试。

- **抽取式阅读理解**(2):[SQuAD 1.1](https://rajpurkar.github.io/SQuAD-explorer/)、[SQuAD 2.0](https://rajpurkar.github.io/SQuAD-explorer/)
- **GLUE子任务**(4):[MNLI、SST-2、CoLA、MRPC](http://gluebenchmark.com)

![english-nlu](./pics/english-nlu.png)

## FAQ
**Q1: 关于PERT的开源版本权重**
A1: 开源版本仅包含Transformer部分的权重,可直接用于下游任务精调,或者其他预训练模型二次预训练的初始权重。原始TF版本权重可能包含**随机初始化**的MLM权重。这是为了:

- 删去不必要的Adam相关权重(大约会减小至1/3);
- 与transformers的BERT模型转换一致(此过程会使用原版BERT结构,因此预训练任务部分的权重会丢失,并保留BERT的MLM随机初始化权重)。

**Q2: 关于PERT在下游任务上的效果**
A2: 初步结论是在阅读理解、序列标注等任务上效果较好,但在文本分类任务上效果较差。具体效果请各位在各自任务上自行尝试。具体细节请参考我们的论文:https://arxiv.org/abs/2203.06906

## 引用
如果本项目中的模型或者相关结论有助于您的研究,请引用以下文章:https://arxiv.org/abs/2203.06906
```tex
@article{cui2022pert,
title={PERT: Pre-training BERT with Permuted Language Model},
author={Cui, Yiming and Yang, Ziqing and Liu, Ting},
year={2022},
eprint={2203.06906},
archivePrefix={arXiv},
primaryClass={cs.CL}
}
```

## 关注我们
欢迎关注哈工大讯飞联合实验室官方微信公众号,了解最新的技术动态。

![qrcode.png](https://github.com/ymcui/cmrc2019/raw/master/qrcode.jpg)

## 问题反馈
如有问题,请在GitHub Issue中提交。

- 在提交问题之前,请先查看FAQ能否解决问题,同时建议查阅以往的issue是否能解决你的问题。
- 重复以及与本项目无关的issue会被[stable-bot](stale · GitHub Marketplace)处理,敬请谅解。
- 我们会尽可能的解答你的问题,但无法保证你的问题一定会被解答。
- 礼貌地提出问题,构建和谐的讨论社区。