-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathretrain.py
32 lines (24 loc) · 1.23 KB
/
retrain.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
from src.representation import load_representations
from src.makeMolecule import molecule_list, normalize, input_checker, store_bad_molecules
from src.crossDouble import training, write_statistics
from src.plots import output_plot
from src.results_processing import train_results_to_logfile
import sys
import time
start = time.time()
input_checker(sys.argv, "retrain")
molecule_file = sys.argv[1]
target_property = str(sys.argv[2])
save_folder = sys.argv[3]
molecules, outputs, conformers, bad_molecules = molecule_list(molecule_file)
store_bad_molecules(bad_molecules, save_folder)
output_plot(molecules, outputs, target_property, folder=save_folder)
representations, molecules = load_representations(molecules, conformers, save_folder)
outputs, heavy_atoms = normalize(molecules, outputs, target_property)
n_folds = 10 # TODO: Make argument
cv_info = training(molecules, heavy_atoms, representations, outputs, save_folder, target_property, n_folds)
end = time.time()
time_elapsed = end-start
results_list = write_statistics(cv_info, target_property, n_folds, time_elapsed, save_folder)
train_results_to_logfile(molecules, outputs, results_list, representations,
target_property, molecule_file, time_elapsed, save_folder)