#シリーズ目次
- 機械学習の理論を理解せずに tensorflow で オセロ AI を作ってみた ~導入編~
- 機械学習の理論を理解せずに tensorflow で オセロ AI を作ってみた ~実装編~
- 機械学習の理論を理解せずに tensorflow で オセロ AI を作ってみた ~いざ対戦編~
- 機械学習の理論を理解しようとしてから オセロ AI を作ってみた 〜再始動‼〜
- 機械学習の理論を理解しようとしてから オセロ AI を作ってみた 〜何これ Alpha Zero 編〜
- エクセルでニュートラルネットワークを作ってみた 〜画像認識 mnist 編〜
エクセルでニュートラルネットワークを作ってみた
はじめにソースコードをダウンロードします。
ソースはここにおいておきます。
$ git clone https://github.com/sasaco/excel_deeplearning.git
フォルダ構成
今回作成した エクセルファイル(mnist.xlsm) と 10種類のフォルダに分けた学習用のビットマップ画像(*.bmp)をたくさん用意しました
操作方法
モードは2つあります
- 学習をするモード
- 学習したニュートラルネットワークを試すモード
1. 学習をするモード の操作方法
上図 1 ~ 10 で指定したフォルダ内の 28 × 28 ピクセルの画像に対して学習を行います
学習 とは 下図の赤字の数値を更新することを意味しています。
- 重みリセットボタン をクリックすると 初期化します。
- 学習開始ボタン をクリックすると 上図 1 ~ 10 で指定したフォルダ内のすべての画像ファイルについて学習開始します
2. 学習したニュートラルネットワークを試すモード の操作方法
判定ボタン をクリックすると 判定したい画像ファイルを選択するウィンドウが表示されます
それまでに 学習したニュートラルネットワークによって 上図 1 ~ 10 から予測を示します。
ニュートラルネットワークのしくみ
このExcel で構築しているニュートラルネットワークの構成図
入力層
入力は 28×28ピクセルのビットマップの各ピクセルの青色の強度を入力層にします
値は 255 で除した 0~1 の値を入力値にしました。
中間層
出力
出力層は 1 ~ 10 で それぞれの出力が 学習した 1 ~ 10 の可能性を示している
下図の場合、5番目が 0.88244 で最大となっているので、このニュートラルネットワークスは
入力に対して、5番目が一番可能性があると判断している
ニュートラルネットワークとは
- ∑ 入力値 × 中間層の重み係数 = 中間層層の出力値
- ∑ 出力層の入力値 × 出力層の重み係数 = 出力値
中間層の出力値 → 出力層の入力値 とするときに活性化関数を通します。
活性化関数はいろいろあるようですが、今回採用した関数は、下式のシグモノイドです
重み係数の調整
Excelの赤い数値(重み係数)を調整して、数字が認識できるようにします。
出力値と正解値との差
下図は1番目の画像を読み込んだ時、ニュートラルネットワークが5番目が 0.88244で最も可能性が高いと判断している
ニュートラルネットワークが出した数値と正解値(0.99 か 0.01)との差を error とする
正解値を算出する重み係数は
ニュートラルネットワークが出した数値と正解値との差 が分かったら
正しい値を算定する重み係数は、上記を逆算すればよい
① × ② × ③ × ④ + ⓹
① ニュートラルネットワークが出した数値と正解値との差
② 活性化関数の逆数(微分)
③ 入力層
④ 学習率
⓹ もともとの重み係数
学習率とは 一回の更新で 100% 反映してしまうと学習が収斂しないので、少しづつ学習するための係数
重み係数の更新
出力値と正解値との差 から 新しい 重み係数が分かったら、重み係数を更新します。
Excel の場合 青い数値を赤い数値にコピーする行為です。
この一連の動作を繰り返して 画像認識できるニュートラルネットワークを育てます。
学習実行
学習を実行したら 200000回の学習で正解率 90% になりました
4日間かかりました。