我正在嘗試使用 Keras (2.8.0) 自動調諧器來解決回歸問題。這是我的代碼:
import pandas as pd
from tensorflow import keras
from keras import layers, losses
from keras_tuner.tuners import RandomSearch
df = pd.read_csv('./datasets/data.csv')
X = df.iloc[:, :-1]
y = df.iloc[:, -1]
def build_model(hp):
model = keras.Sequential()
for i in range(hp.Int('num_layers', 2, 20)):
model.add(layers.Dense(units=hp.Int('units_' str(i),
min_value=32,
max_value=512,
step=32),
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=losses.MeanAbsoluteError(reduction="auto", name="mean_absolute_error"),
metrics=['mean_absolute_error'])
return model
tuner = RandomSearch(
build_model,
objective='val_mean_absolute_error',
max_trials=5,
executions_per_trial=3,
directory='project',
project_name='TunerTest')
model_summary = tuner.search_space_summary()
print(model_summary)
from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=0)
tuner.search(X_train, y_train,
epochs=5,
validation_data=(X_test, y_test))
tuner.results_summary()
代碼運行沒有任何錯誤(假設如此),但在結果中,對于所有迭代,Score都是nan. 以下是其中一次運行的輸出:
Showing 10 best trials
<keras_tuner.engine.objective.Objective object at 0x7fef945235d0>
Trial summary
Hyperparameters:
num_layers: 12
units_0: 128
units_1: 224
learning_rate: 0.01
units_2: 32
units_3: 32
units_4: 32
units_5: 32
units_6: 32
units_7: 32
units_8: 32
units_9: 32
units_10: 32
units_11: 32
Score: nan
我在這里做錯了什么?
uj5u.com熱心網友回復:
這可能是由于您的資料具有nan非常接近于零的值或值。另一個問題可能是資料的差異。也許嘗試對其進行歸一化以避免爆炸梯度甚至應用漸變剪裁。使用隨機資料時,您的代碼有效,但結果不是nan:
import pandas as pd
from tensorflow import keras
from keras import layers, losses
from keras_tuner.tuners import RandomSearch
import numpy as np
X = np.random.random((500, 5))
y = np.random.random((500, 1))
def build_model(hp):
model = keras.Sequential()
for i in range(hp.Int('num_layers', 2, 20)):
model.add(layers.Dense(units=hp.Int('units_' str(i),
min_value=32,
max_value=512,
step=32),
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=losses.MeanAbsoluteError(reduction="auto", name="mean_absolute_error"),
metrics=['mean_absolute_error'])
return model
tuner = RandomSearch(
build_model,
objective='val_mean_absolute_error',
max_trials=5,
executions_per_trial=3,
directory='project',
project_name='TunerTest')
model_summary = tuner.search_space_summary()
from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=0)
tuner.search(X_train, y_train,
epochs=5,
validation_data=(X_test, y_test))
tuner.results_summary()
...
Trial summary
Hyperparameters:
num_layers: 20
units_0: 512
units_1: 384
learning_rate: 0.01
units_2: 32
units_3: 32
units_4: 32
units_5: 32
units_6: 32
units_7: 32
units_8: 32
units_9: 32
units_10: 32
units_11: 32
units_12: 32
units_13: 32
units_14: 32
units_15: 32
units_16: 32
units_17: 32
units_18: 32
units_19: 32
Score: 0.24690431356430054
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/464826.html
標籤:Python 张量流 喀拉斯 深度学习 keras 调谐器
上一篇:在張量流圖中執行查找
