{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "87afa1c4",
   "metadata": {},
   "source": [
    "## DEMO ResNet "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d5c2a19d",
   "metadata": {},
   "source": [
    "We recommend starting with the notebook MLP in the directori DEMO/MLP/."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4482c398",
   "metadata": {},
   "source": [
    "So far the convolutional layers on which the neurons are added, have to be : \n",
    "* kernel_size = 3 \n",
    "* ((padding = 1, , stride = 1) or (padding = 'same')) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "fd9ce658",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../TINY/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "76237807",
   "metadata": {},
   "outputs": [],
   "source": [
    "import TINY\n",
    "import UTILS\n",
    "import SOLVE_EB as EB\n",
    "import GLOBALS as G\n",
    "from mes_imports import *\n",
    "import load_data_Loader\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cfb788a4",
   "metadata": {},
   "source": [
    "## Starting architecture"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1188ea0f",
   "metadata": {},
   "source": [
    "A skip connection is defined by a couple $(i_{in}, i_{out})$ and a transformation skip_fct[$i_{in}$].\n",
    "It transforms the activity of layer $i_{in}$ with the function skip_fct[$i_{in}$] and adds it the the pre-activation of layer $i_{out} + 1$.\n",
    "\n",
    "Currently multiple skip connections starting from $i_{in}$ is not supported.\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "49c746a2-72f9-4144-9f28-9e96ed35048a",
   "metadata": {},
   "outputs": [],
   "source": [
    "G.reduction = 64\n",
    "G.rescale = 'theta' \n",
    "G.lr = 1e-2\n",
    "G.batch_size = 32\n",
    "G.architecture_growth = 'Our' \n",
    "G.lambda_method = 1e-3\n",
    "#nbr_epochs_betw_adding = 0.25\n",
    "nbr_step = 100\n",
    "from settings import starting_architecture_RN18 as starting_architecture"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6445f52a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "skip connection between layer 2  and  3\n",
      "skip connection between layer 4  and  5\n",
      "skip connection between layer 7  and  8\n",
      "skip connection between layer 9  and  10\n",
      "skip connection between layer 12  and  13\n",
      "skip connection between layer 14  and  15\n",
      "skip connection between layer 17  and  18\n",
      "skip connection between layer 19  and  20\n"
     ]
    }
   ],
   "source": [
    "skip_connections = starting_architecture.skip_connections_RN18\n",
    "for (i, j) in zip(skip_connections['in'], skip_connections['out']) :\n",
    "    print('skip connection between layer', i, ' and ', j)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "45493301",
   "metadata": {},
   "source": [
    "The transformation computed by each skip connection is described with the dictionnary skip_fct with its keys {$i_{in}$ for $i_{in} \\ in$ skip_connections['in']}. \n",
    "\n",
    "If the key $i_{in}$ doesn't existst, the identity will performed as the default transformation. In this notebook we choose the identity for all the skip connections,  so the dictionnary skip_fct is empty."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a3fdf352",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys([])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "skip_fct = starting_architecture.skip_fct_RN18\n",
    "skip_fct.keys()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e20e8959",
   "metadata": {},
   "source": [
    "We start with an architecture such that each layer between a skip connection is of size 1/64 the usual size of ResNet18."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5c1dc641",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Reduction is : 64\n",
      "depth  |  layer type | in_chan->out_chan / output size\n",
      "depth 1 |  Conv | 3 -> 64\n",
      "depth 2 |  Conv | 64 -> 1\n",
      "depth 3 |  Conv | 1 -> 64\n",
      "depth 4 |  Conv | 64 -> 1\n",
      "depth 5 |  Conv | 1 -> 64\n",
      "depth 6 |  Conv | 64 -> 128\n",
      "depth 7 |  Conv | 128 -> 2\n",
      "depth 8 |  Conv | 2 -> 128\n",
      "depth 9 |  Conv | 128 -> 2\n",
      "depth 10 |  Conv | 2 -> 128\n",
      "depth 11 |  Conv | 128 -> 256\n",
      "depth 12 |  Conv | 256 -> 4\n",
      "depth 13 |  Conv | 4 -> 256\n",
      "depth 14 |  Conv | 256 -> 4\n",
      "depth 15 |  Conv | 4 -> 256\n",
      "depth 16 |  Conv | 256 -> 512\n",
      "depth 17 |  Conv | 512 -> 8\n",
      "depth 18 |  Conv | 8 -> 512\n",
      "depth 19 |  Conv | 512 -> 8\n",
      "depth 20 |  Conv | 8 -> 512\n",
      "depth 21 | Linear | 100\n"
     ]
    }
   ],
   "source": [
    "skeleton = starting_architecture.skeleton_RN18\n",
    "layer_name = starting_architecture.layer_name_RN18\n",
    "\n",
    "print('Reduction is :', G.reduction)\n",
    "print('depth  |  layer type | in_chan->out_chan / output size')\n",
    "for k in sorted(list(skeleton.keys()))[1:] :\n",
    "    if layer_name[k][0] == 'C' :\n",
    "        print('depth ' + str(k) + ' |  Conv | ' + str(skeleton[k]['in_channels']) + ' -> ' + str(skeleton[k]['out_channels']))\n",
    "        #print('depth ' + str(k) + ' |  Conv | ' + str(RN.outputs_size_after_activation[k]))\n",
    "    else :\n",
    "        print('depth ' + str(k) + ' | Linear | ' + str(skeleton[k]['size']))\n",
    "        #print('depth ' + str(k) + ' | Linear | ' + str(RN.outputs_size_after_activation[k]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "56c55fb3",
   "metadata": {},
   "source": [
    "The activitation functions are stored in fct."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ce1276a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "fct_ 1  :=  ReLU()\n",
      "fct_ 2  :=  ReLU()\n",
      "fct_ 3  :=  ReLU()\n",
      "fct_ 4  :=  ReLU()\n",
      "fct_ 5  :=  ReLU()\n",
      "fct_ 6  :=  AvgPool2d(kernel_size=(2, 2), stride=(2, 2), padding=(0, 0))\n",
      "fct_ 7  :=  ReLU()\n",
      "fct_ 8  :=  ReLU()\n",
      "fct_ 9  :=  ReLU()\n",
      "fct_ 10  :=  ReLU()\n",
      "fct_ 11  :=  AvgPool2d(kernel_size=(2, 2), stride=(2, 2), padding=(0, 0))\n",
      "fct_ 12  :=  ReLU()\n",
      "fct_ 13  :=  ReLU()\n",
      "fct_ 14  :=  ReLU()\n",
      "fct_ 15  :=  ReLU()\n",
      "fct_ 16  :=  AvgPool2d(kernel_size=(2, 2), stride=(2, 2), padding=(0, 0))\n",
      "fct_ 17  :=  ReLU()\n",
      "fct_ 18  :=  ReLU()\n",
      "fct_ 19  :=  ReLU()\n",
      "fct_ 20  :=  AdaptiveAvgPool2d(output_size=(1, 1))\n",
      "fct_ 21  :=  Identity()\n"
     ]
    }
   ],
   "source": [
    "fct = starting_architecture.fct_RN18\n",
    "for k in sorted(list(fct.keys())) :\n",
    "    print('fct_', k, ' := ', fct[k])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2dc7623b",
   "metadata": {},
   "outputs": [],
   "source": [
    "a, b, c, d = starting_architecture.a, starting_architecture.b, starting_architecture.c, starting_architecture.d\n",
    "a0, b0, c0, d0 = starting_architecture.a0, starting_architecture.b0, starting_architecture.c0, starting_architecture.d0\n",
    "ainf, binf, cinf, dinf = starting_architecture.ainf, starting_architecture.binf, starting_architecture.cinf, starting_architecture.dinf\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "68e4c84a-9940-4cf6-8ecc-9b8b0a9a6441",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "architecture growth from  (1, 2, 4, 8) to (64, 128, 256, 512)\n"
     ]
    }
   ],
   "source": [
    "print('architecture growth from ', (a0, b0, c0, d0) , 'to', (a, b, c, d))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b631a833",
   "metadata": {},
   "source": [
    "## The adding strategy"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f3440062",
   "metadata": {},
   "source": [
    "In this notebook the startegy is to add neurons at each layer until it reachs the architecture of the usual RN18. The amount of neurons to add at each depth to achieve this results is in the dictionnary to_add."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a9377ae5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{2: 63, 4: 63, 7: 126, 9: 126, 12: 252, 14: 252, 17: 504, 19: 504}"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "to_add = {2 : (ainf - a0), 4 : (ainf - a0), 7 : (binf - b0), 9 : (binf - b0), \n",
    "          12 : (cinf - c0), 14 : (cinf - c0), 17 : (dinf - d0), 19 : (dinf - d0)}\n",
    "to_add"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "73df8852",
   "metadata": {},
   "source": [
    "## The model RN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ee4eb095",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "After layer 1 : x.shape=torch.Size([1, 64, 32, 32])\n",
      "After layer 2 : x.shape=torch.Size([1, 1, 32, 32])\n",
      "After layer 3 : x.shape=torch.Size([1, 64, 32, 32])\n",
      "After layer 4 : x.shape=torch.Size([1, 1, 32, 32])\n",
      "After layer 5 : x.shape=torch.Size([1, 64, 32, 32])\n",
      "After layer 6 : x.shape=torch.Size([1, 128, 16, 16])\n",
      "After layer 7 : x.shape=torch.Size([1, 2, 16, 16])\n",
      "After layer 8 : x.shape=torch.Size([1, 128, 16, 16])\n",
      "After layer 9 : x.shape=torch.Size([1, 2, 16, 16])\n",
      "After layer 10 : x.shape=torch.Size([1, 128, 16, 16])\n",
      "After layer 11 : x.shape=torch.Size([1, 256, 8, 8])\n",
      "After layer 12 : x.shape=torch.Size([1, 4, 8, 8])\n",
      "After layer 13 : x.shape=torch.Size([1, 256, 8, 8])\n",
      "After layer 14 : x.shape=torch.Size([1, 4, 8, 8])\n",
      "After layer 15 : x.shape=torch.Size([1, 256, 8, 8])\n",
      "After layer 16 : x.shape=torch.Size([1, 512, 4, 4])\n",
      "After layer 17 : x.shape=torch.Size([1, 8, 4, 4])\n",
      "After layer 18 : x.shape=torch.Size([1, 512, 4, 4])\n",
      "After layer 19 : x.shape=torch.Size([1, 8, 4, 4])\n",
      "After layer 20 : x.shape=torch.Size([1, 512, 1, 1])\n",
      "After layer 21 : x.shape=torch.Size([1, 100])\n",
      "Time to build the model: 2.57 seconds\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "dico_parameters = {\n",
    "                    'skeleton' : copy.deepcopy(skeleton),\n",
    "                    'Loss' : UTILS.Loss_entropy,\n",
    "                    'fct' : fct,\n",
    "                    'layer_name' :layer_name,\n",
    "                    'init_deplacement' : 1e-8,\n",
    "                    'batch_size' : G.batch_size,\n",
    "                    'lr' : G.lr,\n",
    "                    'rescale' : G.rescale,\n",
    "                    'exp' : 2,\n",
    "                    'lambda_method' : G.lambda_method,\n",
    "                    'accroissement_decay' : 1e-8,\n",
    "                    'lu_conv' : 0.001,\n",
    "                    'max_batch_estimation' : 100,\n",
    "                    'max_amplitude' : 20.,\n",
    "                    'ind_lmbda_shape' : 1000,\n",
    "                    'init_X_shape' : [3, 32, 32],\n",
    "                    'skip_connections' : skip_connections,\n",
    "                    'skip_fcts' : skip_fct,\n",
    "                    'len_train_dataset' : 50000,\n",
    "                    'len_test_dataset' : 10000,\n",
    "                    'T_j_depth' : [d + 1for d in list(to_add.keys()) if layer_name[d][0] == 'C'],\n",
    "                    'selection_neuron' : UTILS.selection_neuron_seuil,\n",
    "                    'how_to_define_batchsize' : UTILS.indices_non_constant, \n",
    "                    'depth_seuil' : starting_architecture.depth_seuil,\n",
    "                    'architecture_growth' : G.architecture_growth\n",
    "                    }\n",
    "RN = TINY.TINY(dico_parameters)\n",
    "\n",
    "RN.training_data, RN.test_data = load_data_Loader.load_database_CIFAR100(AugD=True)\n",
    "RN.tr_loader = DataLoader(RN.training_data, batch_size=RN.max_batch_estimation, shuffle=True)\n",
    "RN.te_loader = DataLoader(RN.test_data, batch_size=RN.max_batch_estimation, shuffle=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fbcb40fe",
   "metadata": {},
   "source": [
    "The starting architecture is then :"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "d99a3d20",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "depth  |  layer type | output size\n",
      "depth 1 |  Conv | [32, 32, 64]\n",
      "depth 2 |  Conv | [32, 32, 1]\n",
      "depth 3 |  Conv | [32, 32, 64]\n",
      "depth 4 |  Conv | [32, 32, 1]\n",
      "depth 5 |  Conv | [32, 32, 64]\n",
      "depth 6 |  Conv | [16, 16, 128]\n",
      "depth 7 |  Conv | [16, 16, 2]\n",
      "depth 8 |  Conv | [16, 16, 128]\n",
      "depth 9 |  Conv | [16, 16, 2]\n",
      "depth 10 |  Conv | [16, 16, 128]\n",
      "depth 11 |  Conv | [8, 8, 256]\n",
      "depth 12 |  Conv | [8, 8, 4]\n",
      "depth 13 |  Conv | [8, 8, 256]\n",
      "depth 14 |  Conv | [8, 8, 4]\n",
      "depth 15 |  Conv | [8, 8, 256]\n",
      "depth 16 |  Conv | [4, 4, 512]\n",
      "depth 17 |  Conv | [4, 4, 8]\n",
      "depth 18 |  Conv | [4, 4, 512]\n",
      "depth 19 |  Conv | [4, 4, 8]\n",
      "depth 20 |  Conv | [1, 1, 512]\n",
      "depth 21 | Linear | [100]\n"
     ]
    }
   ],
   "source": [
    "print('depth  |  layer type | output size')\n",
    "for k in sorted(list(skeleton.keys()))[1:] :\n",
    "    if layer_name[k][0] == 'C' :\n",
    "        #print('depth ' + str(k) + ' |  Conv | ' + str(skeleton[k]['in_channels']) + ' -> ' + str(skeleton[k]['out_channels']))\n",
    "        print('depth ' + str(k) + ' |  Conv | ' + str(RN.outputs_size_after_activation[k]))\n",
    "    else :\n",
    "        #print('depth ' + str(k) + ' | Linear | ' + str(skeleton[k]['size']))\n",
    "        print('depth ' + str(k) + ' | Linear | ' + str(RN.outputs_size_after_activation[k]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "637718b6",
   "metadata": {},
   "source": [
    "## Architecture growth and training "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "674c0a43",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_tracker = pd.DataFrame()\n",
    "A_tr, A_te, L_tr, L_te, T = np.array([]), np.array([]), np.array([]), np.array([]), np.array([0])\n",
    "nbr_pass = 8\n",
    "\n",
    "path = 'results/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "988e5ffb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def update_quantity_of_interest() :\n",
    "        global L_tr, L_te, A_tr, A_te, T, df_tracker\n",
    "        dico_tracker = {'vps' + str(i) : [ RN.valeurs_propres[i].item()] for i in range(len(RN.valeurs_propres))}\n",
    "\n",
    "        dico_tracker.update({'depth_add' : best_depth, 'nbr_added_neuron': RN.nbr_added_neuron})\n",
    "        dico_tracker.update({'accroissement' : [dico_EB[best_depth]['accroissement']], 'portion_gain' : [dico_EB[best_depth]['portion_gain']],\n",
    "                            'nbr_parameters_apres' : [RN.count_parameters()], 'nbr_parameters_avant' : [nbr_parameters_avant],\n",
    "                            'T' : [T[-1]], 'len_L_tr' : [len(L_tr)], 'lu_conv' : [RN.lu_conv]})\n",
    "\n",
    "        df_tracker = pd.concat([df_tracker, pd.DataFrame.from_dict(dico_tracker)], ignore_index=True)\n",
    "\n",
    "        L_tr = np.concatenate([L_tr, l_tr])\n",
    "        L_te = np.concatenate([L_te, l_te])\n",
    "        A_tr = np.concatenate([A_tr, a_tr])\n",
    "        A_te = np.concatenate([A_te, a_te])\n",
    "        T = np.concatenate([T, t +  T[-1]])\n",
    "\n",
    "def stabilize_training() :\n",
    "    RN.batch_size = math.ceil(np.sqrt(RN.count_parameters() / nbr_parameters_avant) *  RN.batch_size)\n",
    "    #RN.batch_size = math.ceil(RN.count_parameters() / nbr_parameters_avant *  RN.batch_size)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "cd5379e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "count = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "12153913",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/json": {
       "ascii": false,
       "bar_format": null,
       "colour": null,
       "elapsed": 0.008527040481567383,
       "initial": 0,
       "n": 0,
       "ncols": null,
       "nrows": null,
       "postfix": null,
       "prefix": "",
       "rate": null,
       "total": 8,
       "unit": "it",
       "unit_divisor": 1000,
       "unit_scale": false
      },
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "722cdfcd5a674e288177a86d90483bac",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/8 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  5 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  4 ***\n",
      "Batch size for estimation : 1000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  4 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  8 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  7 ***\n",
      "Batch size for estimation : 1000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  7 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  10 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  9 ***\n",
      "Batch size for estimation : 1000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  9 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  13 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  12 ***\n",
      "Batch size for estimation : 1200\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  12 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  15 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  14 ***\n",
      "Batch size for estimation : 1200\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  14 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  18 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  17 ***\n",
      "Batch size for estimation : 32500\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  17 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  20 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  19 ***\n",
      "Batch size for estimation : 32500\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "***  normalize NewNeurons acc. ||parameters|| ***\n",
      "amplitude factor for the new neurons : 0.0010000000474974513\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  19 ***\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for pas in range(nbr_pass) :\n",
    "    size_to_add = len(to_add.keys())\n",
    "    #size_to_add = 1\n",
    "    for j in tqdm(range(size_to_add)) :\n",
    "        nbr_parameters_avant = RN.count_parameters()\n",
    "        k = list(to_add.keys())[j]\n",
    "        best_depth, dico_EB = k, {k : {'accroissement' : 0., 'portion_gain' : 0}}\n",
    "        RN.dico_w = None\n",
    "        RN.how_to_define_batchsize(RN, k + 1, method = 'NG')\n",
    "        EB.compute_optimal_update(RN, k + 1, update = False, compute_gain = False)\n",
    "        RN.how_to_define_batchsize(RN, k, method = 'Add')\n",
    "        EB.add_neurons(RN, k, update = True)\n",
    "        to_add[k] -= RN.alpha.shape[0] \n",
    "        \n",
    "        #### training loop ####\n",
    "        stabilize_training()\n",
    "        RN.tr_loader = iter(UTILS.cycle(DataLoader(RN.training_data, batch_size=RN.batch_size, shuffle=True)))\n",
    "        RN.te_loader = iter(UTILS.cycle(DataLoader(RN.test_data, batch_size=RN.batch_size, shuffle=True)))\n",
    "        optimizer = torch.optim.SGD(RN.parameters(), lr = RN.lr)\n",
    "        l_tr, l_te, l_va, a_tr, a_te, a_va, t = RN.train_batch(nbr_step = nbr_step, optimizer = optimizer)\n",
    "        del RN.tr_loader, RN.te_loader\n",
    "        update_quantity_of_interest()\n",
    "        \n",
    "\n",
    "        df_performance = pd.DataFrame.from_dict({'L_tr' : L_tr, 'L_te' : L_te, 'A_tr' : A_tr, 'A_te' : A_te, 'T' : T[1:]})\n",
    "        df_tracker.to_csv( path + 'df_tracker.csv' , index=False)\n",
    "        df_performance.to_csv( path + '/df_performance.csv', index=False)\n",
    "        RN.T = T[-1]\n",
    "        RN.len_L_tr = len(L_tr)\n",
    "\n",
    "    UTILS.save_model_to_file(RN, path = path + '/' , name='model_' + str(count))\n",
    "    count += 1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9dc2ec0e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "8813716e",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "52c01a99",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_tracker = pd.read_csv(path + 'df_tracker.csv')\n",
    "df_performance = pd.read_csv(path + 'df_performance.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "d454cece",
   "metadata": {},
   "outputs": [],
   "source": [
    "coef = 100 # smoothing coefficient \n",
    "kernel = torch.zeros(1, 1, coef)\n",
    "C = 10\n",
    "for i, t1 in enumerate(torch.linspace(-C, C, coef)[:int(coef/2) + 1]) :\n",
    "    t2 = t1 + 2*C/(coef/2)\n",
    "    #if t1 <= 0 :\n",
    "    h = torch.distributions.normal.Normal(0, 1).cdf(t2) - torch.distributions.normal.Normal(0, 1).cdf(t1)\n",
    "    kernel[0, 0, i] = h\n",
    "kernel /= kernel.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "6aaf892a",
   "metadata": {},
   "outputs": [],
   "source": [
    "A_tr_padd = torch.concatenate([torch.ones(int(coef/2)) * df_performance['A_tr'][:5].mean(), \n",
    "                               torch.from_numpy(df_performance['A_tr'].values.astype(np.float32)),\n",
    "                               torch.ones(int(coef/2)) * df_performance['A_tr'][-5:].mean()])\n",
    "A_te_padd = torch.concatenate([torch.ones(int(coef/2)) * df_performance['A_te'][:5].mean(), \n",
    "                               torch.from_numpy(df_performance['A_te'].values.astype(np.float32)),\n",
    "                               torch.ones(int(coef/2)) * df_performance['A_te'][-5:].mean()])\n",
    "smooth_A_tr = torch.nn.functional.conv1d(A_tr_padd[None, None, :], kernel, padding = 0)\n",
    "smooth_A_te = torch.nn.functional.conv1d(A_te_padd[None, None, :], kernel, padding = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "99ff7825",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1)\n",
    "ax.plot(smooth_A_tr[0, 0], label = 'A_tr')\n",
    "ax.plot(smooth_A_te[0, 0], label = 'A_te')\n",
    "\n",
    "ax.legend()\n",
    "ax_nbrp = ax.twinx()\n",
    "ax_nbrp.plot(df_tracker['len_L_tr'], df_tracker['nbr_parameters_apres'], '+', label = 'nbr_parameters', color = 'black')\n",
    "ax_nbrp.legend(loc = 'lower right')\n",
    "ax.set_title('Acc / nbr of parameters')\n",
    "ax.set_ylabel('Acc')\n",
    "ax_nbrp.set_ylabel('nbr of parameters')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "e45d9d4c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6KD5jA6dOON0XDJmw8aWWq3X3b0bfa8A0Bxeh5v3339fCxcudDl+7bXX6q9//avH1yktLVVNTY3i4uKcjsfFxamkpKTB5/bu3VsnTpzQuXPn9NBDDzkqP+5kZ2dr0aJFHrcLbZO7Lp8V7x50ehysGzayOSWAYON1uDlz5ozCwsJcjnfo0KFJVZHa+1RJto046x6ra/v27Tpz5ow++ugjzZs3TwMGDNCdd97p9tz58+crKyvL8dhisSg+Pt7rdiK4uevymXXVAPU3ddKhE2e0YuvBgOoC8uVqvXR3AQg2Xoeb5ORk5eTk6E9/+pPT8fXr12vIkCEeXyc2NlahoaEuVRqz2exSzanLvojgsGHDdPz4cT300EP1hpvw8HCFh/PHGQ1z1+UzKbm7kntFa29RmVZsPRhQGzb6chdvNqcEEGy8DjcPPvigbrvtNh06dEhXX321JGnLli1at26dx+NtJNusq5SUFOXm5uqWW25xHM/NzdXNN9/s8XWsVqvTmBoAANC2eR1ubrrpJr3++ut65JFH9M9//lMdO3bU8OHD9e9//1tXXHGFV9fKysrStGnTlJqaqvT0dK1evVoFBQWaOXOmJFuXUlFRkV588UVJ0pNPPqk+ffooKSlJkm3dm7/+9a+aNWuWt7cB1Ktul09b2rCxLd0rgOAVYrVarb662O7duzVixAivnrNy5Uo99thjKi4uVnJyspYuXarx48dLkn72s5/pyJEjeu+99yRJK1as0FNPPaXDhw+rffv26t+/v375y1/q7rvvVrt2nq1HaLFYFB0drbKyMkVFRXnVVgAAYAxvPr+bHW7Kysq0du1aPfPMM/r8889VU1PTnMu1OMINAACtjzef315vv2C3detWTZ06VT169NCKFSt03XXX6dNPP23q5QAAAHzCqzE33377rZ5//nmtWbNGFRUVuv3223X27Flt2LDBq5lSAAAALcXjys11112nIUOGaN++fVqxYoWOHTumFStWtGTbAAAAvOZx5eadd97R7Nmz9etf/7rZe0oBAAC0FI8rN9u3b1d5eblSU1OVlpamv//97zpx4kRLtg0AAMBrHoeb9PR0Pf300youLtbdd9+t9evXq1evXjp//rxyc3NVXl7eku0EAADwSLOmgn/11Vd69tln9dJLL+m7775TRkaG3njjDV+2z+eYCg4AQOvjl6ngknTJJZfoscce07fffqt169Y151IAAAA+4dMVilsDKjcAALQ+fqvcAAAABBrCDQAACCqEGwAAEFQINwAAIKgQbgAAQFAh3AAAgKBCuAEAAEGFcAMAAIIK4QYAAAQVwg0AAAgqhBsAABBUCDcAACCoEG78zGyp1NLcAzJbKo1uCgAAQYlw42fm8iot3/K1zOVVRjcFAICgRLgB3GhrFba2dr8Aghvhxg/MlkrtLSpzfElyeswHSuBpaxW2tna/AIJbe6Mb0Bas3Vmg5Vu+djo2b+Mex7/nTBio+zMG+btZAAAEJcKNH0xN66OMIXGSbBWbeRv36NFbhym5V7QkydQ53Mjm4QdmS6WjclG7wmZn6hwuU1SEIW1rCW3tfgG0HYQbPzBFRbh8SCT3inaEGwSGtlZha2v3C6DtINwAP2hrFba2dr8A2g7CjZ+ZOodrzoSBfHAEoLZWYWtr9wug7SDc+JkpKoJSPwAALYip4IAbba3C1tbuF0BwC7FarVajG+FPFotF0dHRKisrU1RUlNHNAQAAHvDm85vKDQAACCqGh5uVK1cqMTFRERERSklJ0fbt2+s9d+PGjcrIyFC3bt0UFRWl9PR0bd682Y+tBQAAgc7QcJOTk6O5c+dqwYIFys/P17hx45SZmamCggK352/btk0ZGRnatGmTdu3apauuuko33nij8vPz/dxyAAAQqAwdc5OWlqbLLrtMq1atchwbPHiwJk+erOzsbI+uMXToUE2ZMkV/+tOfPDqfMTcAALQ+rWLMTXV1tXbt2qWJEyc6HZ84caLy8vI8usb58+dVXl6umJiYes+pqqqSxWJx+gIAAMHLsHBTWlqqmpoaxcXFOR2Pi4tTSUmJR9d4/PHHVVFRodtvv73ec7KzsxUdHe34io+Pb1a7AQBAYDN8QHFISIjTY6vV6nLMnXXr1umhhx5STk6OTCZTvefNnz9fZWVljq/CwsJmtxkAAAQuw1Yojo2NVWhoqEuVxmw2u1Rz6srJydH06dP16quv6pprrmnw3PDwcIWHszAZvGe2VGrtzgJNTevD7tgA0IoYVrkJCwtTSkqKcnNznY7n5uZqzJgx9T5v3bp1+tnPfqZXXnlF119/fUs3E22YubxKy7d8LXN5ldFNAQB4wdC9pbKysjRt2jSlpqYqPT1dq1evVkFBgWbOnCnJ1qVUVFSkF198UZIt2PzkJz/R8uXLNXr0aEfVp2PHjoqOZrM/AABgcLiZMmWKTp48qcWLF6u4uFjJycnatGmTEhISJEnFxcVOa9489dRTOnfunO69917de++9juM//elP9fzzz/u7+QhCZkulo1Kzt6jM6btk24OJLioACGzsLQXUsjT3gJZv+bren8+ZMJBd3QHAAN58fhtauQECzdS0PsoYYhvQvreoTPM27tGjtw5Tci9btye7ZgNA4CPcALWYoiJcup2Se0U7wg0AIPAZvs4NAACALxFugHqYOodrzoSBdEUBQCtDuEFAMVsqtTT3gMyWSqObIlNUhO7PGMTsKABoZQg3CCgsnAcAaC7CDQAACCrMloLhWDgPAOBLhBsYbu3OApeF8+Zt3OP4NwvnAQC8QbiB4Vg4DwDgS4QbGI6F8wAAvsSAYgAAEFQINwgoLJwHAGguuqUQUOwL5wEA0FRUbgAAQFAh3AAAgKBCuAHqCKT9rQAA3iPcAHWwvxUAtG6EGwAAEFSYLQWI/a0AIJgQbgCxvxUABBPCDSD2twKAYEK4AcT+VgAQTBhQDAAAggrhBqiD/a0AoHWjWwqog/2tAKB1o3IDAACCCuEGAAAEFcINAAAIKoQbAAAQVAg3AAAgqBBuAABAUCHctAFmS6WW5h6Q2VJpdFMAAGhxhJs2wFxepeVbvnbseg0AQDAzPNysXLlSiYmJioiIUEpKirZv317vucXFxbrrrrt0ySWXqF27dpo7d67/GgoAAFoFQ8NNTk6O5s6dqwULFig/P1/jxo1TZmamCgoK3J5fVVWlbt26acGCBbr00kv93NrWxWyp1N6iMseXJKfHdFEBAIJViNVqtRr14mlpabrsssu0atUqx7HBgwdr8uTJys7ObvC5V155pUaMGKFly5Z59ZoWi0XR0dEqKytTVFRUU5rdKizNPaDlW76u9+dzJgxkiwEAQKvhzee3YXtLVVdXa9euXZo3b57T8YkTJyovL89nr1NVVaWqqgtjTSwWi8+uHcimpvVRxpA4SbaKzbyNe/TorcOU3CtaktgUEgAQtAwLN6WlpaqpqVFcXJzT8bi4OJWUlPjsdbKzs7Vo0SKfXa+1MEVFyBQV4XQsuVe0I9wAABCsDB9QHBIS4vTYarW6HGuO+fPnq6yszPFVWFjos2t7gmnYAAD4l2GVm9jYWIWGhrpUacxms0s1pznCw8MVHm5cF4x9GnbGkDiXSoq/mDqHa86EgXRFAQDaBMMqN2FhYUpJSVFubq7T8dzcXI0ZM8agVgUnU1SE7s8YZFi4AgDAnwyr3EhSVlaWpk2bptTUVKWnp2v16tUqKCjQzJkzJdm6lIqKivTiiy86nrN7925J0pkzZ3TixAnt3r1bYWFhGjJkiBG34JbZUulYMK/2NGw7U+dwggYAAC3E0HAzZcoUnTx5UosXL1ZxcbGSk5O1adMmJSQkSLIt2ld3zZuRI0c6/r1r1y698sorSkhI0JEjR/zZ9Aat3VngMg173sY9jn8zDRsAgJZj6Do3RvDHOjd1KzfupmFTuQEAwHOtYp2bYMY0bAAAjGP4VHAAAABfIty0MKZhAwDgX3RLtTD7NGwAAOAfVG4AAEBQIdwAAICgQrgBAABBhXADAACCCuEGAAAEFcJNK2K2VGpp7gGZLZVGNwUAgIBFuGlFzOVVWr7la8fWDgAAwBXhBgAABBUW8QtwdTfhrP1dYhNOAADqItwEuLU7C7R8y9dOx+Zt3OP495wJA1kBGQCAWgg3AW5qWh9lDImTZKvYzNu4R4/eOsyxwzh7VgEA4IxwE+BMUREu3U7JvaId4QYAADhjQDEAAAgqhJtWxNQ5XHMmDKQrCgCABtAt1YqYoiIYPAwAQCOo3AAAgKBCuAEAAEGFcAMAAIIK4QYAAAQVwg0AAAgqhBsAABBUCDcAACCoEG4AAEBQIdwAAICgQrgBAABBhXADAACCCuEGAAAEFcKND5ktlVqae0BmS6XRTQEAoM0i3PiQubxKy7d8LXN5ldFNAQCgzTI83KxcuVKJiYmKiIhQSkqKtm/f3uD577//vlJSUhQREaF+/frpH//4h59a6rm1O49SvQEAwCCGhpucnBzNnTtXCxYsUH5+vsaNG6fMzEwVFBS4Pf/w4cO67rrrNG7cOOXn5+uBBx7Q7NmztWHDBj+3/AKzpVJ7i8ocX5K07uNC5R06qb1FZYQcAAD8LMRqtVqNevG0tDRddtllWrVqlePY4MGDNXnyZGVnZ7uc/4c//EFvvPGGvvzyS8exmTNn6vPPP9eOHTs8ek2LxaLo6GiVlZUpKiqq2fewNPeAlm/5ut6fz5kwUPdnDGr26wAA0JZ58/nd3k9tclFdXa1du3Zp3rx5TscnTpyovLw8t8/ZsWOHJk6c6HRs0qRJevbZZ3X27Fl16NDB5TlVVVWqqrowBsZisfig9RdMTeujlIQuOlVRrUPmM1rx7kFJ0qyrB6h/t06Kiewgs6VSpqgIn74uAABwz7BwU1paqpqaGsXFxTkdj4uLU0lJidvnlJSUuD3/3LlzKi0tVY8ePVyek52drUWLFvmu4XWYoiK0dmeBS/VmxdaDjn9TvQEAwH8MCzd2ISEhTo+tVqvLscbOd3fcbv78+crKynI8tlgsio+Pb2pz3Zqa1kcZQ+J00HxGc3N2S5IevXWYkntFS5JMncN9+noAAKB+hoWb2NhYhYaGulRpzGazS3XGrnv37m7Pb9++vbp27er2OeHh4QoPb9lwYYqKsH11Dtedo+K17pNCJfeKdoQbAADgP4bNlgoLC1NKSopyc3Odjufm5mrMmDFun5Oenu5y/jvvvKPU1FS34238zRQVoamjE4xuBgAAbZqhU8GzsrL0zDPPaM2aNfryyy91//33q6CgQDNnzpRk61L6yU9+4jh/5syZOnr0qLKysvTll19qzZo1evbZZ/Xb3/7WqFtwYeocrjkTBtIVBQCAQQwdczNlyhSdPHlSixcvVnFxsZKTk7Vp0yYlJNiqH8XFxU5r3iQmJmrTpk26//779eSTT6pnz57629/+pttuu82oW3Bhiopg8DAAAAYydJ0bI/h6nRsAANDyvPn8Nnz7BQAAAF8i3AAAgKBCuAEAAEGFcAMAAIIK4QYAAAQVwg0AAAgqhBsAABBUCDcAACCoEG4AAEBQMXT7BSPYF2S2WCwGtwQAAHjK/rntycYKbS7clJeXS5Li4+MNbgkAAPBWeXm5oqOjGzynze0tdf78eR07dkydO3dWSEiIR88ZNWqUPvnkkxZumf9ftyWu76trNuc6TXmuxWJRfHy8CgsL2XPMj4z631ZLC9T74m+Z/6/J3zLfsVqtKi8vV8+ePdWuXcOjatpc5aZdu3bq3bu3V88JDQ015D+Sln7dlri+r67ZnOs057lRUVFB9wchkBn1v62WFqj3xd8y/1+Tv2W+1VjFxo4BxR649957g/J1W+L6vrpmc65j1O8L3gvW31Wg3hd/y/x/Tf6WGaPNdUsB7lgsFkVHR6usrCwo/98OgLaBv2U2VG4ASeHh4Vq4cKHCw8ONbgoANBl/y2yo3AAAgKBC5QYAAAQVwg0AAAgqhBsAABBUCDcAACCoEG4AAEBQIdwAHjh8+LCuuuoqDRkyRMOGDVNFRYXRTQIAr3z11VcaMWKE46tjx456/fXXjW5Wi2AqOOCBK664QkuWLNG4ceN06tQpRUVFqX37Nrd7CYAgcebMGfXt21dHjx5VZGSk0c3xOf46A4344osv1KFDB40bN06SFBMTY3CLAKB53njjDU2YMCEog41EtxTagG3btunGG29Uz549FRIS4rYMu3LlSiUmJioiIkIpKSnavn2742dff/21OnXqpJtuukmXXXaZHnnkET+2HgBsmvu3rLb/+Z//0ZQpU1q4xcYh3CDoVVRU6NJLL9Xf//53tz/PycnR3LlztWDBAuXn52vcuHHKzMxUQUGBJOns2bPavn27nnzySe3YsUO5ubnKzc315y0AQLP/ltlZLBZ9+OGHuu666/zRbEMw5gZtSkhIiF577TVNnjzZcSwtLU2XXXaZVq1a5Tg2ePBgTZ48WdnZ2dqxY4cWLVqkt99+W5L0l7/8RZL0u9/9zq9tBwC7pvwts3vppZe0efNmvfzyy/5ssl9RuUGbVl1drV27dmnixIlOxydOnKi8vDxJ0qhRo3T8+HGdPn1a58+f17Zt2zR48GAjmgsAbnnyt8wu2LukJMIN2rjS0lLV1NQoLi7O6XhcXJxKSkokSe3bt9cjjzyi8ePHa/jw4Ro4cKBuuOEGI5oLAG558rdMksrKyvTxxx9r0qRJ/m6iXzFbCpCtxFub1Wp1OpaZmanMzEx/NwsAvNLY37Lo6GgdP37c383yOyo3aNNiY2MVGhrq9P9sJMlsNrv8PyAACFT8LXNGuEGbFhYWppSUFJfZT7m5uRozZoxBrQIA7/C3zBndUgh6Z86c0cGDBx2PDx8+rN27dysmJkZ9+vRRVlaWpk2bptTUVKWnp2v16tUqKCjQzJkzDWw1ADjjb5kXrECQe/fdd62SXL5++tOfOs558sknrQkJCdawsDDrZZddZn3//feNazAAuMHfMs+xzg0AAAgqjLkBAABBhXADAACCCuEGAAAEFcINAAAIKoQbAAAQVAg3AAAgqBBuAABAUCHcAACAoEK4AdCgkJAQvf7660Y3AwA8RrgBgGY4cuSIQkJCtHv3bqObAuAHhBsAPnf27NmgfK2WFkz3AhiJcAO0YVdeeaVmz56t3//+94qJiVH37t310EMPuZxXXFyszMxMdezYUYmJiXr11VcdP7NXLv7nf/5HV155pSIiIvTyyy+7fb2QkBCtWrWq3mtJ0h/+8AcNGjRIF110kfr166cHH3zQ6UP/oYce0ogRI7RmzRr169dP4eHhslqtevvttzV27FhdfPHF6tq1q2644QYdOnTIbTvHjRunjh07atSoUTpw4IA++eQTpaamqlOnTrr22mt14sQJpzY999xzGjx4sCIiIpSUlKSVK1c6fpaYmChJGjlypEJCQnTllVd69Lz63rejR4/qxhtvVJcuXRQZGamhQ4dq06ZNDfwWAbgweONOAAa64oorrFFRUdaHHnrIeuDAAesLL7xgDQkJsb7zzjuOcyRZu3btan366aetX331lfWPf/yjNTQ01Lpv3z6r1Wq1Hj582CrJ2rdvX+uGDRus33zzjbWoqMjt6zV2LavVan344YetH374ofXw4cPWN954wxoXF2f985//7Pj5woULrZGRkdZJkyZZP/vsM+vnn39uPX/+vPWf//yndcOGDdYDBw5Y8/PzrTfeeKN12LBh1pqaGqd2JiUlWd9++23rvn37rKNHj7Zedtll1iuvvNL6wQcfWD/77DPrgAEDrDNnznS83urVq609evRw3NuGDRusMTEx1ueff95qtVqtH3/8sVWS9d///re1uLjYevLkSY+eV9/7dv3111szMjKs//nPf6yHDh2y/t///V+b3dkZaCrCDdCGXXHFFdaxY8c6HRs1apT1D3/4g+OxJKcPe6vVak1LS7P++te/tlqtFz6kly1b1ujrNXYtdx577DFrSkqK4/HChQutHTp0sJrN5gZfy2w2WyVZ9+zZ49TOZ555xnHOunXrrJKsW7ZscRzLzs62XnLJJY7H8fHx1ldeecXp2g8//LA1PT3d6br5+flO53j6vLrv27Bhw6wPPfRQg/cGoGHtjagWAQgcw4cPd3rco0cPmc1mp2Pp6ekuj+sOoE1NTfXo9Rq71j//+U8tW7ZMBw8e1JkzZ3Tu3DlFRUU5PSchIUHdunVzOnbo0CE9+OCD+uijj1RaWqrz589LkgoKCpScnOw4r/b9xsXFSZKGDRvmdMx+/ydOnFBhYaGmT5+uX/7yl45zzp07p+jo6Hrv0Zvn1X3fZs+erV//+td65513dM011+i2225z+R0BaBjhBmjjOnTo4PQ4JCTEEQwaEhIS4vQ4MjKyyW2wX+ujjz7SHXfcoUWLFmnSpEmKjo7W+vXr9fjjjzf6WjfeeKPi4+P19NNPq2fPnjp//rySk5NVXV3tdF7t+7W/bt1j9vu3f3/66aeVlpbmdJ3Q0NB678eb59W9lxkzZmjSpEl688039c477yg7O1uPP/64Zs2aVe/rAXDGgGIAjfroo49cHiclJfn8Wh9++KESEhK0YMECpaamauDAgTp69Gij1zx58qS+/PJL/fGPf9SECRM0ePBgnT59ukntqy0uLk69evXSN998owEDBjh92QcSh4WFSZJqamq8el5D4uPjNXPmTG3cuFG/+c1v9PTTTzf7XoC2hMoNgEa9+uqrSk1N1dixY7V27Vp9/PHHevbZZ31+rQEDBqigoEDr16/XqFGj9Oabb+q1115r9JpdunRR165dtXr1avXo0UMFBQWaN29ek9pX10MPPaTZs2crKipKmZmZqqqq0qeffqrTp08rKytLJpNJHTt21Ntvv63evXsrIiJC0dHRjT6vPnPnzlVmZqYGDRqk06dPa+vWrRo8eLBP7gVoK6jcAGjUokWLtH79eg0fPlwvvPCC1q5dqyFDhvj8WjfffLPuv/9+3XfffRoxYoTy8vL04IMPNnrNdu3aaf369dq1a5eSk5N1//336y9/+UuT2lfXjBkz9Mwzz+j555/XsGHDdMUVV+j55593VGDat2+vv/3tb3rqqafUs2dP3XzzzR49rz41NTW69957NXjwYF177bW65JJLnKaQA2hciNVqtRrdCABtQ0hIiF577TVNnjzZ6KYACGJUbgAAQFAh3AAAgKDCgGIAfkMvOAB/oHIDAACCCuEGAAAEFcINAAAIKoQbAAAQVAg3AAAgqBBuAABAUCHcAACAoEK4AQAAQYVwAwAAgsr/D3t4XpJVecpvAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(df_tracker['nbr_parameters_apres'], A_te_padd[df_tracker['len_L_tr'].values], '+')\n",
    "plt.xlabel('nbr parameters')\n",
    "plt.ylabel('Accuracy test')\n",
    "plt.xscale('log')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "776a27ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>vps0</th>\n",
       "      <th>vps1</th>\n",
       "      <th>vps2</th>\n",
       "      <th>vps3</th>\n",
       "      <th>vps4</th>\n",
       "      <th>vps5</th>\n",
       "      <th>vps6</th>\n",
       "      <th>vps7</th>\n",
       "      <th>vps8</th>\n",
       "      <th>...</th>\n",
       "      <th>vps23</th>\n",
       "      <th>depth_add</th>\n",
       "      <th>nbr_added_neuron</th>\n",
       "      <th>accroissement</th>\n",
       "      <th>portion_gain</th>\n",
       "      <th>nbr_parameters_apres</th>\n",
       "      <th>nbr_parameters_avant</th>\n",
       "      <th>T</th>\n",
       "      <th>len_L_tr</th>\n",
       "      <th>lu_conv</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.024471</td>\n",
       "      <td>0.021132</td>\n",
       "      <td>0.019659</td>\n",
       "      <td>0.018439</td>\n",
       "      <td>0.017467</td>\n",
       "      <td>0.016562</td>\n",
       "      <td>0.015765</td>\n",
       "      <td>0.014933</td>\n",
       "      <td>0.014206</td>\n",
       "      <td>...</td>\n",
       "      <td>0.008816</td>\n",
       "      <td>19</td>\n",
       "      <td>24</td>\n",
       "      <td>0.090533</td>\n",
       "      <td>0.664</td>\n",
       "      <td>650822</td>\n",
       "      <td>429566</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>0.053013</td>\n",
       "      <td>0.048903</td>\n",
       "      <td>0.038659</td>\n",
       "      <td>0.033937</td>\n",
       "      <td>0.030980</td>\n",
       "      <td>0.029312</td>\n",
       "      <td>0.026862</td>\n",
       "      <td>0.026536</td>\n",
       "      <td>0.024432</td>\n",
       "      <td>...</td>\n",
       "      <td>0.015070</td>\n",
       "      <td>17</td>\n",
       "      <td>24</td>\n",
       "      <td>0.039019</td>\n",
       "      <td>0.633</td>\n",
       "      <td>872078</td>\n",
       "      <td>650822</td>\n",
       "      <td>20.577017</td>\n",
       "      <td>313</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>0.018107</td>\n",
       "      <td>0.017103</td>\n",
       "      <td>0.015909</td>\n",
       "      <td>0.015567</td>\n",
       "      <td>0.014988</td>\n",
       "      <td>0.014588</td>\n",
       "      <td>0.014084</td>\n",
       "      <td>0.013802</td>\n",
       "      <td>0.013313</td>\n",
       "      <td>...</td>\n",
       "      <td>0.010031</td>\n",
       "      <td>19</td>\n",
       "      <td>24</td>\n",
       "      <td>0.025497</td>\n",
       "      <td>0.600</td>\n",
       "      <td>1093334</td>\n",
       "      <td>872078</td>\n",
       "      <td>40.208526</td>\n",
       "      <td>579</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>0.014327</td>\n",
       "      <td>0.013892</td>\n",
       "      <td>0.013219</td>\n",
       "      <td>0.012724</td>\n",
       "      <td>0.012373</td>\n",
       "      <td>0.012339</td>\n",
       "      <td>0.012019</td>\n",
       "      <td>0.011765</td>\n",
       "      <td>0.011635</td>\n",
       "      <td>...</td>\n",
       "      <td>0.009279</td>\n",
       "      <td>19</td>\n",
       "      <td>24</td>\n",
       "      <td>0.022836</td>\n",
       "      <td>0.584</td>\n",
       "      <td>1314590</td>\n",
       "      <td>1093334</td>\n",
       "      <td>59.394008</td>\n",
       "      <td>815</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>0.058541</td>\n",
       "      <td>0.049718</td>\n",
       "      <td>0.046374</td>\n",
       "      <td>0.044468</td>\n",
       "      <td>0.042250</td>\n",
       "      <td>0.039763</td>\n",
       "      <td>0.037756</td>\n",
       "      <td>0.033531</td>\n",
       "      <td>0.033054</td>\n",
       "      <td>...</td>\n",
       "      <td>0.022038</td>\n",
       "      <td>17</td>\n",
       "      <td>24</td>\n",
       "      <td>0.016738</td>\n",
       "      <td>0.565</td>\n",
       "      <td>1535846</td>\n",
       "      <td>1314590</td>\n",
       "      <td>77.660275</td>\n",
       "      <td>1027</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>163</th>\n",
       "      <td>0</td>\n",
       "      <td>0.024035</td>\n",
       "      <td>0.021356</td>\n",
       "      <td>0.020226</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2</td>\n",
       "      <td>3</td>\n",
       "      <td>0.001298</td>\n",
       "      <td>0.555</td>\n",
       "      <td>12676262</td>\n",
       "      <td>12672797</td>\n",
       "      <td>2833.891716</td>\n",
       "      <td>11554</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>164</th>\n",
       "      <td>0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000</td>\n",
       "      <td>12676262</td>\n",
       "      <td>12676262</td>\n",
       "      <td>2854.088870</td>\n",
       "      <td>11595</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>165</th>\n",
       "      <td>0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>7</td>\n",
       "      <td>0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000</td>\n",
       "      <td>12676262</td>\n",
       "      <td>12676262</td>\n",
       "      <td>2874.309621</td>\n",
       "      <td>11636</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>166</th>\n",
       "      <td>0</td>\n",
       "      <td>0.059216</td>\n",
       "      <td>0.050403</td>\n",
       "      <td>0.043686</td>\n",
       "      <td>0.036952</td>\n",
       "      <td>0.036151</td>\n",
       "      <td>0.034637</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>7</td>\n",
       "      <td>6</td>\n",
       "      <td>0.000867</td>\n",
       "      <td>0.490</td>\n",
       "      <td>12690104</td>\n",
       "      <td>12676262</td>\n",
       "      <td>2894.702185</td>\n",
       "      <td>11677</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>167</th>\n",
       "      <td>0</td>\n",
       "      <td>0.049422</td>\n",
       "      <td>0.039296</td>\n",
       "      <td>0.037525</td>\n",
       "      <td>0.035522</td>\n",
       "      <td>0.032430</td>\n",
       "      <td>0.029608</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>7</td>\n",
       "      <td>6</td>\n",
       "      <td>0.007535</td>\n",
       "      <td>0.450</td>\n",
       "      <td>12703946</td>\n",
       "      <td>12690104</td>\n",
       "      <td>2915.326182</td>\n",
       "      <td>11718</td>\n",
       "      <td>0.001</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>168 rows × 34 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0      vps0      vps1      vps2      vps3      vps4      vps5  \\\n",
       "0             0  0.024471  0.021132  0.019659  0.018439  0.017467  0.016562   \n",
       "1             0  0.053013  0.048903  0.038659  0.033937  0.030980  0.029312   \n",
       "2             0  0.018107  0.017103  0.015909  0.015567  0.014988  0.014588   \n",
       "3             0  0.014327  0.013892  0.013219  0.012724  0.012373  0.012339   \n",
       "4             0  0.058541  0.049718  0.046374  0.044468  0.042250  0.039763   \n",
       "..          ...       ...       ...       ...       ...       ...       ...   \n",
       "163           0  0.024035  0.021356  0.020226       NaN       NaN       NaN   \n",
       "164           0       NaN       NaN       NaN       NaN       NaN       NaN   \n",
       "165           0       NaN       NaN       NaN       NaN       NaN       NaN   \n",
       "166           0  0.059216  0.050403  0.043686  0.036952  0.036151  0.034637   \n",
       "167           0  0.049422  0.039296  0.037525  0.035522  0.032430  0.029608   \n",
       "\n",
       "         vps6      vps7      vps8  ...     vps23  depth_add  nbr_added_neuron  \\\n",
       "0    0.015765  0.014933  0.014206  ...  0.008816         19                24   \n",
       "1    0.026862  0.026536  0.024432  ...  0.015070         17                24   \n",
       "2    0.014084  0.013802  0.013313  ...  0.010031         19                24   \n",
       "3    0.012019  0.011765  0.011635  ...  0.009279         19                24   \n",
       "4    0.037756  0.033531  0.033054  ...  0.022038         17                24   \n",
       "..        ...       ...       ...  ...       ...        ...               ...   \n",
       "163       NaN       NaN       NaN  ...       NaN          2                 3   \n",
       "164       NaN       NaN       NaN  ...       NaN          7                 0   \n",
       "165       NaN       NaN       NaN  ...       NaN          7                 0   \n",
       "166       NaN       NaN       NaN  ...       NaN          7                 6   \n",
       "167       NaN       NaN       NaN  ...       NaN          7                 6   \n",
       "\n",
       "     accroissement  portion_gain  nbr_parameters_apres  nbr_parameters_avant  \\\n",
       "0         0.090533         0.664                650822                429566   \n",
       "1         0.039019         0.633                872078                650822   \n",
       "2         0.025497         0.600               1093334                872078   \n",
       "3         0.022836         0.584               1314590               1093334   \n",
       "4         0.016738         0.565               1535846               1314590   \n",
       "..             ...           ...                   ...                   ...   \n",
       "163       0.001298         0.555              12676262              12672797   \n",
       "164       0.000000         1.000              12676262              12676262   \n",
       "165       0.000000         1.000              12676262              12676262   \n",
       "166       0.000867         0.490              12690104              12676262   \n",
       "167       0.007535         0.450              12703946              12690104   \n",
       "\n",
       "               T  len_L_tr  lu_conv  \n",
       "0       0.000000         0    0.001  \n",
       "1      20.577017       313    0.001  \n",
       "2      40.208526       579    0.001  \n",
       "3      59.394008       815    0.001  \n",
       "4      77.660275      1027    0.001  \n",
       "..           ...       ...      ...  \n",
       "163  2833.891716     11554    0.001  \n",
       "164  2854.088870     11595    0.001  \n",
       "165  2874.309621     11636    0.001  \n",
       "166  2894.702185     11677    0.001  \n",
       "167  2915.326182     11718    0.001  \n",
       "\n",
       "[168 rows x 34 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_tracker"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c0c1e17",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd21658b",
   "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
