ファインチューニング (機械学習)

出典: フリー百科事典『ウィキペディア(Wikipedia)』

機械学習の文脈において、ファインチューニング: fine-tuning、微調整)は、事前学習したモデルの重みを新しいデータで訓練する転移学習の一つの手法である[1]。ファインチューニングは、ニューラルネットワーク全体で行うことも、また一部の層に対してのみ行うこともできる。後者の場合、ファインチューニングを行わない層は「凍結」され、バックプロパゲーションの過程で更新されない[2]

概要[編集]

畳み込みニューラルネットワークなど、いくつかのアーキテクチャでは、浅い層(入力層に最も近い側)は低レベルの特徴を捉えるために凍結しておくのが一般的で、それより深い層は、モデルが訓練されたタスクとより関連しうる高レベルの特徴を識別することがよくある[2][3]

自然言語処理(NLP)、特に言語モデリングの分野では、ファインチューニングはよく行われる方法である。たとえば、OpenAIGPT-2のような大規模言語モデルの場合、下流のNLPタスクでファインチューニングを行うことで、事前学習モデルが通常達成するよりも優れた結果を得ることができる[4]。大規模かつ一般的なコーパスで事前訓練されたモデルは、通常、出発点としてモデルパラメータを再利用し、最初から訓練されたタスク固有の層を追加することでファインチューニングされる[5]。モデル全体をファインチューニングすることも一般的で、より良い結果が得られることが多いが、その代わりに計算量が多くなる[4]。また、完全なファインチューニングは過剰適合を起こしやすく、ファインチューニングで使用した訓練データの分布以外のデータに対してモデルの性能を低下させる可能性がある[6]

ファインチューニングは通常、教師あり学習で行われるが、弱教師あり学習英語版でモデルをファインチューニングする技術もある[7]。また、ChatGPTGPT-3のファインチューニング版)やSparrow英語版などの言語モデルのファインチューニングには、人間のフィードバックによる強化学習が使用されている[8][9]。低ランク適応(: Low-Rank Adaptation, LoRA)は、既存の重みに追加する低ランク行列英語版(更新行列)を訓練するのに役立つ[10]。基本的な考え方は次のとおりである。モデル内に 行列 があり、 が大きい場合、 自体を に修正するか、 と定義して、 を訓練することができる。ここで、 はサイズ であり、 は更新行列 の低ランクである。

LoRAは言語モデルによく使われるほか、画像モデルにも使われる[11]

参考項目[編集]

  • 転移学習 - 以前に学習した知識を、新しい問題に適用しようする機械学習の研究領域
  • 大規模言語モデル - ニューラルネットワークで構成された言語モデル

脚注[編集]

  1. ^ Quinn, Joanne (2020). Dive into deep learning: tools for engagement. Thousand Oaks, California. p. 551. ISBN 978-1-5443-6137-6. オリジナルのJanuary 10, 2023時点におけるアーカイブ。. https://web.archive.org/web/20230110131250/https://d2l.ai/chapter_computer-vision/fine-tuning.html#steps 2023年1月10日閲覧。 
  2. ^ a b CS231n Convolutional Neural Networks for Visual Recognition”. cs231n.github.io. 2023年3月9日閲覧。
  3. ^ Zeiler, Matthew D; Fergus, Rob (2013). Visualizing and Understanding Convolutional Networks. arXiv:1311.2901. 
  4. ^ a b Dingliwal, Saket; Shenoy, Ashish; Bodapati, Sravan; Gandhe, Ankur; Gadde, Ravi Teja; Kirchhoff, Katrin (2021). Prompt Tuning GPT-2 language model for parameter-efficient domain adaptation of ASR systems. arXiv:2112.08718. 
  5. ^ Dodge, Jesse; Ilharco, Gabriel; Schwartz, Roy; Farhadi, Ali; Hajishirzi, Hannaneh; Smith, Noah (2020). Fine-Tuning Pretrained Language Models: Weight Initializations, Data Orders, and Early Stopping. arXiv:2002.06305. 
  6. ^ Kumar, Ananya; Raghunathan, Aditi; Jones, Robbie; Ma, Tengyu; Liang, Percy (2022). Fine-Tuning can Distort Pretrained Features and Underperform Out-of-Distribution. arXiv:2202.10054. 
  7. ^ Yu, Yue; Zuo, Simiao; Jiang, Haoming; Ren, Wendi; Zhao, Tuo; Zhang, Chao (2020). Fine-Tuning Pre-trained Language Model with Weak Supervision: A Contrastive-Regularized Self-Training Approach. arXiv:2010.07835. 
  8. ^ Introducing ChatGPT”. openai.com. 2023年3月9日閲覧。
  9. ^ Glaese, Amelia; McAleese, Nat; Trębacz, Maja; Aslanides, John; Firoiu, Vlad; Ewalds, Timo; Rauh, Maribeth; Weidinger, Laura et al. (2022). Improving alignment of dialogue agents via targeted human judgements. arXiv:2209.14375. 
  10. ^ Hu, Edward J.; Shen, Yelong; Wallis, Phillip; Allen-Zhu, Zeyuan; Li, Yuanzhi; Wang, Shean; Wang, Lu; Chen, Weizhu (2021-10-16). “LoRA: Low-Rank Adaptation of Large Language Models”. arXiv:2106.09685 [cs]. http://arxiv.org/abs/2106.09685. 
  11. ^ Wu, Hecong (February 2023), ControlLoRA: A Light Neural Network To Control Stable Diffusion Spatial Information, https://github.com/HighCWu/ControlLoRA 2023年4月27日閲覧。