1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

【初心者向け】[環境構築不要][コーディング不要] MNIST を題材に GAN, GRAD-CAM を手軽に実行する on AAS

Last updated at Posted at 2019-12-07

目次

  • 概要
  • 用語
  • 操作説明

概要

AAS(Amazing AI Studio)上で提供されているテンプレートを利用し、データ収集、前処理、学習モデル作成、訓練、検証、推論、データ生成、特徴の可視化方法について理解する

用語

  • MNIST(Modified National Institute of Standards and Technology) とは
    画像処理のトレーニングとテストに使用される「手書き数字」の※大規模データベースです。
    ※大規模データベース:手書き数字画像{トレーニング用:60,000 枚、テスト用:10,000 枚}+対応する画像の正解ラベル(教師データ)

  • GAN(Generative Adversarial Nets) とは
    教師なし学習で使用される生成モデル(画像などを作れる)の一種。
    【コンセプト】贋作者と鑑定士の役を演ずる学習モデル 2 つを競わせる
     ・贋作者:Generator    ・・・鑑定士を騙せるようなデータを生成する(画像を作る)
     ・鑑定士:Discriminator  ・・・贋作者が生成したデータを贋作だと見抜く

  • ACGAN (Auxiliary Classifier Generative Adversarial Nets) とは
     Discriminatorに補助のクラス分類器を付けることでクラスを指定した画像生成が可能になったGANです。
     今回のMNISTを題材とした場合、0~9というクラスそれぞれの数字を指定して画像生成できます。

  • GRAD-CAM(Gradient-weighted Class Activation Mapping) とは
    CNN(Convolutional Neural Network)を利用した分類を行った際、「画像のどの部分に注目して分類したのか」を可視化する手法

  • AAS(Amazing AI Studio) とは
    機械学習向けのビジュアルエディタと実行環境が一緒になったオンライン版 IDE のようなサイトです。
    プログラミングに関してはデータ収集、前処理、訓練、推論、データ生成、特徴の可視化全てをビジュアルブロックを利用しノンコーディングで実現できます。
    また、プログラムの実行は利用ブラウザの JavaScript でなされます。機械学習に関しては tensorflow.js を介して GPU 上(CPU 内臓の GPU も可)で実行されるため計算量が少ない分にはタブレッドやスマホでも訓練・推論が実行できます。
    https://amazing-ai-studio.com/index_ja/

操作説明

[1/4] MNIST

データ収集、前処理、訓練、推論の流れを確認します

  • 作品集のリンクまたは画面上部のGalleriesのリンクを押します
    001_goto_gallery.PNG

  • 『MNIST』を探して「USE THIS」ボタンを押してちょっと待ちます
    002_goto_gallery.PNG

  • Workflows の一番下に『MNIST』が増えているのでそれを選択します
    003_goto_gallery.PNG

  • ビジュアルエディタを上にスクロールして以下の点を確認します

    • [データ収集] MNIST のデータを 6,500 件収集 (本来あるデータ全体の10分の1)
      004_goto_gallery.PNG

    • [前処理] 収集したデータを「訓練」「検証&テスト」用途に 85:15 の割合で分割

    • [前処理] 上記データのラベルを one-hot エンコーディングする

    • [学習モデル作成] 畳み込みとmaxPoolingを 2 組内包したモデルを作成
      005_goto_gallery.PNG

    • [訓練/検証] 200 イテレーション回して数字の特徴を学習する。その際 5回に1回の割合で検証
      006_goto_gallery.PNG

    • [推論] ランダムにピックアップしたテストデータを学習済みのモデルに投入しての結果確認
      007_goto_gallery.PNG

  • 『RUN BLOCKS』ボタンを押してプログラムを読み込みます
    008_goto_gallery.PNG

  • 『LOAD DATA』から順番にボタンをポチポチ押していきます
    009_goto_gallery.PNG

  • 訓練中は自動的にACC/LOSSの値が可視化されるので眺めて待ちます
    010_goto_gallery.PNG

  • 推論した結果を『Images』タブで確認します
    011_goto_gallery.PNG

[2/4] MNIST HANDWRTING RECOGNITION with Grad-CAM

自分で手書きした文字を推論で利用する、学習モデルの保存と読み出し、Grad-CAM利用の流れを確認します

  • [1/4]同様に作品集を開きます

  • 『MNIST HANDWRTING RECOGNITION with Grad-CAM』を探して「USE THIS」ボタンを押してちょっと待つ
    002_001.png

  • Workflows の一番下に『MNIST HANDWRTING RECOGNITION with Grad-CAM』が増えているのでそれを選択します

  • ビジュアルエディタを上にスクロールして以下の点を確認します

    • [前処理] Grad-CAMへの入力に合うようにモノクロ1CHのデータをRGBの3CHになるように変換している
      002_005.png
      002_006.png

    • [学習モデル作成] [1/4]との相違点としてGrad-CAMへの入力に合うようにモノクロ1CHからRGBの3CHに入力層の次元を変更してある
      002_004.png

    • [訓練] 訓練後の学習モデル保存及び、それを読み出すブロック

    • 002_007.png

    • [推論] Grad-CAMの結果をSketch上に描画

    • 002_008.png

  • 尚、PCで利用する場合はテンプレートのままではなく、訓練の対象を増やした方が精度が上がります
    002_003.png

    • MNIST の取得データを 16,250 件に変更する
    • 1イテレーションでピックアップする件数を200件に変更する
  • 『RUN BLOCKS』ボタンを押してプログラムを読み込みます

  • 『LOAD DATA』から順番にボタンをポチポチ押していきます

  • 但し、「LOAD PRE-TRAINDED MODEL」ボタンは押しません
    002_009.png
  • 推論時「DRAW CANVAS」にて数字を手書き後に「PREDICT」ボタンを押します
    002_010.png

  • 推論した結果を『Sketch』タブで確認します

    • 最後のCNN層に於ける着目箇所がヒートマップで可視化されています
      002_011.png
  • ブラウザ再起動後など、学習済みモデルを再利用したい場合

  • 「LOAD DATA」~「TRAIN MODEL」をスキップして「LOAD PRE-TRAINDED MODEL」を押し、学習済みモデルをロードします
  • ロード後、ロード前と同様に推論します
    002_012.png

[3/4] Simple MNIST GAN

ランダムなベクトルを入力として数字っぽい画像を作成できることを確認します

  • 今回は『Workflow』ページ内で『Workflows』ビュー左側の『New』ボタンから『Simple MNIST GAN』のテンプレートを選択する
    003_001_simgle_gan.png

  • ビジュアルエディタを上にスクロールして以下の点を確認します

    • [訓練] Discriminator(鑑定士)とGenerator(贋作者)各々のオプティマイザーの存在を確認します
      003_002_simgle_gan.png
    • [生成] 画像を生成する際はランダムなベクトルを種としていることを確認します
      003_003_simgle_gan.png
  • 『RUN BLOCKS』ボタンを押してプログラムを読み込みます

    • データ生成専用のボタンが確認できます

      003_004_simgle_gan.png

  • 『LOAD DATA』、『TRAIN MODEL』と順次押します

  • 訓練中の動作

    • LOSSはDiscriminator(鑑定士)とGenerator(贋作者)の両方が可視化されます
    • 50EPOCH毎に画像が生成され、その内容は『Images』タブにて確認します
    • 『Images』タブでは追加画像が左上に追加挿入されると見やすいので『Prepend』を有効にします
      003_005_simgle_gan.png
  • 鑑定士、贋作者のLOSSの推移と、贋作者の作成した数字っぽい画像を確認します
    003_006_simgle_gan.png

  • 『GENERATE FROM GENERATOR』ボタンを押すと新たな画像が生成できます
    003_007_simgle_gan.png

[4/4] ACGAN on the MNIST Dataset

0~9というクラスそれぞれの数字を指定して画像生成できることを確認します

  • 『ACGAN on the MNIST Dataset』のテンプレートを選択します
    004_001_acgan.png

  • 『RUN BLOCKS』ボタンを押してプログラムを読み込みます

  • 『LOAD DATA』から順番にボタンをポチポチ押していきます

  • [訓練中] 生成される画像がみずらいです

    • 0~9の10個分横並びのためサムネイルが小さく識別しずらいです
    • Prependスイッチ右のプルダウンでサムネイルのサイズが切り替えできるので『Original』を選択します
    • 004_002_acgan.png
    • 004_003_acgan.png
  • 最終的にこのような画像の生成が確認できます

    • 300 EPOCHまでは数字にはみえないです
    • 400 EPOCHから突然数字っぽくなってます
    • 550 EPOCH以降は、テンプレートのままのハイパーパラメータではあまり生成画像の変化は見られません
    • 004_004_acgan.png
1
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?