ANN モデルのハイパーパラメータ調整に keras チューナーを使用しています。モデルのレイヤー数を 2 ~ 5、ノード数を 10 ~ 30 に変更しています。keras チューナーのランダム検索モデルを使用して、最高のパフォーマンスを発揮するモデルを選択しています。結果を観察したところ、上位の結果は次のとおりです。
Best val_mse So Far: 0.03936238835255305
Total elapsed time: 01h 23m 53s
Results summary
Results in project\Sd attempt10
Showing 10 best trials
Objective(name='val_mse', direction='min')
Trial summary
Hyperparameters:
num_layers: 3
units_0: 15
units_1: 15
learning_rate: 0.001
units_2: 10
Score: 0.03936238835255305
Trial summary
Hyperparameters:
num_layers: 3
units_0: 15
units_1: 25
learning_rate: 0.01
units_2: 20
units_3: 25
units_4: 10
Score: 0.03974008063475291
2 番目の試行の要約では、レイヤーは 3 ではありませんが、ユニットは 5 つの非表示レイヤーに存在することがわかります。
結果を取得するためのコード スニペットも添付しました。
def build_model(hp):
model = keras.Sequential()
for i in range(hp.Int('num_layers', 2, 5)):
model.add(layers.Dense(units=hp.Int('units_' + str(i),
min_value=10,
max_value=30,
step=5),
activation='relu'))
model.add(layers.Dense(1, activation='linear'))
model.compile(
optimizer=keras.optimizers.Adam(
hp.Choice('learning_rate', [1e-2, 1e-3, 1e-4])),
loss='mse',#'mean_absolute_error',
metrics=['mse','mae'])#['mean_absolute_error'])
return model
tuner = RandomSearch(
build_model,
objective='val_mse',
max_trials=25,
executions_per_trial=3,
directory='project',
project_name='Sd attempt10')
tuner.search(X_train, y_train,
epochs=100,
validation_data=(Xnew, yact))
print(tuner.results_summary())
誰かが結果でこの動作を説明できますか?