3_モデル設定_keras
差分
このページの2つのバージョン間の差分を表示します。
| 両方とも前のリビジョン前のリビジョン次のリビジョン | 前のリビジョン | ||
| 3_モデル設定_keras [2017/11/04] – [(3)モデルの設定(Keras)] adash333 | 3_モデル設定_keras [2018/10/07] (現在) – 外部編集 127.0.0.1 | ||
|---|---|---|---|
| 行 10: | 行 10: | ||
| -[[(7)推測(Keras)]] | -[[(7)推測(Keras)]] | ||
| - | 最初に以下をコピペするだけですが、プログラムごとに、さらにimport文の追加が必要になる場合があります。 | + | model = Sequential()からスタートして、順番にモデルを記述していきます。 |
| < | < | ||
| - | import keras | + | #3 モデルの記述(Keras) |
| - | from keras.models import Sequential | + | batch_size = 128 |
| - | from keras.layers import Dense, Dropout | + | num_classes = 10 |
| - | from keras.optimizers import RMSprop | + | # epochs = 20 |
| - | from keras.utils import np_utils | + | epochs = 3 |
| - | from sklearn.model_selection import train_test_split | + | model = Sequential() |
| + | # model.addでモデルを記述していく | ||
| - | import numpy as np | + | model.summary() |
| - | from PIL import Image | + | |
| - | import os | + | model.compile(loss=' |
| + | optimizer=RMSprop(), | ||
| + | metrics=[' | ||
| </ | </ | ||
| - | 始めはかなりとっつきにくいimport文ですが、pythonの勉強をしていくにつれて、徐々に、慣れてきます。 | + | モデルの記述は、見たままな感じで、個人的にはKerasのこのモデルの記述方法が分かりやすくて好みです。 |
| + | |||
| + | |||
| + | ===== 開発環境 ===== | ||
| + | Windows 8.1\\ | ||
| + | Anaconda \\ | ||
| + | Python 3.5\\ | ||
| + | Tensorflow 1.4\\ | ||
| + | Keras 2.0.9\\ | ||
| + | |||
| + | Keras2.0のインストール方法は[[windowsにkeras2.0をインストール]]をご覧下さい。 | ||
| + | |||
| + | このページは、[[(2)データ準備(Keras)]]の続きであり、今回は、モデルの設定を行っていきます。 | ||
| + | |||
| + | ===== 手順 ===== | ||
| + | |||
| + | |||
| + | ==== 0. 前回終了時の画面 ==== | ||
| + | [[(2)データ準備(Keras)]]終了時の、以下のような状態から始めます。 | ||
| + | |||
| + | {{: | ||
| + | ==== 1. モデルの設定 ==== | ||
| + | 以下のコードを入力して、Shift + Enterを押します。 | ||
| + | |||
| + | < | ||
| + | #3 モデル設定(Keras) | ||
| + | batch_size = 128 | ||
| + | # num_classes = 10 | ||
| + | # epochs = 20 | ||
| + | epochs = 3 | ||
| + | |||
| + | # モデルの記述 | ||
| + | model = Sequential() | ||
| + | model.add(Dense(512, | ||
| + | model.add(Dropout(0.2)) | ||
| + | model.add(Dense(512, | ||
| + | model.add(Dropout(0.2)) | ||
| + | model.add(Dense(10, | ||
| + | |||
| + | model.summary() | ||
| + | |||
| + | # 損失関数などを設定 | ||
| + | model.compile(loss=' | ||
| + | optimizer=RMSprop(), | ||
| + | metrics=[' | ||
| + | </ | ||
| + | |||
| + | 以下のような画面になります。 | ||
| + | |||
| + | {{: | ||
| + | |||
| + | {{: | ||
| + | |||
| + | 順に解説していきます。 | ||
| + | |||
| + | < | ||
| + | #3 モデル設定(Keras) | ||
| + | batch_size = 128 | ||
| + | # num_classes = 10 | ||
| + | # epochs = 20 | ||
| + | epochs = 3 | ||
| + | </ | ||
| + | |||
| + | batch_size, epochsなどの数値を設定します。epochsは、学習を繰り返す回数であり、回数が少なすぎても、多すぎても微妙と言われています(参考: | ||
| + | |||
| + | batch_sizeについては、まだよく分かっていないので、今後、勉強して内容が理解できたら、こちらに追加記載させていただきたいと思います。 | ||
| + | |||
| + | < | ||
| + | # モデルの記述 | ||
| + | model = Sequential() | ||
| + | model.add(Dense(512, | ||
| + | model.add(Dropout(0.2)) | ||
| + | model.add(Dense(512, | ||
| + | model.add(Dropout(0.2)) | ||
| + | model.add(Dense(10, | ||
| + | </ | ||
| + | |||
| + | "model = Sequential()" | ||
| + | |||
| + | 今回は、4層のMLP(multiple layer perceptron)のモデルを設定しています。 | ||
| + | < | ||
| + | model.add(Dense(512, | ||
| + | model.add(Dropout(0.2)) | ||
| + | </ | ||
| + | 1層目の入力層は28x28=784個のunit(ノード)で、2層目の中間層は512個のunit(ノード)に設定しています。\\ | ||
| + | 2層目の活性化関数はrelu関数を用いており、\\ | ||
| + | その後、ドロップアウトといって、過学習を防ぐために、512個のunit(ノード)のうち、20%のunit(ノード)を無効化します。 | ||
| + | |||
| + | この話、初めての方には本当に訳わからん状態だとは思いますが、機械学習の理論のところなので、あとで、以下の本を読んで理解するのがお勧めです。 | ||
| + | |||
| + | < | ||
| + | <iframe style=" | ||
| + | </ | ||
| + | |||
| + | (参考)\\ | ||
| + | 2016-07-18 | ||
| + | 【Deep Learning】過学習とDropoutについて\\ | ||
| + | http:// | ||
| + | |||
| + | コードの解説に戻ります。 | ||
| + | |||
| + | < | ||
| + | model.add(Dense(512, | ||
| + | model.add(Dropout(0.2)) | ||
| + | </ | ||
| + | 上記と同様、3層目の中間層を512個のunit(ノード)に設定していて、\\ | ||
| + | 3層目の活性化関数はrelu関数を用いており、\\ | ||
| + | 過学習を防ぐために、512個のunit(ノード)のうち、20%のunit(ノード)を無効化します。 | ||
| + | |||
| + | < | ||
| + | model.add(Dense(10, | ||
| + | </ | ||
| + | 4層目は出力層であり、0から9までの10個に分類するので、4層目は10個のunit(ノード)となります。\\ | ||
| + | 分類問題なので、出力層では活性化関数をsoftmax関数を用いることになります。\\ | ||
| + | 蛇足ですが、回帰分析を行いたい場合は、分類問題の最後のsoftmax関数を恒等関数に変更し、損失関数 (loss function) として2乗和誤差 (mean squared error) を設定すればよいと思われます。 | ||
| + | |||
| + | 入力層と出力層のunit(ノード)数は、常に一定ですが、中間層の層の数を深くしたり(Deep Learning)、中間層のunit(ノード)数を変更したり、畳み込み(Convolution)やMax Poolingを行ったり、損失関数の設定値を変更したりしてモデルをいじることにより、より高い正解率をたたき出すことが求められており、例えば、https:// | ||
| + | |||
| + | < | ||
| + | model.summary() | ||
| + | </ | ||
| + | modelをテキストで表示してくれます | ||
| + | |||
| + | < | ||
| + | # 損失関数などを設定 | ||
| + | model.compile(loss=' | ||
| + | optimizer=RMSprop(), | ||
| + | metrics=[' | ||
| + | </ | ||
| + | 損失関数にcategorical_crossentropy関数を用いています。\\ | ||
| + | categorical_crossentropy: | ||
| + | |||
| + | 今回は、最適化関数(optimizer)に、RMSprop()を用いています。\\ | ||
| + | metricsについてはよくわかりません。。。(爆) | ||
| + | |||
| + | KerasでのModel設定の手順は上記でおしまいです。 | ||
| + | |||
| + | 初めての場合は、次は、とりあえず、< | ||
| + | |||
| + | |||
| + | ===== kerasで損失関数(=目的関数)の利用方法 ===== | ||
| + | |||
| + | 作成中 | ||
| - | keras特有のもの以外のimport文については、以下のリンクをご覧ください。 | + | (参考) |
| + | 損失関数の利用方法について\\ | ||
| + | https:// | ||
| + | https:// | ||
| - | 機械学習で用いるpythonの”import xxx”まとめ\\ | ||
| - | 2017/ | ||
| - | http:// | ||
| + | 機械学習における誤差関数、損失関数、etcについて\\ | ||
| + | http:// | ||
| + | ===== Optimizerについて ===== | ||
| + | optimizer(最適化)について\\ | ||
| + | https:// | ||
| ===== 参考文献 ===== | ===== 参考文献 ===== | ||
| 初めてKerasプログラミングをやるときの超おすすめ本。\\ | 初めてKerasプログラミングをやるときの超おすすめ本。\\ | ||
3_モデル設定_keras.1509781203.txt.gz · 最終更新: 2018/10/07 (外部編集)
