{"cells":[{"cell_type":"markdown","source":[" # A simple test of using `optuna` for hyperparameter optimization"],"metadata":{}},{"cell_type":"code","execution_count":1,"source":["import time\n","from types import SimpleNamespace\n","\n","import pydove as dv\n","from tqdm.notebook import tqdm\n","\n","import torch\n","from cpcn import LinearCPCNetwork, load_mnist, Trainer\n","\n","import optuna\n","from optuna.trial import TrialState"],"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_cpcn(trial):\n","    # n_hidden = trial.suggest_int(\"n_hidden\", 1, 3)\n","    n_hidden = 1\n","    # dims = [28 * 28]\n","    # for i in range(n_hidden):\n","    #     n_units = trial.suggest_int(f\"n_units_l{i}\", 3, 64)\n","    #     dims.append(n_units)\n","    # dims.append(10)\n","    dims = [28 * 28, 5, 10]\n","\n","    z_lr = trial.suggest_float(\"z_lr\", 1e-5, 0.2, log=True)\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 = LinearCPCNetwork(\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","        bias_a=False,\n","        bias_b=False,\n","    )\n","\n","    return net\n","\n","\n","def objective(\n","    trial: optuna.trial.Trial, n_epochs: int, dataset: dict, device: torch.device\n",") -> float:\n","    net = create_cpcn(trial).to(device)\n","\n","    optimizer_type = trial.suggest_categorical(\"optimizer\", [\"Adam\", \"RMSprop\", \"SGD\"])\n","    optimizer_class = getattr(torch.optim, optimizer_type)\n","    # optimizer_class = torch.optim.Adam\n","    lr = trial.suggest_float(\"lr\", 1e-5, 1e-1, log=True)\n","\n","    rep_gamma = trial.suggest_float(\"rep_gamma\", 1e-7, 0.2, log=True)\n","\n","    trainer = Trainer(net, dataset[\"train\"], dataset[\"validation\"])\n","    trainer.set_optimizer(optimizer_class, lr=lr)\n","    trainer.add_scheduler(\n","        lambda optim: torch.optim.lr_scheduler.ExponentialLR(optim, gamma=1 - rep_gamma)\n","    )\n","\n","    trainer.add_epoch_observer(lambda ns: optuna_reporter(trial, ns))\n","    results = trainer.run(n_epochs)\n","\n","    return results.validation.pc_loss[-1]"],"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_epochs = 50\n","dataset = load_mnist(n_train=2000, n_validation=1000, batch_size=100)\n","\n","study = optuna.create_study(direction=\"minimize\")\n","study.optimize(\n","    lambda trial: objective(trial, n_epochs, dataset, device),\n","    n_trials=200,\n","    timeout=1800,\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-04-22 15:01:48,449]\u001b[0m A new study created in memory with name: no-name-31e28eb4-8f33-4bb3-a4b3-85e06b7e9b01\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":"a1afe1766302419d8af3eacd02b9625c"},"text/plain":["  0%|          | 0/200 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:02:06,337]\u001b[0m Trial 0 finished with value: 0.953887140750885 and parameters: {'z_lr': 0.013077177969602663, 'optimizer': 'SGD', 'lr': 0.00048400745856066953, 'rep_gamma': 0.0029504817654824314}. Best is trial 0 with value: 0.953887140750885.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:02:24,009]\u001b[0m Trial 1 finished with value: 0.3223917245864868 and parameters: {'z_lr': 0.07137380845560223, 'optimizer': 'SGD', 'lr': 0.010389901011835529, 'rep_gamma': 6.336119533536925e-05}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:02:41,747]\u001b[0m Trial 2 finished with value: 0.3568132847547531 and parameters: {'z_lr': 0.18737698192393246, 'optimizer': 'RMSprop', 'lr': 0.003537522960408766, 'rep_gamma': 0.00226583103853833}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:02:59,569]\u001b[0m Trial 3 finished with value: 0.40440708100795747 and parameters: {'z_lr': 0.0048712290028189095, 'optimizer': 'Adam', 'lr': 0.000651145586815118, 'rep_gamma': 9.88282058664027e-06}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:17,230]\u001b[0m Trial 4 finished with value: 5.167893886566162 and parameters: {'z_lr': 0.0005224130639626681, 'optimizer': 'SGD', 'lr': 1.5320090201473358e-05, 'rep_gamma': 3.2031631598973628e-06}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:21,184]\u001b[0m Trial 5 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:21,567]\u001b[0m Trial 6 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:21,928]\u001b[0m Trial 7 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:24,070]\u001b[0m Trial 8 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:24,818]\u001b[0m Trial 9 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:03:25,189]\u001b[0m Trial 10 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:25,559]\u001b[0m Trial 11 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:25,929]\u001b[0m Trial 12 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:26,303]\u001b[0m Trial 13 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:27,028]\u001b[0m Trial 14 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:44,652]\u001b[0m Trial 15 finished with value: 0.3630961537361145 and parameters: {'z_lr': 1.0492288357468636e-05, 'optimizer': 'SGD', 'lr': 0.0031631937642834377, 'rep_gamma': 2.191963247061381e-06}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:45,031]\u001b[0m Trial 16 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:45,746]\u001b[0m Trial 17 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:03:55,400]\u001b[0m Trial 18 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:07,477]\u001b[0m Trial 19 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:04:07,854]\u001b[0m Trial 20 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:04:08,250]\u001b[0m Trial 21 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:09,373]\u001b[0m Trial 22 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:10,088]\u001b[0m Trial 23 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:04:10,457]\u001b[0m Trial 24 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:10,821]\u001b[0m Trial 25 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:12,222]\u001b[0m Trial 26 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:12,596]\u001b[0m Trial 27 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:14,331]\u001b[0m Trial 28 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:14,731]\u001b[0m Trial 29 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:15,120]\u001b[0m Trial 30 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:15,485]\u001b[0m Trial 31 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:16,228]\u001b[0m Trial 32 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:16,607]\u001b[0m Trial 33 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:16,968]\u001b[0m Trial 34 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:17,674]\u001b[0m Trial 35 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:29,484]\u001b[0m Trial 36 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:47,083]\u001b[0m Trial 37 finished with value: 0.5316573143005371 and parameters: {'z_lr': 0.10170330612213592, 'optimizer': 'RMSprop', 'lr': 0.002617968606847675, 'rep_gamma': 5.450942913990301e-05}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:04:47,446]\u001b[0m Trial 38 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:47,838]\u001b[0m Trial 39 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:49,944]\u001b[0m Trial 40 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:50,310]\u001b[0m Trial 41 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:04:50,669]\u001b[0m Trial 42 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:01,552]\u001b[0m Trial 43 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:01,919]\u001b[0m Trial 44 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:02,286]\u001b[0m Trial 45 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:05:02,653]\u001b[0m Trial 46 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:03,031]\u001b[0m Trial 47 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:03,409]\u001b[0m Trial 48 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:05:03,778]\u001b[0m Trial 49 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:04,178]\u001b[0m Trial 50 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:05,944]\u001b[0m Trial 51 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:06,670]\u001b[0m Trial 52 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:07,030]\u001b[0m Trial 53 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:07,738]\u001b[0m Trial 54 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:08,096]\u001b[0m Trial 55 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:08,461]\u001b[0m Trial 56 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:11,263]\u001b[0m Trial 57 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:11,626]\u001b[0m Trial 58 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:12,016]\u001b[0m Trial 59 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:12,382]\u001b[0m Trial 60 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:12,743]\u001b[0m Trial 61 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:13,113]\u001b[0m Trial 62 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:13,488]\u001b[0m Trial 63 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:13,848]\u001b[0m Trial 64 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:05:14,211]\u001b[0m Trial 65 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:14,577]\u001b[0m Trial 66 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:17,383]\u001b[0m Trial 67 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:19,146]\u001b[0m Trial 68 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:19,504]\u001b[0m Trial 69 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:25,772]\u001b[0m Trial 70 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:26,141]\u001b[0m Trial 71 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:26,506]\u001b[0m Trial 72 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:33,118]\u001b[0m Trial 73 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:33,481]\u001b[0m Trial 74 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:34,909]\u001b[0m Trial 75 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:36,401]\u001b[0m Trial 76 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:36,782]\u001b[0m Trial 77 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:05:37,151]\u001b[0m Trial 78 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:37,516]\u001b[0m Trial 79 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:05:37,877]\u001b[0m Trial 80 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:38,275]\u001b[0m Trial 81 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:38,990]\u001b[0m Trial 82 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:39,356]\u001b[0m Trial 83 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:39,716]\u001b[0m Trial 84 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:40,081]\u001b[0m Trial 85 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:40,443]\u001b[0m Trial 86 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:47,038]\u001b[0m Trial 87 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:49,165]\u001b[0m Trial 88 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:49,529]\u001b[0m Trial 89 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:49,911]\u001b[0m Trial 90 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:56,486]\u001b[0m Trial 91 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:56,852]\u001b[0m Trial 92 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:57,215]\u001b[0m Trial 93 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:57,574]\u001b[0m Trial 94 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:57,946]\u001b[0m Trial 95 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:05:58,989]\u001b[0m Trial 96 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:01,081]\u001b[0m Trial 97 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:18,307]\u001b[0m Trial 98 finished with value: 0.3288926690816879 and parameters: {'z_lr': 0.15669236230798883, 'optimizer': 'SGD', 'lr': 0.005845301548226558, 'rep_gamma': 0.00013708365196188875}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:06:18,670]\u001b[0m Trial 99 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:06:19,033]\u001b[0m Trial 100 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:19,399]\u001b[0m Trial 101 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:19,763]\u001b[0m Trial 102 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:20,131]\u001b[0m Trial 103 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:20,496]\u001b[0m Trial 104 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:37,926]\u001b[0m Trial 105 finished with value: 0.3606198340654373 and parameters: {'z_lr': 0.15845677902035626, 'optimizer': 'RMSprop', 'lr': 0.002909547814156896, 'rep_gamma': 0.00020133133512964874}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:38,294]\u001b[0m Trial 106 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:55,784]\u001b[0m Trial 107 finished with value: 0.3369475305080414 and parameters: {'z_lr': 0.19058884431266893, 'optimizer': 'SGD', 'lr': 0.005456259529409034, 'rep_gamma': 0.00021507535536015104}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:56,143]\u001b[0m Trial 108 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:56,528]\u001b[0m Trial 109 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:06:57,949]\u001b[0m Trial 110 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:15,267]\u001b[0m Trial 111 finished with value: 0.324372997879982 and parameters: {'z_lr': 0.10048389773058829, 'optimizer': 'SGD', 'lr': 0.008572741215258967, 'rep_gamma': 0.003086755016117828}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:15,641]\u001b[0m Trial 112 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:16,002]\u001b[0m Trial 113 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:33,470]\u001b[0m Trial 114 finished with value: 0.3236955374479294 and parameters: {'z_lr': 0.09653179439981083, 'optimizer': 'SGD', 'lr': 0.008864452845689206, 'rep_gamma': 0.004275149369217429}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:33,833]\u001b[0m Trial 115 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:34,559]\u001b[0m Trial 116 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:34,939]\u001b[0m Trial 117 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:35,312]\u001b[0m Trial 118 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:35,677]\u001b[0m Trial 119 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:36,037]\u001b[0m Trial 120 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:36,407]\u001b[0m Trial 121 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:36,795]\u001b[0m Trial 122 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:37,163]\u001b[0m Trial 123 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:39,280]\u001b[0m Trial 124 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:07:39,661]\u001b[0m Trial 125 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:40,419]\u001b[0m Trial 126 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:07:40,787]\u001b[0m Trial 127 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:41,500]\u001b[0m Trial 128 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:41,870]\u001b[0m Trial 129 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:42,584]\u001b[0m Trial 130 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:43,301]\u001b[0m Trial 131 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:43,667]\u001b[0m Trial 132 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:44,037]\u001b[0m Trial 133 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:44,424]\u001b[0m Trial 134 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:44,796]\u001b[0m Trial 135 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:45,158]\u001b[0m Trial 136 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:45,528]\u001b[0m Trial 137 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:45,927]\u001b[0m Trial 138 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:46,303]\u001b[0m Trial 139 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:07:46,689]\u001b[0m Trial 140 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:47,094]\u001b[0m Trial 141 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:51,647]\u001b[0m Trial 142 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:52,016]\u001b[0m Trial 143 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:52,385]\u001b[0m Trial 144 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:52,744]\u001b[0m Trial 145 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:53,140]\u001b[0m Trial 146 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:07:53,509]\u001b[0m Trial 147 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:53,877]\u001b[0m Trial 148 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:07:55,297]\u001b[0m Trial 149 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:13,332]\u001b[0m Trial 150 finished with value: 0.33249386548995974 and parameters: {'z_lr': 0.13826030600838995, 'optimizer': 'SGD', 'lr': 0.005337778237502806, 'rep_gamma': 0.0006180779741619133}. Best is trial 1 with value: 0.3223917245864868.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:14,044]\u001b[0m Trial 151 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:31,475]\u001b[0m Trial 152 finished with value: 0.32115415036678313 and parameters: {'z_lr': 0.10226242501677259, 'optimizer': 'SGD', 'lr': 0.01017740793487756, 'rep_gamma': 0.0003685567491534252}. Best is trial 152 with value: 0.32115415036678313.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:48,994]\u001b[0m Trial 153 finished with value: 0.3206229954957962 and parameters: {'z_lr': 0.10747476864857959, 'optimizer': 'SGD', 'lr': 0.010412040114088804, 'rep_gamma': 0.0005891430841837224}. Best is trial 153 with value: 0.3206229954957962.\u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:08:49,362]\u001b[0m Trial 154 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:08:49,765]\u001b[0m Trial 155 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:50,146]\u001b[0m Trial 156 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:50,516]\u001b[0m Trial 157 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:50,885]\u001b[0m Trial 158 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:51,272]\u001b[0m Trial 159 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:08:51,654]\u001b[0m Trial 160 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:08:52,043]\u001b[0m Trial 161 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:09:09,651]\u001b[0m Trial 162 finished with value: 0.32039588689804077 and parameters: {'z_lr': 0.16517148828999317, 'optimizer': 'SGD', 'lr': 0.009227660752552786, 'rep_gamma': 0.003673672666925076}. Best is trial 162 with value: 0.32039588689804077.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:09:27,049]\u001b[0m Trial 163 finished with value: 0.3214841216802597 and parameters: {'z_lr': 0.16171175242754146, 'optimizer': 'SGD', 'lr': 0.009444984193650032, 'rep_gamma': 0.0039529487189329205}. Best is trial 162 with value: 0.32039588689804077.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:09:44,506]\u001b[0m Trial 164 finished with value: 0.3196380376815796 and parameters: {'z_lr': 0.15688900607583509, 'optimizer': 'SGD', 'lr': 0.010288099531463566, 'rep_gamma': 0.003719166244929744}. Best is trial 164 with value: 0.3196380376815796.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:02,050]\u001b[0m Trial 165 finished with value: 0.32747802436351775 and parameters: {'z_lr': 0.16698184001361094, 'optimizer': 'SGD', 'lr': 0.008966388838254733, 'rep_gamma': 0.005880630944126639}. Best is trial 164 with value: 0.3196380376815796.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:02,421]\u001b[0m Trial 166 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:02,784]\u001b[0m Trial 167 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:03,149]\u001b[0m Trial 168 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:03,513]\u001b[0m Trial 169 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:03,881]\u001b[0m Trial 170 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:04,263]\u001b[0m Trial 171 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:04,629]\u001b[0m Trial 172 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:04,992]\u001b[0m Trial 173 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:05,373]\u001b[0m Trial 174 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:05,745]\u001b[0m Trial 175 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:06,118]\u001b[0m Trial 176 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:06,485]\u001b[0m Trial 177 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:06,864]\u001b[0m Trial 178 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:07,241]\u001b[0m Trial 179 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:07,613]\u001b[0m Trial 180 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:07,992]\u001b[0m Trial 181 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:18,823]\u001b[0m Trial 182 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:19,188]\u001b[0m Trial 183 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:19,571]\u001b[0m Trial 184 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:19,963]\u001b[0m Trial 185 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:20,331]\u001b[0m Trial 186 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:20,692]\u001b[0m Trial 187 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:21,070]\u001b[0m Trial 188 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:21,443]\u001b[0m Trial 189 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:21,825]\u001b[0m Trial 190 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:22,196]\u001b[0m Trial 191 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:22,581]\u001b[0m Trial 192 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:22,954]\u001b[0m Trial 193 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:23,340]\u001b[0m Trial 194 pruned. \u001b[0m\n"]},{"output_type":"stream","name":"stderr","text":["/mnt/home/ttesileanu/miniconda3/envs/cpcn/lib/python3.9/site-packages/optuna/pruners/_percentile.py:21: RuntimeWarning: All-NaN slice encountered\n","  return np.nanmin(values)\n"]},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:10:23,742]\u001b[0m Trial 195 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:24,123]\u001b[0m Trial 196 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:24,835]\u001b[0m Trial 197 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:25,204]\u001b[0m Trial 198 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:10:25,572]\u001b[0m Trial 199 pruned. \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":["200 trials in 517.3 seconds: 19 complete, 181 pruned.\n","best pc_loss: 0.3196380376815796, for params:\n","    z_lr: 0.15688900607583509\n","    optimizer: SGD\n","    lr: 0.010288099531463566\n","    rep_gamma: 0.003719166244929744\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":{}}],"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}}