{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Decoding of Object `Identity` from VGG-16 Units"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                         \r"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import pickle\n",
    "import numpy as np\n",
    "import torch.nn as nn\n",
    "\n",
    "from torchvision.models import vgg16\n",
    "\n",
    "from torchvision import transforms\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.utils.data import Subset\n",
    "from torchvision.datasets import ImageNet\n",
    "\n",
    "from utils.infonets import InfoNet\n",
    "from utils.miscellaneous import get_info\n",
    "from utils.const import imagenet_id2class, imagenet_class2id\n",
    "\n",
    "from random import sample\n",
    "from tqdm import trange\n",
    "\n",
    "# * Select the hierarchical level\n",
    "n_cls = 10\n",
    "\n",
    "# Among the pool of available idx, pick n_cls randomly\n",
    "cls_idxs = set(sample(range(1000), n_cls))\n",
    "\n",
    "# Prepare the Dataset\n",
    "img_size = 224\n",
    "pop_size = 250\n",
    "batch_size = 50\n",
    "nt_batches = 50\n",
    "nv_batches = 10\n",
    "\n",
    "img_mean, img_std = [0.485, 0.456, 0.406], [0.229, 0.224, 0.225]\n",
    "pipeline = transforms.Compose([\n",
    "    transforms.Resize(img_size),\n",
    "    transforms.CenterCrop(img_size),\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize(mean = img_mean, std = img_std)\n",
    "])\n",
    "\n",
    "# * Here we load the ImageNet dataset\n",
    "train_imagenet = ImageNet('path_to_ImageNet', split = 'train', transform = pipeline)\n",
    "valid_imagenet = ImageNet('path_to_ImageNet', split = 'val',   transform = pipeline)\n",
    "\n",
    "# Take a subset of ImageNet containing only the selected classes\n",
    "train_dxs = [idx for idx, lbl in enumerate(train_imagenet.targets) if lbl in cls_idxs]\n",
    "valid_dxs = [idx for idx, lbl in enumerate(valid_imagenet.targets) if lbl in cls_idxs]\n",
    "\n",
    "train_dataset = Subset(train_imagenet, train_dxs) \n",
    "valid_dataset = Subset(valid_imagenet, valid_dxs) \n",
    "\n",
    "# Construct the loader for the two subset and sample the images\n",
    "train_loader = DataLoader(train_dataset, batch_size = batch_size, shuffle = True)\n",
    "valid_loader = DataLoader(valid_dataset, batch_size = batch_size, shuffle = True)\n",
    "\n",
    "train_data = [batch for batch, _ in zip(train_loader, trange(nt_batches, desc = 'Trainset', leave = False))]\n",
    "valid_data = [batch for batch, _ in zip(valid_loader, trange(nv_batches, desc = 'Validset', leave = False))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/pmurator/SISSA/lib/python3.8/site-packages/torch/nn/functional.py:718: UserWarning: Named tensors and all their associated APIs are an experimental feature and subject to change. Please do not use them for anything important until they are released as stable. (Triggered internally at  /pytorch/c10/core/TensorImpl.h:1156.)\n",
      "  return torch.max_pool2d(input, kernel_size, stride, padding, dilation, ceil_mode)\n"
     ]
    }
   ],
   "source": [
    "import torch.nn as nn\n",
    "\n",
    "from torchvision.models import vgg16\n",
    "from utils.infonets import InfoNet\n",
    "from utils.miscellaneous import get_info\n",
    "\n",
    "vgg = vgg16(pretrained = True)\n",
    "Exp = InfoNet(vgg)\n",
    "\n",
    "# Get network layer shapes for the selected input\n",
    "excluded_layers = (nn.Dropout, nn.BatchNorm2d, nn.AdaptiveAvgPool2d)\n",
    "info = get_info(vgg, (1, 3, img_size, img_size), exclude = excluded_layers)\n",
    "\n",
    "# Use network shapes to select a random population of fixed size\n",
    "units = [np.random.randint(0, shape, size = (pop_size, len(shape))) for shape in info.shapes]\n",
    "    \n",
    "# Mease the receptive field of the units    \n",
    "unit_rfs = Exp.measure_RF(keys = info.names, units = units)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# We prepare the network we want to use for the analysis\n",
    "tnd_vgg = vgg16(pretrained = True)\n",
    "rnd_vgg = vgg16(pretrained = False)\n",
    "\n",
    "# * Prepare the experiments\n",
    "Exp_T = InfoNet(tnd_vgg)\n",
    "Exp_R = InfoNet(rnd_vgg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                                   \r"
     ]
    }
   ],
   "source": [
    "from sklearn.preprocessing import LabelEncoder\n",
    "\n",
    "encoder = LabelEncoder()\n",
    "\n",
    "# Compute the model activations\n",
    "_ = Exp_T.record (units = units, rec_imgs = train_data)\n",
    "_ = Exp_R.record (units = units, rec_imgs = train_data)\n",
    "\n",
    "# * Extract the unit activations from the different experiments\n",
    "exp_layers = [l for l in Exp_T.recorder.keys if 'conv' in l or 'fc' in l]\n",
    "layers = [l for l in info.names if 'conv' in l or 'fc' in l]\n",
    "\n",
    "acts_Tt  = {l : Exp_T.features[L].T  for l, L in zip(layers, exp_layers)}\n",
    "acts_Rt  = {l : Exp_R.features[L].T  for l, L in zip(layers, exp_layers)}\n",
    "\n",
    "train_lbls = torch.cat([tmp[1] for tmp in train_data]).numpy()\n",
    "train_lbls = encoder.fit_transform(train_lbls)\n",
    "\n",
    "# Compute the model activations\n",
    "_ = Exp_T.record (units = units, rec_imgs = valid_data)\n",
    "_ = Exp_R.record (units = units, rec_imgs = valid_data)\n",
    "\n",
    "# * Extract the unit activations from the different experiments\n",
    "exp_layers = [l for l in Exp_T.recorder.keys if 'conv' in l or 'fc' in l]\n",
    "layers = [l for l in info.names if 'conv' in l or 'fc' in l]\n",
    "\n",
    "acts_Tv  = {l : Exp_T.features[L].T  for l, L in zip(layers, exp_layers)}\n",
    "acts_Rv  = {l : Exp_R.features[L].T  for l, L in zip(layers, exp_layers)}\n",
    "\n",
    "valid_lbls = torch.cat([tmp[1] for tmp in valid_data]).numpy()\n",
    "valid_lbls = encoder.fit_transform(valid_lbls)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                     \r"
     ]
    }
   ],
   "source": [
    "from sklearn.svm import SVC\n",
    "from sklearn.pipeline import Pipeline\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "from utils.decoding import decode\n",
    "\n",
    "pipe = Pipeline([('scaler', StandardScaler()), ('svc', SVC())])\n",
    "\n",
    "# Decode from the trained network using single units\n",
    "TSU = [decode((acts_Tt[l], acts_Tv[l]), (train_lbls, valid_lbls), pipe, pop_size = 1,   max_reps = 200) for l in tqdm(layers, desc = 'TSU', leave = False)]\n",
    "\n",
    "# Decode from the random network using single units\n",
    "RSU = [decode((acts_Rt[l], acts_Rv[l]), (train_lbls, valid_lbls), pipe, pop_size = 1,   max_reps = 200) for l in tqdm(layers, desc = 'RSU', leave = False)]\n",
    "\n",
    "# Decode from the trained network using single units\n",
    "TMU = [decode((acts_Tt[l], acts_Tv[l]), (train_lbls, valid_lbls), pipe, pop_size = 100, max_reps = 200) for l in tqdm(layers, desc = 'TMU', leave = False)]\n",
    "\n",
    "# Decode from the random network using single units\n",
    "RMU = [decode((acts_Rt[l], acts_Rv[l]), (train_lbls, valid_lbls), pipe, pop_size = 100, max_reps = 200) for l in tqdm(layers, desc = 'RMU', leave = False)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "tsu_mean_t, tsu_err_t = [tmp[1][0] for tmp in TSU], [tmp[2][0] for tmp in TSU]\n",
    "tsu_mean_v, tsu_err_v = [tmp[1][1] for tmp in TSU], [tmp[2][1] for tmp in TSU]\n",
    "\n",
    "rsu_mean_t, rsu_err_t = [tmp[1][0] for tmp in RSU], [tmp[2][0] for tmp in RSU]\n",
    "rsu_mean_v, rsu_err_v = [tmp[1][1] for tmp in RSU], [tmp[2][1] for tmp in RSU]\n",
    "\n",
    "tmu_mean_t, tmu_err_t = [tmp[1][0] for tmp in TMU], [tmp[2][0] for tmp in TMU]\n",
    "tmu_mean_v, tmu_err_v = [tmp[1][1] for tmp in TMU], [tmp[2][1] for tmp in TMU]\n",
    "\n",
    "rmu_mean_t, rmu_err_t = [tmp[1][0] for tmp in RMU], [tmp[2][0] for tmp in RMU]\n",
    "rmu_mean_v, rmu_err_v = [tmp[1][1] for tmp in RMU], [tmp[2][1] for tmp in RMU]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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//EPHDiQXr16OT9/8cUX1K5dG71eT+3atZk1a1aBcxZC8MMPP2Rbdn2YRHh4OAD9+vVDCOH8nFcIRGH7FkIwc+ZM+vXrh9FoJCIigkWLFqFQKPItKZm17rZg6NChrF+/nk8++QQhBEII5s+fjxCC33//nZYtW6LX61mxYgXHjx+nd+/ehISEYDQaad68OcuWLctmL2cIRHh4OO+88w6PP/44Pj4+VK1alQ8++CDbNklJSYwePZrg4GC8vb3p2LEjO3bsyDbmyy+/pEaNGnh6enLfffdx6VLOflAKRcEY3ASV/TS89pAvYf5aAGKO/EXD6JHEHNkEQFiAltce8iXYV4NdQp8oD56935sXH/TmtYd8eOthH2oE6WgSrifYV/Dig9552nnpQW9C/DW0bWDg3UH+fDDEn/cG+/F/j/kR5OPYd1R9A1H1DIT4awq10yTcQElRHmAXMmfOHB566CEaNmyY53qdTsfbb7/NI488wnPPPYdG4/r7j1dffZXPPvuMqVOn0qFDB2JjY/nnn39ITU3lnnvuoWXLlmzbto34+HhGjRrF8OHD+fHHH53bb9y4kdDQUFatWsXZs2fp378/devW5ZVXXqFfv348/fTTrFy5knvvvReAlJQUlixZwrx58wD4+eefGTt2LNOmTaNbt26sWLGCMWPGEBISwv33339Dx7R9+3aCg4OZNWsW9913H1qtNs9xRd33xIkT+b//+z8mTZrEnDlzGD58OB06dKB69ep52lUobhO24Gg05C6lzMhc1hW4AJxy1U6+2ZTK2Thb4QNdSLVKWh5pZyzS2BkzZnDkyBHq16/Pu+++C8D+/fsBeOmll5gyZQq1a9fG29ubCxcu0L17d9555x08PDz49ttv6dOnD3v37qV+/fr57mPatGlMmDCBF154geXLl/P000/Trl07oqKikFLSs2dPfH19WbZsGQEBASxYsIDOnTtz+PBhQkND2bp1K0OHDuXtt9+mX79+rF27lldffTXf/SkUObHYJF2692Pjyh+zLffwqUzXxxdy5O9vmP2fQAAmZq57sG8/fvrhu1y2+jzUn59//L5AO7P/c23dzbZTVJQAdiErVqzgjTfeKHDMXXfdhd1u59ixY9StW9el+09JSWHatGlMnz6d4cOHA1C7dm2ioqKYNWsWqampLFy4EG9vx53VzJkz6dSpE8eOHaN27doA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+eSTjB8/nqCgINq2bcvUqVNp0qQJRqORKlWqMHLkSBITE53bzJ8/Hy8vL1avXk2jRo0wGo106tSJkydPZrP9/vvvExISgpeXF4MHDyYlJSXbervdzttvv021atUwGAw0btyYJUuWONefOnUKIQTffPMNHTt2xMPDg2bNmrF3717+/fdf2rRpg9FopF27drn2rcif+BQ7k39JZu0+E13vcGdoZ+OtntJNIfaqjYPnrLRrYChSybaKjEqCcxFz5sxh3LhxVKpUidDQUAAeeOABqlevzjPPPMPLL7/MrFmzMJlMHDlyhEaNGrFv3z6X7X/GjBnUqFGDuXPnsn37drRaLf369SuRzX79+vHMM8+wZMkS+vfvDzhE5c8//8zXX3+d73ZDhgxh48aNzJgxg2bNmnH69GnOnj0LwPnz5+nevTuPPfYY8+fP5/jx44wcORKNRsOUKVOcNhYvXswzzzzD5s2b2b17NwMHDqRFixYMGDDAOWbatGlMmDCBF154geXLl/P000/Trl07oqKikFLSs2dPfH19WbZsGQEBASxYsIDOnTtz+PBhQkND2bNnD506deKxxx5j6tSpGAwGNmzYgNVqZcaMGRw5coT69evz7rvvAhAUFERMTAwdOnRgxIgRTJ48GYvFwmuvvUbv3r3ZsmWL8zhmzZrFrFmzaNKkCZ988gmLFy+mefPmJfp9KBQVgXVH1hGbHFuq+wzyDiK6bnSxtlm0aBGjR49m48aNSClZsWIF06dPJyIigtOnT/PUU0/x1FNPsXDhQuc2JpOJSZMmMXfuXNzd3RkyZAhPPPEEK1asAOC7777j9ddf56OPPqJTp058//33vPfeewQEBDhtzJgxgw8++IDPP/+cO++8k0WLFtGnTx927txJ06ZNnePefPNNpk2bRkREBE8++SQDBgwgODiY//3vfwQHBzNkyBCefvppli5dWqLv7lZjtUnsEkfS2RUbVQO11K/qhsaFSWeXEm289/NVzBbJ4928uLN2xX16uumgCSGgbf2Ke4xFRQlgF/H000/j6enJq6++ytNPP82IESOcMUM9evSgR48eHDp0iAEDBtCnTx9mzZrl0v37+vri7e2NVqslJCTEJTY9PDx49NFHmTt3rlMAf/XVV/j4+NCzZ888tzl69CjffPMNy5cv59577wUgIiLCuf7TTz8lLCyMTz/9FI1GQ4MG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",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update ({'font.size' : 14, \"text.usetex\": False})\n",
    "\n",
    "tmp = list(range(len(layers)))\n",
    "\n",
    "tt_par = {'color' : 'cornflowerblue', 'capsize' : 5, 'mec' : 'w', 'mfc' : 'cornflowerblue'}\n",
    "rt_par = {'color' : 'darkseagreen', 'capsize' : 5, 'mec' : 'w', 'mfc' : 'darkseagreen'}\n",
    "\n",
    "tv_par = {'color' : 'cornflowerblue', 'capsize' : 5, 'mec' : 'k', 'mfc' : 'cornflowerblue'}\n",
    "rv_par = {'color' : 'darkseagreen', 'capsize' : 5, 'mec' : 'k', 'mfc' : 'darkseagreen'}\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(ncols = 2, figsize = (10, 4))\n",
    "\n",
    "# * Single-unit decoding analysis\n",
    "axes[0].plot(tmp, rsu_mean_t, c = 'darkseagreen', ls = '--')\n",
    "axes[0].errorbar(tmp[:-3], rsu_mean_t[:-3], rsu_err_t[:-3], fmt = 'o', ms = 9, **rt_par)\n",
    "axes[0].errorbar(tmp[-3:], rsu_mean_t[-3:], rsu_err_t[-3:], fmt = '*', ms = 15, **rt_par)\n",
    "\n",
    "axes[0].plot(tmp, tsu_mean_t, c = 'cornflowerblue', ls = '--')\n",
    "axes[0].errorbar(tmp[:-3], tsu_mean_t[:-3], tsu_err_t[:-3], fmt = 'o', ms = 9, **tt_par)\n",
    "axes[0].errorbar(tmp[-3:], tsu_mean_t[-3:], tsu_err_t[-3:], fmt = '*', ms = 15, **tt_par)\n",
    "\n",
    "axes[0].plot(tmp, rsu_mean_v, c = 'darkseagreen')\n",
    "axes[0].errorbar(tmp[:-3], rsu_mean_v[:-3], rsu_err_v[:-3], fmt = 'o', ms = 8, **rv_par)\n",
    "axes[0].errorbar(tmp[-3:], rsu_mean_v[-3:], rsu_err_v[-3:], fmt = '*', ms = 13, **rv_par)\n",
    "\n",
    "axes[0].plot(tmp, tsu_mean_v, c = 'cornflowerblue')\n",
    "axes[0].errorbar(tmp[:-3], tsu_mean_v[:-3], tsu_err_v[:-3], fmt = 'o', ms = 8, **tv_par)\n",
    "axes[0].errorbar(tmp[-3:], tsu_mean_v[-3:], tsu_err_v[-3:], fmt = '*', ms = 13, **tv_par)\n",
    "\n",
    "\n",
    "# * Multi-unit decoding analysis\n",
    "axes[1].plot(tmp, tmu_mean_t, c = 'cornflowerblue', ls = '--')\n",
    "axes[1].errorbar(tmp[:-3], tmu_mean_t[:-3], tmu_err_t[:-3], fmt = 'o', ms = 9, **tt_par)\n",
    "axes[1].errorbar(tmp[-3:], tmu_mean_t[-3:], tmu_err_t[-3:], fmt = '*', ms = 15, **tt_par)\n",
    "\n",
    "axes[1].plot(tmp, rmu_mean_t, c = 'darkseagreen', ls = '--')\n",
    "axes[1].errorbar(tmp[:-3], rmu_mean_t[:-3], rmu_err_t[:-3], fmt = 'o', ms = 9, **rt_par)\n",
    "axes[1].errorbar(tmp[-3:], rmu_mean_t[-3:], rmu_err_t[-3:], fmt = '*', ms = 15, **rt_par)\n",
    "\n",
    "axes[1].plot(tmp, tmu_mean_v, c = 'cornflowerblue')\n",
    "axes[1].errorbar(tmp[:-3], tmu_mean_v[:-3], tmu_err_v[:-3], fmt = 'o', ms = 8, **tv_par)\n",
    "axes[1].errorbar(tmp[-3:], tmu_mean_v[-3:], tmu_err_v[-3:], fmt = '*', ms = 13, **tv_par)\n",
    "\n",
    "axes[1].plot(tmp, rmu_mean_v, c = 'darkseagreen')\n",
    "axes[1].errorbar(tmp[:-3], rmu_mean_v[:-3], rmu_err_v[:-3], fmt = 'o', ms = 8, **rv_par)\n",
    "axes[1].errorbar(tmp[-3:], rmu_mean_v[-3:], rmu_err_v[-3:], fmt = '*', ms = 13, **rv_par)\n",
    "\n",
    "for ax in axes:\n",
    "    ax.axhline(1 / n_cls, c = 'firebrick')\n",
    "\n",
    "    l1, = ax.plot([-2, -1], [-2, -1], c = 'k', ls = '--')\n",
    "    l2, = ax.plot([-2, -1], [-2, -1], c = 'k', ls = '-')\n",
    "    l3, = ax.plot([-2, -1], [-2, -1], c = 'cornflowerblue')\n",
    "    l4, = ax.plot([-2, -1], [-2, -1], c = 'darkseagreen')\n",
    "    m1 = ax.scatter([-1], [-1], marker = 'o', s = 100, fc = 'none', ec = 'k')\n",
    "    m2 = ax.scatter([-1], [-1], marker = '*', s = 150, fc = 'none', ec = 'k')\n",
    "\n",
    "    ax.set_xlim(left = -0.5)\n",
    "    ax.set_ylim(bottom = 0.075)\n",
    "\n",
    "    ax.set_xticks(tmp)\n",
    "    ax.set_xticklabels([])\n",
    "\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    ax.spines['bottom'].set_bounds(0., 15)\n",
    "\n",
    "    ax.set_xlabel('layers')\n",
    "    ax.xaxis.set_tick_params(width = 1.5)\n",
    "    ax.yaxis.set_tick_params(width = 1.5)\n",
    "    for s in ax.spines.values(): s.set_linewidth(1.5)\n",
    "\n",
    "axes[0].set_ylim(bottom = 0.09, top = .3)\n",
    "axes[0].set_yticks([0.1, 0.15, 0.2, 0.25, 0.3])\n",
    "\n",
    "axes[1].set_ylim(top = 1.03)\n",
    "axes[1].set_yticks([0.1, 0.2, 0.4, 0.6, 0.8, 1.])\n",
    "\n",
    "axes[1].text(5, 1 / n_cls + 0.02, 'random baseline')\n",
    "\n",
    "axes[0].spines['left'].set_bounds(0.1, .3)\n",
    "axes[1].spines['left'].set_bounds(0.1, 1.)\n",
    "\n",
    "axes[0].set_ylabel('accuracy')\n",
    "\n",
    "lgd1 = axes[0].legend((l1, l2), ('trainset', 'validation'), frameon = False, loc = (0.02, 0.6))\n",
    "lgd2 = axes[0].legend((m1, m2), ('convolution', 'fully-connected'), frameon = False, loc = (0.02, 0.8))\n",
    "lgd3 = axes[1].legend((l3, l4), ('trained', 'random'), frameon = False, loc = (0.02, 0.8))\n",
    "axes[0].add_artist(lgd1)\n",
    "\n",
    "fig.savefig('results/Identity_Decoding.png', dpi = 300)\n",
    "fig.savefig('results/Identity_Decoding.pdf', dpi = 300)\n",
    "fig.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "storepath = f'path_where_to_store/Experiment.pkl'\n",
    "\n",
    "with open(storepath, 'wb') as f:\n",
    "    desc =\\\n",
    "        '''\n",
    "            This data bundle contains data on the Decoding Experiment from\n",
    "            VGG-16 on 10 ImageNet random classes. It contains decoding\n",
    "            performances both from a single-unit level and at population\n",
    "            level. The data contains four sub-bundles:\n",
    "            - TSU = Trained (VGG-16) Single Unit (decoding)\n",
    "            - TMU = Trained (VGG-16) Multi Unit (decoding)\n",
    "            - RSU = Random (VGG-16) Single Unit (decoding)\n",
    "            - RMU = Random (VGG-16) Multi Unit (decoding)\n",
    "        '''\n",
    "\n",
    "    bundle = {\n",
    "        'desc' : desc,\n",
    "\n",
    "        'TSU' : TSU,\n",
    "        'TMU' : TMU,\n",
    "        'RSU' : RSU,\n",
    "        'RMU' : RMU\n",
    "    }\n",
    "\n",
    "    pickle.dump(bundle, f)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "d463e5fc653bab9d8e4f24359b8c55f1b66bd68a84a58e4a6e27c30ef7709220"
  },
  "kernelspec": {
   "display_name": "Python 3.8.10 64-bit ('SISSA': venv)",
   "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.8.10"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
