質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Keras

Kerasは、TheanoやTensorFlow/CNTK対応のラッパーライブラリです。DeepLearningの数学的部分を短いコードでネットワークとして表現することが可能。DeepLearningの最新手法を迅速に試すことができます。

Python 2.7

Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

5790閲覧

kerasでニューラルネット(正解データの正規化の必要性)

yamato_user

総合スコア2321

Keras

Kerasは、TheanoやTensorFlow/CNTK対応のラッパーライブラリです。DeepLearningの数学的部分を短いコードでネットワークとして表現することが可能。DeepLearningの最新手法を迅速に試すことができます。

Python 2.7

Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

1グッド

1クリップ

投稿2020/01/03 12:44

下記のようにデータを生成し、学習させました。
結果としては、正常に動作しましたが、中間層の数を増やすと、loss=nanとなります。

質問1:これは勾配爆発が起きているということでしょうか?
質問2:正解データ(y_train/y_test)の方も正規化させて、学習させると、正常に学習が進行しました。予測値の算出は、正規化された値から、元の値を復元して算出していますが、このように、正解データ(y_train/y_test)も正規化させるという方法は一般的でしょうか?
質問3:正解データ(y_train/y_test)は正規化させないで、SGDからAdamに変えてやると、学習は正常に進行します。勾配の更新方法の違いだと思いますが、Adamでも正解データ(y_train/y_test)を正規化させた方がいいでしょうか?

入力データ(X_train/X_test)を正規化させる必要があることは知っていましたが、正解データ(y_train/y_test)の方の正規化の必要性に関しては聞いたことがなく。。。ご教示お願い致します。

# 連続値データの読み込み from sklearn.datasets import load_boston boston = load_boston() # 訓練データとテストデータに分ける from sklearn.model_selection import train_test_split X_train, X_test, y_train, y_test = train_test_split(boston['data'], boston['target'], test_size=0.3, random_state=0) # 正規化(Normarization) from sklearn.preprocessing import MinMaxScaler scaler_x = MinMaxScaler() X_train_n = scaler_x.fit_transform(X_train) X_test_n = scaler_x.transform(X_test)
# 基本モデル生成 from keras.models import Sequential model = Sequential() # 層の追加 from keras.layers import Dense # 中間層 model.add(Dense(128, activation='relu' # 活性化関数)) # 出力層 model.add(Dense(1, activation='linear' # 活性化関数)) # モデルの学習設定 from keras import losses from keras import optimizers model.compile( loss=losses.mean_squared_error,# 平均二乗誤差 optimizer=optimizers.SGD(lr=0.01),# 確率的勾配降下法 ) # モデルの学習 result = model.fit( X_train_n, y_train_n, epochs=100 )
退会済みユーザー👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

質問1:これは勾配爆発が起きているということでしょうか?
隠れ層増加によるNaN発生@stackoverflowによれば、

  • 層を追加することで勾配が不安定になり、結果としてNaNになりうる

だそうですので、答えは恐らくYesです。

対策:

  • xavier initializerによって解決できる可能性がある
  • バッチサイズと学習率を下げれば何とかなるかもしれない

質問2:正解データ(y_train/y_test)も正規化させるという方法は一般的でしょうか?
回帰問題で正解データを正規化する、という操作を私は初耳ですが、前例はあるようです。

  • 回帰させる値の範囲が0~1000のような広い範囲より0~1に押し潰した方が回帰線を計算したときの誤差が小さいからです。ぜひやってください。

だそうです。

質問3:(要旨:正規化させなくてもAdamならうまくいくが)Adamでも正解データ(y_train/y_test)を正規化させた方がいいでしょうか?
質問2の答えから察するに「やった方がいいけれども、やらなくてもうまくいくしそうそうlossが変わらないなら無駄かも」が当たり所と思われます。
何より、こういうデータは少ないですので、可能でしたら試行してぜひとも結果を共有いただければと思います。

投稿2020/01/03 18:41

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問