-
Notifications
You must be signed in to change notification settings - Fork 572
/
Copy pathcnn.py
executable file
·95 lines (66 loc) · 3.36 KB
/
cnn.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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# FCN model
# when tuning start with learning rate->mini_batch_size ->
# momentum-> #hidden_units -> # learning_rate_decay -> #layers
import tensorflow.keras as keras
import tensorflow as tf
import numpy as np
import time
from utils.utils import save_logs
from utils.utils import calculate_metrics
class Classifier_CNN:
def __init__(self, output_directory, input_shape, nb_classes, verbose=False,build=True):
self.output_directory = output_directory
if build == True:
self.model = self.build_model(input_shape, nb_classes)
if (verbose == True):
self.model.summary()
self.verbose = verbose
self.model.save_weights(self.output_directory + 'model_init.hdf5')
return
def build_model(self, input_shape, nb_classes):
padding = 'valid'
input_layer = keras.layers.Input(input_shape)
if input_shape[0] < 60: # for italypowerondemand dataset
padding = 'same'
conv1 = keras.layers.Conv1D(filters=6,kernel_size=7,padding=padding,activation='sigmoid')(input_layer)
conv1 = keras.layers.AveragePooling1D(pool_size=3)(conv1)
conv2 = keras.layers.Conv1D(filters=12,kernel_size=7,padding=padding,activation='sigmoid')(conv1)
conv2 = keras.layers.AveragePooling1D(pool_size=3)(conv2)
flatten_layer = keras.layers.Flatten()(conv2)
output_layer = keras.layers.Dense(units=nb_classes,activation='sigmoid')(flatten_layer)
model = keras.models.Model(inputs=input_layer, outputs=output_layer)
model.compile(loss='mean_squared_error', optimizer=keras.optimizers.Adam(),
metrics=['accuracy'])
file_path = self.output_directory + 'best_model.hdf5'
model_checkpoint = keras.callbacks.ModelCheckpoint(filepath=file_path, monitor='loss',
save_best_only=True)
self.callbacks = [model_checkpoint]
return model
def fit(self, x_train, y_train, x_val, y_val, y_true):
if not tf.test.is_gpu_available:
print('error')
exit()
# x_val and y_val are only used to monitor the test loss and NOT for training
mini_batch_size = 16
nb_epochs = 2000
start_time = time.time()
hist = self.model.fit(x_train, y_train, batch_size=mini_batch_size, epochs=nb_epochs,
verbose=self.verbose, validation_data=(x_val, y_val), callbacks=self.callbacks)
duration = time.time() - start_time
self.model.save(self.output_directory+'last_model.hdf5')
model = keras.models.load_model(self.output_directory + 'best_model.hdf5')
y_pred = model.predict(x_val)
# convert the predicted from binary to integer
y_pred = np.argmax(y_pred, axis=1)
save_logs(self.output_directory, hist, y_pred, y_true, duration,lr=False)
keras.backend.clear_session()
def predict(self, x_test,y_true,x_train,y_train,y_test,return_df_metrics = True):
model_path = self.output_directory + 'best_model.hdf5'
model = keras.models.load_model(model_path)
y_pred = model.predict(x_test)
if return_df_metrics:
y_pred = np.argmax(y_pred, axis=1)
df_metrics = calculate_metrics(y_true, y_pred, 0.0)
return df_metrics
else:
return y_pred