From 162f6b832cdcb99f961373356abddeacb4e20c1e Mon Sep 17 00:00:00 2001 From: RichieHakim Date: Fri, 22 Mar 2024 16:30:23 -0400 Subject: [PATCH] moved initialization of optuna study to __init__ --- bnpm/automatic_regression.py | 51 ++++++++++++++++++------------------ 1 file changed, 25 insertions(+), 26 deletions(-) diff --git a/bnpm/automatic_regression.py b/bnpm/automatic_regression.py index 9c2533c..bcb52d8 100644 --- a/bnpm/automatic_regression.py +++ b/bnpm/automatic_regression.py @@ -202,6 +202,31 @@ def safe_callback(study, trial): else: self.callback_wandb = None + # Set verbosity + if int(self.verbose) <= 1: + optuna.logging.set_verbosity(optuna.logging.WARNING) + elif int(self.verbose) == 2: + optuna.logging.set_verbosity(optuna.logging.INFO) + elif int(self.verbose) > 2: + optuna.logging.set_verbosity(optuna.logging.DEBUG) + + # Initialize an Optuna study + if self.optuna_storage_url is not None: + storage = optuna.storages.RDBStorage( + url=self.optuna_storage_url, + engine_kwargs=self.optuna_engine_kwargs, + ) + else: + storage = None + self.study = optuna.create_study( + direction="minimize", + pruner=optuna.pruners.MedianPruner(n_startup_trials=self.n_startup), + sampler=optuna.samplers.TPESampler(n_startup_trials=self.n_startup), + study_name='Autotuner' if self.optuna_storage_name is None else self.optuna_storage_name, + storage=storage, + load_if_exists=True, + ) + # Initialize variables to store loss and best model self.loss_running_train = [] self.loss_running_test = [] @@ -338,31 +363,6 @@ def fit(self) -> Union[sklearn.base.BaseEstimator, Optional[Dict[str, Any]]]: best_params (Optional[Dict[str, Any]]): The best parameters obtained from hyperparameter tuning. """ - # Set verbosity - if int(self.verbose) <= 1: - optuna.logging.set_verbosity(optuna.logging.WARNING) - elif int(self.verbose) == 2: - optuna.logging.set_verbosity(optuna.logging.INFO) - elif int(self.verbose) > 2: - optuna.logging.set_verbosity(optuna.logging.DEBUG) - - # Initialize an Optuna study - if self.optuna_storage_url is not None: - storage = optuna.storages.RDBStorage( - url=self.optuna_storage_url, - engine_kwargs=self.optuna_engine_kwargs, - ) - else: - storage = None - self.study = optuna.create_study( - direction="minimize", - pruner=optuna.pruners.MedianPruner(n_startup_trials=self.n_startup), - sampler=optuna.samplers.TPESampler(n_startup_trials=self.n_startup), - study_name='Autotuner' if self.optuna_storage_name is None else self.optuna_storage_name, - storage=storage, - load_if_exists=True, - ) - # Optimize the study callbacks = [self.checker.check] + ([self.callback_wandb] if self.callback_wandb is not None else []) self.study.optimize( @@ -733,7 +733,6 @@ def __init__( else: raise ValueError('test_or_train must be either "test" or "train".') - def explainable_variance_ratio(self, v1, v2, sample_weight=None): if isinstance(v1, torch.Tensor): v1 = v1 - torch.nanmean(v1, dim=0)