{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2577f7ef-0986-4943-807b-f8c0fb6fec04",
   "metadata": {},
   "source": [
    "This experiment is not included in the paper since LFL-Type3 converges on this task without MLP gradient shoutcut. But adding the MLP actually makes LFL-Type3 converge more stably with varying random seeds."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "847db128-119d-4381-bd95-15991ae0a96d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "dtype = torch.float64\n",
    "torch.set_default_dtype(dtype)\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.nn import BCELoss, MSELoss, NLLLoss\n",
    "import numpy as np\n",
    "import sympy as sp\n",
    "from madgrad import MADGRAD\n",
    "from dataset.mnist_logic import *\n",
    "from library.mnist_multi_add_networks import *\n",
    "from library.utils import *\n",
    "from itertools import chain\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import confusion_matrix\n",
    "from PIL import Image\n",
    "import os\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "74a90351-2af0-4865-8930-33d27ef417af",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed(42)\n",
    "\n",
    "batch_size = 128\n",
    "loss_fn_supervision = BCELoss()\n",
    "loss_fn_reconstruction = MSELoss()\n",
    "epochs = 2 ** 8\n",
    "even_label_distribution = torch.full(size=(10,), fill_value=1./10.).to(device)\n",
    "noise_scales = [0.21353293235920662, 0.8340490382545882]\n",
    "lfl_lr = 1.4915482741197248\n",
    "cnn_lr = 0.0008197918642308738\n",
    "mlp_lr = 0.0013965393796530681\n",
    "reconstruction_lr = 0.001\n",
    "reg_coef = 0.1540429522200905\n",
    "mlp_loss_weight = 0.28014589825801045\n",
    "label_distribution_wight = 3.3673715892352063\n",
    "\n",
    "def train():\n",
    "    model.train()\n",
    "    losses = {\n",
    "        'reconstruction': [],\n",
    "        'supervision': [],\n",
    "        'accuracy': [],\n",
    "        'regularization': [],\n",
    "        'mlp_supervision': [],\n",
    "        'label_distribution': [],\n",
    "    }\n",
    "    for left_images, right_images, labels, carry in dataloader:\n",
    "        left_images, right_images, labels, carry = left_images.to(device), right_images.to(device), labels.to(device), carry.to(device)\n",
    "        preds_lfl, preds_mlp, carry_lfl, carry_mlp, left_reconstructions, right_reconstructions, left_label_mean, right_label_mean = model(left_images, right_images)\n",
    "        reconstruction_loss = loss_fn_reconstruction(left_reconstructions, left_images) + loss_fn_reconstruction(right_reconstructions, right_images)\n",
    "        accuracy = np.mean([get_accuracy(preds_lfl[:, i, :], labels[:, i, :].type(dtype)) for i in range(preds_lfl.shape[1])] + [get_accuracy(carry_lfl, carry.type(dtype))])\n",
    "        preds_lfl, preds_mlp, labels = torch.flatten(preds_lfl, 1), torch.flatten(preds_mlp, 1), torch.flatten(labels, 1)\n",
    "        preds_lfl_full, preds_mlp_full, actual_full = torch.cat([preds_lfl, carry_lfl], dim=1), torch.cat([preds_mlp, carry_mlp], dim=1), torch.cat([labels, carry], dim=1)\n",
    "        supervision_loss = loss_fn_supervision(preds_lfl_full, actual_full.type(dtype))\n",
    "        # accuracy = (get_accuracy(preds_lfl, labels.type(dtype)) + get_accuracy(carry_lfl, carry.type(dtype))) / 2.\n",
    "        regularization_loss = model.lfl.reg_loss()\n",
    "        mlp_loss = loss_fn_supervision(preds_mlp_full, actual_full.type(dtype))\n",
    "        label_distribution_loss = loss_fn_supervision(left_label_mean, even_label_distribution) + loss_fn_supervision(right_label_mean, even_label_distribution)\n",
    "        \n",
    "        losses['reconstruction'].append(reconstruction_loss.item())\n",
    "        losses['supervision'].append(supervision_loss.item())\n",
    "        losses['accuracy'].append(accuracy)\n",
    "        losses['regularization'].append(regularization_loss.item())\n",
    "        losses['mlp_supervision'].append(mlp_loss.item())\n",
    "        losses['label_distribution'].append(label_distribution_loss.item())\n",
    "        loss = reconstruction_loss + supervision_loss + reg_coef * regularization_loss + mlp_loss_weight * mlp_loss + label_distribution_wight * label_distribution_loss\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "            \n",
    "    mean_loss = {k: np.mean(v) for k, v in losses.items()}\n",
    "    return mean_loss\n",
    "\n",
    "def test():\n",
    "    model.eval()\n",
    "    bceloss, accuracy = [], []\n",
    "    for left_images, right_images, labels, carry in dataloader:\n",
    "        left_images, right_images, labels, carry = left_images.to(device), right_images.to(device), labels.to(device), carry.to(device)\n",
    "        preds_lfl, preds_mlp, carry_lfl, carry_mlp, left_reconstructions, right_reconstructions, left_label_mean, right_label_mean = model(left_images, right_images)\n",
    "        accuracy_ = np.mean([get_accuracy(preds_lfl[:, i, :], labels[:, i, :].type(dtype)) for i in range(preds_lfl.shape[1])] + [get_accuracy(carry_lfl, carry.type(dtype))])\n",
    "        preds, labels = torch.flatten(preds_lfl, 1), torch.flatten(labels, 1)\n",
    "        preds_full, actual_full = torch.cat([preds, carry_lfl], dim=1), torch.cat([labels, carry], dim=1)\n",
    "        bceloss_ = loss_fn_supervision(preds_full, actual_full.type(dtype))\n",
    "        # accuracy_ = (get_accuracy(preds, labels.type(dtype)) + get_accuracy(carry_lfl, carry.type(dtype))) / 2.\n",
    "        bceloss.append(bceloss_.detach().cpu().numpy()), accuracy.append(accuracy_)\n",
    "    bceloss, accuracy = np.mean(bceloss), np.mean(accuracy)\n",
    "    return bceloss, accuracy\n",
    "\n",
    "def test_cnn():\n",
    "    pred, label = [], []\n",
    "    for image, label_ in dataloader:\n",
    "        image, label_ = image.to(device), label_.to(device)\n",
    "        pred_ = model.cnn(image)\n",
    "        pred.append(pred_)\n",
    "        label.append(label_)\n",
    "    pred = torch.argmax(torch.cat(pred, dim=0), dim=1, keepdim=False).detach().cpu().numpy()\n",
    "    label = torch.cat(label, dim=0).detach().cpu().numpy()\n",
    "    return pred, label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f37ce403-77e3-4852-9a53-55cee47e3fa0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch: 0 mean_loss: {'reconstruction': 0.27334496125469704, 'supervision': 0.4546681016087797, 'accuracy': 0.3189697265625, 'regularization': 0.3742678025569183, 'mlp_supervision': 0.47849445717783234, 'label_distribution': 0.6502349563765356}\n",
      "epoch: 1 mean_loss: {'reconstruction': 0.21914920382163972, 'supervision': 0.45427834393925004, 'accuracy': 0.3140869140625, 'regularization': 0.18583160631969087, 'mlp_supervision': 0.3857706793794607, 'label_distribution': 0.650175855679479}\n",
      "epoch: 2 mean_loss: {'reconstruction': 0.18276208296348018, 'supervision': 0.4536496550976047, 'accuracy': 0.3177490234375, 'regularization': 0.12508176617972583, 'mlp_supervision': 0.38568588835487744, 'label_distribution': 0.6501827422984524}\n",
      "epoch: 3 mean_loss: {'reconstruction': 0.16117008390763038, 'supervision': 0.4531381080227195, 'accuracy': 0.31768798828125, 'regularization': 0.09766864373566284, 'mlp_supervision': 0.38603379276647465, 'label_distribution': 0.6501779854129368}\n",
      "epoch: 4 mean_loss: {'reconstruction': 0.14916777720603003, 'supervision': 0.452793536932249, 'accuracy': 0.320068359375, 'regularization': 0.07966786311017945, 'mlp_supervision': 0.3858886912466779, 'label_distribution': 0.6501819571023422}\n",
      "epoch: 5 mean_loss: {'reconstruction': 0.14298595747801615, 'supervision': 0.4526832373337273, 'accuracy': 0.317138671875, 'regularization': 0.06792351584474582, 'mlp_supervision': 0.3858877947425479, 'label_distribution': 0.6501775506636516}\n",
      "epoch: 6 mean_loss: {'reconstruction': 0.1390171591353339, 'supervision': 0.45273828611830136, 'accuracy': 0.31121826171875, 'regularization': 0.06169498396110064, 'mlp_supervision': 0.38591645135984026, 'label_distribution': 0.6501782210431086}\n",
      "epoch: 7 mean_loss: {'reconstruction': 0.13720363747333905, 'supervision': 0.4522997529211229, 'accuracy': 0.314208984375, 'regularization': 0.0565679371298348, 'mlp_supervision': 0.38591541924182604, 'label_distribution': 0.6501760711955391}\n",
      "epoch: 8 mean_loss: {'reconstruction': 0.13606448153826198, 'supervision': 0.4520008108474105, 'accuracy': 0.31915283203125, 'regularization': 0.05234709493888445, 'mlp_supervision': 0.3858886077389373, 'label_distribution': 0.6501824585567326}\n",
      "epoch: 9 mean_loss: {'reconstruction': 0.13581519552892948, 'supervision': 0.4519192508157148, 'accuracy': 0.3193359375, 'regularization': 0.048748054268219494, 'mlp_supervision': 0.38562054350794717, 'label_distribution': 0.6501784397072004}\n",
      "epoch: 10 mean_loss: {'reconstruction': 0.13581600645525632, 'supervision': 0.45188406422009214, 'accuracy': 0.3134765625, 'regularization': 0.046372609389575686, 'mlp_supervision': 0.3860006922318945, 'label_distribution': 0.6501810453508645}\n",
      "epoch: 11 mean_loss: {'reconstruction': 0.13509122562696566, 'supervision': 0.4515873406861688, 'accuracy': 0.31463623046875, 'regularization': 0.0441756900062127, 'mlp_supervision': 0.38610512101192507, 'label_distribution': 0.6501796995350755}\n",
      "epoch: 12 mean_loss: {'reconstruction': 0.13587257310535975, 'supervision': 0.45126590766390434, 'accuracy': 0.31719970703125, 'regularization': 0.04253725895825848, 'mlp_supervision': 0.3859663185433311, 'label_distribution': 0.6501792323715212}\n",
      "epoch: 13 mean_loss: {'reconstruction': 0.13581892718309596, 'supervision': 0.45130862809551237, 'accuracy': 0.3157958984375, 'regularization': 0.04033802284336371, 'mlp_supervision': 0.386200812760352, 'label_distribution': 0.6501763469680271}\n",
      "epoch: 14 mean_loss: {'reconstruction': 0.1355747911795392, 'supervision': 0.45114938424732376, 'accuracy': 0.31787109375, 'regularization': 0.039026638009276526, 'mlp_supervision': 0.38551336974315203, 'label_distribution': 0.6501799090935403}\n",
      "epoch: 15 mean_loss: {'reconstruction': 0.1354488062367716, 'supervision': 0.45111639186191776, 'accuracy': 0.3193359375, 'regularization': 0.0378493512037359, 'mlp_supervision': 0.3857380816900493, 'label_distribution': 0.650179414859634}\n",
      "epoch: 16 mean_loss: {'reconstruction': 0.13578115220850034, 'supervision': 0.4509325037686261, 'accuracy': 0.31768798828125, 'regularization': 0.03664577216142488, 'mlp_supervision': 0.3858846871487369, 'label_distribution': 0.6501747720731526}\n",
      "epoch: 17 mean_loss: {'reconstruction': 0.135274411713662, 'supervision': 0.4509681945715873, 'accuracy': 0.31549072265625, 'regularization': 0.03568701537221014, 'mlp_supervision': 0.38592675446774094, 'label_distribution': 0.6501737986856275}\n",
      "epoch: 18 mean_loss: {'reconstruction': 0.13553181724900387, 'supervision': 0.4510957998599383, 'accuracy': 0.3201904296875, 'regularization': 0.034860405820279085, 'mlp_supervision': 0.38580848560216985, 'label_distribution': 0.6501745992920338}\n",
      "epoch: 19 mean_loss: {'reconstruction': 0.13579568057501623, 'supervision': 0.4512403511266412, 'accuracy': 0.31396484375, 'regularization': 0.033766007396900444, 'mlp_supervision': 0.38569603261549396, 'label_distribution': 0.6501754888854219}\n",
      "epoch: 20 mean_loss: {'reconstruction': 0.13552346721052852, 'supervision': 0.4510691591052394, 'accuracy': 0.31671142578125, 'regularization': 0.034050819369831994, 'mlp_supervision': 0.38578882140821613, 'label_distribution': 0.6501741279915272}\n",
      "epoch: 21 mean_loss: {'reconstruction': 0.13556999628209898, 'supervision': 0.45066755211434534, 'accuracy': 0.31915283203125, 'regularization': 0.03390663059825724, 'mlp_supervision': 0.3865192851142166, 'label_distribution': 0.6501730039444551}\n",
      "epoch: 22 mean_loss: {'reconstruction': 0.13466882384468853, 'supervision': 0.4507228062615404, 'accuracy': 0.31329345703125, 'regularization': 0.03254134653396694, 'mlp_supervision': 0.38620984517453094, 'label_distribution': 0.6501810812037855}\n",
      "epoch: 23 mean_loss: {'reconstruction': 0.13553491462961922, 'supervision': 0.4506785786856188, 'accuracy': 0.3187255859375, 'regularization': 0.03212278428976628, 'mlp_supervision': 0.3857946656119653, 'label_distribution': 0.6501759731341465}\n",
      "epoch: 24 mean_loss: {'reconstruction': 0.13535312197320937, 'supervision': 0.4507648655923314, 'accuracy': 0.31500244140625, 'regularization': 0.03177767925261679, 'mlp_supervision': 0.38607362090555447, 'label_distribution': 0.6501752921915713}\n",
      "epoch: 25 mean_loss: {'reconstruction': 0.13569964529029147, 'supervision': 0.4505601263079581, 'accuracy': 0.31634521484375, 'regularization': 0.03145937222606557, 'mlp_supervision': 0.38576506379548825, 'label_distribution': 0.6501869655642298}\n",
      "epoch: 26 mean_loss: {'reconstruction': 0.1354203359685281, 'supervision': 0.450791726436788, 'accuracy': 0.31494140625, 'regularization': 0.030785321832028763, 'mlp_supervision': 0.38626764826890336, 'label_distribution': 0.6501848722939214}\n",
      "epoch: 27 mean_loss: {'reconstruction': 0.13538186530984958, 'supervision': 0.4505037068154234, 'accuracy': 0.3153076171875, 'regularization': 0.031057647008265358, 'mlp_supervision': 0.38601095906419014, 'label_distribution': 0.6501774793357231}\n",
      "epoch: 28 mean_loss: {'reconstruction': 0.13529955201258217, 'supervision': 0.4505751860497448, 'accuracy': 0.30914306640625, 'regularization': 0.030200747863209403, 'mlp_supervision': 0.3860279264982588, 'label_distribution': 0.650176624124717}\n",
      "epoch: 29 mean_loss: {'reconstruction': 0.1347076341767055, 'supervision': 0.45004237157058113, 'accuracy': 0.31658935546875, 'regularization': 0.030968872124055108, 'mlp_supervision': 0.3858591193557058, 'label_distribution': 0.6501991721016191}\n",
      "epoch: 30 mean_loss: {'reconstruction': 0.1354685341272843, 'supervision': 0.44417149708695164, 'accuracy': 0.32110595703125, 'regularization': 0.03071364394883802, 'mlp_supervision': 0.3850451226030526, 'label_distribution': 0.6508172600993944}\n",
      "epoch: 31 mean_loss: {'reconstruction': 0.13544865687485125, 'supervision': 0.4243320134666516, 'accuracy': 0.33599853515625, 'regularization': 0.03254855268728681, 'mlp_supervision': 0.3821597279120277, 'label_distribution': 0.6521282843211396}\n",
      "epoch: 32 mean_loss: {'reconstruction': 0.13290066201037243, 'supervision': 0.4114121704099884, 'accuracy': 0.35211181640625, 'regularization': 0.03706806515496646, 'mlp_supervision': 0.3760360747458156, 'label_distribution': 0.6527803714526055}\n",
      "epoch: 33 mean_loss: {'reconstruction': 0.13056910690307377, 'supervision': 0.3987645152370719, 'accuracy': 0.38232421875, 'regularization': 0.041931890007295414, 'mlp_supervision': 0.36577560515629803, 'label_distribution': 0.6534793931175983}\n",
      "epoch: 34 mean_loss: {'reconstruction': 0.12834131031291363, 'supervision': 0.3861083891885503, 'accuracy': 0.42449951171875, 'regularization': 0.044673401256685105, 'mlp_supervision': 0.35271018481857924, 'label_distribution': 0.6536791395342512}\n",
      "epoch: 35 mean_loss: {'reconstruction': 0.12641097119518457, 'supervision': 0.36799571860289115, 'accuracy': 0.486328125, 'regularization': 0.04678206646967066, 'mlp_supervision': 0.340564916952073, 'label_distribution': 0.6543018763429431}\n",
      "epoch: 36 mean_loss: {'reconstruction': 0.12394446098943379, 'supervision': 0.3344614992063159, 'accuracy': 0.55615234375, 'regularization': 0.05075790099958796, 'mlp_supervision': 0.32558909088326926, 'label_distribution': 0.6552008518168058}\n",
      "epoch: 37 mean_loss: {'reconstruction': 0.12147249482015166, 'supervision': 0.28742823083071395, 'accuracy': 0.63653564453125, 'regularization': 0.05742323417150105, 'mlp_supervision': 0.3098522367280142, 'label_distribution': 0.6556231125997647}\n",
      "epoch: 38 mean_loss: {'reconstruction': 0.11929153700865319, 'supervision': 0.23978473752878865, 'accuracy': 0.68878173828125, 'regularization': 0.06332628401910191, 'mlp_supervision': 0.2915561751225989, 'label_distribution': 0.6562432426249855}\n",
      "epoch: 39 mean_loss: {'reconstruction': 0.11648436867726522, 'supervision': 0.2144852444466958, 'accuracy': 0.7149658203125, 'regularization': 0.06730332129680201, 'mlp_supervision': 0.2723680812520354, 'label_distribution': 0.6565276490574921}\n",
      "epoch: 40 mean_loss: {'reconstruction': 0.11419659152969966, 'supervision': 0.1949805206493122, 'accuracy': 0.74078369140625, 'regularization': 0.07043833277587483, 'mlp_supervision': 0.25042880209073026, 'label_distribution': 0.6570246125843433}\n",
      "epoch: 41 mean_loss: {'reconstruction': 0.11290257111170407, 'supervision': 0.16315724448421823, 'accuracy': 0.81268310546875, 'regularization': 0.0729171579900833, 'mlp_supervision': 0.21633380577290778, 'label_distribution': 0.6570191421429461}\n",
      "epoch: 42 mean_loss: {'reconstruction': 0.11088239124263191, 'supervision': 0.11482717694945432, 'accuracy': 0.8878173828125, 'regularization': 0.07682866446655719, 'mlp_supervision': 0.17959024617471278, 'label_distribution': 0.6576977224421262}\n",
      "epoch: 43 mean_loss: {'reconstruction': 0.10955273552991338, 'supervision': 0.08507801148762334, 'accuracy': 0.92327880859375, 'regularization': 0.07885939756648169, 'mlp_supervision': 0.1497627692680072, 'label_distribution': 0.6586456918451735}\n",
      "epoch: 44 mean_loss: {'reconstruction': 0.10873733223686455, 'supervision': 0.057803580828335546, 'accuracy': 0.95037841796875, 'regularization': 0.08173164670160653, 'mlp_supervision': 0.11932511217205989, 'label_distribution': 0.658220231192487}\n",
      "epoch: 45 mean_loss: {'reconstruction': 0.10787124533617784, 'supervision': 0.045693807125002955, 'accuracy': 0.9617919921875, 'regularization': 0.08282718494909692, 'mlp_supervision': 0.09555347382748117, 'label_distribution': 0.6583193028869226}\n",
      "epoch: 46 mean_loss: {'reconstruction': 0.10730155602560956, 'supervision': 0.03447040009181001, 'accuracy': 0.9691162109375, 'regularization': 0.0835935202821315, 'mlp_supervision': 0.07733369794625178, 'label_distribution': 0.6581922364123487}\n",
      "epoch: 47 mean_loss: {'reconstruction': 0.10749672728817375, 'supervision': 0.03345507744041525, 'accuracy': 0.97052001953125, 'regularization': 0.08366257527073961, 'mlp_supervision': 0.06576267578703206, 'label_distribution': 0.6580947350089535}\n",
      "epoch: 48 mean_loss: {'reconstruction': 0.10715376748891813, 'supervision': 0.025944166590263856, 'accuracy': 0.97747802734375, 'regularization': 0.08365677081909881, 'mlp_supervision': 0.05198143208217838, 'label_distribution': 0.6581927639700418}\n",
      "epoch: 49 mean_loss: {'reconstruction': 0.10656986179438796, 'supervision': 0.028355121643028378, 'accuracy': 0.9747314453125, 'regularization': 0.08364719141928126, 'mlp_supervision': 0.04816103297880063, 'label_distribution': 0.6585632482494638}\n",
      "epoch: 50 mean_loss: {'reconstruction': 0.10714004294104323, 'supervision': 0.028961645728494793, 'accuracy': 0.97412109375, 'regularization': 0.08363621216732861, 'mlp_supervision': 0.0461051881303794, 'label_distribution': 0.6584805700801264}\n",
      "epoch: 51 mean_loss: {'reconstruction': 0.10666787741749102, 'supervision': 0.022251455941387936, 'accuracy': 0.98040771484375, 'regularization': 0.08362698196432933, 'mlp_supervision': 0.0370634392464459, 'label_distribution': 0.6577687751310293}\n",
      "epoch: 52 mean_loss: {'reconstruction': 0.1067708392539004, 'supervision': 0.020190771828380725, 'accuracy': 0.98175048828125, 'regularization': 0.08361750004303162, 'mlp_supervision': 0.03342199530905577, 'label_distribution': 0.6582828855107862}\n",
      "epoch: 53 mean_loss: {'reconstruction': 0.10710842257812661, 'supervision': 0.020542231243242365, 'accuracy': 0.982666015625, 'regularization': 0.08360867303783032, 'mlp_supervision': 0.03181178987711521, 'label_distribution': 0.6580729906809555}\n",
      "epoch: 54 mean_loss: {'reconstruction': 0.10652295507367758, 'supervision': 0.01839102825215016, 'accuracy': 0.984375, 'regularization': 0.08360033478917128, 'mlp_supervision': 0.028507876663051185, 'label_distribution': 0.6589597724050459}\n",
      "epoch: 55 mean_loss: {'reconstruction': 0.10715129274807403, 'supervision': 0.020036611804196976, 'accuracy': 0.98223876953125, 'regularization': 0.0835924552609766, 'mlp_supervision': 0.02903174038344291, 'label_distribution': 0.6580149518738931}\n",
      "epoch: 56 mean_loss: {'reconstruction': 0.10700023329428329, 'supervision': 0.015813319745462833, 'accuracy': 0.98663330078125, 'regularization': 0.08358521751281847, 'mlp_supervision': 0.02380142321466225, 'label_distribution': 0.6585050483768129}\n",
      "epoch: 57 mean_loss: {'reconstruction': 0.10662928949206239, 'supervision': 0.018844203959292267, 'accuracy': 0.9832763671875, 'regularization': 0.08357862808517155, 'mlp_supervision': 0.025888275749531987, 'label_distribution': 0.6583765867198709}\n",
      "epoch: 58 mean_loss: {'reconstruction': 0.10678873375177009, 'supervision': 0.019492399049431078, 'accuracy': 0.981201171875, 'regularization': 0.0835719874028013, 'mlp_supervision': 0.02679228397701862, 'label_distribution': 0.657624120786461}\n",
      "epoch: 59 mean_loss: {'reconstruction': 0.1069024758535421, 'supervision': 0.018079811503025206, 'accuracy': 0.98309326171875, 'regularization': 0.08356561150388025, 'mlp_supervision': 0.02425545574367663, 'label_distribution': 0.6591228461720898}\n",
      "epoch: 60 mean_loss: {'reconstruction': 0.10715641727236208, 'supervision': 0.0159792155831762, 'accuracy': 0.9874267578125, 'regularization': 0.08355933378658159, 'mlp_supervision': 0.022084971241775088, 'label_distribution': 0.6588001387087185}\n",
      "epoch: 61 mean_loss: {'reconstruction': 0.10678725632655953, 'supervision': 0.01615242676898651, 'accuracy': 0.9864501953125, 'regularization': 0.08355351047527232, 'mlp_supervision': 0.02167100245453244, 'label_distribution': 0.6575553628405707}\n",
      "epoch: 62 mean_loss: {'reconstruction': 0.10737026687271771, 'supervision': 0.014466435470061186, 'accuracy': 0.98724365234375, 'regularization': 0.08354769667565787, 'mlp_supervision': 0.02046636641048403, 'label_distribution': 0.6577571718415163}\n",
      "epoch: 63 mean_loss: {'reconstruction': 0.10684640697221703, 'supervision': 0.012743622468440777, 'accuracy': 0.98883056640625, 'regularization': 0.08354276391503956, 'mlp_supervision': 0.018292144278260185, 'label_distribution': 0.6587284227399908}\n",
      "epoch: 64 mean_loss: {'reconstruction': 0.10697007104894529, 'supervision': 0.013215533391967405, 'accuracy': 0.9896240234375, 'regularization': 0.08353785383958545, 'mlp_supervision': 0.017652707229974897, 'label_distribution': 0.6592577172382761}\n",
      "epoch: 65 mean_loss: {'reconstruction': 0.1071690702597817, 'supervision': 0.014210331617971753, 'accuracy': 0.98797607421875, 'regularization': 0.08353331252027442, 'mlp_supervision': 0.018726373998395898, 'label_distribution': 0.6583736095387835}\n",
      "epoch: 66 mean_loss: {'reconstruction': 0.10751037861696729, 'supervision': 0.013711579815767278, 'accuracy': 0.9881591796875, 'regularization': 0.08352869787495593, 'mlp_supervision': 0.018617841759842248, 'label_distribution': 0.6587327766989095}\n",
      "epoch: 67 mean_loss: {'reconstruction': 0.10690255104926173, 'supervision': 0.012028429301594949, 'accuracy': 0.990478515625, 'regularization': 0.08352421897536971, 'mlp_supervision': 0.016212558243925895, 'label_distribution': 0.6583711587066233}\n",
      "epoch: 68 mean_loss: {'reconstruction': 0.10649570991789034, 'supervision': 0.012303012305463646, 'accuracy': 0.98876953125, 'regularization': 0.0835193070169478, 'mlp_supervision': 0.01692732096627673, 'label_distribution': 0.6582185441509112}\n",
      "epoch: 69 mean_loss: {'reconstruction': 0.10724911344563175, 'supervision': 0.01084596145895487, 'accuracy': 0.99163818359375, 'regularization': 0.08351465162701027, 'mlp_supervision': 0.014273138391460216, 'label_distribution': 0.6586047416607954}\n",
      "epoch: 70 mean_loss: {'reconstruction': 0.10808038394844267, 'supervision': 0.012116699181150157, 'accuracy': 0.99017333984375, 'regularization': 0.08351035594366729, 'mlp_supervision': 0.016142960514934974, 'label_distribution': 0.6591299393127632}\n",
      "epoch: 71 mean_loss: {'reconstruction': 0.10728839129654041, 'supervision': 0.012130068490390599, 'accuracy': 0.99090576171875, 'regularization': 0.08350650758015216, 'mlp_supervision': 0.015595806891434517, 'label_distribution': 0.6580163627877577}\n",
      "epoch: 72 mean_loss: {'reconstruction': 0.10719604230868773, 'supervision': 0.010901034680070854, 'accuracy': 0.99078369140625, 'regularization': 0.08350303023119252, 'mlp_supervision': 0.014165460710447962, 'label_distribution': 0.6581993828436183}\n",
      "epoch: 73 mean_loss: {'reconstruction': 0.10733827734270922, 'supervision': 0.009886374720151674, 'accuracy': 0.9921875, 'regularization': 0.08349928001675985, 'mlp_supervision': 0.013130419937888473, 'label_distribution': 0.6580430175454131}\n",
      "epoch: 74 mean_loss: {'reconstruction': 0.10767176564493709, 'supervision': 0.010804339096583612, 'accuracy': 0.99114990234375, 'regularization': 0.08349573446325198, 'mlp_supervision': 0.015002841624276685, 'label_distribution': 0.6588543190890683}\n",
      "epoch: 75 mean_loss: {'reconstruction': 0.10715163742896608, 'supervision': 0.010343121703377214, 'accuracy': 0.99072265625, 'regularization': 0.08349249306550487, 'mlp_supervision': 0.014318939211855262, 'label_distribution': 0.6582475671676806}\n",
      "epoch: 76 mean_loss: {'reconstruction': 0.10701975187926313, 'supervision': 0.01077914724525323, 'accuracy': 0.99127197265625, 'regularization': 0.08348918420721455, 'mlp_supervision': 0.014233131888909815, 'label_distribution': 0.6586695079925258}\n",
      "epoch: 77 mean_loss: {'reconstruction': 0.10697013713395513, 'supervision': 0.008475209092180396, 'accuracy': 0.9930419921875, 'regularization': 0.083486178074937, 'mlp_supervision': 0.011958609143904439, 'label_distribution': 0.6580347081277784}\n",
      "epoch: 78 mean_loss: {'reconstruction': 0.1070432654421112, 'supervision': 0.009072886156003874, 'accuracy': 0.99285888671875, 'regularization': 0.08348318529336039, 'mlp_supervision': 0.011945094694270908, 'label_distribution': 0.6581239665473404}\n",
      "epoch: 79 mean_loss: {'reconstruction': 0.10702283306630422, 'supervision': 0.008846824935394659, 'accuracy': 0.9925537109375, 'regularization': 0.08348020984982837, 'mlp_supervision': 0.012128192251181023, 'label_distribution': 0.6586502345402245}\n",
      "epoch: 80 mean_loss: {'reconstruction': 0.10740473409985443, 'supervision': 0.009764630025299686, 'accuracy': 0.9920654296875, 'regularization': 0.08347718858110131, 'mlp_supervision': 0.012817808246362555, 'label_distribution': 0.6575928365149786}\n",
      "epoch: 81 mean_loss: {'reconstruction': 0.10733465026832426, 'supervision': 0.008771891257767093, 'accuracy': 0.99285888671875, 'regularization': 0.08347441329373724, 'mlp_supervision': 0.011744205327830437, 'label_distribution': 0.6585882201333908}\n",
      "epoch: 82 mean_loss: {'reconstruction': 0.10745457461521002, 'supervision': 0.008810548209446902, 'accuracy': 0.99322509765625, 'regularization': 0.08347163016060867, 'mlp_supervision': 0.011335249565233985, 'label_distribution': 0.6580662134911328}\n",
      "epoch: 83 mean_loss: {'reconstruction': 0.1067995480488382, 'supervision': 0.008333693816036332, 'accuracy': 0.99310302734375, 'regularization': 0.08346892710641933, 'mlp_supervision': 0.010819312318805886, 'label_distribution': 0.6580502585485086}\n",
      "epoch: 84 mean_loss: {'reconstruction': 0.10723578647898623, 'supervision': 0.008102048082336798, 'accuracy': 0.99273681640625, 'regularization': 0.08346655546055268, 'mlp_supervision': 0.01183812219581742, 'label_distribution': 0.6580673331845375}\n",
      "epoch: 85 mean_loss: {'reconstruction': 0.10706596863851565, 'supervision': 0.00937866654001519, 'accuracy': 0.991455078125, 'regularization': 0.08346418542715144, 'mlp_supervision': 0.012824940712236655, 'label_distribution': 0.6585381853359846}\n",
      "epoch: 86 mean_loss: {'reconstruction': 0.10763540162994603, 'supervision': 0.009715835872027238, 'accuracy': 0.9918212890625, 'regularization': 0.08346175675005799, 'mlp_supervision': 0.012159686383499943, 'label_distribution': 0.6583981093472887}\n",
      "epoch: 87 mean_loss: {'reconstruction': 0.10746507044742246, 'supervision': 0.007859317397083782, 'accuracy': 0.99365234375, 'regularization': 0.08345932362238295, 'mlp_supervision': 0.010206702528623213, 'label_distribution': 0.6591458715692091}\n",
      "epoch: 88 mean_loss: {'reconstruction': 0.10687096304985316, 'supervision': 0.006609257358721382, 'accuracy': 0.994384765625, 'regularization': 0.08345709291911232, 'mlp_supervision': 0.009543059791788122, 'label_distribution': 0.658041012399543}\n",
      "epoch: 89 mean_loss: {'reconstruction': 0.10703176425759059, 'supervision': 0.008712342340736954, 'accuracy': 0.9918212890625, 'regularization': 0.08345649489772158, 'mlp_supervision': 0.011392749389750231, 'label_distribution': 0.6580076272835006}\n",
      "epoch: 90 mean_loss: {'reconstruction': 0.10761866786506687, 'supervision': 0.009938902713329726, 'accuracy': 0.99163818359375, 'regularization': 0.08345348877020235, 'mlp_supervision': 0.01374634104638276, 'label_distribution': 0.6582330658159536}\n",
      "epoch: 91 mean_loss: {'reconstruction': 0.10732399772419446, 'supervision': 0.009800820514692207, 'accuracy': 0.9912109375, 'regularization': 0.08345119157777517, 'mlp_supervision': 0.012791531343275491, 'label_distribution': 0.6582565972426291}\n",
      "epoch: 92 mean_loss: {'reconstruction': 0.10685186805560268, 'supervision': 0.00716706003458792, 'accuracy': 0.99462890625, 'regularization': 0.08344904138583503, 'mlp_supervision': 0.009001648320599867, 'label_distribution': 0.6581110916557334}\n",
      "epoch: 93 mean_loss: {'reconstruction': 0.1074148237083083, 'supervision': 0.005763700281958816, 'accuracy': 0.99560546875, 'regularization': 0.08344708097682027, 'mlp_supervision': 0.007622850807329506, 'label_distribution': 0.6581426344556923}\n",
      "epoch: 94 mean_loss: {'reconstruction': 0.10767375197807472, 'supervision': 0.006174414971646692, 'accuracy': 0.99505615234375, 'regularization': 0.08344521223225014, 'mlp_supervision': 0.008709686238672992, 'label_distribution': 0.658226598051018}\n",
      "epoch: 95 mean_loss: {'reconstruction': 0.1073802649710317, 'supervision': 0.007471220485681665, 'accuracy': 0.99371337890625, 'regularization': 0.08344330986004608, 'mlp_supervision': 0.01036713157346059, 'label_distribution': 0.6585103017729512}\n",
      "epoch: 96 mean_loss: {'reconstruction': 0.1072282415316056, 'supervision': 0.006503781872962267, 'accuracy': 0.99468994140625, 'regularization': 0.08344136000994039, 'mlp_supervision': 0.00896344826862518, 'label_distribution': 0.658254651806863}\n",
      "epoch: 97 mean_loss: {'reconstruction': 0.10712304364621367, 'supervision': 0.005624603326305018, 'accuracy': 0.99591064453125, 'regularization': 0.0834395518677738, 'mlp_supervision': 0.007494911393540089, 'label_distribution': 0.6584448007376509}\n",
      "epoch: 98 mean_loss: {'reconstruction': 0.10709489196070882, 'supervision': 0.006774585041825654, 'accuracy': 0.993896484375, 'regularization': 0.08343785761066377, 'mlp_supervision': 0.009239281494386836, 'label_distribution': 0.6581104073813837}\n",
      "epoch: 99 mean_loss: {'reconstruction': 0.10732003305691856, 'supervision': 0.006510869758108667, 'accuracy': 0.99444580078125, 'regularization': 0.08343617160981381, 'mlp_supervision': 0.008498210107393756, 'label_distribution': 0.6583526475515964}\n",
      "epoch: 100 mean_loss: {'reconstruction': 0.10742038161632973, 'supervision': 0.006662174912761015, 'accuracy': 0.99371337890625, 'regularization': 0.08343463809789667, 'mlp_supervision': 0.009338898665079136, 'label_distribution': 0.6581422852116374}\n",
      "epoch: 101 mean_loss: {'reconstruction': 0.10781843237246531, 'supervision': 0.005981959617269084, 'accuracy': 0.9952392578125, 'regularization': 0.08343308273703598, 'mlp_supervision': 0.00799923224150662, 'label_distribution': 0.6584079334064049}\n",
      "epoch: 102 mean_loss: {'reconstruction': 0.1074398797537464, 'supervision': 0.005994147171825876, 'accuracy': 0.99609375, 'regularization': 0.08343164701943162, 'mlp_supervision': 0.007400898558115666, 'label_distribution': 0.658093310807178}\n",
      "epoch: 103 mean_loss: {'reconstruction': 0.1072958164965771, 'supervision': 0.005674742131916293, 'accuracy': 0.995849609375, 'regularization': 0.0834302670046317, 'mlp_supervision': 0.0069216663751072655, 'label_distribution': 0.6581442490972481}\n",
      "epoch: 104 mean_loss: {'reconstruction': 0.10773429011871119, 'supervision': 0.006487459949402625, 'accuracy': 0.9942626953125, 'regularization': 0.08342888077402234, 'mlp_supervision': 0.008583395739477988, 'label_distribution': 0.6584085976785267}\n",
      "epoch: 105 mean_loss: {'reconstruction': 0.1073039125658349, 'supervision': 0.005292412296531697, 'accuracy': 0.995361328125, 'regularization': 0.08342753482886155, 'mlp_supervision': 0.0069920523596813935, 'label_distribution': 0.6580979460037529}\n",
      "epoch: 106 mean_loss: {'reconstruction': 0.10738815665658516, 'supervision': 0.006544903412785476, 'accuracy': 0.99432373046875, 'regularization': 0.08342613836583576, 'mlp_supervision': 0.00895074639102955, 'label_distribution': 0.6584472078812779}\n",
      "epoch: 107 mean_loss: {'reconstruction': 0.10668828884120701, 'supervision': 0.004596402951894888, 'accuracy': 0.9970703125, 'regularization': 0.08342484807311083, 'mlp_supervision': 0.0057843158614034485, 'label_distribution': 0.6585109179083022}\n",
      "epoch: 108 mean_loss: {'reconstruction': 0.10744839184704014, 'supervision': 0.005851465656847427, 'accuracy': 0.99542236328125, 'regularization': 0.08342350678673394, 'mlp_supervision': 0.007123592336705758, 'label_distribution': 0.6580647068920771}\n",
      "epoch: 109 mean_loss: {'reconstruction': 0.10741614711714574, 'supervision': 0.005072794557186331, 'accuracy': 0.99566650390625, 'regularization': 0.08342219847716996, 'mlp_supervision': 0.0068424425981656375, 'label_distribution': 0.658023038233911}\n",
      "epoch: 110 mean_loss: {'reconstruction': 0.10736623011300982, 'supervision': 0.005118665728466152, 'accuracy': 0.99578857421875, 'regularization': 0.0834216015913779, 'mlp_supervision': 0.006748830212768586, 'label_distribution': 0.6585701523849576}\n",
      "epoch: 111 mean_loss: {'reconstruction': 0.10734669541293985, 'supervision': 0.0060177202324749445, 'accuracy': 0.994384765625, 'regularization': 0.08342008263254032, 'mlp_supervision': 0.008222104752562222, 'label_distribution': 0.6586405386714963}\n",
      "epoch: 112 mean_loss: {'reconstruction': 0.10739911895437337, 'supervision': 0.006034345576195211, 'accuracy': 0.99456787109375, 'regularization': 0.08341873270771713, 'mlp_supervision': 0.008723664144943355, 'label_distribution': 0.6585338853327845}\n",
      "epoch: 113 mean_loss: {'reconstruction': 0.10706122881966991, 'supervision': 0.006649308071446338, 'accuracy': 0.99420166015625, 'regularization': 0.0834183550001921, 'mlp_supervision': 0.00844474820392259, 'label_distribution': 0.6580931295649759}\n",
      "epoch: 114 mean_loss: {'reconstruction': 0.10732687658736886, 'supervision': 0.005122202870565352, 'accuracy': 0.995849609375, 'regularization': 0.08341841133367436, 'mlp_supervision': 0.00652321332801083, 'label_distribution': 0.6589371136057249}\n",
      "epoch: 115 mean_loss: {'reconstruction': 0.10718466757848696, 'supervision': 0.005411147740300555, 'accuracy': 0.99578857421875, 'regularization': 0.08341661435002948, 'mlp_supervision': 0.007435058828204259, 'label_distribution': 0.6583583913865164}\n",
      "epoch: 116 mean_loss: {'reconstruction': 0.1070086068627766, 'supervision': 0.004913327508082128, 'accuracy': 0.99627685546875, 'regularization': 0.0834150366317826, 'mlp_supervision': 0.006784305184701857, 'label_distribution': 0.6582815886010356}\n",
      "epoch: 117 mean_loss: {'reconstruction': 0.10703230652413141, 'supervision': 0.004401361365741922, 'accuracy': 0.99658203125, 'regularization': 0.08341382860780999, 'mlp_supervision': 0.005840457048048573, 'label_distribution': 0.6586713521693758}\n",
      "epoch: 118 mean_loss: {'reconstruction': 0.10683879551327516, 'supervision': 0.004754060794155815, 'accuracy': 0.99603271484375, 'regularization': 0.08341266235180421, 'mlp_supervision': 0.00645859542365587, 'label_distribution': 0.6580915068606819}\n",
      "epoch: 119 mean_loss: {'reconstruction': 0.10760755265436739, 'supervision': 0.004529789129796722, 'accuracy': 0.996337890625, 'regularization': 0.08341150759537624, 'mlp_supervision': 0.0060076291782505415, 'label_distribution': 0.6590567866994606}\n",
      "epoch: 120 mean_loss: {'reconstruction': 0.10735688744768855, 'supervision': 0.004045433271437937, 'accuracy': 0.99652099609375, 'regularization': 0.08341043329949555, 'mlp_supervision': 0.005752428005490421, 'label_distribution': 0.6577282224132317}\n",
      "epoch: 121 mean_loss: {'reconstruction': 0.10781267177625856, 'supervision': 0.004602934639629812, 'accuracy': 0.99603271484375, 'regularization': 0.08340943327059341, 'mlp_supervision': 0.006239535422867766, 'label_distribution': 0.6577766896351087}\n",
      "epoch: 122 mean_loss: {'reconstruction': 0.10679107092254778, 'supervision': 0.0038669443775459643, 'accuracy': 0.99700927734375, 'regularization': 0.08340843916680826, 'mlp_supervision': 0.005490417944475693, 'label_distribution': 0.6588103899569483}\n",
      "epoch: 123 mean_loss: {'reconstruction': 0.10766791618357882, 'supervision': 0.004228583426617373, 'accuracy': 0.9967041015625, 'regularization': 0.08340744030188471, 'mlp_supervision': 0.00554909241341703, 'label_distribution': 0.6587769969678527}\n",
      "epoch: 124 mean_loss: {'reconstruction': 0.107096410278498, 'supervision': 0.005009689048806602, 'accuracy': 0.9954833984375, 'regularization': 0.08340650023696305, 'mlp_supervision': 0.00673745230029299, 'label_distribution': 0.6580647990026789}\n",
      "epoch: 125 mean_loss: {'reconstruction': 0.10727749812785224, 'supervision': 0.004926714255939099, 'accuracy': 0.99627685546875, 'regularization': 0.0834056531100569, 'mlp_supervision': 0.006860624473593802, 'label_distribution': 0.6582380501329743}\n",
      "epoch: 126 mean_loss: {'reconstruction': 0.10737383846612025, 'supervision': 0.0037204260841609132, 'accuracy': 0.9970703125, 'regularization': 0.08340476374160952, 'mlp_supervision': 0.005070573454095725, 'label_distribution': 0.6584427266193531}\n",
      "epoch: 127 mean_loss: {'reconstruction': 0.10759247577417061, 'supervision': 0.004156676088258982, 'accuracy': 0.9967041015625, 'regularization': 0.08340388238051064, 'mlp_supervision': 0.006286671390742423, 'label_distribution': 0.6586145641570225}\n",
      "epoch: 128 mean_loss: {'reconstruction': 0.10659146716546591, 'supervision': 0.003198329946266698, 'accuracy': 0.9969482421875, 'regularization': 0.08340299774572202, 'mlp_supervision': 0.004357987391207604, 'label_distribution': 0.6585508616764781}\n",
      "epoch: 129 mean_loss: {'reconstruction': 0.10777734414122356, 'supervision': 0.0027900844790963706, 'accuracy': 0.997802734375, 'regularization': 0.08340218279898641, 'mlp_supervision': 0.0038754437118411447, 'label_distribution': 0.6581548537566794}\n",
      "epoch: 130 mean_loss: {'reconstruction': 0.10665231056191384, 'supervision': 0.0038051409914974287, 'accuracy': 0.99700927734375, 'regularization': 0.08340136111506413, 'mlp_supervision': 0.005550623779040935, 'label_distribution': 0.6588245854945849}\n",
      "epoch: 131 mean_loss: {'reconstruction': 0.10757520215517001, 'supervision': 0.0036245722342889827, 'accuracy': 0.99725341796875, 'regularization': 0.08340059178506858, 'mlp_supervision': 0.005032376997207078, 'label_distribution': 0.6585724744298618}\n",
      "epoch: 132 mean_loss: {'reconstruction': 0.10725853766555106, 'supervision': 0.004434901932310182, 'accuracy': 0.99609375, 'regularization': 0.083399834312099, 'mlp_supervision': 0.006281550214342272, 'label_distribution': 0.6589455937683133}\n",
      "epoch: 133 mean_loss: {'reconstruction': 0.10729521403441886, 'supervision': 0.005825815212252121, 'accuracy': 0.99468994140625, 'regularization': 0.08339912241341607, 'mlp_supervision': 0.00810236066334474, 'label_distribution': 0.6586739588287462}\n",
      "epoch: 134 mean_loss: {'reconstruction': 0.10785167359586252, 'supervision': 0.004792965732682232, 'accuracy': 0.99627685546875, 'regularization': 0.08339847819114224, 'mlp_supervision': 0.006341878476708503, 'label_distribution': 0.6590142009654554}\n",
      "epoch: 135 mean_loss: {'reconstruction': 0.10715031558624413, 'supervision': 0.004942940077948517, 'accuracy': 0.99591064453125, 'regularization': 0.08339775036979663, 'mlp_supervision': 0.006475219828743144, 'label_distribution': 0.6578501469393193}\n",
      "epoch: 136 mean_loss: {'reconstruction': 0.10721050159369314, 'supervision': 0.004601514589183319, 'accuracy': 0.9969482421875, 'regularization': 0.08339695435521988, 'mlp_supervision': 0.005333824583667473, 'label_distribution': 0.6587774583160692}\n",
      "epoch: 137 mean_loss: {'reconstruction': 0.10766087683263599, 'supervision': 0.0027554749491996364, 'accuracy': 0.99798583984375, 'regularization': 0.08339620170473742, 'mlp_supervision': 0.0035495270817369213, 'label_distribution': 0.658851267436898}\n",
      "epoch: 138 mean_loss: {'reconstruction': 0.10708921131359737, 'supervision': 0.0029895546742384114, 'accuracy': 0.9981689453125, 'regularization': 0.08339548306586422, 'mlp_supervision': 0.0035946908091941646, 'label_distribution': 0.6587150658567887}\n",
      "epoch: 139 mean_loss: {'reconstruction': 0.10734700007698042, 'supervision': 0.003478301014224509, 'accuracy': 0.99737548828125, 'regularization': 0.08339479675971448, 'mlp_supervision': 0.004952131899070138, 'label_distribution': 0.6582409551378812}\n",
      "epoch: 140 mean_loss: {'reconstruction': 0.10757226328217204, 'supervision': 0.004520273071442627, 'accuracy': 0.996337890625, 'regularization': 0.08339423854472039, 'mlp_supervision': 0.00600434804074368, 'label_distribution': 0.6585360286948958}\n",
      "epoch: 141 mean_loss: {'reconstruction': 0.10761783876520385, 'supervision': 0.004673675619093501, 'accuracy': 0.99609375, 'regularization': 0.08339363202668246, 'mlp_supervision': 0.006159553747631993, 'label_distribution': 0.6584291550415537}\n",
      "epoch: 142 mean_loss: {'reconstruction': 0.1073097430224538, 'supervision': 0.0033374909878513704, 'accuracy': 0.99786376953125, 'regularization': 0.08339295712710001, 'mlp_supervision': 0.004307850425672002, 'label_distribution': 0.6583678463005126}\n",
      "epoch: 143 mean_loss: {'reconstruction': 0.1073109275705671, 'supervision': 0.004052913708262999, 'accuracy': 0.99700927734375, 'regularization': 0.08339235863991912, 'mlp_supervision': 0.005280773874117266, 'label_distribution': 0.65833117907798}\n",
      "epoch: 144 mean_loss: {'reconstruction': 0.10779747122910513, 'supervision': 0.0028019319701032813, 'accuracy': 0.99786376953125, 'regularization': 0.08339174346670142, 'mlp_supervision': 0.0037274499132528226, 'label_distribution': 0.6583417566056283}\n",
      "epoch: 145 mean_loss: {'reconstruction': 0.1072025653774599, 'supervision': 0.0024161394597174645, 'accuracy': 0.99798583984375, 'regularization': 0.08339111458288126, 'mlp_supervision': 0.0031745523390286383, 'label_distribution': 0.6584248063408994}\n",
      "epoch: 146 mean_loss: {'reconstruction': 0.10706517956147327, 'supervision': 0.00264174121359647, 'accuracy': 0.997314453125, 'regularization': 0.08339052299312943, 'mlp_supervision': 0.004076837582366356, 'label_distribution': 0.6588414489986427}\n",
      "epoch: 147 mean_loss: {'reconstruction': 0.10746868868424267, 'supervision': 0.00328046800541705, 'accuracy': 0.9971923828125, 'regularization': 0.08338990131244843, 'mlp_supervision': 0.004567140562230959, 'label_distribution': 0.6585321705720852}\n",
      "epoch: 148 mean_loss: {'reconstruction': 0.10784486063890678, 'supervision': 0.0027843911962847916, 'accuracy': 0.99755859375, 'regularization': 0.08338932181327406, 'mlp_supervision': 0.003735062030855855, 'label_distribution': 0.658429671382875}\n",
      "epoch: 149 mean_loss: {'reconstruction': 0.10740656961548774, 'supervision': 0.0031156964962163612, 'accuracy': 0.99761962890625, 'regularization': 0.08338874132954976, 'mlp_supervision': 0.004186785183991342, 'label_distribution': 0.6578476945083811}\n",
      "epoch: 150 mean_loss: {'reconstruction': 0.10771351661663231, 'supervision': 0.00249543232574549, 'accuracy': 0.99835205078125, 'regularization': 0.08338816646549287, 'mlp_supervision': 0.003165079239942372, 'label_distribution': 0.6585206111174046}\n",
      "epoch: 151 mean_loss: {'reconstruction': 0.10728972995878275, 'supervision': 0.0029077347881198397, 'accuracy': 0.998046875, 'regularization': 0.08338788425364965, 'mlp_supervision': 0.004025932269177305, 'label_distribution': 0.6584736972364691}\n",
      "epoch: 152 mean_loss: {'reconstruction': 0.10750167768646955, 'supervision': 0.003688664275303751, 'accuracy': 0.9976806640625, 'regularization': 0.0833874068815505, 'mlp_supervision': 0.004449559840183651, 'label_distribution': 0.6588093026386086}\n",
      "epoch: 153 mean_loss: {'reconstruction': 0.10749146719844854, 'supervision': 0.0022029589788422456, 'accuracy': 0.998291015625, 'regularization': 0.08338696505838886, 'mlp_supervision': 0.002933931772591622, 'label_distribution': 0.6581925989666972}\n",
      "epoch: 154 mean_loss: {'reconstruction': 0.10779876121275135, 'supervision': 0.001898802431407378, 'accuracy': 0.99822998046875, 'regularization': 0.08338642457375182, 'mlp_supervision': 0.0028419424584127514, 'label_distribution': 0.6580141061417589}\n",
      "epoch: 155 mean_loss: {'reconstruction': 0.107703895003299, 'supervision': 0.003525113227526483, 'accuracy': 0.99737548828125, 'regularization': 0.083385781605079, 'mlp_supervision': 0.0046800075578577165, 'label_distribution': 0.6588176736510114}\n",
      "epoch: 156 mean_loss: {'reconstruction': 0.10711577315546411, 'supervision': 0.002436379530383114, 'accuracy': 0.99822998046875, 'regularization': 0.08338525656969331, 'mlp_supervision': 0.003403389734866219, 'label_distribution': 0.6588768458241696}\n",
      "epoch: 157 mean_loss: {'reconstruction': 0.10734097632267597, 'supervision': 0.003804308655067217, 'accuracy': 0.9969482421875, 'regularization': 0.08338468574639737, 'mlp_supervision': 0.005152218794536924, 'label_distribution': 0.6594248276881429}\n",
      "epoch: 158 mean_loss: {'reconstruction': 0.1072658074649041, 'supervision': 0.002752743286028466, 'accuracy': 0.998046875, 'regularization': 0.08338413616670723, 'mlp_supervision': 0.003589046039088247, 'label_distribution': 0.6582852495608353}\n",
      "epoch: 159 mean_loss: {'reconstruction': 0.10735174349896578, 'supervision': 0.0034560747287611165, 'accuracy': 0.99688720703125, 'regularization': 0.08338363508402215, 'mlp_supervision': 0.004599713688630834, 'label_distribution': 0.6582185439557806}\n",
      "epoch: 160 mean_loss: {'reconstruction': 0.10733194719451518, 'supervision': 0.004603077928045089, 'accuracy': 0.99591064453125, 'regularization': 0.08338326762721598, 'mlp_supervision': 0.00656086615020759, 'label_distribution': 0.6583710956663089}\n",
      "epoch: 161 mean_loss: {'reconstruction': 0.10748430325567386, 'supervision': 0.00433868630078809, 'accuracy': 0.99658203125, 'regularization': 0.08338281866988989, 'mlp_supervision': 0.0058529384413372, 'label_distribution': 0.658375324714178}\n",
      "epoch: 162 mean_loss: {'reconstruction': 0.10770908419804565, 'supervision': 0.002812541878871684, 'accuracy': 0.99786376953125, 'regularization': 0.0833824501647551, 'mlp_supervision': 0.003750112863141181, 'label_distribution': 0.657903870768968}\n",
      "epoch: 163 mean_loss: {'reconstruction': 0.10783592787295732, 'supervision': 0.0026868700146354656, 'accuracy': 0.9981689453125, 'regularization': 0.08338217489963716, 'mlp_supervision': 0.00346119218042805, 'label_distribution': 0.6580889154776968}\n",
      "epoch: 164 mean_loss: {'reconstruction': 0.10750419178372496, 'supervision': 0.005124617944206647, 'accuracy': 0.99652099609375, 'regularization': 0.08338182834235533, 'mlp_supervision': 0.006191106783090126, 'label_distribution': 0.6589503150575585}\n",
      "epoch: 165 mean_loss: {'reconstruction': 0.10743987828390301, 'supervision': 0.0040783692026524, 'accuracy': 0.99658203125, 'regularization': 0.08338128083620684, 'mlp_supervision': 0.0055638591474993105, 'label_distribution': 0.6589561731659729}\n",
      "epoch: 166 mean_loss: {'reconstruction': 0.1075870630991405, 'supervision': 0.0026930656150207562, 'accuracy': 0.9981689453125, 'regularization': 0.08338088717803804, 'mlp_supervision': 0.003487746852304939, 'label_distribution': 0.6578217280129047}\n",
      "epoch: 167 mean_loss: {'reconstruction': 0.10746937697557793, 'supervision': 0.0035705496097870135, 'accuracy': 0.99700927734375, 'regularization': 0.08338039731859737, 'mlp_supervision': 0.005029049665503323, 'label_distribution': 0.658170338907489}\n",
      "epoch: 168 mean_loss: {'reconstruction': 0.1074556224509946, 'supervision': 0.001967481620481052, 'accuracy': 0.998779296875, 'regularization': 0.08337990189989651, 'mlp_supervision': 0.0027117066905729377, 'label_distribution': 0.6590096241032206}\n",
      "epoch: 169 mean_loss: {'reconstruction': 0.10782137899388149, 'supervision': 0.0030576721290640554, 'accuracy': 0.9976806640625, 'regularization': 0.08337952905455293, 'mlp_supervision': 0.004318570161215363, 'label_distribution': 0.659126710372524}\n",
      "epoch: 170 mean_loss: {'reconstruction': 0.1078840564038353, 'supervision': 0.002465770821018888, 'accuracy': 0.99871826171875, 'regularization': 0.08337918756989698, 'mlp_supervision': 0.0031284944470118935, 'label_distribution': 0.6580714948837465}\n",
      "epoch: 171 mean_loss: {'reconstruction': 0.10710640477082417, 'supervision': 0.0015183226059263745, 'accuracy': 0.99884033203125, 'regularization': 0.08337869925226193, 'mlp_supervision': 0.0024079600593604478, 'label_distribution': 0.6577440515619379}\n",
      "epoch: 172 mean_loss: {'reconstruction': 0.10724116521465606, 'supervision': 0.0035462393834690092, 'accuracy': 0.99749755859375, 'regularization': 0.08337823251638743, 'mlp_supervision': 0.004376302284891132, 'label_distribution': 0.6586314769094491}\n",
      "epoch: 173 mean_loss: {'reconstruction': 0.10749545994558934, 'supervision': 0.0030647218622089347, 'accuracy': 0.99755859375, 'regularization': 0.0833776813381398, 'mlp_supervision': 0.004100618104669444, 'label_distribution': 0.6590623872781544}\n",
      "epoch: 174 mean_loss: {'reconstruction': 0.10782581775559777, 'supervision': 0.002590675266493775, 'accuracy': 0.998291015625, 'regularization': 0.08337720052674302, 'mlp_supervision': 0.003204357789148922, 'label_distribution': 0.6583126658245075}\n",
      "epoch: 175 mean_loss: {'reconstruction': 0.10720658238797522, 'supervision': 0.002394439306652949, 'accuracy': 0.99810791015625, 'regularization': 0.08337698869343171, 'mlp_supervision': 0.0029210449584955284, 'label_distribution': 0.6581205532967077}\n",
      "epoch: 176 mean_loss: {'reconstruction': 0.10743664104548695, 'supervision': 0.0031891615772317527, 'accuracy': 0.99749755859375, 'regularization': 0.08337679641231999, 'mlp_supervision': 0.004400214046919409, 'label_distribution': 0.6582016636293224}\n",
      "epoch: 177 mean_loss: {'reconstruction': 0.10753946445896412, 'supervision': 0.0026683260996926243, 'accuracy': 0.99822998046875, 'regularization': 0.08337645514437386, 'mlp_supervision': 0.003350923711196655, 'label_distribution': 0.6583401754783129}\n",
      "epoch: 178 mean_loss: {'reconstruction': 0.10746904928181772, 'supervision': 0.003096043191853882, 'accuracy': 0.99774169921875, 'regularization': 0.08337643889946987, 'mlp_supervision': 0.004177244252220269, 'label_distribution': 0.658350868349377}\n",
      "epoch: 179 mean_loss: {'reconstruction': 0.10753140983512526, 'supervision': 0.0025623865684223962, 'accuracy': 0.9986572265625, 'regularization': 0.08337594351441435, 'mlp_supervision': 0.0027115646135432996, 'label_distribution': 0.6597308640183918}\n",
      "epoch: 180 mean_loss: {'reconstruction': 0.1070558197571858, 'supervision': 0.003251346043262061, 'accuracy': 0.9981689453125, 'regularization': 0.08337553800379183, 'mlp_supervision': 0.00381077084008767, 'label_distribution': 0.6589172231294524}\n",
      "epoch: 181 mean_loss: {'reconstruction': 0.10771374959928104, 'supervision': 0.002606231048514376, 'accuracy': 0.99798583984375, 'regularization': 0.08337511299451895, 'mlp_supervision': 0.0038462026755215627, 'label_distribution': 0.6582635106849846}\n",
      "epoch: 182 mean_loss: {'reconstruction': 0.10741379697686937, 'supervision': 0.0019701002203015303, 'accuracy': 0.9989013671875, 'regularization': 0.08337474168275079, 'mlp_supervision': 0.0023024550480550167, 'label_distribution': 0.6584213869225646}\n",
      "epoch: 183 mean_loss: {'reconstruction': 0.10729244906196947, 'supervision': 0.001566176254778244, 'accuracy': 0.99932861328125, 'regularization': 0.08337437471838914, 'mlp_supervision': 0.0019469939950851312, 'label_distribution': 0.6583904636888935}\n",
      "epoch: 184 mean_loss: {'reconstruction': 0.10744768756964215, 'supervision': 0.001757860609095943, 'accuracy': 0.99884033203125, 'regularization': 0.08337396953365897, 'mlp_supervision': 0.0022795213331437596, 'label_distribution': 0.6586032024010338}\n",
      "epoch: 185 mean_loss: {'reconstruction': 0.10748793274074689, 'supervision': 0.0012140733191726837, 'accuracy': 0.99896240234375, 'regularization': 0.08337357440811466, 'mlp_supervision': 0.0018187281240191792, 'label_distribution': 0.6582757918141423}\n",
      "epoch: 186 mean_loss: {'reconstruction': 0.10741842870903598, 'supervision': 0.0027138549693174843, 'accuracy': 0.99755859375, 'regularization': 0.08337319590565814, 'mlp_supervision': 0.004051373829896554, 'label_distribution': 0.6580819765928385}\n",
      "epoch: 187 mean_loss: {'reconstruction': 0.10736651352281448, 'supervision': 0.002020583727314302, 'accuracy': 0.99810791015625, 'regularization': 0.08337281354189872, 'mlp_supervision': 0.0027521659661284025, 'label_distribution': 0.6587002275590708}\n",
      "epoch: 188 mean_loss: {'reconstruction': 0.10735213939130925, 'supervision': 0.002340315740885673, 'accuracy': 0.99847412109375, 'regularization': 0.083372465735982, 'mlp_supervision': 0.0031339310763932827, 'label_distribution': 0.6583667622851843}\n",
      "epoch: 189 mean_loss: {'reconstruction': 0.1071260456220074, 'supervision': 0.0015881497560181566, 'accuracy': 0.99896240234375, 'regularization': 0.08337234452873221, 'mlp_supervision': 0.002379525944906198, 'label_distribution': 0.6585891118968845}\n",
      "epoch: 190 mean_loss: {'reconstruction': 0.10757106065729712, 'supervision': 0.002531823772837007, 'accuracy': 0.99786376953125, 'regularization': 0.08337199351297968, 'mlp_supervision': 0.0034837250515335596, 'label_distribution': 0.6585408013667486}\n",
      "epoch: 191 mean_loss: {'reconstruction': 0.1072779769661229, 'supervision': 0.0024320259385937305, 'accuracy': 0.99810791015625, 'regularization': 0.08337164408278741, 'mlp_supervision': 0.003141376291303225, 'label_distribution': 0.6587645927434229}\n",
      "epoch: 192 mean_loss: {'reconstruction': 0.10762162613386109, 'supervision': 0.00197749008636007, 'accuracy': 0.99847412109375, 'regularization': 0.08337173532416195, 'mlp_supervision': 0.0026997411971601626, 'label_distribution': 0.6586949571137881}\n",
      "epoch: 193 mean_loss: {'reconstruction': 0.10723466900854559, 'supervision': 0.0023769767516942566, 'accuracy': 0.9976806640625, 'regularization': 0.08337183746052028, 'mlp_supervision': 0.00410515497012625, 'label_distribution': 0.6589629659475473}\n",
      "epoch: 194 mean_loss: {'reconstruction': 0.10697438650087664, 'supervision': 0.0024128172939445187, 'accuracy': 0.99822998046875, 'regularization': 0.08337088683977062, 'mlp_supervision': 0.0028527955506413346, 'label_distribution': 0.6582417970601884}\n",
      "epoch: 195 mean_loss: {'reconstruction': 0.10734771500625864, 'supervision': 0.0018267716200266858, 'accuracy': 0.99871826171875, 'regularization': 0.08337033573302066, 'mlp_supervision': 0.0023454613663667, 'label_distribution': 0.6581199809424033}\n",
      "epoch: 196 mean_loss: {'reconstruction': 0.10766717199759376, 'supervision': 0.0015501081069579322, 'accuracy': 0.9990234375, 'regularization': 0.08337003984598154, 'mlp_supervision': 0.0018871907794908848, 'label_distribution': 0.6588649117088218}\n",
      "epoch: 197 mean_loss: {'reconstruction': 0.1075400436644551, 'supervision': 0.0009343928120168583, 'accuracy': 0.99957275390625, 'regularization': 0.08336978694055333, 'mlp_supervision': 0.0011179758007230636, 'label_distribution': 0.6586026855846202}\n",
      "epoch: 0 mean_loss: {'reconstruction': 0.10736293604886363, 'supervision': 0.05633212122860913, 'accuracy': 0.9728597005208334, 'regularization': 0.1444378520356998, 'mlp_supervision': 0.13309761107377072, 'label_distribution': 0.6544256616370913}\n",
      "epoch: 1 mean_loss: {'reconstruction': 0.10706463658394061, 'supervision': 0.0018717832324600385, 'accuracy': 0.9994710286458333, 'regularization': 0.1665555088061117, 'mlp_supervision': 0.047121707268172275, 'label_distribution': 0.654140355789347}\n",
      "epoch: 2 mean_loss: {'reconstruction': 0.107267022126661, 'supervision': 0.0014879549982102188, 'accuracy': 0.9994303385416666, 'regularization': 0.16659086804011816, 'mlp_supervision': 0.03373111367803368, 'label_distribution': 0.6542386100670279}\n",
      "epoch: 3 mean_loss: {'reconstruction': 0.1077673724373937, 'supervision': 0.0011935926859334106, 'accuracy': 0.9996337890625, 'regularization': 0.16660859342354273, 'mlp_supervision': 0.026671113691603007, 'label_distribution': 0.6540562286786599}\n",
      "epoch: 4 mean_loss: {'reconstruction': 0.10719822406774727, 'supervision': 0.0008361404871351689, 'accuracy': 0.999755859375, 'regularization': 0.16661971162406622, 'mlp_supervision': 0.022080351839163702, 'label_distribution': 0.6541419631392881}\n",
      "epoch: 0 mean_loss: {'reconstruction': 0.10724643175999271, 'supervision': 0.0012237172169080163, 'accuracy': 0.999847412109375, 'regularization': 0.16662838231895966, 'mlp_supervision': 0.02369924250665295, 'label_distribution': 0.6529408893209704}\n",
      "epoch: 1 mean_loss: {'reconstruction': 0.10742358072696298, 'supervision': 0.0010707133340040688, 'accuracy': 0.999755859375, 'regularization': 0.16663627663383687, 'mlp_supervision': 0.018649448621107397, 'label_distribution': 0.6528165901453453}\n",
      "epoch: 2 mean_loss: {'reconstruction': 0.10738674656655844, 'supervision': 0.0009279776106637201, 'accuracy': 0.99981689453125, 'regularization': 0.16664999585706042, 'mlp_supervision': 0.01532490398818717, 'label_distribution': 0.6528130009893438}\n"
     ]
    }
   ],
   "source": [
    "model = MNISTMultiAddLFLType3_MLP(fuzzifier_layer_kwargs={'noise_scale': noise_scales[0]}, lfl_layer_kwargs=[{}, {'noise_scale': noise_scales[1]}]).to(device)\n",
    "optimizer = MADGRAD([\n",
    "    {'params': model.lfl.parameters(), 'lr': lfl_lr},\n",
    "    {'params': model.cnn.parameters(), 'lr': cnn_lr},\n",
    "    {'params': model.mlp.parameters(), 'lr': mlp_lr},\n",
    "    {'params': model.reconstruction_layer.parameters(), 'lr': reconstruction_lr},\n",
    "])\n",
    "loss_records = []\n",
    "\n",
    "use_n_digits = [1, 2, 3]\n",
    "loss_records_ = {n_digits: [] for n_digits in use_n_digits}\n",
    "for n_digits in loss_records_:\n",
    "    train_dataset = MNISTMultiDigitADDDataset(mnist_train, n_digits=n_digits)\n",
    "    dataloader = DataLoader(train_dataset, batch_size=batch_size)\n",
    "    for epoch in range(epochs):\n",
    "        mean_loss = train()\n",
    "        loss_records_[n_digits].append(mean_loss)\n",
    "        print(f'epoch: {epoch} mean_loss: {mean_loss}')\n",
    "        if mean_loss['supervision'] < 0.001:\n",
    "            break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "188ae5aa-9e1c-4046-9198-df5facd62325",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(c0 & l0 & r0) | (c0 & l1 & r3) | (c0 & l2 & r5) | (c0 & l3 & r1) | (c0 & l4 & r6) | (c0 & l5 & r2) | (c0 & l6 & r4) | (c0 & l7 & r8) | (c0 & l8 & r7) | (c0 & l9 & r9) | (c1 & l0 & r7) | (c1 & l1 & r9) | (c1 & l2 & r6) | (c1 & l3 & r5) | (c1 & l4 & r8) | (c1 & l5 & r3) | (c1 & l6 & r2) | (c1 & l7 & r0) | (c1 & l8 & r4) | (c1 & l9 & r1),\n",
       " (c0 & l0 & r8) | (c0 & l1 & r2) | (c0 & l2 & r1) | (c0 & l3 & r9) | (c0 & l4 & r5) | (c0 & l5 & r4) | (c0 & l6 & r7) | (c0 & l7 & r6) | (c0 & l8 & r0) | (c0 & l9 & r3) | (c1 & l0 & r0) | (c1 & l1 & r3) | (c1 & l2 & r5) | (c1 & l3 & r1) | (c1 & l4 & r6) | (c1 & l5 & r2) | (c1 & l6 & r4) | (c1 & l7 & r8) | (c1 & l8 & r7) | (c1 & l9 & r9),\n",
       " (c0 & l0 & r6) | (c0 & l1 & r4) | (c0 & l2 & r9) | (c0 & l3 & r3) | (c0 & l4 & r1) | (c0 & l5 & r7) | (c0 & l6 & r0) | (c0 & l7 & r5) | (c0 & l8 & r8) | (c0 & l9 & r2) | (c1 & l0 & r8) | (c1 & l1 & r2) | (c1 & l2 & r1) | (c1 & l3 & r9) | (c1 & l4 & r5) | (c1 & l5 & r4) | (c1 & l6 & r7) | (c1 & l7 & r6) | (c1 & l8 & r0) | (c1 & l9 & r3),\n",
       " (c0 & l0 & r5) | (c0 & l1 & r7) | (c0 & l2 & r3) | (c0 & l3 & r2) | (c0 & l4 & r9) | (c0 & l5 & r0) | (c0 & l6 & r8) | (c0 & l7 & r1) | (c0 & l8 & r6) | (c0 & l9 & r4) | (c1 & l0 & r6) | (c1 & l1 & r4) | (c1 & l2 & r9) | (c1 & l3 & r3) | (c1 & l4 & r1) | (c1 & l5 & r7) | (c1 & l6 & r0) | (c1 & l7 & r5) | (c1 & l8 & r8) | (c1 & l9 & r2),\n",
       " (c0 & l0 & r1) | (c0 & l1 & r0) | (c0 & l2 & r2) | (c0 & l3 & r4) | (c0 & l4 & r3) | (c0 & l5 & r8) | (c0 & l6 & r6) | (c0 & l7 & r9) | (c0 & l8 & r5) | (c0 & l9 & r7) | (c1 & l0 & r5) | (c1 & l1 & r7) | (c1 & l2 & r3) | (c1 & l3 & r2) | (c1 & l4 & r9) | (c1 & l5 & r0) | (c1 & l6 & r8) | (c1 & l7 & r1) | (c1 & l8 & r6) | (c1 & l9 & r4),\n",
       " (c0 & l0 & r9) | (c0 & l1 & r8) | (c0 & l2 & r4) | (c0 & l3 & r7) | (c0 & l4 & r2) | (c0 & l5 & r6) | (c0 & l6 & r5) | (c0 & l7 & r3) | (c0 & l8 & r1) | (c0 & l9 & r0) | (c1 & l0 & r1) | (c1 & l1 & r0) | (c1 & l2 & r2) | (c1 & l3 & r4) | (c1 & l4 & r3) | (c1 & l5 & r8) | (c1 & l6 & r6) | (c1 & l7 & r9) | (c1 & l8 & r5) | (c1 & l9 & r7),\n",
       " (c0 & l0 & r3) | (c0 & l1 & r6) | (c0 & l2 & r7) | (c0 & l3 & r0) | (c0 & l4 & r4) | (c0 & l5 & r5) | (c0 & l6 & r1) | (c0 & l7 & r2) | (c0 & l8 & r9) | (c0 & l9 & r8) | (c1 & l0 & r9) | (c1 & l1 & r8) | (c1 & l2 & r4) | (c1 & l3 & r7) | (c1 & l4 & r2) | (c1 & l5 & r6) | (c1 & l6 & r5) | (c1 & l7 & r3) | (c1 & l8 & r1) | (c1 & l9 & r0),\n",
       " (c0 & l0 & r2) | (c0 & l1 & r5) | (c0 & l2 & r0) | (c0 & l3 & r8) | (c0 & l4 & r7) | (c0 & l5 & r1) | (c0 & l6 & r9) | (c0 & l7 & r4) | (c0 & l8 & r3) | (c0 & l9 & r6) | (c1 & l0 & r3) | (c1 & l1 & r6) | (c1 & l2 & r7) | (c1 & l3 & r0) | (c1 & l4 & r4) | (c1 & l5 & r5) | (c1 & l6 & r1) | (c1 & l7 & r2) | (c1 & l8 & r9) | (c1 & l9 & r8),\n",
       " (c0 & l0 & r4) | (c0 & l1 & r1) | (c0 & l2 & r8) | (c0 & l3 & r6) | (c0 & l4 & r0) | (c0 & l5 & r9) | (c0 & l6 & r3) | (c0 & l7 & r7) | (c0 & l8 & r2) | (c0 & l9 & r5) | (c1 & l0 & r2) | (c1 & l1 & r5) | (c1 & l2 & r0) | (c1 & l3 & r8) | (c1 & l4 & r7) | (c1 & l5 & r1) | (c1 & l6 & r9) | (c1 & l7 & r4) | (c1 & l8 & r3) | (c1 & l9 & r6),\n",
       " (c0 & l0 & r7) | (c0 & l1 & r9) | (c0 & l2 & r6) | (c0 & l3 & r5) | (c0 & l4 & r8) | (c0 & l5 & r3) | (c0 & l6 & r2) | (c0 & l7 & r0) | (c0 & l8 & r4) | (c0 & l9 & r1) | (c1 & l0 & r4) | (c1 & l1 & r1) | (c1 & l2 & r8) | (c1 & l3 & r6) | (c1 & l4 & r0) | (c1 & l5 & r9) | (c1 & l6 & r3) | (c1 & l7 & r7) | (c1 & l8 & r2) | (c1 & l9 & r5),\n",
       " (c0 & l0 & r2) | (c0 & l0 & r3) | (c0 & l0 & r4) | (c0 & l0 & r7) | (c0 & l0 & r9) | (c0 & l1 & r9) | (c0 & l2 & r0) | (c0 & l2 & r2) | (c0 & l2 & r3) | (c0 & l2 & r4) | (c0 & l2 & r6) | (c0 & l2 & r7) | (c0 & l2 & r8) | (c0 & l2 & r9) | (c0 & l3 & r0) | (c0 & l3 & r2) | (c0 & l3 & r3) | (c0 & l3 & r4) | (c0 & l3 & r5) | (c0 & l3 & r6) | (c0 & l3 & r7) | (c0 & l3 & r8) | (c0 & l3 & r9) | (c0 & l4 & r0) | (c0 & l4 & r2) | (c0 & l4 & r3) | (c0 & l4 & r4) | (c0 & l4 & r7) | (c0 & l4 & r8) | (c0 & l4 & r9) | (c0 & l5 & r3) | (c0 & l5 & r9) | (c0 & l6 & r2) | (c0 & l6 & r3) | (c0 & l6 & r9) | (c0 & l7 & r0) | (c0 & l7 & r2) | (c0 & l7 & r3) | (c0 & l7 & r4) | (c0 & l7 & r7) | (c0 & l7 & r9) | (c0 & l8 & r2) | (c0 & l8 & r3) | (c0 & l8 & r4) | (c0 & l8 & r9) | (c0 & l9 & r0) | (c0 & l9 & r1) | (c0 & l9 & r2) | (c0 & l9 & r3) | (c0 & l9 & r4) | (c0 & l9 & r5) | (c0 & l9 & r6) | (c0 & l9 & r7) | (c0 & l9 & r8) | (c0 & l9 & r9) | (c1 & l0 & r2) | (c1 & l0 & r3) | (c1 & l0 & r4) | (c1 & l0 & r9) | (c1 & l2 & r0) | (c1 & l2 & r2) | (c1 & l2 & r3) | (c1 & l2 & r4) | (c1 & l2 & r7) | (c1 & l2 & r8) | (c1 & l2 & r9) | (c1 & l3 & r0) | (c1 & l3 & r2) | (c1 & l3 & r3) | (c1 & l3 & r4) | (c1 & l3 & r6) | (c1 & l3 & r7) | (c1 & l3 & r8) | (c1 & l3 & r9) | (c1 & l4 & r0) | (c1 & l4 & r2) | (c1 & l4 & r3) | (c1 & l4 & r4) | (c1 & l4 & r7) | (c1 & l4 & r9) | (c1 & l5 & r9) | (c1 & l6 & r3) | (c1 & l6 & r9) | (c1 & l7 & r2) | (c1 & l7 & r3) | (c1 & l7 & r4) | (c1 & l7 & r7) | (c1 & l7 & r9) | (c1 & l8 & r2) | (c1 & l8 & r3) | (c1 & l8 & r9) | (c1 & l9 & r0) | (c1 & l9 & r2) | (c1 & l9 & r3) | (c1 & l9 & r4) | (c1 & l9 & r5) | (c1 & l9 & r6) | (c1 & l9 & r7) | (c1 & l9 & r8) | (c1 & l9 & r9),\n",
       " (c0 & l0 & r0) | (c0 & l0 & r1) | (c0 & l0 & r5) | (c0 & l0 & r6) | (c0 & l0 & r8) | (c0 & l1 & r0) | (c0 & l1 & r1) | (c0 & l1 & r2) | (c0 & l1 & r3) | (c0 & l1 & r4) | (c0 & l1 & r5) | (c0 & l1 & r6) | (c0 & l1 & r7) | (c0 & l1 & r8) | (c0 & l2 & r1) | (c0 & l2 & r5) | (c0 & l3 & r1) | (c0 & l4 & r1) | (c0 & l4 & r5) | (c0 & l4 & r6) | (c0 & l5 & r0) | (c0 & l5 & r1) | (c0 & l5 & r2) | (c0 & l5 & r4) | (c0 & l5 & r5) | (c0 & l5 & r6) | (c0 & l5 & r7) | (c0 & l5 & r8) | (c0 & l6 & r0) | (c0 & l6 & r1) | (c0 & l6 & r4) | (c0 & l6 & r5) | (c0 & l6 & r6) | (c0 & l6 & r7) | (c0 & l6 & r8) | (c0 & l7 & r1) | (c0 & l7 & r5) | (c0 & l7 & r6) | (c0 & l7 & r8) | (c0 & l8 & r0) | (c0 & l8 & r1) | (c0 & l8 & r5) | (c0 & l8 & r6) | (c0 & l8 & r7) | (c0 & l8 & r8) | (c1 & l0 & r0) | (c1 & l0 & r1) | (c1 & l0 & r5) | (c1 & l0 & r6) | (c1 & l0 & r7) | (c1 & l0 & r8) | (c1 & l1 & r0) | (c1 & l1 & r1) | (c1 & l1 & r2) | (c1 & l1 & r3) | (c1 & l1 & r4) | (c1 & l1 & r5) | (c1 & l1 & r6) | (c1 & l1 & r7) | (c1 & l1 & r8) | (c1 & l1 & r9) | (c1 & l2 & r1) | (c1 & l2 & r5) | (c1 & l2 & r6) | (c1 & l3 & r1) | (c1 & l3 & r5) | (c1 & l4 & r1) | (c1 & l4 & r5) | (c1 & l4 & r6) | (c1 & l4 & r8) | (c1 & l5 & r0) | (c1 & l5 & r1) | (c1 & l5 & r2) | (c1 & l5 & r3) | (c1 & l5 & r4) | (c1 & l5 & r5) | (c1 & l5 & r6) | (c1 & l5 & r7) | (c1 & l5 & r8) | (c1 & l6 & r0) | (c1 & l6 & r1) | (c1 & l6 & r2) | (c1 & l6 & r4) | (c1 & l6 & r5) | (c1 & l6 & r6) | (c1 & l6 & r7) | (c1 & l6 & r8) | (c1 & l7 & r0) | (c1 & l7 & r1) | (c1 & l7 & r5) | (c1 & l7 & r6) | (c1 & l7 & r8) | (c1 & l8 & r0) | (c1 & l8 & r1) | (c1 & l8 & r4) | (c1 & l8 & r5) | (c1 & l8 & r6) | (c1 & l8 & r7) | (c1 & l8 & r8) | (c1 & l9 & r1)]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "learned_expression = model.lfl.expression([sp.Symbol(f'l{i}') for i in range(0, 10)] + [sp.Symbol(f'r{i}') for i in range(0, 10)] + [sp.Symbol(f'c{i}') for i in range(0, 2)])\n",
    "learned_expression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0e27d8f2-b672-458a-abdc-c9a84928a30f",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_name = 'MNIST Multi-digit Sum LFL-Type3-MLP'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "877bf22b-d781-427b-bb62-d94d4b39866f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x100 with 20 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reconstructions_folder = f'figures/{save_name}_digit_reconstructions'\n",
    "if not os.path.exists(reconstructions_folder):\n",
    "    os.makedirs(reconstructions_folder)\n",
    "encoding = torch.nn.functional.one_hot(torch.tensor(np.arange(10))).type(dtype).to(device)\n",
    "reconstruction = torch.clip(model.reconstruction_layer(encoding).reshape(-1, 28, 28) * 1.5, 0., 1.)\n",
    "plt.figure(figsize=(5, 1), dpi=100)\n",
    "for i in range(10):\n",
    "    reconstructed_image = reconstruction[i].detach().cpu().numpy()\n",
    "    reconstructed_image = np.round(reconstructed_image * 255.).astype(np.uint8)\n",
    "    empty_image = np.zeros((28, 28), dtype=np.uint8)\n",
    "    yellow_image = np.stack([reconstructed_image, reconstructed_image, empty_image], axis=2)\n",
    "    cyan_image = np.stack([empty_image, reconstructed_image, reconstructed_image], axis=2)\n",
    "    Image.fromarray(yellow_image).save(os.path.join(reconstructions_folder, f'{i}_yellow.jpg'))\n",
    "    Image.fromarray(cyan_image).save(os.path.join(reconstructions_folder, f'{i}_cyan.jpg'))\n",
    "    plt.subplot(2, 10, i + 1)\n",
    "    plt.imshow(yellow_image, vmin=0, vmax=1);plt.xticks([]);plt.yticks([])\n",
    "    plt.subplot(2, 10, 10 + i + 1)\n",
    "    plt.imshow(cyan_image, vmin=0, vmax=1);plt.xticks([]);plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3857d038-f74f-452c-ad95-eb5096725923",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train dataset\tBCE loss: 0.0015459350491395791\taccuracy: 0.999664306640625\n"
     ]
    }
   ],
   "source": [
    "dataloader = DataLoader(train_dataset, batch_size=batch_size)\n",
    "bceloss, accuracy = test()\n",
    "print(f'train dataset\\tBCE loss: {bceloss}\\taccuracy: {accuracy}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a8c120c6-d9cc-4368-8afe-058f71e77141",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6orRo0cjNjYWR44cwZYtW3Du3DlERUXB3t4eP/74I7744gtYWloiNzcXADBv3jzs2bMH69atQ0lJifYy+IMHD8LHx6fNe/a0JyYmBmvWrEFUVBRiYmJQUVGBlJQUnUXOv6TPPHVkLoioFdJehEZET0Lz5dXHjx8Xb7/9tvDw8BByuVw8/fTT4ujRozp99blkOjMzU4wePVrY2dkJuVwuPD09xZQpU0R6erpOv/v374s33nhDuLm5CYVCIYKCgkR2drZ45ZVX2r0MvtmXX34pJk6cKOzt7YVcLhdeXl5iwYIFQqVS6fQJCQkRCoVCABDh4eHa5zQajfjkk09EaGiosLW1FVZWVsLHx0fMnDlTHDt2TGdfd+7cEfPnzxeOjo7C2tpahIeHi/z8/Daz/VJrl8E3NjaKjRs3Cm9vb2FpaSl8fHzEu+++K3Jyclr07cg8NdNnLngZPFFLMiE68eE7RGRQUlJSMG/ePOTm5vLzsoiIwDVAREREZIJYABEREZHJYQFEREREJodrgIiIiMjk8AgQERERmRwWQERERGRyWAARERGRyWEBRERERCaHBRARERGZHBZAREREZHJYABEREZHJYQFEREREJocFEBEREZkcFkBERERkclgAERERkcn5/yn4rDsn70xNAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x640 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataloader = DataLoader(mnist_train, batch_size=batch_size)\n",
    "pred, label = test_cnn()\n",
    "visualize_confusion(confusion_matrix(label, pred), name=f'{save_name} train')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2cb2a766-20f2-4c04-a4ef-fd50fb5becf3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test\tBCE loss: 0.06914502128815722\taccuracy: 0.9849853515625\n"
     ]
    }
   ],
   "source": [
    "test_dataset = MNISTMultiDigitADDDataset(mnist_test, n_digits=3, lenth=65536)\n",
    "dataloader = DataLoader(test_dataset, batch_size=batch_size)\n",
    "bceloss, accuracy = test()\n",
    "print(f'test\\tBCE loss: {bceloss}\\taccuracy: {accuracy}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9ebb8f30-676e-4da7-a8b0-0ffa5e3efd5c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x640 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataloader = DataLoader(mnist_test, batch_size=batch_size)\n",
    "pred, label = test_cnn()\n",
    "visualize_confusion(confusion_matrix(label, pred), name=f'{save_name} test')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f5b6b16b-1941-4abf-935d-68c7ac8c0051",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test\tBCE loss: 0.07521120399301248\taccuracy: 0.9797117248062015\n",
      "CPU times: user 1min 41s, sys: 7.01 s, total: 1min 48s\n",
      "Wall time: 1min 9s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "test_dataset = MNISTMultiDigitADDDataset(mnist_test, n_digits=128, lenth=8192)\n",
    "dataloader = DataLoader(test_dataset, batch_size=batch_size)\n",
    "bceloss, accuracy = test()\n",
    "print(f'test\\tBCE loss: {bceloss}\\taccuracy: {accuracy}')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
