这是笔者重新实现的keras版的transformer模型库,致力于用尽可能清爽的代码来实现结合transformer和keras。
本项目的初衷是为了修改、定制上的方便,所以可能会频繁更新。
因此欢迎star,但不建议fork,因为你fork下来的版本可能很快就过期了。
目前已经实现: - 加载bert/roberta/albert的预训练权重进行finetune; - 实现语言模型、seq2seq所需要的attention mask; - 丰富的examples; - 从零预训练代码(支持TPU、多GPU,请看pretraining); - 兼容keras、tf.keras
安装稳定版:
pip install bert4keras
安装最新版:
pip install git+https://www.github.com/bojone/bert4keras.git
使用例子请参考examples目录。
之前基于keras-bert给出的例子,仍适用于本项目,只需要将bert_model的加载方式换成本项目的。
理论上兼容Python2和Python3,兼容tensorflow 1.14+和tensorflow 2.x,实验环境是Python 2.7、Tesorflow 1.14+以及Keras 2.3.1(已经在2.2.4、2.3.0、2.3.1、tf.keras下测试通过)。
为了获得最好的体验,建议你使用Tensorflow 1.14 + Keras 2.3.1组合。
关于环境组合 - 支持tf+keras和tf+tf.keras,后者需要提前传入环境变量TF_KERAS=1。 - 当使用tf+keras时,建议2.2.4 <= keras <= 2.3.1,以及 1.14 <= tf <= 2.2,不能使用tf 2.3+。 - keras 2.4+可以用,但事实上keras 2.4.x基本上已经完全等价于tf.keras了,因此如果你要用keras 2.4+,倒不如直接用tf.keras。
当然,乐于贡献的朋友如果发现了某些bug的话,也欢迎指出修正甚至Pull Requests~
目前支持加载的权重: - Google原版bert: https://github.com/google-research/bert - brightmart版roberta: https://github.com/brightmart/roberta_zh - 哈工大版roberta: https://github.com/ymcui/Chinese-BERT-wwm - Google原版albert[例子]: https://github.com/google-research/ALBERT - brightmart版albert: https://github.com/brightmart/albert_zh - 转换后的albert: https://github.com/bojone/albert_zh - 华为的NEZHA: https://github.com/huawei-noah/Pretrained-Language-Model/tree/master/NEZHA-TensorFlow - 华为的NEZHA-GEN: https://github.com/huawei-noah/Pretrained-Language-Model/tree/master/NEZHA-Gen-TensorFlow - 自研语言模型: https://github.com/ZhuiyiTechnology/pretrained-models - T5模型: https://github.com/google-research/text-to-text-transfer-transformer - GPT_OpenAI: https://github.com/bojone/CDial-GPT-tf - GPT2_ML: https://github.com/imcaspar/gpt2-ml - Google原版ELECTRA: https://github.com/google-research/electra - 哈工大版ELECTRA: https://github.com/ymcui/Chinese-ELECTRA - CLUE版ELECTRA: https://github.com/CLUEbenchmark/ELECTRA - LaBSE(多国语言BERT): https://github.com/bojone/labse - Chinese-GEN项目下的模型: https://github.com/bojone/chinese-gen - T5.1.1: https://github.com/google-research/text-to-text-transfer-transformer/blob/master/released_checkpoints.md#t511 - Multilingual T5: https://github.com/google-research/multilingual-t5/
注意事项
- 注1:brightmart版albert的开源时间早于Google版albert,这导致早期brightmart版albert的权重与Google版的不完全一致,换言之两者不能直接相互替换。为了减少代码冗余,bert4keras的0.2.4及后续版本均只支持加载Google版以brightmart版中带Google字眼的权重。如果要加载早期版本的权重,请用0.2.3版本,或者考虑作者转换过的albert_zh。
- 注2:下载下来的ELECTRA权重,如果没有json配置文件的话,参考这里自己改一个(需要加上type_vocab_size字段)。
residual_attention_scores参数来实现RealFormer,只需要在build_transformer_model中传入参数residual_attention_scores=True启用。PositionEmbedding引入层次分解,可以让BERT直接处理超长文本,在build_transformer_model中传入参数hierarchical_position=True启用。extend_with_parameter_wise_lr,可用于给每层设置不同的学习率。WebServing类,允许简单地将模型转换为Web接口,详情请参考该类的说明。Transformer类加入prefix参数;snippets.py引入to_array函数;AutoRegressiveDecoder修改rtype='logits'时的一个隐藏bug。Tokenizer原来的max_length参数重命名为maxlen,同时保留向后兼容性,建议大家用新参数名。RECOMPUTE=1启用。rematch方法。Tokenizer增加rematch方法,给出分词结果与原序列的映射关系。DataGenerator,允许传入迭代器时进行局部shuffle。key_size的选项。DataGenerator;优化模型写法。tokenizer.py更名为tokenizers.py。application='seq2seq'改名为application='unilm'。build_bert_model更名为build_transformer_model。models.py结构。bert.py更名为models.py。AutoRegressiveDecoder类,统一处理Seq2Seq的解码问题。load_vocab函数;将build_bert_model中的keep_words参数更名为keep_tokens,此处改动可能会对部分脚本产生影响。build_bert_model函数里加上model='nezha';此外原来albert的加载方式albert=True改为model='albert'。model.save保存模型结构,用load_model加载整个模型(只需要在load_model之前执行from bert4keras.layers import *,不需要额外写custom_objects)。TF_KERAS=1来切换tf.keras。load_pretrained_model函数里加上albert=True。之前一直用CyberZHG大佬的keras-bert,如果纯粹只是为了在keras下对bert进行调用和fine tune来说,keras-bert已经足够能让人满意了。
然而,如果想要在加载官方预训练权重的基础上,对bert的内部结构进行修改,那么keras-bert就比较难满足我们的需求了,因为keras-bert为了代码的复用性,几乎将每个小模块都封装为了一个单独的库,比如keras-bert依赖于keras-transformer,而keras-transformer依赖于keras-multi-head,keras-multi-head依赖于keras-self-attention,这样一重重依赖下去,改起来就相当头疼了。
所以,我决定重新写一个keras版的bert,争取在几个文件内把它完整地实现出来,减少这些依赖性,并且保留可以加载官方预训练权重的特性。
感谢CyberZHG大佬实现的keras-bert,本实现有不少地方参考了keras-bert的源码,在此衷心感谢大佬的无私奉献。
@misc{bert4keras,
title={bert4keras},
author={Jianlin Su},
year={2020},
howpublished={\url{https://bert4keras.spaces.ac.cn}},
}
QQ交流群:808623966,微信群请加机器人微信号spaces_ac_cn
$ claude mcp add bert4keras \
-- python -m otcore.mcp_server <graph>