{"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 LinearBioPCN, 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_biopcn(trial):\n","    dims = [28 * 28, 5, 10]\n","\n","    rho = 0.015\n","\n","    z_lr = trial.suggest_float(\"z_lr\", 0.01, 0.2, log=True)\n","    # z_lr = 0.1\n","\n","    # set parameters to match a simple PCN network\n","    g_a = 0.5 * torch.ones(len(dims) - 2)\n","    g_a[-1] *= 2\n","\n","    g_b = 0.5 * torch.ones(len(dims) - 2)\n","    g_b[0] *= 2\n","\n","    net = LinearBioPCN(\n","        dims,\n","        z_lr=z_lr,\n","        z_it=50,\n","        g_a=g_a,\n","        g_b=g_b,\n","        c_m=0,\n","        l_s=g_b,\n","        rho=rho,\n","        bias_a=False,\n","        bias_b=False,\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_biopcn(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:49,046]\u001b[0m A new study created in memory with name: no-name-549721c2-0cf9-44aa-a674-e9546d2fa588\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":"706e9533c55d462990473773e119265d"},"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":"c5d235d442bd45e7a1b03c82570618ea"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:26:42,176]\u001b[0m Trial 0 finished with value: 0.6084989905357361 and parameters: {'z_lr': 0.038522002211863124, 'lr': 0.006787027494852526, 'lr_rate': 0.006877190717936717, 'Q_lrf': 0.7760034678738864}. Best is trial 0 with value: 0.6084989905357361.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"b3450b1f1e9349318d43a1fbc47c465b"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:27:29,684]\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":"f85be6d18b754e22a65b36258e903795"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:28:16,348]\u001b[0m Trial 2 finished with value: 0.7891234159469604 and parameters: {'z_lr': 0.01325310443360926, 'lr': 0.008260745183109512, 'lr_rate': 0.0001154257044083364, 'Q_lrf': 0.42135169450516174}. Best is trial 0 with value: 0.6084989905357361.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"57fbf293d2d84239986a1d5ca0c724bc"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:29:03,362]\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":"894ecbcd89784c918b366cc948dcd1b0"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:29:50,243]\u001b[0m Trial 4 finished with value: 2.2908244132995605 and parameters: {'z_lr': 0.03049698674558967, 'lr': 0.0006754213311238003, 'lr_rate': 8.146078329472453e-05, 'Q_lrf': 0.9124755124242356}. Best is trial 0 with value: 0.6084989905357361.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"3c7cbb7091f84244941450fe0f511e48"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:30:37,833]\u001b[0m Trial 5 finished with value: 0.3702264428138733 and parameters: {'z_lr': 0.13456989566363015, 'lr': 0.002929420137785704, 'lr_rate': 0.0001866907164621902, 'Q_lrf': 3.5126516651181805}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"711f6eafb155426986da60a814652505"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:31:25,261]\u001b[0m Trial 6 finished with value: 3.9356799125671387 and parameters: {'z_lr': 0.03665888431434577, 'lr': 0.004645908620518579, 'lr_rate': 0.000151803277662764, 'Q_lrf': 0.16541746050010894}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"18a0605ed33346e28f27385ea2e774f6"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:32:12,523]\u001b[0m Trial 7 finished with value: 0.8982683420181274 and parameters: {'z_lr': 0.10117005889429422, 'lr': 0.0006471057980224879, 'lr_rate': 0.004618014776221226, 'Q_lrf': 5.330808717723938}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"34e17e76fcda488db947f0b14c805f90"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:33:00,890]\u001b[0m Trial 8 finished with value: 18.97935676574707 and parameters: {'z_lr': 0.13607459530153945, 'lr': 0.001986274647451033, 'lr_rate': 0.009789658043153923, 'Q_lrf': 0.2264220075612389}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"d85979e445a840ebb0ee1e71cf2575b7"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:33:46,835]\u001b[0m Trial 9 finished with value: 0.7105798721313477 and parameters: {'z_lr': 0.018223155573181923, 'lr': 0.004410047218501098, 'lr_rate': 0.004555134038546109, 'Q_lrf': 0.7766072419353063}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"dd0cddd3d84c420cb2b3bda8bdb9146d"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:34:32,611]\u001b[0m Trial 10 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":"57d8aae40b444858be023ddda9f06466"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:35:18,508]\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":"efd5a70bd54149888724f96d3735c2ba"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:36:03,903]\u001b[0m Trial 12 finished with value: 0.37180426716804504 and parameters: {'z_lr': 0.05048039332158416, 'lr': 0.003116003634180505, 'lr_rate': 5.4623365617103015e-05, 'Q_lrf': 2.2699129796242987}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"2de696baf8a7426b9b0da28bdde4442e"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-05-06 15:36:49,456]\u001b[0m Trial 13 finished with value: 0.7712779641151428 and parameters: {'z_lr': 0.02487099787014018, 'lr': 0.0009023598338073872, 'lr_rate': 0.0017385220232214035, 'Q_lrf': 4.130845309066667}. Best is trial 5 with value: 0.3702264428138733.\u001b[0m\n"]},{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"2bb95677e3d0492ca71b2a5928f16c84"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:37:35,394]\u001b[0m Trial 14 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":"8c80a68f26294b628a71f92a7517b7cb"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:38:20,683]\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":"d48c2e121c3044e4ba173afae8ac35c8"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:39:06,338]\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":"63a4985129284d2eb29d0ad3f74e8806"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:39:52,184]\u001b[0m Trial 17 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":"f4c1a0afc2154175b5616155295fa57e"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:40:38,851]\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":"024e11417c7a424e8cd7c5dddaa2d4d9"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:41:25,358]\u001b[0m Trial 19 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":"3f9dd11087c147b08810151a27e5d986"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:42:11,849]\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":"52fb9574a5f8464f8af082169a296a25"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:42:58,400]\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":"c9c76f0828234f3984b67f3bfb71f80c"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:43:44,766]\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":"b4887bc6f7d141b396cd67695460671b"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:44:31,136]\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":"45b3de2c37ad42179284b6e19116ff19"},"text/plain":["  0%|          | 0/5 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[33m[W 2022-05-06 15:45:17,218]\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 1168.3 seconds: 10 complete, 0 pruned.\n","best pc_loss: 0.3702264428138733, for params:\n","    z_lr: 0.13456989566363015\n","    lr: 0.002929420137785704\n","    lr_rate: 0.0001866907164621902\n","    Q_lrf: 3.5126516651181805\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_biopcn.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}}