metadata
language: ja
tags:
- mobilebert
license: cc-by-sa-3.0
datasets:
- wikipedia
MobileBERT 日本語事前学習済みモデルについて
AI関係の仕事をしている櫻本です。
2020年に発表されたBERTの発展型モデルの一つである「MobileBERT」の日本語事前学習済みモデルを構築しました。
このページを見つけた方はかなりラッキーですから、ぜひ一度使ってみてください!!
利用方法
既にtransformersでBERTを利用されている方向けです。
トークナイザは東北大学さんのモデル(cl-tohoku/bert-large-japanese)からお借りしましたのでご指定ください。
後は、BertForなんちゃら~のクラスをMobileBertForなんちゃら~に直して、このリポジトリを指定するだけです!
tokenizer = BertJapaneseTokenizer.from_pretrained("cl-tohoku/bert-large-japanese")
model = MobileBertForSequenceClassification.from_pretrained("ysakuramoto/mobilebert-ja") # 文書分類の場合
(注意:文書分類などのタスクに利用するには、ファインチューニングが必要です)
BERTとの性能比較
文書分類と固有表現抽出について、ファインチューニング・性能評価を行いました。
参考程度にご覧ください。(ファインチューニング後の性能を保証するものではありません)
文書分類(MobileBertForSequenceClassification)
メトリック BERT MobileBERT(高速化前) MobileBERT(高速化後) 学習時間(s) 585.0 399.7 - 推論時間(s) 259.0 108.7 70.5 精度 86.4% 85.5% 86.4% - 条件
- ライブドアニュースコーパスのタイトルとカテゴリで学習・推論。
- BERTモデルに、'cl-tohoku/bert-base-japanese-whole-word-masking'を利用。
- 推論データ n=1,474。精度はAccuracy。
- エポック数=10, lr=1e-4
- 推論時の高速化として、枝刈り・量子化・jitコンパイルを実施。
- Google Colabにて、学習にGPU、推論にCPUを利用。推論はバッチ処理でなく1件ずつ処理。
- 条件
固有表現抽出(BertForTokenClassification)
メトリック BERT MobileBERT(高速化前) MobileBERT(高速化後) 学習時間(s) 428.0 294.0 - 推論時間(s) 163.5 78.4 40.9 精度 86.4% 82.5% 83.3% - 条件
- ストックーマークさんのwikipediaデータセットで学習・推論。(https://github.com/stockmarkteam/ner-wikipedia-dataset)
- BERTモデルに、'cl-tohoku/bert-base-japanese-whole-word-masking'を利用。
- 推論データ n=2,140。精度は完全一致のAccuracy。
- エポック数=10, lr=1e-4
- 推論時の高速化として、枝刈り・量子化・jitコンパイルを実施。
- Google Colabにて、学習にGPU、推論にCPUを利用。推論はバッチ処理でなく1件ずつ処理。
- 条件
モデルの説明
- モデルの構造
- 論文中の"MobileBERT"構造に従いました。(論文中にはMobileBERTTINYというバージョンもありますがそちらではないです)
- 論文中のTable.1 をご確認ください。 https://arxiv.org/abs/2004.02984
- 論文中の"MobileBERT"構造に従いました。(論文中にはMobileBERTTINYというバージョンもありますがそちらではないです)
- 学習に利用したデータ
- 東北大学さんが公開されている方法で、2021年8月時点のwikipediaデータを利用しました。
- 東北大学さんのgithub https://github.com/cl-tohoku/bert-japanese
- 東北大学さんが公開されている方法で、2021年8月時点のwikipediaデータを利用しました。
- トークナイザ
- 東北大学さんのモデル"cl-tohoku/bert-large-japanese"からお借りしました。vocab sizeは32768です。
- 学習方法
- Google ColabからTPUを用いて学習しました。
- IB-BERTLARGEをlr=5e-4で1Mステップ学習しました。
- 240kステップの蒸留後、mobileBERTをlr=5e-4で2Mステップ学習しました。
- トータルで2ヶ月半くらいかかりました。。エラーも出まくってつらかったです。
- Google ColabからTPUを用いて学習しました。
- tensorflow liteでの利用
- こちらで説明されています。その名の通りモバイルで動かせるんですね。
ライセンス
CC-BY SA 3.0
トークナイザについては東北大学さんのモデル"cl-tohoku/bert-large-japanese"からお借りしました。