-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathregress_nn_future_era.py
33 lines (22 loc) · 1013 Bytes
/
regress_nn_future_era.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import pickle
import xarray
from sklearn.preprocessing import StandardScaler
from sklearn.model_selection import train_test_split
import tensorflow as tf
from tensorflow.keras.layers import Input, Dense, Activation, Dropout
from tensorflow.keras.models import Model
x = xarray.open_dataarray('data/x_training_future_era.nc')
pcs = xarray.open_dataarray('data/pcs_training_future_era.nc')
sc = StandardScaler()
X_train = sc.fit_transform(x)
y_train = pcs
input_layer = Input(shape=(X_train.shape[1],))
dense_layer_1 = Dense(100, activation='relu')(input_layer)
dense_layer_2 = Dense(50, activation='relu')(dense_layer_1)
dense_layer_3 = Dense(25, activation='relu')(dense_layer_2)
output = Dense(2)(dense_layer_3)
model = Model(inputs=input_layer, outputs=output)
model.compile(loss="mean_squared_error", optimizer="adam", metrics=["mean_squared_error"])
history = model.fit(X_train, y_train, epochs=500, verbose=1)
pickle.dump(sc, open("data/scaler_future_era", "wb"))
model.save('data/nn_future_era')