{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "93f8c938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from torchvision import datasets, transforms\n",
    "from torch.autograd import Variable\n",
    "from torchvision.utils import save_image, make_grid\n",
    "import cvxpy as cvx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from utils import *\n",
    "from algorithms import *\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "99b54b79",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the testing set\n",
    "test_dataset = datasets.MNIST(root='../../data/', train=False, transform=transforms.ToTensor(), download=True)\n",
    "\n",
    "# find the index sets of each class\n",
    "index_dict = find_index_classes(test_dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "52b2dc48",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABJ4AAAE3CAYAAADrOItrAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAxXUlEQVR4nO3dd5RW1fUw4E1VEFRAULALkgSxYo0aUQmoCEFDxJLEEpVY0ViisYGaGI0tPwu2RNQg2CNERezG9kU0amxRVOwVpIli4f3+yMrNPRdmHIa5MDM8z1pZa5/Z73vvmTm+hZ179m1SqVQqAQAAAAB1rOmSngAAAAAAjZPCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMANHJNmjSJ4cOHZ+NRo0ZFkyZNYsqUKbU63pQpU6JJkyZx7rnn1s0EG5jevXtH7969l/Q0AAAaBIUnAGjALr300mjSpElsscUWdX7sO++8MylYLW5z5syJ4cOHx4MPPljqeZb07wkA0JgpPAFAAzZ69OhYa6214h//+EdMnjy5To995513xogRI+r0mAtjzpw5MWLEiMVSeFqY33PixIkxceLEEmcEANB4KDwBQAP1xhtvxGOPPRbnn39+dOzYMUaPHr2kp7RUaNmyZbRs2XJJTwMAoEFQeAKABmr06NHRrl276N+/fwwePLhOC0/77bdfXHLJJRHxnx5R//1f0RVXXBFdu3aNZZZZJjbbbLN48skn53vMyy+/HIMHD4727dvHsssuG5tuummMGzeu2vNPmTIlOnbsGBERI0aMyM6f3xJXk+N+9dVXMWLEiFh33XVj2WWXjQ4dOsQ222wT99xzz0L9nnnFHk8PPvhgNGnSJG688cYYMWJErLrqqtG2bdsYPHhwzJgxI+bOnRtHHXVUdOrUKdq0aRP7779/zJ07Nznm1VdfHTvssEN06tQplllmmejRo0eMHDlyvnPPmzcvhg8fHl26dInWrVvH9ttvHy+++GKstdZasd9++yWPnT59ehx11FGx+uqrxzLLLBPdunWLs88+O+bNm5c8buzYsdGrV69o27ZtLL/88rH++uvHH//4x2r/BgAANdV8SU8AAKid0aNHx+677x4tW7aMvfbaK0aOHBlPPvlkbLbZZot87KFDh8Z7770X99xzT1x33XULfMz1118fs2bNiqFDh0aTJk3inHPOid133z1ef/31aNGiRUREvPDCC7H11lvHqquuGieccEIst9xyceONN8agQYPilltuid12222Bx+7YsWOMHDkyDjnkkNhtt91i9913j4iIDTbYYKGOO3z48DjrrLPiwAMPjM033zxmzpwZkyZNiqeffjp++MMf1uj3rKmzzjorWrVqFSeccEJMnjw5LrroomjRokU0bdo0Pv300xg+fHg88cQTMWrUqFh77bXj1FNPzZ47cuTIWG+99WLgwIHRvHnzGD9+fBx66KExb968OOyww7LHnXjiiXHOOefEgAEDol+/fvHss89Gv3794osvvkjmMmfOnNhuu+3i3XffjaFDh8Yaa6wRjz32WJx44onx/vvvx4UXXhgREffcc0/stddeseOOO8bZZ58dEREvvfRSPProozFs2LBF+nsAAERERAUAaHAmTZpUiYjKPffcU6lUKpV58+ZVVltttcqwYcPme2xEVE477bRsfPXVV1ciovLGG29Ue47DDjussqCvCm+88UYlIiodOnSoTJs2Lfv57bffXomIyvjx47Of7bjjjpX111+/8sUXX2Q/mzdvXuX73/9+Zd111632/B9//PF8c1/Y42644YaV/v371+r3rMp2221X2W677bLxAw88UImISs+ePStffvll9vO99tqr0qRJk8rOO++cPH+rrbaqrLnmmsnP5syZM995+vXrV1lnnXWy8QcffFBp3rx5ZdCgQcnjhg8fXomIyr777pv97Iwzzqgst9xylVdeeSV57AknnFBp1qxZ5a233qpUKpXKsGHDKssvv3zl66+/rtHvDgCwsGy1A4AGaPTo0bHyyivH9ttvHxH/2SY2ZMiQGDt2bHzzzTeLZQ5DhgyJdu3aZeNtt902IiJef/31iIiYNm1a3H///bHHHnvErFmz4pNPPolPPvkkpk6dGv369YtXX3013n333YU+78Icd8UVV4wXXnghXn311Tr4jav385//PLvSKyJiiy22iEqlEgcccEDyuC222CLefvvt+Prrr7OftWrVKotnzJgRn3zySWy33Xbx+uuvx4wZMyIi4r777ouvv/46Dj300OR4RxxxxHxzuemmm2LbbbeNdu3aZX+fTz75JPr06RPffPNNPPzwwxHxn7/PZ599lm09BACoawpPANDAfPPNNzF27NjYfvvt44033ojJkyfH5MmTY4sttogPP/ww7rvvvsUyjzXWWCMZ/7cI9emnn0ZExOTJk6NSqcQpp5wSHTt2TP532mmnRUTERx99tNDnXZjjnn766TF9+vTo3r17rL/++nHcccfFc889V+vfuTrFv8cKK6wQERGrr776fD+fN29eVlCKiHj00UejT58+sdxyy8WKK64YHTt2jN/85jcREdnj3nzzzYiI6NatW3K89u3bJwXAiIhXX301JkyYMN/fp0+fPhHxv7/PoYceGt27d4+dd945VltttTjggANiwoQJi/R3AADI0+MJABqY+++/P95///0YO3ZsjB07dr786NGjo2/fvqXPo1mzZgv8eaVSiYjImlgfe+yx0a9fvwU+tlhEqYmFOe4PfvCDeO211+L222+PiRMnxlVXXRUXXHBBXHbZZXHggQcu9LmrU9Xf49v+Tq+99lrsuOOO8d3vfjfOP//8WH311aNly5Zx5513xgUXXDBfM/CamDdvXvzwhz+M448/foH57t27R0REp06d4plnnom777477rrrrrjrrrvi6quvjp///OdxzTXXLPR5AQCKFJ4AoIEZPXp0dOrUKbsbW96tt94at912W1x22WXJ9q3a+La7u32bddZZJyIiWrRokV1pUxfnX9jjtm/fPvbff//Yf//9Y/bs2fGDH/wghg8fnhWeFvX3XFTjx4+PuXPnxrhx45Krph544IHkcWuuuWZE/OeKr7XXXjv7+dSpU7OrzP6ra9euMXv27Br9fVq2bBkDBgyIAQMGxLx58+LQQw+Nyy+/PE455ZRaFQYBAPJstQOABuTzzz+PW2+9NXbdddcYPHjwfP87/PDDY9asWTFu3LhFPtdyyy0XERHTp0+v1fM7deoUvXv3jssvvzzef//9+fIff/xxtc9v3br1As+/MMedOnVqkmvTpk1069Yt5s6dm/1sUX/PRfXfK6L+ewVUxH+211199dXJ43bcccdo3rx5jBw5Mvn5xRdfPN8x99hjj3j88cfj7rvvni83ffr0rL9U8e/TtGnT7M6B+b8RAEBtueIJABqQcePGxaxZs2LgwIELzG+55ZbRsWPHGD16dAwZMmSRztWrV6+IiDjyyCOjX79+0axZs9hzzz0X6hiXXHJJbLPNNrH++uvHQQcdFOuss058+OGH8fjjj8c777wTzz77bJXPbdWqVfTo0SNuuOGG6N69e7Rv3z569uwZPXv2rPFxe/ToEb17945evXpF+/btY9KkSXHzzTfH4YcfXqe/56Lo27dvdtXR0KFDY/bs2XHllVdGp06dksLayiuvHMOGDYvzzjsvBg4cGDvttFM8++yzcdddd8VKK62UXLl13HHHxbhx42LXXXeN/fbbL3r16hWfffZZ/Otf/4qbb745pkyZEiuttFIceOCBMW3atNhhhx1itdVWizfffDMuuuii2GijjeJ73/veYvsbAACNl8ITADQgo0ePjmWXXTZ++MMfLjDftGnT6N+/f4wePTqmTp0aHTp0qPW5dt999zjiiCNi7Nix8Ze//CUqlcpCF2R69OgRkyZNihEjRsSoUaNi6tSp0alTp9h4443j1FNP/dbnX3XVVXHEEUfE0UcfHV9++WWcdtpp0bNnzxof98gjj4xx48bFxIkTY+7cubHmmmvGmWeeGccdd1yd/p6L4jvf+U7cfPPNcfLJJ8exxx4bq6yyShxyyCHRsWPH+e6Id/bZZ0fr1q3jyiuvjHvvvTe22mqrmDhxYmyzzTax7LLLZo9r3bp1PPTQQ/G73/0ubrrpprj22mtj+eWXj+7du8eIESOyxuc//elP44orrohLL700pk+fHqusskoMGTIkhg8fHk2bujAeAFh0TSr567oBAGhQpk+fHu3atYszzzwzTjrppCU9HQCAhP8rCwCggfj888/n+9mFF14YERG9e/devJMBAKgBW+0AABqIG264IUaNGhW77LJLtGnTJh555JEYM2ZM9O3bN7beeuslPT0AgPkoPAEANBAbbLBBNG/ePM4555yYOXNm1nD8zDPPXNJTAwBYID2eAAAAACiFHk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFApPAAAAAJRC4QkAAACAUig8AQAAAFAKhScAAAAASqHwBAAAAEApFJ4AAAAAKIXCEwAAAAClUHgCAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACiFwhMAAAAApVB4AgAAAKAUCk8AAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABK0bwmD5o3b16899570bZt22jSpEnZc6IalUolZs2aFV26dImmTRetbmhd6w/r2jjV5bpGWNv6wro2Tta18fIZ2zh5zTZO1rVxsq6N08Ksa40KT++9916svvrqdTI56sbbb78dq6222iIdw7rWP9a1caqLdY2wtvWNdW2crGvj5TO2cfKabZysa+NkXRunmqxrjcqNbdu2rZMJUXfqYk2sa/1jXRunuloTa1u/WNfGybo2Xj5jGyev2cbJujZO1rVxqsl61Kjw5PK1+qcu1sS61j/WtXGqqzWxtvWLdW2crGvj5TO2cfKabZysa+NkXRunmqyH5uIAAAAAlELhCQAAAIBSKDwBAAAAUAqFJwAAAABKofAEAAAAQCkUngAAAAAohcITAAAAAKVQeAIAAACgFM2X9ASAxu3YY49Nxq1atcriDTbYIMkNHjy4yuOMHDkyGT/++ONZfN111y3KFAGgQVpmmWWS8aOPPprFG2+8cZIbP358Fg8aNKjUeQFAniueAAAAACiFwhMAAAAApWh0W+2WW265ZPyHP/whi4cOHZrknnrqqWT8k5/8JIvffPPNEmbHktC9e/csfvnll5PcsGHDsviiiy5abHNq7G644YYsrm77XNG8efOqzBVfv3369Mnihx56KMm99dZbNT4nEW3atEnGq622WhYfeuihVT7vz3/+czJ+5pln6nReQMPSrl27ZLzGGmvU6HnF71xHH310Fj///PNJ7pVXXsniZ599dmGn2Cjkt9ddcMEFSW6jjTbK4kqlkuSK33sBYHFxxRMAAAAApVB4AgAAAKAUCk8AAAAAlKLR9Xjq3LlzMj7ooIOyuNg/plevXsl41113zeJLLrmkhNmxJORvJ1z8b+Cdd95Z3NNplPI9nSJq3tep2HPr7rvvzuJ11lknyQ0YMCAZd+3aNYv32WefJHfWWWfV6PxLs3xfp+OOOy7JnXzyyTU6xi9/+ctknP/vIN8/LSJi2rRpCztFlpBNNtkkGd96661ZvNZaa5V+/r59+ybjl156KYvffvvt0s9P9fr375+MBw4cmMW9e/dOct26davRMfN9myIi1lxzzSzO9zMqatasWY2O39gceeSRWXzwwQcnufvvvz+LTz311CT3xBNPlDsxoE6tt956Wdy8efX/bF9ae97RcLjiCQAAAIBSKDwBAAAAUIpGsdWuY8eOWXzNNdcswZlQH+VvLfzZZ58ludtuu20xz6bx2HTTTbN4t912q/JxL7zwQjLOb8v45JNPktzs2bOzuGXLlkmuuEVgww03zOIOHTrUYMbknXjiiVl8wgkn1OoYxW0ue++9dxbvsMMOSW7//ffP4okTJ9bqfCwe/fr1S8bVbXUqQ3Fb7QEHHJDFe+6552Kdy9Iiv3U5IuKwww7L4nzLgoiIVq1aJeMmTZos8vm7d+++yMdYmqyyyipV5u69994strUO6r/8e+ovfvGLJHfeeedl8bdttfvXv/6VxZVKpcbnf+yxx7L45ptvTnKTJk3K4lmzZtX4mEQsv/zyWVxsAdKzZ88s7tOnT5L76quvyp3YEuSKJwAAAABKofAEAAAAQCkUngAAAAAoRYPs8ZS/jWxExKBBg7J48803r/Vxf/CDH2Rx06ZpTS5/i8qHH3641uegfPl9sxERhx9+eBZfd911i3s6jVbnzp2zuNjjI9/Xqdgv5v3336/R8Y855phk3KNHjyofe8cdd9TomPzPlClTqszlewNccsklSS6/ti1atEhyp59+ehYXe5DcfvvtWXz22WcnuXPOOScZz5kzp8q5UY5874hddtllCc4k4qmnnkrGv/rVr7J4ueWWS3LFvn3UzmqrrZaMhw0bVvo5X3755Swu9gKkem3bts3iYj+QfI8n6ofBgwcn43zftPfeey/JffHFF1k8evToJPfBBx9k8eTJk+tyiixGxT55+X6zffv2TXIL06tpgw02qNXz8j1Tf/nLXya5/Pt0sRdRTb/PLy322WefZPzb3/42i1dfffUqn5fvBRURMXXq1LqdWD3iiicAAAAASqHwBAAAAEApGuRWuwsuuCAZz5s3r06Ou/vuuy8wjoh48803s3jIkCFJrrgtgCXru9/9bjLOb8244YYbFvd0Gq3x48dncbdu3ZJc/par06ZNq9Xxi7dNL27rYtHktygX3XTTTVm8MFtu8luS85eOR0S0b98+i0855ZQkV7yV+wEHHJDFjfm2svXJ9ttvn8VbbbVVkituhSxbu3btknF+m23r1q2TnK12qZVWWikZ51+/jz76aJKbMGFCFs+dOzfJzZgxI4uLf+PidseJEydm8fPPP5/k/t//+39Z/M9//jPJff7551Weg1SXLl2Scf6W6/lboUdEPP3004tlTtRc8T10rbXWqtHzhg4dmozz362WxPbUd955J4uLv9OkSZMW93QalC222CKLL7744iTXq1evKp/3j3/8I4vz79kLct9992Xx2muvneTy77fTp09Pcj/+8Y+zuNge43vf+14W//73v09y++67b7XzWRrkt6lfeOGFSa5Dhw5ZXN3Wx4suuigZ51vERNT+31H1kSueAAAAACiFwhMAAAAApVB4AgAAAKAUDabH05133pnFTZvWTb2seLvC2bNnZ/Gaa66Z5PJ7ZfP7bSMimjVrVifzoW4cf/zxyTjfn8se9HLk/8aL4rjjjsvi7t27V/vYfO+QfEzN7LLLLllc7JN35pln1uqYjzzySBb/6Ec/SnJnnXVWFm+zzTZJbu+9967ymPvvv38y/vrrr2s1N1I9e/ZMxmPGjMni1157Lcn97ne/Wyxz+q/ifztUL99zKd9vKSK9TfZuu+1W5TGeeOKJZLzJJptk8ZQpU5LcGmuskYzzfV/qqucmqZNPPnlJTyGx5ZZbZnF1twnP9/2LiHjllVdKm1N9dtBBByXj/G3vX3rppSSX76mTfx1GRPTu3TuL82sQEfH2229ncXVrUlT8TP3444+zuHPnzlU+76233krGvl9XL99Hqbiu+f4/xX9j7rrrrllc/HdrdfLfx77Nvffem8VXXnllksv33CzOm4hjjz02i/O9TBdGsXf0TjvtlIx/+9vfZnGxH9SXX35Zq3MuKa54AgAAAKAUCk8AAAAAlKLebrXbbrvtkvF3vvOdLC5eyl3TS7svu+yyZFy8JD1/++AddtghyZ100klVHveQQw7J4pEjR9ZoLtSd4m1pN91002Scv7TbLZvrl/wlxBERp59+eha3bNkyyX300UfJ+MQTT8ziOXPmlDC7xi1/aXXx/a4uXifFW3znt8DecccdSa5du3bJOL/1bvz48UnuxhtvXOS5Mf/Wnfx2reJl3vlt6GXJX6Je/Py3fStVfG+8/vrrszi/tS4i3SaZf81/m+L2urziFhvK179//ypzf/rTn0o5Z/77bPH8+ffsVq1aVXmMmTNnJuMLLrggi88444xFnWKDkb/N/YLGeRMmTKgyl/+7b7TRRknuqaeeyuLNNtusxnP74osvknH+O3NxG2D+fbq4JZu6kW+DEBHx6aefln7OnXfeOYv32GOP0s/XkBVb8RTbQeQ999xzWfzhhx8muT59+lT5vBVWWCEZ57fzjR49Osl98MEHVU+2HnLFEwAAAAClUHgCAAAAoBQKTwAAAACUol71eMr36hk7dmySW2mllWp0jOJt3W+55ZYsHjFiRJKrri9M8TgHH3xwFnfs2DHJnXPOOVm87LLLJrmLL744i7/66qsqz0ftFfuBFOVvDUv9UuzHVexdknfDDTck44ceeqiUOS0t8r0bij2eqnPggQdmcb4XU0TE5ZdfXqNjjBkzJhkfeuihVT523XXXrfHcqN7gwYOzuNhHYvLkyVm8JG6Lne+jWOzp9OCDD2bx9OnTF9OM6pc2bdpkcb6/XUTaK++TTz5Jcueee24W64XXsLRu3TqLmzdPv66/++67WTxq1KgaHzN/nOKt0W+77bZkvMoqq2Rx06bp/0+d/15V7B2WP+4aa6yR5PLfpa+99tokV/zezfzy/X4eeOCBKh9XXQ+pb/PjH/84i4v9F//1r39lcfE7GdV74403avS4n/zkJ8n4iiuuqPO5rLPOOsn4qquuyuL8Z01Rvo/Y0qrYW61t27ZZ/Pe//z3J5f99WqwP7LXXXln8m9/8Jsl17do1Geffi2+//fYkl+/PNW3atOqmXi+44gkAAACAUig8AQAAAFCKerXVLn8JcE231kWkW2723HPPJFe87Lymipf8nnXWWVl8/vnnJ7n85dD5bXcREePGjctitx4tx/rrr19tvrgmLFl//etfs7hv375VPq54GX7x9u8smuq2U22wwQZZXN324RYtWiS5b9v2Whv5rX0REf/+97+z+J577klyM2bMqPPzNyb5S/jzn1sREZdeeulinUt+a31ExD777JPF33zzTZI788wzs3hp3bI+aNCgLD7hhBOS3FtvvZXF2267bZLzmmi48u99K6+8cpKr6fabLl26JOP8Vrdv+0x97733svi6665Lcvn3i3feeafKY+S/A0ekW3w7d+6c5Gy1WzI6deqUjPNrW9xiefrpp2dxQ9jWU5+MHDkyi3v27JnkDjnkkCw+7bTTktzDDz+cxS+//HKNz9e9e/dkfMwxx2TxQQcdVOPj3HHHHVlc3Oa9NFpmmWWScaVSyeILLrigyud98cUXyfjqq6/O4uL2yuJWyLzilvkvv/yy6snWQ654AgAAAKAUCk8AAAAAlELhCQAAAIBS1KseTzVV7E1ywAEHZHFtezp9m/w+9XwvioiIzTbbrJRzUrUtt9wyi/fff/8k989//jMZF/vAsHgV+zh8//vfz+LiXun86zff1yUiYvbs2SXMbumV77VVvH39/fffn8XF3iL5ferFHk9lKN6OO38L5+Je93z/kuItZ5fGW8mvsMIKyTj/vlmU7z+xOOTXKiLt6/jSSy8luepuG760yL9vFuU/86rrt0PDsvHGG1eZe/XVV2t0jGIfp6FDh2ZxvjdJRPq+HxFx9NFHZ/ELL7xQo/MV1XSeLDmHHXZYMu7YsWMWf/rpp0ku32OR2jv11FOTcf61XvycHjNmTBYXPweK36/zfZ2Kfdnat2+fxcXX/ttvv53FN910U5LL9/WaNWtWLO322muvKnP9+/dPxvnv2dXZdNNNa3z+J554Ihk3tH8bueIJAAAAgFIoPAEAAABQinq71a54C8+8LbbYYjHO5D+aNGmSxcW5VTfX4cOHZ/HPfvazOp/X0qpPnz5ZnL98NCJiwoQJybh4C0sWr1tuuSUZd+jQocrH/uUvf8ni1157rbQ5ETFz5swszv/di4qX8ea3Gu+xxx5JLv9azN82uyytW7dOxvnf4/nnn09ye++9dxbXdttIQ1Pcyrrqqqtmcf7y/SWha9euVeaKa0fE4MGDq8zttNNOWVy8FXd+y+kzzzxT5/OiPF26dKnV8/LbbYYMGVLl46688spkPGzYsGRcxm26n3766QXGLF5bb711Fp9wwglVPm7QoEHJ2Htz3Zg6dWoyzm/Revjhh5PcBhtskMXF10xxq93yyy+fxcXtdPlzXnrppUnuj3/8YxYXt1eSKn53GjhwYBYXW+9897vfzeL1118/ye22225Z3K5duyQ3ffr0ZJzPH3TQQUkuv6XyxRdfrG7q9YIrngAAAAAohcITAAAAAKVQeAIAAACgFPWqx9Mvf/nLLC7e3ntJGzBgQBYXb3Gbn2tx3vkeT9SdDTfcMIuL+5hvvvnmxT0dCvJ7njfZZJMqH/fggw8m42J/EuqfO+64Y4FxRESzZs2yuG3btlUeY+WVV07GxdfwRx99VOVzR4wYkcUHHHBAksv3fOrZs2eSO//887P417/+dZJrrL1virc+zv+e+b4REWl/rmnTppUyn06dOmVxdT2LHnnkkVLO35Dlb3Fe/J6R7+VVvE33ySefnMWXXXZZksvflnmNNdZIcpMnT87ib+uJtt5662Xx448/nuTeeeedap9L1fLvofk+o9/miCOOyOIVV1wxyV1//fVZfMghh9R+cjVU/Bz46quvsriMHlLUTL4HY4sWLZLcfffdl8XF1zPl+MlPfpLFxb61efn+bQvy7rvvZvGhhx6a5PLft4vfDai5e++9NxnPmDEji4t9nPI9l4rfc6s75mGHHZaM//a3v2Xxuuuum+SOPPLILM7XUeorVzwBAAAAUAqFJwAAAABKofAEAAAAQCnqVY+nfB+lJSHfQ6FHjx5J7je/+U2NjvHxxx8n4/x+dmpvlVVWScbbbrttFv/73/9OcrfddttimRP/06FDh2Scf70U+wfkFXvrzJ49u07nRd1baaWVsrjYb+Cxxx7L4unTp1d5jOpy32bYsGFZfMMNNyS5kSNHZnGxx1OfPn2y+KyzzkpyO++8c63nU599/vnnyfi1117L4h//+MdJLt+vK98Pa2EU/+brrLNOMl5rrbWyuLp+B/Wtx2N9cO6552bxr371qxo/r2nT//3/i8WeH8VxXSh+B8r3Fdlzzz3r/HyNWf41Ut3rpahz585VPi+fK0uXLl2y+Be/+EWSu/XWW0s/P/Nr1apVMt5pp52yuNhrK99r079haq9v377J+MADD8zi6nocLoqLL744i8ePH1/KOZZ2xR6Ye+yxRxYXewyvsMIKVR7noosuyuJi39EvvvgiGeffN0844YQk169fvyzu2rVrkst/56svXPEEAAAAQCkUngAAAAAoRb3aareknXTSSVlcvJVhdaZMmZLF++67b5J76623FnleROy3337JOH9b7rvuumsxz4aiY445JhlvttlmVT72r3/9axbnL+mmfipugb7wwguzOL+lIiLdSnP77beXOq+IdGtfRMQ222yTxU8//XSSy2/72mqrrZJcftvBhAkT6nKK9Ur+9Va8PXv//v2zeMyYMbU6/ieffJKMi9t88ts0qzNq1Khanb8xy19eX9xiev3112dx8+bp17rVV189i/Pb7sqSb1kQkW4pOfnkk5PcmWeeWfp8lkZDhw7N4q233jrJ5ccnnnhikrviiiuS8dSpU2t1/vy2kDlz5iS58847r1bHZNEcd9xxyXjjjTfO4uJnXvFzlVT+e0/x9vX57XTFFiHVbZ299957s3jixIlJ7qmnnsri/PasiPnbwowYMSKL//znPye54jZo6kZ+7YpbKPfee+8sLraYOPXUU7O4uLWu6Iwzzsji733ve0lu4MCBCzxmxPw1ifrAFU8AAAAAlELhCQAAAIBSKDwBAAAAUIqlusfTnXfemYy/853v1Oo4L774YhY/8sgjizQnFmzNNdesMvfpp58uxpmwIAtze+/DDz88i2fPnl3GdKhDbdq0Scb5/gYtW7ZMcrfccksW5/stRUQ88cQTJcwuNWvWrCzea6+9ktzjjz+exW3btk1y+VvZNuYeTy+//HIW528BHBGx0UYbZXG3bt1qdfzirYSLrrnmmizeZ599qnzc559/XqvzN2bffPNNFk+aNCnJde/evcrn7bjjjlncokWLJDd8+PAsrq4v36LI9xLr1atXKedoLIo98zp37lyr4+R7M22yySZJbty4cVmc7xsSkfa6i4jYddddszj/3lrMFXt35fsHFft4LY7PAdKefRERp5xySjKeOXNmFp9++umLZU4NVb6HXkTEDjvskMXFnnZ5c+fOTcY33XRTFp977rlJ7o033sjiL7/8Msnl+wble1UuSP47WdeuXZOcHk/ly/d7WtC4tvLfiYo9HvM9nrbffvsk1759+yyeNm1ancxlUbniCQAAAIBSKDwBAAAAUIp6tdUuf0l2dbf93XnnnavMFW8HW7x0Oa94jnnz5n3bFBeoeLtx6l7+su6i8ePHL8aZsKjyl35+9dVXtT7OjBkzqjxOfkvJCiusUOUxVlxxxWRc0y2D+W0vEelWreLtoxu6MWPGJONVV101i88+++wkl38Pb9asWbkT+xYbbrhhMs7Prei5554rezr13jPPPLPAuC69/vrrNXpcz549k/Hzzz9fxnSWCvfdd1+Vufz2yuJWu6+//jqLr7766iR35ZVXJuOjjjoqi/O3j2bhvPfee8n41VdfzeJiu4H8dp/LL788yeU/g95///0kl1/n4veql156KRnnPx/PO++8JPeLX/xigeeLSLfXFbfzUZ4OHTpk8f/93/8lueLncb7ViO2P1XvllVeS8ZAhQ2r0vPzrNyLinnvuyeLddtstya211lpZvP766ye5/NbVb/Puu+9mcfH1TONw4403JuP8Vrvif5v51ib1ZUutK54AAAAAKIXCEwAAAAClUHgCAAAAoBT1qsfTyJEjs/icc86p8nF/+9vfknF1vZkWpm9TTR972WWX1fiY1F7+duyrrLLKEpwJdamu+unkb01b7GOx8sorZ3FN9+Mvig8++CCLf/vb35Z+viUp30evePvt/K1cr7322iT30EMPZfHvf//7JFfsoVBTw4YNS8YHHnhgFhdvJVxdjycWj/waVLceejotHhMnTszi4vtW8+b/+3p40EEHJblu3bol4969e9fofO+8885CznDplu+jdMcddyS5XXbZJYvvvvvuJHf++edncfGzMW+LLbZIxieeeGKV+eLr9d///ncWn3TSSUnutttuq/Kc1J1i36YJEyZk8dprr53kXnvttWR8yimnlDexRmb48OHJuGXLlll82GGHJbm2bdtmcbFX0zXXXFPnc8v3dIqI2G677bI43weVxqNYq8jXS370ox8ludNOOy2Lx44dm+Rq+717UbniCQAAAIBSKDwBAAAAUIomlUql8m0PmjlzZrW3JK8r+dvFPv7440muY8eOWdy0aVovW5jtdHnF43z44YdZXLwN5cEHH5zFxUuXl8Tt02fMmBHLL7/8Ih1jca1rbeVv33v00UcnuX/+859ZvPnmmye54q3uG5KGuq633nprMi5e7lmf5G8TXt17x7hx45LxpEmTqnzs3//+9yxe0K2J62JdI+rfa7ZNmzbJ+Nlnn83izp07J7llllkmi4t/99q+h+e3Ay2MJ598Mhn3798/i6dOnVrj4zTWdS1L/rLv6rZ61HZd68rSsq6tWrXK4j//+c9Jbo899qjVMYufv/ktYj/96U+T3GeffVarcyyKhvoZW3w/feCBB7K4uPWxOvktczX4+p8ZNWpUMv71r3+dxQvznlmWpeU1m9e9e/dk/PLLL1f52OJ3svHjx5cyp7pW39d11VVXTcZ77rlnFhdfszvssEONjlnc1pp/nd5yyy1J7uKLL07GDWV7XX1f14bqmGOOScZ/+MMfsrj477Sf/exnWfz555/Xyflrsq6ueAIAAACgFApPAAAAAJRC4QkAAACAUizZRgoFb775Zhbn98lGRAwaNCiLi7fQriv52wlfcsklpZyDqrVu3ToZ528XXHTzzTdncUPu6dRY7L777sn4+OOPz+IWLVrU+DjrrbdeFg8ZMqTGzyv2J5kyZUqVj83vka+uJwLfbvbs2cm4a9euWbzvvvsmufx7es+ePZNcly5d6nxujz32WDLO33L8yiuvTHL1oUfJ0mDZZZetMldXPQaoufzf/Kijjkpy+f5tm266aZLr1KlTMs6/31533XVJrngrcmqn2Ft0yy23zOLiZ2W+59NBBx2U5K666qos/rYeT3/605+y2Gdl/ZDvhTtx4sQqH3fccccl47/97W+lzWlp9u677ybjfG9aWNyuvfbaZDx06NAsLv477fTTT8/i5557rtyJ5bjiCQAAAIBSKDwBAAAAUIomlRrcT7W+3a5wp512SsYHH3xwFg8YMCDJ5W+JfsUVVyS54i0rX3zxxSx+6623FnmeZWqotwSuTnFL1kMPPZTFH330UZLbe++9s3jOnDnlTmwxaozrilvHFq2yyirJOL+tJyJ9T8/fNjwiYrPNNsviV155JclNmjQpi99+++0kN3fu3NpNthrWdeF88MEHWdy8ebrT/4wzzsjiP/7xj4ttTgtiXVP52y5HpNu8IiJGjBiRxcXP6vrGZ2zjtLS8ZvMtQU488cQqH7f55psn4/xnY0OytKzr0sa6Lh5rrLFGFhdbkIwZMyaL99lnnzo5X03W1RVPAAAAAJRC4QkAAACAUig8AQAAAFCK5t/+kPpnwoQJ1Y5pmL766qtk/P3vf38JzQQoU77Xz4Icf/zxVebuuuuuup4Oi8mTTz6Zxeeff36SK/byov647rrrqh0D5dhmm22S8RFHHLGEZgI0NPl+1ffee2+SGzhwYBb36NEjyeV7Xtc1VzwBAAAAUAqFJwAAAABK0SC32gEADcuAAQOW9BQAGoxtt902Gbdp06bKx7722mtZPHv27NLmBDQ8gwcPTsbPPvtsFnfr1i3J2WoHAAAAQIOj8AQAAABAKRSeAAAAACiFHk8AAAANRL5HS0TEjjvumMXTpk1b3NMB6rGZM2cm47XXXnuJzMMVTwAAAACUQuEJAAAAgFLYagcAAFCPnHXWWdWOARoSVzwBAAAAUAqFJwAAAABKUaPCU6VSKXseLKS6WBPrWv9Y18aprtbE2tYv1rVxsq6Nl8/YxslrtnGyro2TdW2carIeNSo8zZo1a5EnQ92qizWxrvWPdW2c6mpNrG39Yl0bJ+vaePmMbZy8Zhsn69o4WdfGqSbr0aRSg/LUvHnz4r333ou2bdtGkyZN6mRy1E6lUolZs2ZFly5domnTRdspaV3rD+vaONXlukZY2/rCujZO1rXx8hnbOHnNNk7WtXGyro3TwqxrjQpPAAAAALCwNBcHAAAAoBQKTwAAAACUQuEJAAAAgFIoPAEAAABQCoUnAAAAAEqh8AQAAABAKRSeAAAAACjF/wfL/FOMGCdKiwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# the index set of test images to be used \n",
    "num_images = 10 # set it to be 30 to reproduce our results\n",
    "test_index_set = select_testImageIndexes(index_dict, num_images)\n",
    "\n",
    "# the corresponding test images \n",
    "images = []\n",
    "for i in range(len(test_index_set)):\n",
    "    images.append(test_dataset[test_index_set[i]][0][0])\n",
    "showImages(images)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "781cf8ae",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the pre-trained VAE model\n",
    "vae = VAE(x_dim=784, h_dim1=500, h_dim2=500, z_dim=20)\n",
    "vae.load_state_dict(torch.load('models/params_mnist.ckpt')) # load the pre-trained model\n",
    "vae = vae.cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "658af5c5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n"
     ]
    }
   ],
   "source": [
    "m, n = 200, 784\n",
    "num_trials = 2 # set it to be 10 to reproduce our results\n",
    "R, Delta, sigma = 5, 3, 0.1 # the default parameters for '1bitDither', 'unifQuant' and 'relu' respectively \n",
    "model = '1bit' # set it to be '1bit' or 'relu' or '1bitDither' or 'unifQuant'\n",
    "lambda_reg = np.sqrt(np.log(n)/m) # the regularization parameter for Lasso\n",
    "method = 'CSGM' # 'CSGM' or 'Lasso'\n",
    "res = solver(m, images, vae, lambda_reg=lambda_reg, num_trials=num_trials, R=R, Delta=Delta, sigma=sigma, model=model, method=method)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1aa441a3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABJ4AAAG/CAYAAAAZ2x3eAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACRHklEQVR4nO3dd5hUVfLw8SIHGck5R8koUSUpIKAIIiJgzqKi4vpb86pgWNecc8CEKIgBFAyYUDGBoiIZySCZAQRBnX7/2JezVTVMMzP0ndDz/TzPPk9da+i+06dvmLun6hSKxWIxAQAAAAAAABKscG7vAAAAAAAAAJITD54AAAAAAAAQCR48AQAAAAAAIBI8eAIAAAAAAEAkePAEAAAAAACASPDgCQAAAAAAAJHgwRMAAAAAAAAiwYMnAAAAAAAARIIHTwAAAAAAAIgED54AAJlSqFAhGTVqVNh+/vnnpVChQrJs2bJsvd6yZcukUKFCcs899yRmB/OZo446So466qjc3o0CY9SoUVKoUKHc3g1EKLPHVL169eTss8+OfH8AAMB/8eAJACCPPfaYFCpUSDp16pTw154yZYp5YJXTdu7cKaNGjZJPP/000vfJ7d8T2J8ZM2bIqFGjZOvWrQV6HwAAQM7iwRMAQMaOHSv16tWTb7/9VhYvXpzQ154yZYqMHj06oa+ZFTt37pTRo0fnyIOnrPyeH3zwgXzwwQcR7hFgzZgxQ0aPHp3rD55yex8WLFggTz/9dK69PwAABQ0PngCggFu6dKnMmDFD7rvvPqlcubKMHTs2t3epQChevLgUL148t3cDmbBz587c3oUcl5aWJn/88Udu70YkSpQoIcWKFcvt3QAAoMDgwRMAFHBjx46V8uXLS79+/WTw4MEJffB09tlny6OPPioi/+0Rtfd/3lNPPSUNGzaUEiVKSIcOHeS7775L9zPz58+XwYMHS4UKFaRkyZLSvn17mTRpUtz3X7ZsmVSuXFlEREaPHh3eX5fEZeZ1//zzTxk9erQ0btxYSpYsKRUrVpQuXbrIhx9+mKXfU/P9aD799FMpVKiQjB8/XkaPHi01a9aUlJQUGTx4sKSmpsru3bvliiuukCpVqkiZMmXknHPOkd27d5vXHDNmjPTo0UOqVKkiJUqUkObNm8vjjz+e7r3T0tJk1KhRUqNGDSldurQcffTRMnfu3H32vtm6datcccUVUrt2bSlRooQ0atRI7rzzTklLSzM/9+qrr0q7du0kJSVFDj74YGnVqpU8+OCDcT8DEZF77rlHjjzySKlYsaKUKlVK2rVrJ6+//nq6nytUqJBceuml8tZbb0nLli2lRIkS0qJFC3nvvffS/ewXX3whHTp0kJIlS0rDhg3lySef3O9+7HXUUUdJy5YtZdasWdKtWzcpXbq0XH/99SIisnv3brn55pulUaNGUqJECaldu7ZcffXV6cZBROTll1+Wjh07SunSpaV8+fLSrVu3dDPcHnvsMWnRooWUKFFCatSoISNGjEg3E2jv/sydO1eOPvpoKV26tNSsWVPuuuuudO/58MMPS4sWLcJ7tm/fXl555RUR+W+Pq6uuukpEROrXrx++o3t7tO39fMeOHRv26b333gvfSz9jcG+Ptueff9789/nz58uQIUOkcuXKUqpUKTnkkEPkhhtuyNQ+7P3c2rVrJ6VKlZIKFSrIsGHDZOXKlel+173njFKlSknHjh3l888/T/czGfHf87396r744gu5/PLLpXLlylKuXDkZPny47NmzR7Zu3SpnnnmmlC9fXsqXLy9XX321xGIx85qZ/R7v2rVLLr/8cqlUqZKkpKTIgAEDZPXq1enOSyIiq1evlnPPPVeqVq0avu/PPfdcuteMN+4AAOQFRXN7BwAAuWvs2LEyaNAgKV68uJxyyiny+OOPy3fffScdOnQ44NcePny4rFmzRj788EN56aWX9vkzr7zyimzfvl2GDx8uhQoVkrvuuksGDRokv/76a5iV8Msvv0jnzp2lZs2acu2118pBBx0k48ePl4EDB8rEiRPlxBNP3OdrV65cWR5//HG5+OKL5cQTT5RBgwaJiEjr1q2z9LqjRo2SO+64Q84//3zp2LGjbNu2TWbOnCnff/+9HHPMMZn6PTPrjjvukFKlSsm1114rixcvlocffliKFSsmhQsXli1btsioUaPk66+/lueff17q168vN910U/i3jz/+uLRo0UIGDBggRYsWlcmTJ8sll1wiaWlpMmLEiPBz1113ndx1113Sv39/6dOnj/z444/Sp0+fdDNcdu7cKd27d5fVq1fL8OHDpU6dOjJjxgy57rrrZO3atfLAAw+IiMiHH34op5xyivTs2VPuvPNOERGZN2+efPnllzJy5Mi4v++DDz4oAwYMkNNOO0327Nkjr776qpx88snyzjvvSL9+/czPfvHFF/LGG2/IJZdcIikpKfLQQw/JSSedJCtWrJCKFSuKiMjPP/8svXv3lsqVK8uoUaPkr7/+kptvvlmqVq2a6THYtGmTHHvssTJs2DA5/fTTpWrVqpKWliYDBgyQL774Qi688EJp1qyZ/Pzzz3L//ffLwoUL5a233gr/fvTo0TJq1Cg58sgj5ZZbbpHixYvLN998Ix9//LH07t1bRP77nRo9erT06tVLLr74YlmwYEE49r788kszI2fLli3St29fGTRokAwZMkRef/11ueaaa6RVq1Zy7LHHiojI008/LZdffrkMHjxYRo4cKX/88Yf89NNP8s0338ipp54qgwYNkoULF8q4cePk/vvvl0qVKomIhAezIiIff/yxjB8/Xi699FKpVKmS1KtXL0slcT/99JN07dpVihUrJhdeeKHUq1dPlixZIpMnT5bbb799v/tw++23y4033ihDhgyR888/XzZs2CAPP/ywdOvWTX744QcpV66ciIg8++yzMnz4cDnyyCPliiuukF9//VUGDBggFSpUkNq1a2d6f73LLrtMqlWrJqNHj5avv/5annrqKSlXrpzMmDFD6tSpI//+979lypQpcvfdd0vLli3lzDPPDP82s9/js88+W8aPHy9nnHGGHH744fLZZ5+l+56LiKxbt04OP/zw8ECwcuXKMnXqVDnvvPNk27ZtcsUVV4jI/scdAIA8IQYAKLBmzpwZE5HYhx9+GIvFYrG0tLRYrVq1YiNHjkz3syISu/nmm8P2mDFjYiISW7p0adz3GDFiRGxfl5ulS5fGRCRWsWLF2ObNm8N/f/vtt2MiEps8eXL4bz179oy1atUq9scff4T/lpaWFjvyyCNjjRs3jvv+GzZsSLfvWX3dNm3axPr165et3zMj3bt3j3Xv3j1sf/LJJzERibVs2TK2Z8+e8N9POeWUWKFChWLHHnus+fdHHHFErG7duua/7dy5M9379OnTJ9agQYOw/dtvv8WKFi0aGzhwoPm5UaNGxUQkdtZZZ4X/duutt8YOOuig2MKFC83PXnvttbEiRYrEVqxYEYvFYrGRI0fGDj744Nhff/2Vqd893j7v2bMn1rJly1iPHj3MfxeRWPHixWOLFy8O/+3HH3+MiUjs4YcfDv9t4MCBsZIlS8aWL18e/tvcuXNjRYoUydT4dO/ePSYisSeeeML895deeilWuHDh2Oeff27++xNPPBETkdiXX34Zi8VisUWLFsUKFy4cO/HEE2N///23+dm0tLRYLBaLrV+/Pla8ePFY7969zc888sgjMRGJPffcc+n258UXXwz/bffu3bFq1arFTjrppPDfTjjhhFiLFi3i/m533313hsesiMQKFy4c++WXX8x/3/u9/OSTT8x/33v8jhkzJvy3bt26xVJSUsxnr3/vePuwbNmyWJEiRWK33367+e8///xzrGjRouG/79mzJ1alSpXYoYceGtu9e3f4uaeeeiomIuaYykjdunXN93zvuaxPnz5mX4844ohYoUKFYhdddFH4b3/99VesVq1a6d4nM9/jWbNmxUQkdsUVV5ifPfvss9Odo84777xY9erVYxs3bjQ/O2zYsFjZsmXD+2Vm3AEAyG2U2gFAATZ27FipWrWqHH300SLy33KboUOHyquvvip///13juzD0KFDpXz58mG7a9euIiLy66+/iojI5s2b5eOPP5YhQ4bI9u3bZePGjbJx40bZtGmT9OnTRxYtWiSrV6/O8vtm5XXLlSsnv/zyiyxatCgBv3F8Z555ppnt0qlTJ4nFYnLuueean+vUqZOsXLlS/vrrr/DfSpUqFeLU1FTZuHGjdO/eXX799VdJTU0VEZGPPvpI/vrrL7nkkkvM61122WXp9mXChAnStWtXKV++fPh8Nm7cKL169ZK///5bpk+fLiL//Xx+//33UHqYFXqft2zZIqmpqdK1a1f5/vvv0/1sr169pGHDhmG7devWcvDBB4fvyt9//y3vv/++DBw4UOrUqRN+rlmzZtKnT59M71OJEiXknHPOMf9twoQJ0qxZM2natKn5LHr06CEiIp988omIiLz11luSlpYmN910kxQubG+z9pZfTps2Tfbs2SNXXHGF+ZkLLrhADj74YHn33XfNvytTpoycfvrpYbt48eLSsWPH8HuL/HcMVq1atc8y1czq3r27NG/ePFv/dsOGDTJ9+nQ599xzzWcvIvstOxUReeONNyQtLU2GDBliPt9q1apJ48aNw+c7c+ZMWb9+vVx00UWmR9rZZ58tZcuWzda+73XeeeeZfd177J133nnhvxUpUkTat29vPnuRzH2P95aF7u/Yi8ViMnHiROnfv7/EYjHzefTp00dSU1PD6yZi3AEAiBqldgBQQP3999/y6quvytFHHy1Lly4N/71Tp05y7733ykcffRTKgqLk/0jd+xBqy5YtIiKyePFiicVicuONN8qNN964z9dYv3691KxZM0vvm5XXveWWW+SEE06QJk2aSMuWLaVv375yxhlnhJK9RPKfx94/pn0JUdmyZSUtLU1SU1NDmdmXX34pN998s3z11VfpGmKnpqZK2bJlZfny5SIi0qhRI5OvUKGCeQAoIrJo0SL56aefTDmWtn79ehH57x/S48ePl2OPPVZq1qwpvXv3liFDhkjfvn33+/u+8847ctttt8ns2bNNr6R9Pazwn43If78ve78rGzZskF27dknjxo3T/dwhhxwiU6ZM2e/+iIjUrFkzXeP3RYsWybx58/b7WSxZskQKFy4c9wHO3jE45JBDzH8vXry4NGjQIOT3qlWrVrrPo3z58vLTTz+F7WuuuUamTZsmHTt2lEaNGknv3r3l1FNPlc6dO+/nt/2f+vXrZ/pnvb0PYlq2bJmtf79o0SKJxWL7HDsRCQ9j9342/ueKFSsmDRo0yNZ775WVY2/vd26vzHyPly9fLoULF073OftjccOGDbJ161Z56qmn5Kmnntrnvu79viVi3AEAiBoPngCggPr4449l7dq18uqrr8qrr76aLj927NgcefBUpEiRff732P9v3ru3ifU///nPDGet+D/cMiMrr9utWzdZsmSJvP322/LBBx/IM888I/fff7888cQTcv7552f5vePJ6PPY3+e0ZMkS6dmzpzRt2lTuu+8+qV27thQvXlymTJki999/f7pm4JmRlpYmxxxzjFx99dX7zDdp0kRERKpUqSKzZ8+W999/X6ZOnSpTp06VMWPGyJlnnikvvPBChq//+eefy4ABA6Rbt27y2GOPSfXq1aVYsWIyZsyYfTZH3t9nkCh69speaWlp0qpVK7nvvvv2+W8OpLfQ/mTm927WrJksWLBA3nnnHXnvvfdk4sSJ8thjj8lNN90ko0ePztT77Ov3zmi2UqJnRKalpUmhQoVk6tSp+/x9y5Qpk9D325esHHv6s8/q93h/9h6rp59+upx11ln7/Jm9D70TMe4AAESNB08AUECNHTtWqlSpElZj09544w1588035YknntjnH6NZkZkym3j2zmIoVqyY9OrVK2Hvn9XXrVChgpxzzjlyzjnnyI4dO6Rbt24yatSo8ODpQH/PAzV58mTZvXu3TJo0yczc2FuitFfdunVF5L8zvvTMi02bNqWbxdGwYUPZsWNHpj6f4sWLS//+/aV///6SlpYml1xyiTz55JNy4403ZvhgcOLEiVKyZEl5//33pUSJEuG/jxkzZv+/8D7sXUltXyWRCxYsyNZr7tWwYUP58ccfpWfPnnHHumHDhpKWliZz586VQw89dJ8/s3cMFixYYGbp7NmzR5YuXZqt77mIyEEHHSRDhw6VoUOHyp49e2TQoEFy++23y3XXXSclS5bM1nd07yw432Tcz8ra+3vMmTMn7utltA8NGzaUWCwm9evXDw8092XvZ7do0aJQ5ijy35Unly5dKm3atIn7/lHI7Pe4bt26kpaWJkuXLjUzthYvXmx+rnLlypKSkiJ///13pr4L+xt3AAByGz2eAKAA2rVrl7zxxhty/PHHy+DBg9P979JLL5Xt27fLpEmTDvi9DjroIBFJ/4drZlWpUkWOOuooefLJJ2Xt2rXp8hs2bIj770uXLr3P98/K627atMnkypQpI40aNTIlNQf6ex6ovbMy9EyM1NTUdH/89uzZU4oWLSqPP/64+e+PPPJIutccMmSIfPXVV/L++++ny23dujX0l/KfT+HChcOMDP0Z7WufCxUqZGbPLFu2zKwQlxVFihSRPn36yFtvvSUrVqwI/33evHn7/B2yYsiQIbJ69Wp5+umn0+V27dolv//+u4iIDBw4UAoXLiy33HJLullme8emV69eUrx4cXnooYfMeD377LOSmpq6z1XO9sePQfHixaV58+YSi8Xkzz//FJHsfUfr1q0rRYoUCf289nrsscfMduXKlaVbt27y3HPPmc9exH4nM9qHQYMGSZEiRWT06NHpZrDFYrHw+7Vv314qV64sTzzxhOzZsyf8zPPPP5+rx15mvsd7Z1b6z+7hhx9O93onnXSSTJw4cZ8P8uKdm/Y17gAA5DZmPAFAATRp0iTZvn27DBgwYJ/5ww8/XCpXrixjx46VoUOHHtB7tWvXTkRELr/8cunTp48UKVJEhg0blqXXePTRR6VLly7SqlUrueCCC6RBgwaybt06+eqrr2TVqlXy448/ZvhvS5UqJc2bN5fXXntNmjRpIhUqVJCWLVtKy5YtM/26zZs3l6OOOkratWsnFSpUkJkzZ8rrr78ul156aUJ/zwPRu3fvMOto+PDhsmPHDnn66aelSpUq5sFa1apVZeTIkXLvvffKgAEDpG/fvvLjjz/K1KlTpVKlSmZGylVXXSWTJk2S448/Xs4++2xp166d/P777/Lzzz/L66+/LsuWLZNKlSrJ+eefL5s3b5YePXpIrVq1ZPny5fLwww/LoYceKs2aNctwn/v16yf33Xef9O3bV0499VRZv369PProo9KoUSPTvygrRo8eLe+995507dpVLrnkEvnrr7/k4YcflhYtWmT7NUVEzjjjDBk/frxcdNFF8sknn0jnzp3l77//lvnz58v48ePl/fffl/bt20ujRo3khhtukFtvvVW6du0qgwYNkhIlSsh3330nNWrUkDvuuEMqV64s1113nYwePVr69u0rAwYMkAULFshjjz0mHTp0MI3EM6t3795SrVo16dy5s1StWlXmzZsnjzzyiPTr109SUlJE5H/f0RtuuEGGDRsmxYoVk/79+4eHQftStmxZOfnkk+Xhhx+WQoUKScOGDeWdd94JPYa0hx56SLp06SJt27aVCy+8UOrXry/Lli2Td999V2bPnh13Hxo2bCi33XabXHfddbJs2TIZOHCgpKSkyNKlS+XNN9+UCy+8UP75z39KsWLF5LbbbpPhw4dLjx49ZOjQobJ06VIZM2bMAfd4yq7Mfo/btWsnJ510kjzwwAOyadMmOfzww+Wzzz6ThQsXioidDfaf//xHPvnkE+nUqZNccMEF0rx5c9m8ebN8//33Mm3aNNm8ebOIZG7cAQDIdTm6hh4AIE/o379/rGTJkrHff/89w585++yzY8WKFQvLeYtb7nvvEuT7Wppd++uvv2KXXXZZrHLlyrFChQqFJe33Lsd+9913p/s3/r1isVhsyZIlsTPPPDNWrVq1WLFixWI1a9aMHX/88bHXX399v7/vjBkzYu3atYsVL1483Wtn5nVvu+22WMeOHWPlypWLlSpVKta0adPY7bffHtuzZ89+f8+MdO/e3SzJvnfZ+gkTJpif2/s5f/fdd+a/33zzzTERiW3YsCH8t0mTJsVat24dK1myZKxevXqxO++8M/bcc8+lG6e//vorduONN8aqVasWK1WqVKxHjx6xefPmxSpWrGiWjo/FYrHt27fHrrvuulijRo1ixYsXj1WqVCl25JFHxu65557w+7/++uux3r17x6pUqRIrXrx4rE6dOrHhw4fH1q5dG/cziMVisWeffTbWuHHj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LjLb+nug+6eJiGzevDmru4hc0rZtW7P9xhtvhLhevXqRv3/v3r3N9rx580K8cuXKyN8f8fXr189sDxgwIMRHHXWUyTVq1ChTr6n7NomI1K1bN8S6n5FXpEiRTL1+srn88stDfOGFF5rcxx9/HOKbbrrJ5L7++utodwxAQrVo0SLERYvG/7O9oPa8Q/7BjCcAAAAAAABEggdPAAAAAAAAiERSlNpVrlw5xC+88EIu7gnyIr208O+//25yb775Zg7vTfJo3759iE888cQMf+6XX34x27osY+PGjSa3Y8eOEBcvXtzkfIlAmzZtQlyxYsVM7DG06667LsTXXntttl7Dl7mceuqpIe7Ro4fJnXPOOSH+4IMPsvV+yBl9+vQx2/FKnaLgy2rPPffcEA8bNixH96Wg0KXLIiIjRowIsW5ZICJSqlQps12oUKEDfv8mTZoc8GsUJNWqVcswN23atBBTWgfkffqcet5555ncvffeG+L9ldr9/PPPIY7FYpl+/xkzZoT49ddfN7mZM2eGePv27Zl+TYgcfPDBIfYtQFq2bBniXr16mdyff/4Z7Y7lImY8AQAAAAAAIBI8eAIAAAAAAEAkePAEAAAAAACASOTLHk96GVkRkYEDB4a4Y8eO2X7dbt26hbhwYftMTi9ROX369Gy/B6Kn62ZFRC699NIQv/TSSzm9O0mrevXqIfY9PnRfJ98vZu3atZl6/f/7v/8z282bN8/wZ999991MvSb+Z9myZRnmdG+ARx991OT02BYrVszkbrnllhD7HiRvv/12iO+8806Tu+uuu8z2zp07M9w3REP3jjjuuONycU9EZs2aZbavvPLKEB900EEm5/v2IXtq1apltkeOHBn5e86fPz/Evhcg4ktJSQmx7weiezwhbxg8eLDZ1n3T1qxZY3J//PFHiMeOHWtyv/32W4gXL16cyF1EDvJ98nS/2d69e5tcVno1tW7dOlv/TvdMveiii0xOn6d9L6LM3s8XFKeddprZvv3220Ncu3btDP+d7gUlIrJp06bE7lgewownAAAAAAAARIIHTwAAAAAAAIhEviy1u//++812WlpaQl530KBB+4xFRJYvXx7ioUOHmpwvC0Duatq0qdnWpRmvvfZaTu9O0po8eXKIGzVqZHJ6ydXNmzdn6/X9sum+rAsHRpcoexMmTAhxVkpudEmynjouIlKhQoUQ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S/WKiFx//fUhZkn1fdOfy1133WVyuvROl22IiHzyySch9qVMesq+L5XU07UrV65scnr5aF/255f21VPUfYmlX04YmdepU6cQDxs2zOT0d8WXs//+++8J3xdf1nP88ceH2C8Fro/9nJ5WnlfoY+2YY44xOT3Vv127dianS910WYSILfdZtmyZyW3YsCHE/vj0x68eSz8NX58v/P2QLplbvny5yelSnYJ6ftdj3rp1a5PTn7MuOxexx2u8UlR/bfbH3WWXXRZi38KgTJkyIfbXav26+rwvYr+Pr7/+usnp71kylNDq760ve3r//fdD7I9L/Xn6z1bfP/mcvo7r8RFJX1qlj6/t27eb3IgRI0J8wgknmJy+/vrzQH4vlUy0smXLmm19XMyaNcvk9DXunXfeMTn9t6ovT413nPhrrL6X8iWc/fr1C7Euu/ev48u858+fH+L8Nv7+89H8uVG3ivDHxMiRI0Ncr149k9PHiy9FXLFiRYh9SWu1atXMtv5sfdls1Pz76e9Rdu7HmfEEAAAAAACASPDgCQAAAAAAAJHgwRMAAAAAAAAikad6POk6ws6dO5tcr169QuxrlXft2hXi+++/3+QeeuihEOva8n3RS1b6XgS6j5BfClwvS+37ZhxxxBEh9ssMI/t0/e11111ncr63jF4Wen/fAURP9yG49NJLTU6fA3SPEZH0vbtSU1MTv3NJRtf/63pyEZGxY8eGWC/VKmKXefV9JGrXrh3iI4880uR03wC/1LI+9vzYbt261WzrJWgXL15scnpp9fzWUyCn+eWcda9En/vmm29C/PXXX0e7Y5K+P9jw4cND7Pt66X4oBaXHl17SXESkR48eIR49erTJ6aWY/XlRL7f97LPPmtzatWtD7Ps46HPH/np86V4Z/nyhj3t/X1VQl1zPLL1stu9tqs+hc+bMMTn9ucbr89KgQQOT8/fPhx9+eIh9ny3dF8i/v15uvEWLFiZ3yimnhNjfj7344osh9t+VZOj5pOlrl+51tq/tqPm+Pfqa68+3+j7itddeMzmux5b/fs+bNy/E/jz56aefhlj/LSpi+4P5zzje8a2vCyL2fs33I9bngmLFipmc/tv17bffNjl9P5ZMvfj8Z1CpUqUQd+vWzeT0va6+dxax/feee+45k9PX1XPPPdfk9DMPEfsd8Pum/x6OYgz8veKBvgczngAAAAAA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",
      "text/plain": [
       "<Figure size 1500x500 with 30 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# display all the test images\n",
    "nrows = num_trials + 1\n",
    "fig, ax = plt.subplots(nrows, num_images, figsize=(15,5))\n",
    "\n",
    "row_num = 0\n",
    "for j in range(num_images):\n",
    "    ax[row_num, j].imshow(images[j].view(28,28).cpu().numpy(), cmap ='gray')\n",
    "    ax[row_num,j].set_xticks([])\n",
    "    ax[row_num,j].set_yticks([])\n",
    "\n",
    "for i in range(num_trials):\n",
    "    for j in range(num_images):\n",
    "        ax[i+1, j].imshow((res[j+i*num_images].reshape(28,28)), cmap ='gray')\n",
    "        ax[i+1, j].set_xticks([])\n",
    "        ax[i+1, j].set_yticks([])\n",
    "fig.suptitle('All the test images and reconstructed images')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9615c08",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.10.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
