diff --git a/mlair/run_modules/experiment_setup.py b/mlair/run_modules/experiment_setup.py index 8036413c8aefc3f70f8c24e59812c1a3b3324de1..209859c1ff38efe2667c918aa5b79c96f2524be0 100644 --- a/mlair/run_modules/experiment_setup.py +++ b/mlair/run_modules/experiment_setup.py @@ -6,6 +6,7 @@ import logging import os import sys from typing import Union, Dict, Any, List, Callable +from dill.source import getsource from mlair.configuration import path_config from mlair import helpers @@ -217,7 +218,7 @@ class ExperimentSetup(RunEnvironment): hpc_hosts=None, model=None, batch_size=None, epochs=None, data_handler=None, data_origin: Dict = None, competitors: list = None, competitor_path: str = None, use_multiprocessing: bool = None, use_multiprocessing_on_debug: bool = None, - max_number_multiprocessing: int = None, **kwargs): + max_number_multiprocessing: int = None, start_script: Union[Callable, str] = None, **kwargs): # create run framework super().__init__() @@ -366,6 +367,10 @@ class ExperimentSetup(RunEnvironment): # set model architecture class self._set_param("model_class", model, VanillaModel) + # store starting script if provided + if start_script is not None: + self._store_start_script(start_script, experiment_path) + # set remaining kwargs if len(kwargs) > 0: for k, v in kwargs.items(): @@ -387,6 +392,18 @@ class ExperimentSetup(RunEnvironment): logging.debug(f"set experiment attribute: {param}({scope})={value}") return value + @staticmethod + def _store_start_script(start_script, store_path): + out_file = os.path.join(store_path, "start_script.txt") + if isinstance(start_script, Callable): + with open(out_file, "w") as fh: + fh.write(getsource(start_script)) + if isinstance(start_script, str): + with open(start_script, 'r') as f: + with open(out_file, "w") as out: + for line in (f.readlines()): + print(line, end='', file=out) + def _compare_variables_and_statistics(self): """ Compare variables and statistics. diff --git a/run.py b/run.py index f2bb336e8a886a3c0c4d60736c77b5ebc27cad67..eb703e11cf9a3028dda0368ac3f7b7ca1578bd2a 100644 --- a/run.py +++ b/run.py @@ -28,7 +28,7 @@ def main(parser_args): evaluate_bootstraps=False, # plot_list=["PlotCompetitiveSkillScore"], competitors=["test_model", "test_model2"], competitor_path=os.path.join(os.getcwd(), "data", "comp_test"), - **parser_args.__dict__) + **parser_args.__dict__, start_script=__file__) workflow.run() diff --git a/run_HPC.py b/run_HPC.py index d6dbb4dc61e88a1e139b3cbe549bc6a3f2f0ab8a..dfa5045bbccf993d2381ff32c5aead90ea6957f3 100644 --- a/run_HPC.py +++ b/run_HPC.py @@ -7,7 +7,7 @@ from mlair.workflows import DefaultWorkflowHPC def main(parser_args): - workflow = DefaultWorkflowHPC(**parser_args.__dict__) + workflow = DefaultWorkflowHPC(**parser_args.__dict__, start_script=__file__) workflow.run() diff --git a/run_hourly.py b/run_hourly.py index 48c7205883eda7e08ee1c14fe3c0a8a9f429e3da..869f8ea16cd4093e04e40f1b05f863ca45ce3c99 100644 --- a/run_hourly.py +++ b/run_hourly.py @@ -22,7 +22,7 @@ def main(parser_args): train_model=False, create_new_model=False, network="UBA", - plot_list=["PlotStationMap"], **parser_args.__dict__) + plot_list=["PlotStationMap"], **parser_args.__dict__, start_script=__file__) workflow.run() diff --git a/run_hourly_kz.py b/run_hourly_kz.py index 5536b56e732d81b84dfee7f34bd68d0d2ba49020..ba2939162c3fd22fc6a611bc7bc21b9334fbfd3b 100644 --- a/run_hourly_kz.py +++ b/run_hourly_kz.py @@ -19,7 +19,7 @@ def main(parser_args): test_end="2011-12-31", stations=["DEBW107", "DEBW013"] ) - workflow = DefaultWorkflow(**args) + workflow = DefaultWorkflow(**args, start_script=__file__) workflow.run() diff --git a/run_mixed_sampling.py b/run_mixed_sampling.py index 6ffb659953157060c39afb5960821e729df555dd..819ef51129854b4539632ef91a55e33a2607eb55 100644 --- a/run_mixed_sampling.py +++ b/run_mixed_sampling.py @@ -36,7 +36,7 @@ def main(parser_args): test_end="2011-12-31", **parser_args.__dict__, ) - workflow = DefaultWorkflow(**args) + workflow = DefaultWorkflow(**args, start_script=__file__) workflow.run() diff --git a/run_zam347.py b/run_zam347.py index 352f04177167441d3636359a9f6ade5f039c12c1..49fce3e7a0c0f2b24691c5b02590ff435300f552 100644 --- a/run_zam347.py +++ b/run_zam347.py @@ -31,7 +31,7 @@ def load_stations(): def main(parser_args): - workflow = DefaultWorkflowHPC(stations=load_stations(), **parser_args.__dict__) + workflow = DefaultWorkflowHPC(stations=load_stations(), **parser_args.__dict__, start_script=__file__) workflow.run()