{"cells":[{"cell_type":"markdown","source":[" # A simple test of using `optuna` for hyperparameter optimization"],"metadata":{}},{"cell_type":"code","execution_count":1,"source":["import os\n","import time\n","from types import SimpleNamespace\n","from functools import partial\n","\n","import pydove as dv\n","from tqdm.notebook import tqdm\n","\n","import torch\n","from cpcn import PCNetwork, load_mnist, Trainer\n","\n","import optuna\n","from optuna.trial import TrialState\n","\n","import pickle"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ## Defining the optimization"],"metadata":{}},{"cell_type":"code","execution_count":2,"source":["def optuna_reporter(trial: optuna.trial.Trial, ns: SimpleNamespace):\n","    trial.report(ns.val_loss, ns.epoch)\n","\n","    # early pruning\n","    if trial.should_prune():\n","        raise optuna.exceptions.TrialPruned()\n","\n","\n","def create_pcn(trial):\n","    dims = [28 * 28, 5, 10]\n","\n","    z_lr = trial.suggest_float(\"z_lr\", 0.01, 0.2, log=True)\n","    rho = 0.015\n","    net = PCNetwork(\n","        dims,\n","        activation=lambda _: _,\n","        z_lr=z_lr,\n","        z_it=50,\n","        variances=1,\n","        bias=False,\n","        constrained=True,\n","        rho=rho,\n","    )\n","\n","    return net\n","\n","\n","def objective(\n","    trial: optuna.trial.Trial,\n","    n_batches: int,\n","    dataset: dict,\n","    device: torch.device,\n","    seed: int,\n","    n_rep: int,\n",") -> float:\n","    scores = torch.zeros(n_rep)\n","    for i in tqdm(range(n_rep)):\n","        torch.manual_seed(seed + i)\n","        net = create_pcn(trial).to(device)\n","\n","        optimizer_class = torch.optim.SGD\n","        lr = trial.suggest_float(\"lr\", 5e-4, 0.05, log=True)\n","\n","        trainer = Trainer(net, dataset[\"train\"], dataset[\"validation\"])\n","        trainer.set_optimizer(optimizer_class, lr=lr)\n","\n","        lr_power = 1.0\n","        lr_rate = trial.suggest_float(\"lr_rate\", 1e-5, 0.2, log=True)\n","        trainer.add_scheduler(\n","            partial(\n","                torch.optim.lr_scheduler.LambdaLR,\n","                lr_lambda=lambda batch: 1 / (1 + lr_rate * batch ** lr_power),\n","            ),\n","            every=1,\n","        )\n","\n","        Q_lrf = trial.suggest_float(\"Q_lrf\", 0.1, 20, log=True)\n","        trainer.set_lr_factor(\"Q\", Q_lrf)\n","\n","        trainer.peek_validation(count=10)\n","\n","        # trainer.add_epoch_observer(lambda ns: optuna_reporter(trial, ns))\n","        results = trainer.run(n_batches=n_batches)\n","        scores[i] = results.validation[\"pc_loss\"][-1]\n","\n","    score = torch.quantile(scores, 0.90).item()\n","    return score"],"outputs":[],"metadata":{}},{"cell_type":"code","execution_count":3,"source":["# minimizing PC loss\n","t0 = time.time()\n","\n","device = torch.device(\"cpu\")\n","\n","n_batches = 500\n","seed = 1927\n","n_rep = 5\n","\n","dataset = load_mnist(n_validation=500, batch_size=100)\n","\n","sampler = optuna.samplers.TPESampler(seed=seed)\n","study = optuna.create_study(direction=\"minimize\", sampler=sampler)\n","study.optimize(\n","    lambda trial: objective(trial, n_batches, dataset, device, seed, n_rep),\n","    n_trials=25,\n","    timeout=15000,\n","    show_progress_bar=True,\n",")\n","\n","pruned_trials = study.get_trials(deepcopy=False, states=[TrialState.PRUNED])\n","complete_trials = study.get_trials(deepcopy=False, states=[TrialState.COMPLETE])\n","\n","t1 = time.time()"],"outputs":[{"output_type":"stream","name":"stderr","text":["\u001b[32m[I 2022-05-06 15:25:38,486]\u001b[0m A new study created in memory with name: no-name-391238bd-8c39-4372-84c1-f9ce7a0ecfad\u001b[0m\n","/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/progress_bar.py:47: ExperimentalWarning: Progress bar is experimental (supported from v1.2.0). The interface can change in the future.\n","  self._init_valid()\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"5c9b62bd72c24255a6f32f09f8ab0b70"},"text/plain":["  0%|          | 0/25 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"0aacfbecfb4e47af98fd3c838fe59d73"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:26:45,043]\u001b[0m Trial 0 finished with value: 0.49540260434150696 and parameters: {'z_lr': 0.038522002211863124, 'lr': 0.006787027494852526, 'lr_rate': 0.006877190717936717, 'Q_lrf': 0.7760034678738864}. Best is trial 0 with value: 0.49540260434150696.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"b2aecc8eed1e4d57aa7c3cbc81d5c6bd"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:27:52,430]\u001b[0m Trial 1 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"ddcad83eea30424cbaf56e5b8a9311aa"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:28:58,661]\u001b[0m Trial 2 finished with value: 0.4324120879173279 and parameters: {'z_lr': 0.01325310443360926, 'lr': 0.008260745183109512, 'lr_rate': 0.0001154257044083364, 'Q_lrf': 0.42135169450516174}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"f300e866de4c480c93a4daa2ae2cbb40"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:30:04,722]\u001b[0m Trial 3 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"f94d0f447f6f4b1c9b32387af743ae89"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:31:09,201]\u001b[0m Trial 4 finished with value: 0.7286754846572876 and parameters: {'z_lr': 0.03049698674558967, 'lr': 0.0006754213311238003, 'lr_rate': 8.146078329472453e-05, 'Q_lrf': 0.9124755124242356}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"53acd4fd020c418697d3a6f212f4e6fd"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:32:13,125]\u001b[0m Trial 5 finished with value: 0.5100265741348267 and parameters: {'z_lr': 0.13456989566363015, 'lr': 0.002929420137785704, 'lr_rate': 0.0001866907164621902, 'Q_lrf': 3.5126516651181805}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"33dfc7b08a6e445b940757efb0773eee"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:33:17,560]\u001b[0m Trial 6 finished with value: 0.45858198404312134 and parameters: {'z_lr': 0.03665888431434577, 'lr': 0.004645908620518579, 'lr_rate': 0.000151803277662764, 'Q_lrf': 0.16541746050010894}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"feab6d7732a54f7c8b7e0d300690f78e"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:34:22,483]\u001b[0m Trial 7 finished with value: 0.9343171715736389 and parameters: {'z_lr': 0.10117005889429422, 'lr': 0.0006471057980224879, 'lr_rate': 0.004618014776221226, 'Q_lrf': 5.330808717723938}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"355dbf33ecd24dee9dc6179893ad064b"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:35:27,490]\u001b[0m Trial 8 finished with value: 0.7011626362800598 and parameters: {'z_lr': 0.13607459530153945, 'lr': 0.001986274647451033, 'lr_rate': 0.009789658043153923, 'Q_lrf': 0.2264220075612389}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"a05fbcc8675e4f61b0d2784df9cb586c"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:36:32,121]\u001b[0m Trial 9 finished with value: 0.5281911492347717 and parameters: {'z_lr': 0.018223155573181923, 'lr': 0.004410047218501098, 'lr_rate': 0.004555134038546109, 'Q_lrf': 0.7766072419353063}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"bf93c40f8db449abb69d620fd47a3d37"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:37:36,413]\u001b[0m Trial 10 finished with value: 2.3322625160217285 and parameters: {'z_lr': 0.02032607427162081, 'lr': 0.01831586703007104, 'lr_rate': 0.0005744400105194197, 'Q_lrf': 0.5046225466152642}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"46a670245445485eadaf78395bb5c116"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:38:42,142]\u001b[0m Trial 11 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"73426752df7747faa511cfbc802b3796"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:39:48,284]\u001b[0m Trial 12 finished with value: 0.4979213774204254 and parameters: {'z_lr': 0.05048039332158416, 'lr': 0.003116003634180505, 'lr_rate': 5.4623365617103015e-05, 'Q_lrf': 2.2699129796242987}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"7d431773c191470c9924d43bd0d239b7"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:40:53,402]\u001b[0m Trial 13 finished with value: 0.6116417050361633 and parameters: {'z_lr': 0.011852367436335191, 'lr': 0.04994058641470777, 'lr_rate': 0.1904923006028014, 'Q_lrf': 0.3008683913876301}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"45fe813a2c1b4507b10667df3ccc4ff6"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:41:58,170]\u001b[0m Trial 14 finished with value: 0.7558650374412537 and parameters: {'z_lr': 0.010419636201061542, 'lr': 0.012609998637445425, 'lr_rate': 1.369890947307503e-05, 'Q_lrf': 0.10225983428765013}. Best is trial 2 with value: 0.4324120879173279.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"e12f936024fd4ecc9c9783047a335168"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:43:03,584]\u001b[0m Trial 15 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"3396fbb395434ec797f5c0a70ffc15fd"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:44:09,174]\u001b[0m Trial 16 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"1c43a9d3cded4583a363db02c13b5fc8"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:45:13,877]\u001b[0m Trial 17 finished with value: 0.4311029314994812 and parameters: {'z_lr': 0.06226272247172135, 'lr': 0.010456710062440562, 'lr_rate': 0.00040119027305766085, 'Q_lrf': 0.1126254030237743}. Best is trial 17 with value: 0.4311029314994812.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"8cd8200f42a54b2395884cddb9567a18"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:46:01,848]\u001b[0m Trial 18 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"5ee7cf1e6bee4cf7b582988a0cf82a96"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:46:48,074]\u001b[0m Trial 19 finished with value: 18.439855575561523 and parameters: {'z_lr': 0.06744527806716986, 'lr': 0.01567565278256672, 'lr_rate': 0.0007485671761625453, 'Q_lrf': 0.10405606728037237}. Best is trial 17 with value: 0.4311029314994812.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"0f4437cd48db4ccb9d5271994a351797"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:47:34,663]\u001b[0m Trial 20 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"b8739b43bc1c4122ba0d58052dc887a1"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:48:21,271]\u001b[0m Trial 21 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"3b2f2ec10daa4470a9a9d5fdcf46ce68"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:49:07,962]\u001b[0m Trial 22 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"db67c539e93b431fbcb63ff089e9773c"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:49:54,291]\u001b[0m Trial 23 failed, because the objective function returned nan.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"9e87570d319041f8b4a5dda642d03732"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:50:41,290]\u001b[0m Trial 24 failed, because the objective function returned nan.\u001b[0m\n"]}],"metadata":{}},{"cell_type":"code","execution_count":4,"source":["print(\n","    f\"{len(study.trials)} trials in {t1 - t0:.1f} seconds: \"\n","    f\"{len(complete_trials)} complete, {len(pruned_trials)} pruned.\"\n",")\n","\n","trial = study.best_trial\n","print(f\"best pc_loss: {trial.value}, for params:\")\n","for key, value in trial.params.items():\n","    print(\"    {}: {}\".format(key, value))"],"outputs":[{"output_type":"stream","name":"stdout","text":["25 trials in 1502.9 seconds: 14 complete, 0 pruned.\n","best pc_loss: 0.4311029314994812, for params:\n","    z_lr: 0.06226272247172135\n","    lr: 0.010456710062440562\n","    lr_rate: 0.00040119027305766085\n","    Q_lrf: 0.1126254030237743\n"]}],"metadata":{}},{"cell_type":"code","execution_count":5,"source":["optuna.visualization.matplotlib.plot_param_importances(study)"],"outputs":[{"output_type":"stream","name":"stderr","text":["<ipython-input-5-83c13c1a414d>:1: ExperimentalWarning: plot_param_importances is experimental (supported from v2.2.0). The interface can change in the future.\n","  optuna.visualization.matplotlib.plot_param_importances(study)\n"]},{"output_type":"execute_result","data":{"text/plain":["<AxesSubplot:title={'center':'Hyperparameter Importances'}, xlabel='Importance for Objective Value', ylabel='Hyperparameter'>"]},"metadata":{},"execution_count":5},{"output_type":"display_data","data":{"image/png":"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","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"image/png":{"width":432,"height":288},"needs_background":"light"}}],"metadata":{}},{"cell_type":"code","execution_count":6,"source":["with open(os.path.join(\"save\", \"hyperopt_pcn.pkl\"), \"wb\") as f:\n","    pickle.dump(study, f)"],"outputs":[],"metadata":{}}],"nbformat":4,"nbformat_minor":2,"metadata":{"language_info":{"codemirror_mode":{"name":"ipython","version":3},"file_extension":".py","mimetype":"text/x-python","name":"python","nbconvert_exporter":"python","pygments_lexer":"ipython3","version":3},"orig_nbformat":4}}