-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.py
93 lines (76 loc) · 2.93 KB
/
main.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
from data_main import Data
import two_stage
import sddp
import results_analysis_archive as ra
import commands
from plot_gis_archive import Plot
from argparse import ArgumentParser
from argparse import ArgumentDefaultsHelpFormatter as arg_help_format
import warnings
warnings.simplefilter("ignore")
parser = ArgumentParser(formatter_class=arg_help_format)
options, continuous_args, defaults = commands.get_commands()
for arg_name, val_dict in options.items():
parser.add_argument("--" + arg_name,
type=val_dict['type'],
choices=val_dict['choices'],
default=defaults[arg_name],
help=val_dict['help'])
for arg_name, val_dict in continuous_args.items():
parser.add_argument("--" + arg_name,
type=val_dict['type'],
default=defaults[arg_name],
help=val_dict['help'])
args = vars(parser.parse_args())
# correct wrong combinations
if args['model'] == '2ssp':
if args['eval'] not in ['mc_tree', 'oos']:
print('argument \'--eval\' changed to: \'oos\'')
args['eval'] = 'oos'
else: # mssp
args['eval'] = 'both'
if args['method'] == 'ext':
print('argument \'--method\' changed to: \'bb\'')
args['method'] = 'bb'
if args['hurricane'] == 'Ian':
if args['landfall'] == 'd':
print('argument \'--landfall\' changed to: \'r\'')
args['landfall'] = 'r'
if args['instance'] != 3:
print('argument \'--instance\' changed to: \'3\'')
args['instance'] = 3
else: # Florence
if args['landfall'] == 'r':
print('argument \'--landfall\' changed to: \'d\'')
args['landfall'] = 'd'
if args['oos_heur'] == 2:
print('argument \'--oos_heur\' changed to: \'1\'')
args['oos_heur'] == 1
if __name__ == "__main__":
print("Running main.py with:")
print('.' * 30)
print("{:<20} {:<20}".format("arg", "value"))
print('.' * 30)
for key, value in args.items():
print("{:<20} {:<20}".format(key, value))
print('.' * 30, "\n")
data = Data(args)
if args["task"] == "create_data":
data.create_data()
else:
data.read_data()
if args["task"] == "solve":
if args["model"] == "mssp":
sddp.solve_mssp(data, **args)
elif args["model"] == "2ssp":
Model2SSP = two_stage.SolveStaticTwoStage(data, args)
Model2SSP.solve_static_2ssp()
Model2SSP.oos_test_anticipative()
Model2SSP.oos_test_myopic()
# archive >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
elif args["task"] == "plot":
PLOT = Plot(data, args)
PLOT.plot()
elif args["task"] == "analyze_result":
ra.summary(data.DIR[4])
# <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<