{"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 PCNetwork, 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_pcn(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","    net = PCNetwork(dims, lr_inference=z_lr, it_inference=50, variances=1, bias=False)\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_pcn(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:46:51,170]\u001b[0m A new study created in memory with name: no-name-77a68a70-4ab4-4e9a-a295-446827340ee7\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":"0be5c0cc5b4c484aab3c5266a075a73d"},"text/plain":["  0%|          | 0/200 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["\u001b[32m[I 2022-04-22 15:47:36,612]\u001b[0m Trial 0 finished with value: 0.4091533780097961 and parameters: {'z_lr': 1.55313346369138e-05, 'optimizer': 'RMSprop', 'lr': 7.009228163037984e-05, 'rep_gamma': 1.0994543507895935e-06}. Best is trial 0 with value: 0.4091533780097961.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:48:21,270]\u001b[0m Trial 1 finished with value: 0.3196363776922226 and parameters: {'z_lr': 0.030982911050303995, 'optimizer': 'SGD', 'lr': 0.007883917380251172, 'rep_gamma': 0.0003888369712551073}. Best is trial 1 with value: 0.3196363776922226.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:49:09,402]\u001b[0m Trial 2 finished with value: 0.3384138703346252 and parameters: {'z_lr': 0.0006558296928443135, 'optimizer': 'Adam', 'lr': 0.001360766562640757, 'rep_gamma': 0.11962902010790549}. Best is trial 1 with value: 0.3196363776922226.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:49:55,838]\u001b[0m Trial 3 finished with value: 0.3058592826128006 and parameters: {'z_lr': 0.00925915714785049, 'optimizer': 'SGD', 'lr': 0.020872283638775045, 'rep_gamma': 9.975457889325983e-05}. Best is trial 3 with value: 0.3058592826128006.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:50:41,477]\u001b[0m Trial 4 finished with value: 0.4803879648447037 and parameters: {'z_lr': 0.021251889754387434, 'optimizer': 'SGD', 'lr': 0.0003110647010961386, 'rep_gamma': 2.12305261959075e-06}. Best is trial 3 with value: 0.3058592826128006.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:50:46,957]\u001b[0m Trial 5 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:50:47,896]\u001b[0m Trial 6 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:51:33,814]\u001b[0m Trial 7 finished with value: 0.31523340940475464 and parameters: {'z_lr': 0.008470547502350068, 'optimizer': 'RMSprop', 'lr': 0.0010504628692473465, 'rep_gamma': 0.0001888727429397433}. Best is trial 3 with value: 0.3058592826128006.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:51:34,709]\u001b[0m Trial 8 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:51:36,455]\u001b[0m Trial 9 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:52:20,788]\u001b[0m Trial 10 finished with value: 0.28941442370414733 and parameters: {'z_lr': 0.001801791443332209, 'optimizer': 'SGD', 'lr': 0.09867287976036955, 'rep_gamma': 0.02535194839905894}. Best is trial 10 with value: 0.28941442370414733.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:05,041]\u001b[0m Trial 11 finished with value: 0.3039181977510452 and parameters: {'z_lr': 0.0016988513257523263, 'optimizer': 'SGD', 'lr': 0.0913058792903974, 'rep_gamma': 0.04858160937413848}. Best is trial 10 with value: 0.28941442370414733.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:06,826]\u001b[0m Trial 12 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:07,707]\u001b[0m Trial 13 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:08,605]\u001b[0m Trial 14 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:09,510]\u001b[0m Trial 15 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:10,534]\u001b[0m Trial 16 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:11,598]\u001b[0m Trial 17 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:53,894]\u001b[0m Trial 18 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:57,053]\u001b[0m Trial 19 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:53:58,117]\u001b[0m Trial 20 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:08,447]\u001b[0m Trial 21 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:10,565]\u001b[0m Trial 22 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:17,814]\u001b[0m Trial 23 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:19,914]\u001b[0m Trial 24 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:20,969]\u001b[0m Trial 25 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:22,041]\u001b[0m Trial 26 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:25,169]\u001b[0m Trial 27 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:26,236]\u001b[0m Trial 28 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:27,282]\u001b[0m Trial 29 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:28,380]\u001b[0m Trial 30 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:54:39,786]\u001b[0m Trial 31 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:55:23,604]\u001b[0m Trial 32 finished with value: 0.3195889234542847 and parameters: {'z_lr': 0.04015073513593336, 'optimizer': 'RMSprop', 'lr': 0.0007609880581152889, 'rep_gamma': 1.828484752159382e-05}. Best is trial 10 with value: 0.28941442370414733.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:55:24,498]\u001b[0m Trial 33 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:55:26,264]\u001b[0m Trial 34 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:55:27,152]\u001b[0m Trial 35 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:55:28,088]\u001b[0m Trial 36 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:55:29,906]\u001b[0m Trial 37 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:56:13,732]\u001b[0m Trial 38 finished with value: 0.27798483371734617 and parameters: {'z_lr': 0.07013523227236648, 'optimizer': 'Adam', 'lr': 0.0019029161562895882, 'rep_gamma': 0.0001904413582563675}. Best is trial 38 with value: 0.27798483371734617.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:56:15,529]\u001b[0m Trial 39 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 15:57:02,068]\u001b[0m Trial 40 finished with value: 0.2737004548311234 and parameters: {'z_lr': 0.19620002040569087, 'optimizer': 'Adam', 'lr': 0.0023515343888461503, 'rep_gamma': 0.00097710896992131}. Best is trial 40 with value: 0.2737004548311234.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:57:45,757]\u001b[0m Trial 41 finished with value: 0.2712996304035187 and parameters: {'z_lr': 0.17701699635245485, 'optimizer': 'Adam', 'lr': 0.0019011949827574036, 'rep_gamma': 0.0009889336509135245}. Best is trial 41 with value: 0.2712996304035187.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:58:34,920]\u001b[0m Trial 42 finished with value: 0.2773547023534775 and parameters: {'z_lr': 0.1970187506807808, 'optimizer': 'Adam', 'lr': 0.0016348137530575236, 'rep_gamma': 0.0008818808914036667}. Best is trial 41 with value: 0.2712996304035187.\u001b[0m\n","\u001b[32m[I 2022-04-22 15:59:19,204]\u001b[0m Trial 43 finished with value: 0.27400929629802706 and parameters: {'z_lr': 0.17340867510385394, 'optimizer': 'Adam', 'lr': 0.001769958236283733, 'rep_gamma': 0.0006802701057044613}. Best is trial 41 with value: 0.2712996304035187.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:00:03,013]\u001b[0m Trial 44 finished with value: 0.27702914774417875 and parameters: {'z_lr': 0.16451603603747092, 'optimizer': 'Adam', 'lr': 0.0017844877200908853, 'rep_gamma': 0.0005429781409538303}. Best is trial 41 with value: 0.2712996304035187.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:00:03,895]\u001b[0m Trial 45 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:00:05,650]\u001b[0m Trial 46 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:00:50,203]\u001b[0m Trial 47 finished with value: 0.2737461268901825 and parameters: {'z_lr': 0.12030013177494939, 'optimizer': 'Adam', 'lr': 0.001790452755593587, 'rep_gamma': 0.000493756565042382}. Best is trial 41 with value: 0.2712996304035187.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:00:51,084]\u001b[0m Trial 48 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:01:39,497]\u001b[0m Trial 49 finished with value: 0.2717859923839569 and parameters: {'z_lr': 0.0478840573669227, 'optimizer': 'Adam', 'lr': 0.002675536721133413, 'rep_gamma': 0.00047684141307275486}. Best is trial 41 with value: 0.2712996304035187.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:02:26,914]\u001b[0m Trial 50 finished with value: 0.27003507912158964 and parameters: {'z_lr': 0.05242995093616817, 'optimizer': 'Adam', 'lr': 0.003305817586700149, 'rep_gamma': 0.004008317841607828}. Best is trial 50 with value: 0.27003507912158964.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:02:27,814]\u001b[0m Trial 51 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:03:15,158]\u001b[0m Trial 52 finished with value: 0.2725343644618988 and parameters: {'z_lr': 0.10840294766821412, 'optimizer': 'Adam', 'lr': 0.002942545373993972, 'rep_gamma': 0.00043614508223794354}. Best is trial 50 with value: 0.27003507912158964.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:03:58,645]\u001b[0m Trial 53 finished with value: 0.26952100694179537 and parameters: {'z_lr': 0.10410318304398178, 'optimizer': 'Adam', 'lr': 0.0031695411569079355, 'rep_gamma': 0.00017384420735519038}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:04:21,663]\u001b[0m Trial 54 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:04:22,697]\u001b[0m Trial 55 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:05:09,764]\u001b[0m Trial 56 finished with value: 0.2729198068380356 and parameters: {'z_lr': 0.02948158867291727, 'optimizer': 'Adam', 'lr': 0.003303702523638419, 'rep_gamma': 0.002947631277641212}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:05:53,574]\u001b[0m Trial 57 finished with value: 0.2767695814371109 and parameters: {'z_lr': 0.032058724059478585, 'optimizer': 'Adam', 'lr': 0.0037381821570738887, 'rep_gamma': 0.0032000512075377957}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:05:54,478]\u001b[0m Trial 58 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:06:29,116]\u001b[0m Trial 59 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:07:13,832]\u001b[0m Trial 60 finished with value: 0.2723400592803955 and parameters: {'z_lr': 0.06625129569578442, 'optimizer': 'Adam', 'lr': 0.005519375849744375, 'rep_gamma': 0.014000189044325479}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:07:14,723]\u001b[0m Trial 61 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:07:15,611]\u001b[0m Trial 62 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:07:16,560]\u001b[0m Trial 63 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:07:17,444]\u001b[0m Trial 64 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:07:18,326]\u001b[0m Trial 65 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:08:02,175]\u001b[0m Trial 66 finished with value: 0.27338609993457796 and parameters: {'z_lr': 0.01861963908503096, 'optimizer': 'Adam', 'lr': 0.0027184306731326624, 'rep_gamma': 0.0016059078943192436}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:08:03,056]\u001b[0m Trial 67 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:08:03,938]\u001b[0m Trial 68 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:08:35,685]\u001b[0m Trial 69 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:08:36,584]\u001b[0m Trial 70 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:08:48,784]\u001b[0m Trial 71 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:02,848]\u001b[0m Trial 72 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:03,752]\u001b[0m Trial 73 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:04,641]\u001b[0m Trial 74 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:05,545]\u001b[0m Trial 75 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:06,430]\u001b[0m Trial 76 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:07,309]\u001b[0m Trial 77 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:08,193]\u001b[0m Trial 78 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:09:52,747]\u001b[0m Trial 79 finished with value: 0.27414858937263487 and parameters: {'z_lr': 0.04692926076773167, 'optimizer': 'Adam', 'lr': 0.0023925258397688802, 'rep_gamma': 0.00014335099864441487}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:10:38,266]\u001b[0m Trial 80 finished with value: 0.2710556209087372 and parameters: {'z_lr': 0.010762888922024238, 'optimizer': 'Adam', 'lr': 0.004466852623079141, 'rep_gamma': 0.012171607226184442}. Best is trial 53 with value: 0.26952100694179537.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:22,251]\u001b[0m Trial 81 finished with value: 0.26764023303985596 and parameters: {'z_lr': 0.010105783788220024, 'optimizer': 'Adam', 'lr': 0.004157609360972105, 'rep_gamma': 0.011343868716670088}. Best is trial 81 with value: 0.26764023303985596.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:23,188]\u001b[0m Trial 82 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:24,082]\u001b[0m Trial 83 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:24,967]\u001b[0m Trial 84 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:25,846]\u001b[0m Trial 85 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:28,562]\u001b[0m Trial 86 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:29,499]\u001b[0m Trial 87 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:30,599]\u001b[0m Trial 88 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:32,672]\u001b[0m Trial 89 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:11:55,026]\u001b[0m Trial 90 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:12:40,396]\u001b[0m Trial 91 finished with value: 0.2739782750606537 and parameters: {'z_lr': 0.025514069165430444, 'optimizer': 'Adam', 'lr': 0.0026845453417652042, 'rep_gamma': 0.0028720789530830913}. Best is trial 81 with value: 0.26764023303985596.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:13:25,020]\u001b[0m Trial 92 finished with value: 0.2707387685775757 and parameters: {'z_lr': 0.09729559957524683, 'optimizer': 'Adam', 'lr': 0.004262249565385744, 'rep_gamma': 0.0004523391877317405}. Best is trial 81 with value: 0.26764023303985596.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:14:11,325]\u001b[0m Trial 93 finished with value: 0.26961122155189515 and parameters: {'z_lr': 0.1503483915492477, 'optimizer': 'Adam', 'lr': 0.004408280231756005, 'rep_gamma': 0.0005800691602124723}. Best is trial 81 with value: 0.26764023303985596.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:14:22,198]\u001b[0m Trial 94 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:14:23,995]\u001b[0m Trial 95 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:14:24,926]\u001b[0m Trial 96 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:14:25,828]\u001b[0m Trial 97 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:14:26,717]\u001b[0m Trial 98 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:12,040]\u001b[0m Trial 99 finished with value: 0.27343247532844545 and parameters: {'z_lr': 0.14941884687428272, 'optimizer': 'Adam', 'lr': 0.004196016669150803, 'rep_gamma': 0.0007937877510821461}. Best is trial 81 with value: 0.26764023303985596.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:12,926]\u001b[0m Trial 100 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:15,585]\u001b[0m Trial 101 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:16,469]\u001b[0m Trial 102 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:28,996]\u001b[0m Trial 103 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:31,731]\u001b[0m Trial 104 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:34,496]\u001b[0m Trial 105 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:15:35,427]\u001b[0m Trial 106 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:16:20,851]\u001b[0m Trial 107 finished with value: 0.2708333104848862 and parameters: {'z_lr': 0.19742540048587223, 'optimizer': 'Adam', 'lr': 0.003989063879117595, 'rep_gamma': 0.009522600531766765}. Best is trial 81 with value: 0.26764023303985596.\u001b[0m\n","\u001b[32m[I 2022-04-22 16:16:21,774]\u001b[0m Trial 108 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:16:22,709]\u001b[0m Trial 109 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:16:25,433]\u001b[0m Trial 110 pruned. \u001b[0m\n","\u001b[32m[I 2022-04-22 16:17:10,858]\u001b[0m Trial 111 finished with value: 0.27149864137172697 and parameters: {'z_lr': 0.09527878612238397, 'optimizer': 'Adam', 'lr': 0.0030162922720854447, 'rep_gamma': 0.0056805222739493046}. Best is trial 81 with value: 0.26764023303985596.\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":["112 trials in 1819.8 seconds: 33 complete, 79 pruned.\n","best pc_loss: 0.26764023303985596, for params:\n","    z_lr: 0.010105783788220024\n","    optimizer: Adam\n","    lr: 0.004157609360972105\n","    rep_gamma: 0.011343868716670088\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}}