-
Notifications
You must be signed in to change notification settings - Fork 283
/
evaluate.py
38 lines (28 loc) · 1.2 KB
/
evaluate.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
"""Evaluate the model"""
import argparse
import os
import tensorflow as tf
from model.input_fn import test_input_fn
from model.model_fn import model_fn
from model.utils import Params
parser = argparse.ArgumentParser()
parser.add_argument('--model_dir', default='experiments/base_model',
help="Experiment directory containing params.json")
parser.add_argument('--data_dir', default='data/mnist',
help="Directory containing the dataset")
if __name__ == '__main__':
tf.reset_default_graph()
tf.logging.set_verbosity(tf.logging.INFO)
# Load the parameters
args = parser.parse_args()
json_path = os.path.join(args.model_dir, 'params.json')
assert os.path.isfile(json_path), "No json configuration file found at {}".format(json_path)
params = Params(json_path)
# Define the model
tf.logging.info("Creating the model...")
estimator = tf.estimator.Estimator(model_fn, params=params, model_dir=args.model_dir)
# Evaluate the model on the test set
tf.logging.info("Evaluation on the test set.")
res = estimator.evaluate(lambda: test_input_fn(args.data_dir, params))
for key in res:
print("{}: {}".format(key, res[key]))