Skip to Content
Deep Learning 向けの PyTorch プログラミング
book

Deep Learning 向けの PyTorch プログラミング

by Ian Pointer
May 2025
Intermediate to advanced
220 pages
3h 27m
Japanese
O'Reilly Media, Inc.
Content preview from Deep Learning 向けの PyTorch プログラミング

第4章. 転移学習とその他のトリック

この作品はAIを使って翻訳されている。ご意見、ご感想をお待ちしている:translation-feedback@oreilly.com

前章でアーキテクチャを見てきて、すでに学習済みのモデルをダウンロードしてさらに学習させることはできないかと思うかもしれない。答えはイエスだ!あるタスク(例えばImageNet)のために訓練されたネットワークを、別のタスク(魚対猫)に適応させるの

なぜこんなことをするのか?ImageNetで訓練されたアーキテクチャは、すでに画像について非常に多くのことを知っており、特に、何かが猫なのか魚なのか(犬なのかクジラなのか)についてはかなり詳しいことがわかった。基本的に空白のニューラルネットワークから始める必要がなくなるため、転移学習ではトレーニングに費やす時間が大幅に短縮されトレーニングデータセットも大幅に少なくすることができる。従来のDeep Learningアプローチでは、良い結果を出すために膨大な量のデータが必要だった。転移学習を使えば、数百枚の画像で人間レベルの分類器を構築できる。

ResNetによる転移学習

今、やるべきことは、第3章でやったようにResNetモデルを作成して、それを既存のトレーニングループに組み込むことだ。それは可能だ!ResNetモデルには何も不思議なところはない。すでに見たのと同じ構成要素から作られている。しかし、これは大きなモデルであり、あなたのデータでベースラインのResNetよりも多少の改善は見られるだろうが、トレーニング信号がアーキテクチャのすべての部分に届き、新しい分類タスクに向けて大きくトレーニングされるようにするには、多くのデータが必要になる。このアプローチでは、多くのデータを使うことを避けようとしている。

しかし、ここで重要なのは、これまでのようにランダムなパラメータで初期化されたアーキテクチャを扱っているわけではないということだ。学習済みのResNetモデルには、画像認識や分類に必要な情報がすでにエンコーディングされている。その代わりに、ネットワークを微調整する。通常ImageNet分類を行う標準的な1,000カテゴリの線形レイヤーの代わりに、最後に新しいネットワークブロックを含むように、階層化アーキテクチャを少し変更する。そして、既存のResNetレイヤーをすべてフリーズさせ、学習時には、新しいレイヤーのパラメータのみを更新するが、フリーズさせたレイヤーのアクティブ度はそのまま利用する。これにより、事前学習済みのレイヤーが既に持っている情報を保持したまま、新しいレイヤーを素早く学習することができる。

まず、事前学習済みのResNet-50モデルを作成しよう:

from torchvision import models
transfer_model = models.ResNet50(pretrained=True)

次に、レイヤーをフリーズさせる必要がある。その方法は簡単で、requires_grad() を使って、アキュムレータが勾配を蓄積しないようにする。これはネットワークのすべてのパラメータに対して行う必要があるが、便利なことにPyTorchはparameters() メソッドを提供しており、これを使うとかなり簡単にできる:

for name, param in transfer_model.named_parameters():
    param.requires_grad = False
チップ

モデルのBatchNorm ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

生成 Deep Learning 第2版 ―絵を描き、物語や音楽を作り、ゲームをプレイする

生成 Deep Learning 第2版 ―絵を描き、物語や音楽を作り、ゲームをプレイする

David Foster, 松田 晃一, 小沼 千絵
直感 Deep Learning ―Python×Kerasでアイデアを形にするレシピ

直感 Deep Learning ―Python×Kerasでアイデアを形にするレシピ

Antonio Gulli, Sujit Pal, 大串 正矢, 久保 隆宏, 中山 光樹

Publisher Resources

ISBN: 9798341650367