-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathevaluation_and_predictions_precipitation.py
99 lines (73 loc) · 3.2 KB
/
evaluation_and_predictions_precipitation.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
96
97
98
99
import h5py
import matplotlib.pyplot as plt
import numpy as np
import tensorflow as tf
from tensorflow.keras.models import load_model
from tensorflow.keras.callbacks import ModelCheckpoint
from utils import *
from models import *
from generators import DataGeneratorPrecipitationData as DataGenerator
##---- Evaluating model saved in "saved_models_precipitation/best_model.hdf5" ----##
# Select dataset
# filename = "dataset_precipitation/Data_20/train_test_2016-2019_input-length_12_img-ahead_6_rain-threshhold_20.h5"
filename = "dataset_precipitation/Data_50/train_test_2016-2019_input-length_12_img-ahead_6_rain-threshhold_50.h5"
# Read dataset
try:
f = h5py.File(filename, 'r')
except:
raise Exception('\n\nNo data was found! Get and decompress the data as indicated first.')
# Test data to numpy array
data_test = f['/test/images']
#Parameters
lags = 12
lat = data_test.shape[-2]
long = data_test.shape[-1]
loss = 'mse'
optimizer = tf.keras.optimizers.Adam(learning_rate=0.0001)
batch_size = 2
# Mean value training dataset 50% pixel occurence
threshold = 0.0013051119
# Custom metrics (Denormalized MSE and binarized metrics)
denormalized_mse = MSE_denormalized(47.83, batch_size, reduction_sum=True, latitude=lat, longitude=long) #MSE per image
binarized_metrics = thresholded_mask_metrics(threshold=threshold)
metrics = [denormalized_mse.mse_denormalized_per_image, denormalized_mse.mse_denormalized_per_pixel, binarized_metrics.acc, binarized_metrics.precision, binarized_metrics.recall, binarized_metrics.f1_score, binarized_metrics.CSI, binarized_metrics.FAR]
#Loade model and compile with custom metrics
filepath="saved_models_precipitation/best_model.hdf5"
try:
model = load_model(filepath, compile=False)
except:
raise Exception('\n\nNo trained model was found! Run first the trainig script or request pretrained model.')
model.compile(loss=denormalized_mse.mse_denormalized_per_image, optimizer=optimizer, metrics=metrics)
#Generator
test_generator = DataGenerator(data_test, batch_size, lags)
#Evaluate with generator
print("\nEvaluating...")
result = model.evaluate(test_generator)
print("\n>>> Results evaluation:")
print(" - MSE:", result[2])
print(" - MSE per image:", result[1])
print(" - Acc:", result[3])
print(" - Precision:", result[4])
print(" - Recall:", result[5])
##---- Visualize individual prdiction examples ----##
for t in range(165, 170, 2):
#Generating targets and labels
x = data_test[t:(t+2), :lags, :, :]
y = data_test[t:(t+2), -1, :, :]
x = np.expand_dims(x, axis=-1)
y = np.expand_dims(y, axis=-1)
y = np.expand_dims(y, axis=1)
#Predicting
pred = model.predict(x)
#Visualizing predictions
for i in range(len(pred)):
fig, ax = plt.subplots(1,2, figsize=(8,5), gridspec_kw={'width_ratios': [3.21, 4]})
ax[0].imshow(y[i,0,:,:, 0], origin='lower')
ax[0].set_title("Ground truth", fontsize=16)
ax[0].axis('off')
im=ax[1].imshow(pred[i,0,:,:,0], origin='lower')
ax[1].set_title("Prediction", fontsize=16)
ax[1].axis('off')
fig.tight_layout()
fig.colorbar(im, shrink=0.71)
plt.show()