{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4cc2754f-13b6-466c-9a05-b5cc84c26d57",
   "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_add_networks import *\n",
    "from library.utils import DSL_bceloss, seed\n",
    "from itertools import chain\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import confusion_matrix\n",
    "from library.utils import visualize_confusion\n",
    "from PIL import Image\n",
    "import os\n",
    "import json"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b6ce03b7-4391-4127-8306-ef76069f2792",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "seed(42)\n",
    "\n",
    "train_dataset = MnistADDDataset(mnist_train, lenth=8192)\n",
    "batch_size = 128\n",
    "loss_fn_supervision = DSL_bceloss\n",
    "loss_fn_reconstruction = MSELoss()\n",
    "dataloader = DataLoader(train_dataset, batch_size=batch_size)\n",
    "\n",
    "def train():\n",
    "    model.train()\n",
    "    losses = {\n",
    "        'reconstruction': [],\n",
    "        'supervision': [],\n",
    "        'accuracy': []\n",
    "        # 'regularization': []\n",
    "    }\n",
    "    for left_image, right_image, label in dataloader:\n",
    "        left_image, right_image, label = left_image.to(device), right_image.to(device), label.to(device)\n",
    "        \n",
    "        pred, left_reconstruction, right_reconstruction = model(left_image, right_image)\n",
    "        reconstruction_loss = loss_fn_reconstruction(left_reconstruction, left_image) + loss_fn_reconstruction(right_reconstruction, right_image)\n",
    "        supervision_loss, accuracy = loss_fn_supervision(pred, label.type(dtype))\n",
    "        \n",
    "        losses['reconstruction'].append(reconstruction_loss.item())\n",
    "        losses['supervision'].append(supervision_loss.item())\n",
    "        losses['accuracy'].append(accuracy)\n",
    "        loss = reconstruction_loss + supervision_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_image, right_image, label in dataloader:\n",
    "        left_image, right_image, label = left_image.to(device), right_image.to(device), label.type(dtype).to(device)\n",
    "        pred, left_reconstruction, right_reconstruction = model(left_image, right_image)\n",
    "        bceloss_, accuracy_ = DSL_bceloss(pred, label)\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": "068b3087-54ac-4c88-9336-bee4fec7d3e9",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch: 0 loss terms: {'reconstruction': 0.2752913565380391, 'supervision': 0.22683129125145438, 'accuracy': 0.05419921875}\n",
      "epoch: 1 loss terms: {'reconstruction': 0.2349158316678743, 'supervision': 0.21947448656669802, 'accuracy': 0.051513671875}\n",
      "epoch: 2 loss terms: {'reconstruction': 0.203274541726737, 'supervision': 0.24960187220621594, 'accuracy': 0.06591796875}\n",
      "epoch: 3 loss terms: {'reconstruction': 0.18097566729495196, 'supervision': 0.25206405517340436, 'accuracy': 0.06494140625}\n",
      "epoch: 4 loss terms: {'reconstruction': 0.16586692452466267, 'supervision': 0.2402813935634183, 'accuracy': 0.0614013671875}\n",
      "epoch: 5 loss terms: {'reconstruction': 0.15582784400939595, 'supervision': 0.2553592204515636, 'accuracy': 0.0672607421875}\n",
      "epoch: 6 loss terms: {'reconstruction': 0.14837449412898907, 'supervision': 0.2514758149545518, 'accuracy': 0.0667724609375}\n",
      "epoch: 7 loss terms: {'reconstruction': 0.14363640099821098, 'supervision': 0.2596358183128016, 'accuracy': 0.070068359375}\n",
      "epoch: 8 loss terms: {'reconstruction': 0.14013533621169383, 'supervision': 0.26777436260903065, 'accuracy': 0.0743408203125}\n",
      "epoch: 9 loss terms: {'reconstruction': 0.13844270986194426, 'supervision': 0.26594262291166415, 'accuracy': 0.073486328125}\n",
      "epoch: 10 loss terms: {'reconstruction': 0.1372762816005143, 'supervision': 0.27236858744698844, 'accuracy': 0.07763671875}\n",
      "epoch: 11 loss terms: {'reconstruction': 0.1357830446655372, 'supervision': 0.292980662269846, 'accuracy': 0.0872802734375}\n",
      "epoch: 12 loss terms: {'reconstruction': 0.1360434201998978, 'supervision': 0.2710975481871858, 'accuracy': 0.078369140625}\n",
      "epoch: 13 loss terms: {'reconstruction': 0.13540732832826785, 'supervision': 0.2926724778018099, 'accuracy': 0.0908203125}\n",
      "epoch: 14 loss terms: {'reconstruction': 0.13470250370400216, 'supervision': 0.2911022123870356, 'accuracy': 0.0904541015625}\n",
      "epoch: 15 loss terms: {'reconstruction': 0.13391719508592043, 'supervision': 0.26969939481946786, 'accuracy': 0.0810546875}\n",
      "epoch: 16 loss terms: {'reconstruction': 0.13366453031195197, 'supervision': 0.29453144595521397, 'accuracy': 0.093017578125}\n",
      "epoch: 17 loss terms: {'reconstruction': 0.13285663742410214, 'supervision': 0.2930938995167477, 'accuracy': 0.0933837890625}\n",
      "epoch: 18 loss terms: {'reconstruction': 0.13419109440012128, 'supervision': 0.25683049184098966, 'accuracy': 0.072509765625}\n",
      "epoch: 19 loss terms: {'reconstruction': 0.133378807060746, 'supervision': 0.288333856528627, 'accuracy': 0.09228515625}\n",
      "epoch: 20 loss terms: {'reconstruction': 0.132797107823664, 'supervision': 0.28279565118704386, 'accuracy': 0.095458984375}\n",
      "epoch: 21 loss terms: {'reconstruction': 0.1316093821487183, 'supervision': 0.30792235608870666, 'accuracy': 0.11474609375}\n",
      "epoch: 22 loss terms: {'reconstruction': 0.13040088479597856, 'supervision': 0.33550799852111024, 'accuracy': 0.13330078125}\n",
      "epoch: 23 loss terms: {'reconstruction': 0.1305622521722134, 'supervision': 0.35213014734702236, 'accuracy': 0.149658203125}\n",
      "epoch: 24 loss terms: {'reconstruction': 0.12963247483065496, 'supervision': 0.35860896731302677, 'accuracy': 0.1605224609375}\n",
      "epoch: 25 loss terms: {'reconstruction': 0.12935053199306398, 'supervision': 0.35638780980294704, 'accuracy': 0.157470703125}\n",
      "epoch: 26 loss terms: {'reconstruction': 0.1281972314236852, 'supervision': 0.3577187867642157, 'accuracy': 0.171875}\n",
      "epoch: 27 loss terms: {'reconstruction': 0.12762856721156282, 'supervision': 0.34151842537968413, 'accuracy': 0.158447265625}\n",
      "epoch: 28 loss terms: {'reconstruction': 0.1273802702016733, 'supervision': 0.3570754536646301, 'accuracy': 0.1690673828125}\n",
      "epoch: 29 loss terms: {'reconstruction': 0.12665813300054884, 'supervision': 0.3760837064045488, 'accuracy': 0.19140625}\n",
      "epoch: 30 loss terms: {'reconstruction': 0.1274352934808575, 'supervision': 0.37435084388510653, 'accuracy': 0.1934814453125}\n",
      "epoch: 31 loss terms: {'reconstruction': 0.12707294641332334, 'supervision': 0.3711626447358031, 'accuracy': 0.2047119140625}\n",
      "epoch: 32 loss terms: {'reconstruction': 0.1263461483590665, 'supervision': 0.37058334125507364, 'accuracy': 0.206787109375}\n",
      "epoch: 33 loss terms: {'reconstruction': 0.12718174076494548, 'supervision': 0.3594397577114562, 'accuracy': 0.191650390625}\n",
      "epoch: 34 loss terms: {'reconstruction': 0.1262118997375126, 'supervision': 0.3501493474765104, 'accuracy': 0.210693359375}\n",
      "epoch: 35 loss terms: {'reconstruction': 0.12468156983082786, 'supervision': 0.3233848018686969, 'accuracy': 0.2119140625}\n",
      "epoch: 36 loss terms: {'reconstruction': 0.1238044881445062, 'supervision': 0.30611891597717084, 'accuracy': 0.198486328125}\n",
      "epoch: 37 loss terms: {'reconstruction': 0.12337898814676831, 'supervision': 0.33241409295206015, 'accuracy': 0.26220703125}\n",
      "epoch: 38 loss terms: {'reconstruction': 0.12202220639991293, 'supervision': 0.3166910669626756, 'accuracy': 0.2899169921875}\n",
      "epoch: 39 loss terms: {'reconstruction': 0.11975487874536148, 'supervision': 0.27413511639900146, 'accuracy': 0.28515625}\n",
      "epoch: 40 loss terms: {'reconstruction': 0.11906585997963268, 'supervision': 0.2859273381753491, 'accuracy': 0.3001708984375}\n",
      "epoch: 41 loss terms: {'reconstruction': 0.11870419589559944, 'supervision': 0.2714954266860812, 'accuracy': 0.3143310546875}\n",
      "epoch: 42 loss terms: {'reconstruction': 0.11868289356625181, 'supervision': 0.2469668891358638, 'accuracy': 0.3126220703125}\n",
      "epoch: 43 loss terms: {'reconstruction': 0.11808860820994599, 'supervision': 0.2314250195547387, 'accuracy': 0.3365478515625}\n",
      "epoch: 44 loss terms: {'reconstruction': 0.11745085858840451, 'supervision': 0.2186562491873052, 'accuracy': 0.35791015625}\n",
      "epoch: 45 loss terms: {'reconstruction': 0.1166557857469464, 'supervision': 0.20019166417663445, 'accuracy': 0.3668212890625}\n",
      "epoch: 46 loss terms: {'reconstruction': 0.11677403137830297, 'supervision': 0.1980815376596729, 'accuracy': 0.4033203125}\n",
      "epoch: 47 loss terms: {'reconstruction': 0.11644134665654646, 'supervision': 0.14951784017241848, 'accuracy': 0.4356689453125}\n",
      "epoch: 48 loss terms: {'reconstruction': 0.11540042165612177, 'supervision': 0.15100867211764904, 'accuracy': 0.4559326171875}\n",
      "epoch: 49 loss terms: {'reconstruction': 0.11449815487857133, 'supervision': 0.12433457606819255, 'accuracy': 0.4801025390625}\n",
      "epoch: 50 loss terms: {'reconstruction': 0.11473418086072526, 'supervision': 0.1141368357285451, 'accuracy': 0.4935302734375}\n",
      "epoch: 51 loss terms: {'reconstruction': 0.11445698655342451, 'supervision': 0.0982347075338467, 'accuracy': 0.4716796875}\n",
      "epoch: 52 loss terms: {'reconstruction': 0.11422042748137491, 'supervision': 0.09471804012154587, 'accuracy': 0.47119140625}\n",
      "epoch: 53 loss terms: {'reconstruction': 0.11445876545961556, 'supervision': 0.1119809569948166, 'accuracy': 0.4932861328125}\n",
      "epoch: 54 loss terms: {'reconstruction': 0.11405906757538586, 'supervision': 0.11817788967264983, 'accuracy': 0.4893798828125}\n",
      "epoch: 55 loss terms: {'reconstruction': 0.11438867893907943, 'supervision': 0.10765568048851587, 'accuracy': 0.49365234375}\n",
      "epoch: 56 loss terms: {'reconstruction': 0.11422933153288396, 'supervision': 0.10559152626322665, 'accuracy': 0.4954833984375}\n",
      "epoch: 57 loss terms: {'reconstruction': 0.11376352149371782, 'supervision': 0.0966459703174534, 'accuracy': 0.490234375}\n",
      "epoch: 58 loss terms: {'reconstruction': 0.11374776362641101, 'supervision': 0.10443673584340943, 'accuracy': 0.5029296875}\n",
      "epoch: 59 loss terms: {'reconstruction': 0.11405902562862291, 'supervision': 0.08536945920220473, 'accuracy': 0.4853515625}\n",
      "epoch: 60 loss terms: {'reconstruction': 0.1142913187487026, 'supervision': 0.10742014017583386, 'accuracy': 0.4964599609375}\n",
      "epoch: 61 loss terms: {'reconstruction': 0.11387494224624545, 'supervision': 0.09893813434213473, 'accuracy': 0.5003662109375}\n",
      "epoch: 62 loss terms: {'reconstruction': 0.11455648411995602, 'supervision': 0.10843517648998774, 'accuracy': 0.4908447265625}\n",
      "epoch: 63 loss terms: {'reconstruction': 0.11387662243358312, 'supervision': 0.09525440520749745, 'accuracy': 0.499267578125}\n",
      "epoch: 64 loss terms: {'reconstruction': 0.11402488118315265, 'supervision': 0.09555278232293071, 'accuracy': 0.494140625}\n",
      "epoch: 65 loss terms: {'reconstruction': 0.11450544725337361, 'supervision': 0.09571710448605845, 'accuracy': 0.4932861328125}\n",
      "epoch: 66 loss terms: {'reconstruction': 0.11455515857641055, 'supervision': 0.0846597924280465, 'accuracy': 0.4976806640625}\n",
      "epoch: 67 loss terms: {'reconstruction': 0.11386194393012243, 'supervision': 0.07462029173660237, 'accuracy': 0.5010986328125}\n",
      "epoch: 68 loss terms: {'reconstruction': 0.11369143752767304, 'supervision': 0.09224182422133373, 'accuracy': 0.5037841796875}\n",
      "epoch: 69 loss terms: {'reconstruction': 0.11401478155353978, 'supervision': 0.07631378479693622, 'accuracy': 0.5081787109375}\n",
      "epoch: 70 loss terms: {'reconstruction': 0.11481435109496768, 'supervision': 0.09207043624953752, 'accuracy': 0.506591796875}\n",
      "epoch: 71 loss terms: {'reconstruction': 0.11434526085953177, 'supervision': 0.09161543742448633, 'accuracy': 0.49951171875}\n",
      "epoch: 72 loss terms: {'reconstruction': 0.11422099837644005, 'supervision': 0.08701580286795847, 'accuracy': 0.5029296875}\n",
      "epoch: 73 loss terms: {'reconstruction': 0.11466632336090696, 'supervision': 0.08997590085013872, 'accuracy': 0.4979248046875}\n",
      "epoch: 74 loss terms: {'reconstruction': 0.11480174110866886, 'supervision': 0.08587563928905088, 'accuracy': 0.4984130859375}\n",
      "epoch: 75 loss terms: {'reconstruction': 0.11433295552372967, 'supervision': 0.09701564066622527, 'accuracy': 0.4986572265625}\n",
      "epoch: 76 loss terms: {'reconstruction': 0.11406283796106734, 'supervision': 0.09557040919582796, 'accuracy': 0.502197265625}\n",
      "epoch: 77 loss terms: {'reconstruction': 0.11422608779761036, 'supervision': 0.0880048562670054, 'accuracy': 0.496337890625}\n",
      "epoch: 78 loss terms: {'reconstruction': 0.11411662192625444, 'supervision': 0.07938149860797487, 'accuracy': 0.503662109375}\n",
      "epoch: 79 loss terms: {'reconstruction': 0.11410432010207108, 'supervision': 0.08950312944538912, 'accuracy': 0.5037841796875}\n",
      "epoch: 80 loss terms: {'reconstruction': 0.11420201353793133, 'supervision': 0.08995599313439295, 'accuracy': 0.5079345703125}\n",
      "epoch: 81 loss terms: {'reconstruction': 0.11424764319151348, 'supervision': 0.09125948289172459, 'accuracy': 0.5106201171875}\n",
      "epoch: 82 loss terms: {'reconstruction': 0.11431944310390546, 'supervision': 0.08597165803119594, 'accuracy': 0.513427734375}\n",
      "epoch: 83 loss terms: {'reconstruction': 0.11400137001823832, 'supervision': 0.08969195566391003, 'accuracy': 0.5018310546875}\n",
      "epoch: 84 loss terms: {'reconstruction': 0.1141479293919071, 'supervision': 0.07878391484626762, 'accuracy': 0.5023193359375}\n",
      "epoch: 85 loss terms: {'reconstruction': 0.11423847607769014, 'supervision': 0.08709094098881168, 'accuracy': 0.5010986328125}\n",
      "epoch: 86 loss terms: {'reconstruction': 0.11470597767416413, 'supervision': 0.07574290310660785, 'accuracy': 0.4912109375}\n",
      "epoch: 87 loss terms: {'reconstruction': 0.11439639966435103, 'supervision': 0.06976528150320349, 'accuracy': 0.50439453125}\n",
      "epoch: 88 loss terms: {'reconstruction': 0.11395655120097282, 'supervision': 0.08041775909551754, 'accuracy': 0.503173828125}\n",
      "epoch: 89 loss terms: {'reconstruction': 0.11399516197930412, 'supervision': 0.08075832187640311, 'accuracy': 0.495849609375}\n",
      "epoch: 90 loss terms: {'reconstruction': 0.11467353517989842, 'supervision': 0.08500759236356026, 'accuracy': 0.51220703125}\n",
      "epoch: 91 loss terms: {'reconstruction': 0.11427773572632301, 'supervision': 0.07108475993568145, 'accuracy': 0.498046875}\n",
      "epoch: 92 loss terms: {'reconstruction': 0.11411842321430041, 'supervision': 0.08384199058208261, 'accuracy': 0.5001220703125}\n",
      "epoch: 93 loss terms: {'reconstruction': 0.11434853551199728, 'supervision': 0.09129365268342977, 'accuracy': 0.5045166015625}\n",
      "epoch: 94 loss terms: {'reconstruction': 0.11473141415438551, 'supervision': 0.09235866997200565, 'accuracy': 0.49462890625}\n",
      "epoch: 95 loss terms: {'reconstruction': 0.11446126263826803, 'supervision': 0.07596919299482101, 'accuracy': 0.4974365234375}\n",
      "epoch: 96 loss terms: {'reconstruction': 0.11405131957411899, 'supervision': 0.08575009288650812, 'accuracy': 0.5072021484375}\n",
      "epoch: 97 loss terms: {'reconstruction': 0.11419535758889088, 'supervision': 0.09671863697293429, 'accuracy': 0.5054931640625}\n",
      "epoch: 98 loss terms: {'reconstruction': 0.11393034543613517, 'supervision': 0.07392208177308385, 'accuracy': 0.5072021484375}\n",
      "epoch: 99 loss terms: {'reconstruction': 0.1146320981484163, 'supervision': 0.09400961838617086, 'accuracy': 0.4970703125}\n",
      "epoch: 100 loss terms: {'reconstruction': 0.11457158959558081, 'supervision': 0.09921417898586689, 'accuracy': 0.5008544921875}\n",
      "epoch: 101 loss terms: {'reconstruction': 0.11475424445528597, 'supervision': 0.0823087663360089, 'accuracy': 0.5048828125}\n",
      "epoch: 102 loss terms: {'reconstruction': 0.11430678728056966, 'supervision': 0.08092537678803703, 'accuracy': 0.5023193359375}\n",
      "epoch: 103 loss terms: {'reconstruction': 0.11422967273853621, 'supervision': 0.06620114695841704, 'accuracy': 0.512939453125}\n",
      "epoch: 104 loss terms: {'reconstruction': 0.11479621005902085, 'supervision': 0.08074468834114701, 'accuracy': 0.4986572265625}\n",
      "epoch: 105 loss terms: {'reconstruction': 0.1143928973613804, 'supervision': 0.07770117183272555, 'accuracy': 0.504150390625}\n",
      "epoch: 106 loss terms: {'reconstruction': 0.11458552705464087, 'supervision': 0.07625744854038555, 'accuracy': 0.5008544921875}\n",
      "epoch: 107 loss terms: {'reconstruction': 0.11356863008270747, 'supervision': 0.0757218281388857, 'accuracy': 0.501708984375}\n",
      "epoch: 108 loss terms: {'reconstruction': 0.11461815360437394, 'supervision': 0.07634864954374003, 'accuracy': 0.5072021484375}\n",
      "epoch: 109 loss terms: {'reconstruction': 0.11433357358487332, 'supervision': 0.07995395403632793, 'accuracy': 0.506103515625}\n",
      "epoch: 110 loss terms: {'reconstruction': 0.11436351031766392, 'supervision': 0.06961610465804877, 'accuracy': 0.49658203125}\n",
      "epoch: 111 loss terms: {'reconstruction': 0.114458910137181, 'supervision': 0.06545994230681838, 'accuracy': 0.5001220703125}\n",
      "epoch: 112 loss terms: {'reconstruction': 0.11440994811269765, 'supervision': 0.07123598992173444, 'accuracy': 0.510498046875}\n",
      "epoch: 113 loss terms: {'reconstruction': 0.11404951920825288, 'supervision': 0.07181426560285398, 'accuracy': 0.5047607421875}\n",
      "epoch: 114 loss terms: {'reconstruction': 0.11439350631681897, 'supervision': 0.08512267689207625, 'accuracy': 0.497802734375}\n",
      "epoch: 115 loss terms: {'reconstruction': 0.11401025038294413, 'supervision': 0.06956498492024477, 'accuracy': 0.5150146484375}\n",
      "epoch: 116 loss terms: {'reconstruction': 0.11402286902051448, 'supervision': 0.07937555488886672, 'accuracy': 0.49609375}\n",
      "epoch: 117 loss terms: {'reconstruction': 0.11395822222854521, 'supervision': 0.0807769484522271, 'accuracy': 0.5010986328125}\n",
      "epoch: 118 loss terms: {'reconstruction': 0.11399757308670712, 'supervision': 0.08498482837253057, 'accuracy': 0.5069580078125}\n",
      "epoch: 119 loss terms: {'reconstruction': 0.11449920681825881, 'supervision': 0.06870929456006122, 'accuracy': 0.5}\n",
      "epoch: 120 loss terms: {'reconstruction': 0.11422269090915821, 'supervision': 0.08137078790748427, 'accuracy': 0.5089111328125}\n",
      "epoch: 121 loss terms: {'reconstruction': 0.11450757480886062, 'supervision': 0.06581246096315063, 'accuracy': 0.50927734375}\n",
      "epoch: 122 loss terms: {'reconstruction': 0.11388954719575545, 'supervision': 0.0730972799339105, 'accuracy': 0.487548828125}\n",
      "epoch: 123 loss terms: {'reconstruction': 0.1145216940819021, 'supervision': 0.069104291013688, 'accuracy': 0.5050048828125}\n",
      "epoch: 124 loss terms: {'reconstruction': 0.11404275504118577, 'supervision': 0.06201204359007072, 'accuracy': 0.498046875}\n",
      "epoch: 125 loss terms: {'reconstruction': 0.1143128806799733, 'supervision': 0.06246942285862976, 'accuracy': 0.5010986328125}\n",
      "epoch: 126 loss terms: {'reconstruction': 0.11461915270873466, 'supervision': 0.06270025791653872, 'accuracy': 0.49853515625}\n",
      "epoch: 127 loss terms: {'reconstruction': 0.11452105352111554, 'supervision': 0.08394015213331965, 'accuracy': 0.51025390625}\n"
     ]
    }
   ],
   "source": [
    "model = MNISTAddDSL(n_choice=10, n_output=19).to(device)\n",
    "epochs = 2 ** 7\n",
    "optimizer = MADGRAD([{'params': model.lfl.parameters()}, {'params': chain(model.cnn.parameters(), model.reconstruction_layer.parameters()), 'lr': 1e-3}], lr=0.11639833786002995)\n",
    "\n",
    "loss_records = []\n",
    "for epoch in range(epochs):\n",
    "    mean_loss = train()\n",
    "    loss_records.append(mean_loss)\n",
    "    print(f'epoch: {epoch} loss terms: {mean_loss}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "06d35235-facb-46fd-bba2-034ab29127eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[l5 & r5,\n",
       " (l5 & r7) | (l7 & r5),\n",
       " (l1 & r5) | (l5 & r1) | (l7 & r7),\n",
       " (l1 & r7) | (l5 & r8) | (l7 & r1) | (l8 & r5),\n",
       " (l0 & r5) | (l1 & r1) | (l5 & r0) | (l7 & r8) | (l8 & r7),\n",
       " (l0 & r7) | (l1 & r8) | (l4 & r5) | (l5 & r4) | (l7 & r0) | (l8 & r1),\n",
       " (l0 & r1) | (l1 & r0) | (l4 & r7) | (l5 & r9) | (l7 & r4) | (l8 & r8) | (l9 & r5),\n",
       " (l0 & r8) | (l1 & r4) | (l2 & r5) | (l4 & r1) | (l5 & r2) | (l7 & r9) | (l8 & r0) | (l9 & r7),\n",
       " (l0 & r0) | (l1 & r9) | (l2 & r7) | (l3 & r5) | (l4 & r8) | (l5 & r3) | (l7 & r2) | (l8 & r4) | (l9 & r1),\n",
       " (l0 & r4) | (l1 & r2) | (l2 & r1) | (l3 & r7) | (l4 & r0) | (l5 & r6) | (l6 & r5) | (l7 & r3) | (l8 & r9) | (l9 & r8),\n",
       " (l0 & r9) | (l1 & r3) | (l2 & r8) | (l3 & r1) | (l4 & r4) | (l6 & r7) | (l7 & r6) | (l8 & r2) | (l9 & r0),\n",
       " (l0 & r2) | (l1 & r6) | (l2 & r0) | (l3 & r8) | (l4 & r9) | (l6 & r1) | (l8 & r3) | (l9 & r4),\n",
       " (l0 & r3) | (l2 & r4) | (l3 & r0) | (l4 & r2) | (l6 & r8) | (l8 & r6) | (l9 & r9),\n",
       " (l0 & r6) | (l2 & r9) | (l3 & r4) | (l4 & r3) | (l6 & r0) | (l9 & r2),\n",
       " (l2 & r2) | (l3 & r9) | (l4 & r6) | (l6 & r4) | (l9 & r3),\n",
       " (l2 & r3) | (l3 & r2) | (l6 & r9) | (l9 & r6),\n",
       " (l2 & r6) | (l3 & r3) | (l6 & r2),\n",
       " (l3 & r6) | (l6 & r3),\n",
       " l6 & r6]"
      ]
     },
     "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)])\n",
    "learned_expression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ee414a37-995b-400e-b92f-19a7281594a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "save_name = 'MNIST-Sum DSL'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "646ab6e4-8d01-465e-9523-ae8acdb96be1",
   "metadata": {
    "tags": []
   },
   "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": "c9b1e22c-3ed8-4134-a529-727c2f1646dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# print latex formula for the paper\n",
    "\n",
    "# for i, expression in enumerate(learned_expression):\n",
    "#     exp_str = str(expression).replace('&', '\\\\wedge').replace('|', '\\\\vee')\n",
    "#     for j, j_ in [('l', 'yellow'), ('r', 'cyan')]:\n",
    "#         for k in range(10):\n",
    "#             exp_str = exp_str.replace(f'{j}{k}', '\\\\raisebox{-0.2\\\\height}{\\\\includegraphics[height=1em]{' + reconstructions_folder + f'/{k}_{j_}.jpg' + '}}')\n",
    "#     exp_str = '$y_{' + str(i) + '} = ' + exp_str + '$\\n'\n",
    "#     print(exp_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9ae7cd4b-7808-4c53-916b-1679aa4e183a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train dataset\tBCE loss: 0.10128672778205161\taccuracy: 0.989013671875\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": 9,
   "id": "54e6e8d8-0cc6-4785-ac38-cb3f33fb12fc",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAJXCAYAAAB7SesVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAABOvAAATrwFj5o7DAADDv0lEQVR4nOzdd1hT1xvA8W/Y4AIEBHHg3ltxi6LiHnW1aq17tFW7ftra2jpqrVXbaq1a695774WzdYt7gxNBQKZsSH5/UFJTQBmBhOT9PE+e1nPXezg3yZtzzz1XoVKpVAghhBBCGBETXQcghBBCCJHXJAESQgghhNGRBEgIIYQQRkcSICGEEEIYHUmAhBBCCGF0JAESQgghhNGRBEgIIYQQRkcSICGEEEIYHUmAhBBCCGF0JAESQgghhNGRBEgIIYQQRkcSICGEEEIYHUmAhMgCNzc3FAoFCoWCuXPnZrhecnIyLi4u6nVXrFihsXzFihXqZR07dsxwP4MGDUKhUPDHH3+ku33Lli3T3W7Pnj107doVFxcXLCwssLOzo1KlSvTo0YM5c+YQHBwMwOTJk9VxZPY1aNCgt/6dHj16xNixY6lSpQo2NjbY2NhQunRpmjdvzoQJEzh79uxb96GPUtvj9VfBggVxdXXF09OTr776ihs3brxxHyqVijVr1uDl5YWjoyPm5uY4ODhQtWpV+vXrx8KFC4mOjtbYJrWdMvO311epf7vjx4/rOhQhADDTdQBC5FerVq3ik08+SXfZwYMHCQwMzNR+9u/fz99//02TJk20EtdHH33EwoULAahRowZNmjTB1NSUe/fusXPnTrZv30758uXp3LkztWvXZuDAgWn2sXLlSgB69uxJwYIFNZY1a9bsjcf39vama9euREdH4+TkRIsWLShatCiBgYFcvHiR06dPc//+fbZs2aKV+upCrVq1qF27NgDx8fEEBwdz+fJljh07xk8//UTv3r35448/sLe319guMTGRnj17snv3bhQKBfXr18fNzQ2lUsnNmzdZv34969evp3nz5lSvXj1XYlcoFJQuXZpHjx7lyv6FyC8kARIiG+rWrcvly5e5efMm1apVS7N81apVANSrV49Lly5luB9ra2tiY2OZOHEi3t7eOY5r586dLFy4kEKFCrF79248PDw0lgcFBbFhwwaKFSsGQPfu3enevXua/aQmQLNn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YABarZadO3cyadIkbty4weLFi/W2yevrlJ/XQgjxH4oQosRbunSpAiienp7KgwcPctrDwsKUsmXLKjVq1Mhpu3HjhgIoZmZmypUrV3Qe5/jx4wqgTJkyRac9PT1dadCggeLh4aFotVpFURRl586dCqAMHTpUZ93NmzcrgPLf3Y+fn5/i4eGR83tiYqJiZ2enuLi4KBEREXp9yszM1Mk7efJkvXU2bNigAMqyZct02h88eKBUqlRJadGiRU7bggULFED57LPPdNadNWuWAuhke5x9+/YpgLJ06dKcttTUVCU9PV1v3QEDBigmJiZKWFhYTlt+Xqf8vBZP+jcSwljJKTAhjMiIESMoW7Zszu9ubm706dOHixcvcvXqVZ11O3XqRNWqVXXa1qxZg0ajoV+/fsTExOT83L9/n44dO3Lr1q2cx9myZQsA48aN03mMbt26Ua1atadm3bVrF3FxcYwbN05nRCebicnTd1+rV6/G1tYWf39/nbypqam0adOGw4cPk5ycnJPXzMyM9957T+cxRo4cSbly5Z76XI9jbm6OqWnWYHt6ejpxcXHExMTQpk0btFptrqfi8vI65ee1EELok1NgQhgRHx8fvbbq1asDcP36dby9vXPaq1SporfupUuXUBQl12XZIiMjqVq1KtevX8fU1DTXdatXr86VK1eemDX74O3r6/vE9Z7k0qVLxMfH4+Tk9Nh1YmJiqFixItevX8fd3Z0yZcroLLewsOCFF14gPj7+mXN89913/Pjjj1y+fBmtVquz7P79+3rr5+V1ys9rIYTQJwWQECJX1tbWem1arZZSpUqxfft2vRsZZqtZs2aB5njc8+SFVqvFxcWFFStWPHad7LlNheWbb77hgw8+oEOHDowdOxYXFxfMzc05deoUH374oV5BlFdqvBZClCRSAAlhRC5fvkzXrl112i5dugTACy+88NTtvb292blzJ5UrV37iyEP24+3cuZNr167pnfLKfs4nyR65OHPmDK+88spj13tSgeTt7c2OHTto1qwZVlZWT827Z88eHj58qDMKlJqayvXr17G1tX1q5tysXLmSypUrExwcrHPaLjQ09LHb5OV1ys9rIYTQJ3OAhDAiP/74I4mJiTm/37t3j9WrV1O9enWd01+P069fPwAmTpyY68hFVFRUzv9nH8D/97//6ayzZcuWp57+Amjbti329vbMnDlT53GzKX/fNDG7WMntFFX//v3JyMjgk08+yfU5/ps3PT2dWbNm6awzf/58Hjx48NS8j1OqVCmdvADJycnMnTv3sdvk5XXKz2shhNAnI0BCGBEbGxuaNGnCoEGDSEtL48cffyQpKYnZs2fnaftGjRoxadIkpk+fztWrV+nRowfOzs6EhYXxxx9/cO3atZyRjXbt2tG5c2eWLFlCbGxszmXwCxYsoGbNmoSEhDzxuUqXLs2iRYvo1asXtWrVYujQoVSuXJnw8HCCgoJYvHgxvr6+2Nvb4+Xlxdq1a6lSpQqOjo44OTnRqlUrevXqRXBwMN988w0nTpzA398fGxsb7ty5w969ezE3N2ffvn0ADB48mIULF/Lpp58SGhqacxn8+vXr8fLyeuw9e54mICCAiRMn4u/vT0BAAHFxcSxbtkxnkvN/5eV1ys9rIYTIhboXoQkhikL25dW7du1SPv74Y8Xd3V2xsLBQ6tWrp2zfvl1n3bxcMr1lyxalVatWSvny5RULCwvFw8ND6dq1q7J27Vqd9ZKSkpT3339fcXZ2ViwtLZUGDRooO3fuVAYOHPjUy+Cz/fHHH0qnTp0UGxsbxcLCQvH09FSGDh2qxMTE6KzTqFEjxdLSUgEUPz+/nGVarVb56aeflCZNmihlypRRrKysFC8vL6V3797Kjh07dJ4rNjZWGTJkiGJnZ6dYW1srfn5+yvHjxx+b7b9yuww+IyND+eyzz5TKlSsr5ubmipeXlzJ9+nRl9+7deuvm53XKlpfXQi6DF0KfRlGe4Y/vCCGKlWXLljF48GD27dsnfy9LCCGQOUBCCCGEMEJSAAkhhBDC6EgBJIQQQgijI3OAhBBCCGF0ZARICCGEEEZHCiAhhBBCGB0pgIQQQghhdKQAEkIIIYTRkQJICCGEEEZHCiAhhBBCGB0pgIQQQghhdKQAEkIIIYTRkQJICCGEEEZHCiAhhBBCGB0pgIQQQghhdP4fW+xmwTjB5+QAAAAASUVORK5CYII=",
      "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": 10,
   "id": "0ef0901d-071d-466f-aeed-14353ce7ef18",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test\tBCE loss: 0.19994378249422695\taccuracy: 0.978302001953125\n"
     ]
    }
   ],
   "source": [
    "test_dataset = MnistADDDataset(mnist_test, 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": 11,
   "id": "66ae6fab-03c5-4316-a02b-43a4c499c559",
   "metadata": {
    "tags": []
   },
   "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": 12,
   "id": "eabd7908-7c85-42e3-beb8-cb2d4a3f3b42",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(f'records/{save_name}.json', 'w') as f:\n",
    "    json.dump(loss_records, f)"
   ]
  }
 ],
 "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
}
