{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "43ca4d48",
   "metadata": {},
   "source": [
    "## Annexe, fig. 11 : MNIST dataset, TINY vs Big "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7128aa0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../TINY/')\n",
    "import TINY \n",
    "import UTILS\n",
    "from mes_imports import *\n",
    "import load_data_Loader\n",
    "import SOLVE_EB as EB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "43f1a65f-a2a7-42aa-a031-ed206b4f767e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.simplefilter('module')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "eb1204ff-8172-43c5-9798-7d6d90e2ec82",
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm.notebook import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2bb22a41",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.set_num_threads(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a28439c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def Loss_entropy(x1, x2, reduction = 'mean') :\n",
    "    #print(x1.shape, x2.shape)\n",
    "    return(torch.nn.CrossEntropyLoss(reduction = reduction)(x1, x2))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2d404d78",
   "metadata": {},
   "outputs": [],
   "source": [
    "dico_performance = {'TINY' : {}, 'Random' : {}}\n",
    "tot_nbr_pass = 5\n",
    "init_deplacement = 1e-4\n",
    "accroissement_decay = 1e-4\n",
    "lr = 1e-3\n",
    "epoch_sup = 4\n",
    "epoch_btt = 0.1\n",
    "starting_batch_size = 32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "84b5a14b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def stabilize_training() :\n",
    "    MLP_model.batch_size = math.ceil(np.sqrt(MLP_model.count_parameters() / nbr_parameters_avant) *  MLP_model.batch_size)\n",
    "    #MLP_model.batch_size = math.ceil(MLP_model.count_parameters() / nbr_parameters_avant *  MLP_model.batch_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "f33a4495",
   "metadata": {},
   "outputs": [],
   "source": [
    "dico_tracker = {'TINY' : {}, 'Big' : {}}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5b56f8a3",
   "metadata": {},
   "source": [
    "### TINY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "df4fc272",
   "metadata": {},
   "outputs": [],
   "source": [
    "strucs = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "abe46c76",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "After layer 1 : x.shape=torch.Size([1, 1])\n",
      "After layer 2 : x.shape=torch.Size([1, 1])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.00 seconds\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b34d913b337c4aacaf4c545e32444697",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 4000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.13371829688549042\n",
      "norm_x_over_norm_DE_depthp1 :  0.2674260437488556\n",
      "L_plus < L_moins: 2.4791932106018066 < 2.479193687438965\n",
      "Delta Loss :  [0.0, -4.76837158203125e-07, -1.430511474609375e-06]  ... [-0.042977333068847656, -0.07552456855773926, -0.12181758880615234]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [4.0, 8.0, 16.0]\n",
      "rate of decrease : 0.05065971985459328 ampli_fct : 16.0 L[0] : 2.4046242237091064\n",
      "amplitude factor for the new neurons : 16.0\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.157651662826538\n",
      "norm_x_over_norm_DE_depthp1 :  13.721232414245605\n",
      "L_plus < L_moins: 2.317979097366333 < 2.3180317878723145\n",
      "Delta Loss :  [0.0, -9.5367431640625e-06, -1.9311904907226562e-05]  ... [-0.0029380321502685547, -0.003216266632080078, 0.002607107162475586]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.03125, 0.0625, 0.125]\n",
      "rate of decrease : 0.0014695972204208374 ampli_fct : 0.0625 L[0] : 2.1885361671447754\n",
      "amplitude factor for the new neurons : 0.0625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 15700\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.977500557899475\n",
      "norm_x_over_norm_DE_depthp1 :  2.287900686264038\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -6.532669067382812e-05, -0.00012993812561035156]  ... [-0.12929975986480713, -0.1810779571533203, -0.18048381805419922]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.25, 0.5, 1.0]\n",
      "rate of decrease : 0.08623253554105759 ampli_fct : 0.5 L[0] : 2.099879741668701\n",
      "amplitude factor for the new neurons : 0.5\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.7849385738372803\n",
      "norm_x_over_norm_DE_depthp1 :  10.419681549072266\n",
      "L_plus < L_moins: 1.7646410465240479 < 1.7646715641021729\n",
      "Delta Loss :  [0.0, -0.00012695789337158203, -0.0002549886703491211]  ... [-0.19050168991088867, -0.27321887016296387, -0.2211771011352539]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.125, 0.25, 0.5]\n",
      "rate of decrease : 0.1497044712305069 ampli_fct : 0.25 L[0] : 1.8250547647476196\n",
      "amplitude factor for the new neurons : 0.25\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 43200\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.5935351848602295\n",
      "norm_x_over_norm_DE_depthp1 :  4.378350257873535\n",
      "L_plus < L_moins: 1.2284166812896729 < 1.228479266166687\n",
      "Delta Loss :  [0.0, -0.0002777576446533203, -0.0005528926849365234]  ... [-0.41084665060043335, -0.41487592458724976, -0.12491905689239502]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.25, 0.5, 1.0]\n",
      "rate of decrease : 0.3117247223854065 ampli_fct : 0.5 L[0] : 1.3309048414230347\n",
      "amplitude factor for the new neurons : 0.5\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 7.200684547424316\n",
      "norm_x_over_norm_DE_depthp1 :  34.07843780517578\n",
      "L_plus < L_moins: 0.7367743253707886 < 0.7368300557136536\n",
      "Delta Loss :  [0.0, -0.0003007650375366211, -0.0005788803100585938]  ... [-0.021340608596801758, -0.031168222427368164, -0.027858853340148926]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.0078125, 0.015625, 0.03125]\n",
      "rate of decrease : 0.040965646505355835 ampli_fct : 0.015625 L[0] : 0.7608380317687988\n",
      "amplitude factor for the new neurons : 0.015625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1700\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 50000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.818204879760742\n",
      "norm_x_over_norm_DE_depthp1 :  10.881708145141602\n",
      "L_plus < L_moins: 0.6340101957321167 < 0.6340184211730957\n",
      "Delta Loss :  [0.0, -0.00010335445404052734, -0.00020629167556762695]  ... [-0.02080404758453369, -0.03045588731765747, -0.008979380130767822]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.015625, 0.03125, 0.0625]\n",
      "rate of decrease : 0.04483811557292938 ampli_fct : 0.03125 L[0] : 0.6792410016059875\n",
      "amplitude factor for the new neurons : 0.03125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 1100\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 1300\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 8.63665771484375\n",
      "norm_x_over_norm_DE_depthp1 :  47.24612808227539\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -0.00020873546600341797, -0.0004145503044128418]  ... [-0.01680666208267212, -0.01874786615371704, 0.008120715618133545]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.0078125, 0.015625, 0.03125]\n",
      "rate of decrease : 0.03074640966951847 ampli_fct : 0.015625 L[0] : 0.6097579002380371\n",
      "amplitude factor for the new neurons : 0.015625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 4100\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 50000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 3.7116522789001465\n",
      "norm_x_over_norm_DE_depthp1 :  5.25596284866333\n",
      "L_plus < L_moins: 0.5854535102844238 < 0.5854623317718506\n",
      "Delta Loss :  [0.0, -2.4378299713134766e-05, -4.4465065002441406e-05]  ... [-0.0001862645149230957, -0.0002523660659790039, -0.00023037195205688477]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.0009765625, 0.001953125, 0.00390625]\n",
      "rate of decrease : 0.00046416791155934334 ampli_fct : 0.001953125 L[0] : 0.5436956286430359\n",
      "amplitude factor for the new neurons : 0.001953125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 1600\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 1800\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 9.46299934387207\n",
      "norm_x_over_norm_DE_depthp1 :  54.40370559692383\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -5.549192428588867e-05, -0.00011032819747924805]  ... [-0.000708460807800293, -0.0010600090026855469, -0.0009022355079650879]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.0009765625, 0.001953125, 0.00390625]\n",
      "rate of decrease : 0.0020118486136198044 ampli_fct : 0.001953125 L[0] : 0.526883065700531\n",
      "amplitude factor for the new neurons : 0.001953125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "Acc test : 0.8928000044822693 Acc train : 0.9018000018596649 lr : 0.001\n",
      "Acc test : 0.9023999989032745 Acc train : 0.9146000027656556 lr : 0.001\n",
      "Acc test : 0.9051999974250794 Acc train : 0.9088000011444092 lr : 0.001\n",
      "After layer 1 : x.shape=torch.Size([1, 1])\n",
      "After layer 2 : x.shape=torch.Size([1, 1])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.00 seconds\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "37a26768a25644a5b6d4d9124e77b075",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/5 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 4000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.058344773948192596\n",
      "norm_x_over_norm_DE_depthp1 :  0.12558673322200775\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -2.384185791015625e-07, -2.384185791015625e-07]  ... [-0.008704900741577148, -0.01852893829345703, -0.038022756576538086]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [4.0, 8.0, 16.0]\n",
      "rate of decrease : 0.014987975358963013 ampli_fct : 16.0 L[0] : 2.536884069442749\n",
      "amplitude factor for the new neurons : 16.0\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.55887508392334\n",
      "norm_x_over_norm_DE_depthp1 :  22.88406753540039\n",
      "L_plus < L_moins: 2.4478235244750977 < 2.4478538036346436\n",
      "Delta Loss :  [0.0, -3.6716461181640625e-05, -7.319450378417969e-05]  ... [-0.011441946029663086, -0.015274286270141602, -0.00931096076965332]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.03125, 0.0625, 0.125]\n",
      "rate of decrease : 0.006743714213371277 ampli_fct : 0.0625 L[0] : 2.2649664878845215\n",
      "amplitude factor for the new neurons : 0.0625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 15700\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.7471051216125488\n",
      "norm_x_over_norm_DE_depthp1 :  2.39973783493042\n",
      "L_plus < L_moins: 2.0203146934509277 < 2.0203380584716797\n",
      "Delta Loss :  [0.0, -6.628036499023438e-05, -0.00010704994201660156]  ... [-0.001083970069885254, -0.0014481544494628906, -0.0011632442474365234]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.00390625, 0.0078125, 0.015625]\n",
      "rate of decrease : 0.0007323137833736837 ampli_fct : 0.0078125 L[0] : 1.9775054454803467\n",
      "amplitude factor for the new neurons : 0.0078125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.480463743209839\n",
      "norm_x_over_norm_DE_depthp1 :  13.877179145812988\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -7.87973403930664e-05, -0.00017940998077392578]  ... [-0.17310857772827148, -0.250543475151062, -0.24773085117340088]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.125, 0.25, 0.5]\n",
      "rate of decrease : 0.1313757747411728 ampli_fct : 0.25 L[0] : 1.9070751667022705\n",
      "amplitude factor for the new neurons : 0.25\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1000\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 43200\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.9038722515106201\n",
      "norm_x_over_norm_DE_depthp1 :  2.3107738494873047\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -3.5762786865234375e-07, -5.626678466796875e-05]  ... [-0.11019384860992432, -0.11474823951721191, -0.011524796485900879]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.125, 0.25, 0.5]\n",
      "rate of decrease : 0.09646163135766983 ampli_fct : 0.25 L[0] : 1.189573884010315\n",
      "amplitude factor for the new neurons : 0.25\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 5.246688365936279\n",
      "norm_x_over_norm_DE_depthp1 :  30.617809295654297\n",
      "L_plus < L_moins: 0.909891664981842 < 0.9099122881889343\n",
      "Delta Loss :  [0.0, -0.0003388524055480957, -0.0006752610206604004]  ... [-0.1011430025100708, -0.11436456441879272, 0.01090914011001587]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.03125, 0.0625, 0.125]\n",
      "rate of decrease : 0.1189858689904213 ampli_fct : 0.0625 L[0] : 0.9611608982086182\n",
      "amplitude factor for the new neurons : 0.0625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 1700\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 50000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.3048105239868164\n",
      "norm_x_over_norm_DE_depthp1 :  1.6514759063720703\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, 3.516674041748047e-06]  ... [0.0, 3.516674041748047e-06]\n",
      "betas :  [0.0, 6.103515625e-05] ... [0.0, 6.103515625e-05]\n",
      "rate of decrease : 0.0 ampli_fct : 0.0 L[0] : 0.7237244844436646\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 1100\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. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 8.395225524902344\n",
      "norm_x_over_norm_DE_depthp1 :  65.44473266601562\n",
      "L_plus < L_moins: 0.6035912036895752 < 0.6036127805709839\n",
      "Delta Loss :  [0.0, -0.0001304149627685547, -0.0002582669258117676]  ... [-0.00635838508605957, -0.009542346000671387, -0.008623301982879639]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.00390625, 0.0078125, 0.015625]\n",
      "rate of decrease : 0.01406110916286707 ampli_fct : 0.0078125 L[0] : 0.6786339282989502\n",
      "amplitude factor for the new neurons : 0.0078125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 2500\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 50000\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 3.5132081508636475\n",
      "norm_x_over_norm_DE_depthp1 :  9.805335998535156\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -0.0003001689910888672, -0.0005965828895568848]  ... [-0.04974508285522461, -0.05893176794052124, 0.012291967868804932]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.015625, 0.03125, 0.0625]\n",
      "rate of decrease : 0.09157621115446091 ampli_fct : 0.03125 L[0] : 0.6435270309448242\n",
      "amplitude factor for the new neurons : 0.03125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 1600\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 1300\n",
      "*** method : OUR ***\n",
      "eigh succed\n",
      "svd succed\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 9.212728500366211\n",
      "norm_x_over_norm_DE_depthp1 :  77.90261840820312\n",
      "L_plus < L_moins: 0.5808113813400269 < 0.5809276700019836\n",
      "Delta Loss :  [0.0, -9.083747863769531e-05, -0.00018292665481567383]  ... [-0.004833877086639404, -0.006662428379058838, -0.0005947351455688477]\n",
      "betas :  [0.0, 6.103515625e-05, 0.0001220703125] ... [0.00390625, 0.0078125, 0.015625]\n",
      "rate of decrease : 0.012254553847014904 ampli_fct : 0.0078125 L[0] : 0.543669581413269\n",
      "amplitude factor for the new neurons : 0.0078125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "Acc test : 0.897400004863739 Acc train : 0.9218000006675721 lr : 0.001\n",
      "Acc test : 0.9054000020027161 Acc train : 0.9198000001907348 lr : 0.001\n",
      "Acc test : 0.9056000018119812 Acc train : 0.9230000007152558 lr : 0.001\n"
     ]
    }
   ],
   "source": [
    "for expe in range(2) :\n",
    "    L_tr, L_te, A_tr, A_te, T = np.array([]), np.array([]), np.array([]), np.array([]), np.array([0])\n",
    "    layer_name = {1 : 'L', 2 : 'L', 3 :'L'}\n",
    "    skeleton = {0: {}, 1 : {'size' : 1}, 2 : {'size' : 1}, 3 : {'size' : 10}}\n",
    "    fct = {depth : torch.nn.SELU() for depth in range(1, 3)}\n",
    "    fct.update({3 : torch.nn.Identity()})\n",
    "    dico_parameters = {\n",
    "                     'skeleton' : copy.deepcopy(skeleton),\n",
    "                    'Loss' : Loss_entropy,\n",
    "                    'fct' : fct,\n",
    "                    'layer_name' :layer_name,\n",
    "                    'rescale' : 'DE',\n",
    "                    'init_deplacement' : init_deplacement, # min amplitude factor\n",
    "                    'batch_size' : starting_batch_size,# batchsize for training\n",
    "                    'lr' : lr,# leraning rate for training\n",
    "                    'lambda_method' : 0, # = 0 for searching the amplitude factor, if > 0 the \n",
    "                                         # amplitude factor is automatically set to this value\n",
    "                    'accroissement_decay' : accroissement_decay,# the minimum decay to update the \n",
    "                                                 # architecture with the NewNeurons/BestUpdate \n",
    "                    'depth_seuil' : {1 : 10, 2 : 10}, #maximum number of neurons to add by depth\n",
    "                    'lu_lin' : 5, #reduce the variance of estimators by sqrt of lu_lin > 1\n",
    "                    'max_batch_estimation' : 100, # maximum size of batch at a time\n",
    "                    'max_amplitude' : 20., # max amplitude factor\n",
    "                    'ind_lmbda_shape' : 1000,\n",
    "                    'init_X_shape' : [1, 28, 28], # size of the input, if your X are 1-d, unsqueeze it\n",
    "                    'len_train_dataset' : 50000, # size of training data\n",
    "                    'len_test_dataset' : 10000, # size of testing data\n",
    "                    'selection_neuron' : UTILS.selection_neuron_seuil,\n",
    "                    'how_to_define_batchsize' : UTILS.indices_non_constant,\n",
    "                    }\n",
    "    MLP_model = TINY.TINY(dico_parameters)\n",
    "\n",
    "    for nbr_pass in tqdm(range(tot_nbr_pass)) :\n",
    "        for depth in [1, 2] :\n",
    "            MLP_model.training_data, MLP_model.test_data = load_data_Loader.load_database_MNIST(batch_size = MLP_model.max_batch_estimation)\n",
    "            MLP_model.tr_loader, MLP_model.te_loader =  iter(UTILS.cycle(DataLoader(MLP_model.training_data, batch_size=MLP_model.max_batch_estimation, shuffle=True))),  iter(UTILS.cycle(DataLoader(MLP_model.test_data, batch_size=MLP_model.max_batch_estimation, shuffle=True)))\n",
    "\n",
    "            nbr_parameters_avant = MLP_model.count_parameters()\n",
    "            MLP_model.dico_w = None\n",
    "            MLP_model.how_to_define_batchsize(MLP_model, depth + 1, method = 'NG')\n",
    "            EB.compute_optimal_update(MLP_model, depth + 1, update = False, compute_gain=False)\n",
    "            MLP_model.how_to_define_batchsize(MLP_model, depth, method = 'Add')\n",
    "            EB.add_neurons(MLP_model, depth, update = True)\n",
    "            #MLP_model.transform_dico_w(depth)\n",
    "            #EB.compute_optimal_update(MLP_model, depth + 1, update = True)\n",
    "\n",
    "            stabilize_training()\n",
    "            MLP_model.training_data, MLP_model.test_data = load_data_Loader.load_database_MNIST(batch_size = MLP_model.batch_size)\n",
    "            MLP_model.tr_loader, MLP_model.te_loader =  iter(UTILS.cycle(DataLoader(MLP_model.training_data, batch_size=MLP_model.max_batch_estimation, shuffle=True))),  iter(UTILS.cycle(DataLoader(MLP_model.test_data, batch_size=MLP_model.max_batch_estimation, shuffle=True)))\n",
    "            optimizer = torch.optim.SGD(MLP_model.parameters(), lr = MLP_model.lr)\n",
    "            l_tr, l_te, _, a_tr, a_te, _, t = MLP_model.train_batch(epoch_btt, optimizer = optimizer)\n",
    "            L_tr, L_te = np.concatenate([L_tr, l_tr]), np.concatenate([L_te, l_te])\n",
    "            A_tr, A_te = np.concatenate([A_tr, a_tr]), np.concatenate([A_te, a_te])\n",
    "            T = np.concatenate([T, t + T[-1]])\n",
    "\n",
    "    MLP_model.training_data, MLP_model.test_data = load_data_Loader.load_database_MNIST(batch_size = MLP_model.batch_size)\n",
    "    MLP_model.tr_loader, MLP_model.te_loader =  iter(UTILS.cycle(DataLoader(MLP_model.training_data, batch_size=MLP_model.max_batch_estimation, shuffle=True))),  iter(UTILS.cycle(DataLoader(MLP_model.test_data, batch_size=MLP_model.max_batch_estimation, shuffle=True)))\n",
    "    optimizer = torch.optim.SGD(MLP_model.parameters(), lr = MLP_model.lr)\n",
    "    l_tr, l_te, _, a_tr, a_te, _, t = MLP_model.train_batch(epoch_sup, optimizer = optimizer)\n",
    "    L_tr, L_te = np.concatenate([L_tr, l_tr]), np.concatenate([L_te, l_te])\n",
    "    A_tr, A_te = np.concatenate([A_tr, a_tr]), np.concatenate([A_te, a_te])\n",
    "    T = np.concatenate([T, t + T[-1]])\n",
    "\n",
    "    dico_tracker['TINY'][expe] = {'L_tr' : L_tr, 'L_te' : L_te, 'A_tr' : A_tr, 'A_te' : A_te, 'T' : T[1:]}\n",
    "    strucs.append([MLP_model.layer[1]['L'].out_features, MLP_model.layer[2]['L'].out_features])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "24acf750",
   "metadata": {},
   "outputs": [],
   "source": [
    "dico_tracker['Big'] = {'small_bs' : {}, 'big_bs' : {}}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "361b53f4",
   "metadata": {},
   "source": [
    "### Big"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e54fd8f7",
   "metadata": {},
   "source": [
    "To change the batchsize of training, change the variable 'batch size' in the dictionnary dico_parameters."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "66528c4f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "After layer 1 : x.shape=torch.Size([1, 1000])\n",
      "After layer 2 : x.shape=torch.Size([1, 1000])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.01 seconds\n",
      "Acc test : 0.8855999958515167 Acc train : 0.8787999999523163 lr : 0.001\n",
      "Acc test : 0.9042000043392181 Acc train : 0.8868000030517578 lr : 0.001\n",
      "Acc test : 0.9114000010490417 Acc train : 0.896599999666214 lr : 0.001\n",
      "After layer 1 : x.shape=torch.Size([1, 1000])\n",
      "After layer 2 : x.shape=torch.Size([1, 1000])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.01 seconds\n",
      "Acc test : 0.7951999962329864 Acc train : 0.7835999965667725 lr : 0.001\n",
      "Acc test : 0.8417999994754791 Acc train : 0.8374000012874603 lr : 0.001\n",
      "Acc test : 0.8648000037670136 Acc train : 0.8592000019550323 lr : 0.001\n",
      "After layer 1 : x.shape=torch.Size([1, 1000])\n",
      "After layer 2 : x.shape=torch.Size([1, 1000])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.01 seconds\n",
      "Acc test : 0.8801999986171722 Acc train : 0.8755999958515167 lr : 0.001\n",
      "Acc test : 0.8999999988079072 Acc train : 0.8874000012874603 lr : 0.001\n",
      "Acc test : 0.9090000033378601 Acc train : 0.9050000011920929 lr : 0.001\n",
      "After layer 1 : x.shape=torch.Size([1, 1000])\n",
      "After layer 2 : x.shape=torch.Size([1, 1000])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.01 seconds\n",
      "Acc test : 0.8007999968528747 Acc train : 0.7887999939918519 lr : 0.001\n",
      "Acc test : 0.8379999995231628 Acc train : 0.8433999955654145 lr : 0.001\n",
      "Acc test : 0.8605999982357025 Acc train : 0.8553999972343445 lr : 0.001\n"
     ]
    }
   ],
   "source": [
    "for expe in range(2) :\n",
    "    for bs, batch_size in zip(['small_bs', 'big_bs'], [starting_batch_size, MLP_model.batch_size]) :\n",
    "    #for bs, batch_size in zip(['big_bs'], [MLP_model.batch_size]) :\n",
    "        L_tr, L_te, A_tr, A_te, T = np.array([]), np.array([]), np.array([]), np.array([]), np.array([])\n",
    "        layer_name = {1 : 'L', 2 : 'L', 3 :'L'}\n",
    "        skeleton = {0: {}, 1 : {'size' : 1000}, 2 : {'size' : 1000}, 3 : {'size' : 10}}\n",
    "        fct = {depth : torch.nn.SELU() for depth in range(1, 3)}\n",
    "        fct.update({3 : torch.nn.Identity()})\n",
    "        dico_parameters = {\n",
    "                         'skeleton' : copy.deepcopy(skeleton),\n",
    "                        'Loss' : Loss_entropy,\n",
    "                        'fct' : fct,\n",
    "                        'layer_name' :layer_name,\n",
    "                        'rescale' : 'DE',\n",
    "                        'init_deplacement' :1e-8,\n",
    "                        'batch_size' : batch_size, #starting_batch_size,# batchsize for training\n",
    "                        'lr' : lr,# leraning rate for training\n",
    "                        'max_batch_estimation' : 100, # maximum size of batch at a time\n",
    "                        'init_X_shape' : [1, 28, 28], # size of the input, if your X are 1-d, unsqueeze it\n",
    "                        'len_train_dataset' : 50000, # size of training data\n",
    "                        'len_test_dataset' : 10000, # size of testing data\n",
    "                        }\n",
    "        MLP_big = TINY.TINY(dico_parameters)\n",
    "        MLP_big.training_data, MLP_big.test_data = load_data_Loader.load_database_MNIST(batch_size = MLP_big.batch_size)\n",
    "        MLP_big.tr_loader, MLP_big.te_loader =  iter(UTILS.cycle(DataLoader(MLP_model.training_data, batch_size=MLP_model.max_batch_estimation, shuffle=True))),  iter(UTILS.cycle(DataLoader(MLP_model.test_data, batch_size=MLP_model.max_batch_estimation, shuffle=True)))\n",
    "        optimizer = torch.optim.SGD(MLP_big.parameters(), lr = MLP_big.lr)\n",
    "        l_tr, l_te, _, a_tr, a_te, _, t = MLP_big.train_batch(epoch_sup, optimizer = optimizer)\n",
    "        L_tr, L_te = np.concatenate([L_tr, l_tr]), np.concatenate([L_te, l_te])\n",
    "        A_tr, A_te = np.concatenate([A_tr, a_tr]), np.concatenate([A_te, a_te])\n",
    "        T = np.concatenate([T, t])\n",
    "\n",
    "        dico_tracker['Big'][bs][expe] = {'L_tr' : L_tr, 'L_te' : L_te, 'A_tr' : A_tr, 'A_te' : A_te, 'T' : T, 'batch_size' : MLP_big.batch_size}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d7f903f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "#dico_tracker['Big']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c11286e5",
   "metadata": {},
   "source": [
    "### Register"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "56fbc0ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "var = 'A_te'\n",
    "limit = 500\n",
    "V_TINY = np.concatenate([dico_tracker['TINY'][expe]['A_te'][:limit][None, :] for expe in dico_tracker['TINY'].keys()])\n",
    "T_TINY = np.concatenate([dico_tracker['TINY'][expe]['T'][:limit][None, :] for expe in dico_tracker['TINY'].keys()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "5f9df8b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "V_BSbs = np.concatenate([dico_tracker['Big']['small_bs'][expe]['A_te'][:limit][None, :] for expe in dico_tracker['Big']['small_bs'].keys()])\n",
    "T_BSbs = np.concatenate([dico_tracker['Big']['small_bs'][expe]['T'][:limit][None, :] for expe in dico_tracker['Big']['small_bs'].keys()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3fe095e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "V_BBbs = np.concatenate([dico_tracker['Big']['big_bs'][expe]['A_te'][:limit][None, :] for expe in dico_tracker['Big']['big_bs'].keys()])\n",
    "T_BBbs = np.concatenate([dico_tracker['Big']['big_bs'][expe]['T'][:limit][None, :] for expe in dico_tracker['Big']['big_bs'].keys()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "7a9e489b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.17      , 0.16      , 0.12      , 0.28999999, 0.2       ,\n",
       "        0.14      , 0.11      , 0.14      , 0.14      , 0.14      ,\n",
       "        0.18000001, 0.25999999, 0.18000001, 0.14      , 0.20999999,\n",
       "        0.19      , 0.19      , 0.18000001, 0.2       , 0.17      ,\n",
       "        0.19      , 0.23999999, 0.15000001, 0.20999999, 0.25999999,\n",
       "        0.20999999, 0.22      , 0.17      , 0.17      , 0.22      ,\n",
       "        0.20999999, 0.17      , 0.18000001, 0.2       , 0.15000001,\n",
       "        0.14      , 0.22      , 0.25      , 0.2       , 0.09      ,\n",
       "        0.09      , 0.2       , 0.22      , 0.22      , 0.15000001,\n",
       "        0.16      , 0.12      , 0.19      , 0.18000001, 0.14      ,\n",
       "        0.19      , 0.18000001, 0.19      , 0.2       , 0.16      ,\n",
       "        0.30000001, 0.19      , 0.31      , 0.22      , 0.17      ,\n",
       "        0.19      , 0.1       , 0.18000001, 0.23999999, 0.25      ,\n",
       "        0.12      , 0.18000001, 0.13      , 0.17      , 0.14      ,\n",
       "        0.25999999, 0.2       , 0.2       , 0.25999999, 0.12      ,\n",
       "        0.17      , 0.16      , 0.2       , 0.13      , 0.18000001,\n",
       "        0.22      , 0.20999999, 0.19      , 0.15000001, 0.12      ,\n",
       "        0.20999999, 0.16      , 0.12      , 0.20999999, 0.25999999,\n",
       "        0.2       , 0.28      , 0.16      , 0.2       , 0.2       ,\n",
       "        0.16      , 0.18000001, 0.23      , 0.13      , 0.20999999,\n",
       "        0.14      , 0.15000001, 0.22      , 0.20999999, 0.17      ,\n",
       "        0.17      , 0.18000001, 0.08      , 0.14      , 0.16      ,\n",
       "        0.2       , 0.18000001, 0.20999999, 0.17      , 0.22      ,\n",
       "        0.25      , 0.22      , 0.22      , 0.14      , 0.23999999,\n",
       "        0.13      , 0.22      , 0.13      , 0.20999999, 0.23      ,\n",
       "        0.28999999, 0.1       , 0.19      , 0.23      , 0.22      ,\n",
       "        0.14      , 0.23999999, 0.16      , 0.23      , 0.27000001,\n",
       "        0.20999999, 0.23999999, 0.2       , 0.19      , 0.18000001,\n",
       "        0.25999999, 0.2       , 0.2       , 0.23      , 0.16      ,\n",
       "        0.28      , 0.25999999, 0.18000001, 0.27000001, 0.27000001,\n",
       "        0.17      , 0.27000001, 0.20999999, 0.25999999, 0.25999999,\n",
       "        0.34999999, 0.23      , 0.15000001, 0.20999999, 0.20999999,\n",
       "        0.19      , 0.25999999, 0.25      , 0.28      , 0.20999999,\n",
       "        0.2       , 0.18000001, 0.2       , 0.22      , 0.27000001,\n",
       "        0.22      , 0.27000001, 0.23      , 0.27000001, 0.2       ,\n",
       "        0.28999999, 0.2       , 0.18000001, 0.20999999, 0.25      ,\n",
       "        0.25999999, 0.22      , 0.2       , 0.13      , 0.2       ,\n",
       "        0.20999999, 0.25      , 0.25      , 0.23      , 0.25999999,\n",
       "        0.31999999, 0.28999999, 0.25      , 0.27000001, 0.23      ,\n",
       "        0.14      , 0.28999999, 0.19      , 0.28      , 0.25      ,\n",
       "        0.27000001, 0.23999999, 0.23      , 0.23999999, 0.23999999,\n",
       "        0.18000001, 0.11      , 0.2       , 0.23999999, 0.23      ,\n",
       "        0.31      , 0.22      , 0.31      , 0.23      , 0.30000001,\n",
       "        0.23      , 0.2       , 0.2       , 0.28      , 0.20999999,\n",
       "        0.20999999, 0.25      , 0.27000001, 0.25999999, 0.28999999,\n",
       "        0.22      , 0.34999999, 0.30000001, 0.20999999, 0.23      ,\n",
       "        0.28999999, 0.22      , 0.23      , 0.25999999, 0.31      ,\n",
       "        0.22      , 0.20999999, 0.28      , 0.25      , 0.25      ,\n",
       "        0.31999999, 0.22      , 0.28999999, 0.23999999, 0.30000001,\n",
       "        0.27000001, 0.25999999, 0.31999999, 0.34      , 0.31      ,\n",
       "        0.28      , 0.27000001, 0.28999999, 0.28      , 0.27000001,\n",
       "        0.31999999, 0.31      , 0.28      , 0.30000001, 0.41      ,\n",
       "        0.30000001, 0.33000001, 0.33000001, 0.38999999, 0.23999999,\n",
       "        0.27000001, 0.22      , 0.31      , 0.37      , 0.27000001,\n",
       "        0.31999999, 0.25999999, 0.31      , 0.28999999, 0.28      ,\n",
       "        0.28      , 0.30000001, 0.31      , 0.25      , 0.28999999,\n",
       "        0.37      , 0.31999999, 0.31      , 0.31      , 0.25999999,\n",
       "        0.34      , 0.43000001, 0.43000001, 0.50999999, 0.47      ,\n",
       "        0.55000001, 0.5       , 0.54000002, 0.47999999, 0.47      ,\n",
       "        0.56      , 0.58999997, 0.47      , 0.49000001, 0.61000001,\n",
       "        0.58999997, 0.62      , 0.56999999, 0.62      , 0.63      ,\n",
       "        0.56      , 0.47999999, 0.58999997, 0.56      , 0.55000001,\n",
       "        0.5       , 0.47      , 0.56      , 0.52999997, 0.52999997,\n",
       "        0.56      , 0.44999999, 0.52999997, 0.55000001, 0.56      ,\n",
       "        0.63999999, 0.55000001, 0.55000001, 0.54000002, 0.51999998,\n",
       "        0.54000002, 0.56      , 0.62      , 0.55000001, 0.69999999,\n",
       "        0.60000002, 0.54000002, 0.56      , 0.58999997, 0.5       ,\n",
       "        0.61000001, 0.64999998, 0.51999998, 0.54000002, 0.58999997,\n",
       "        0.66000003, 0.58999997, 0.66000003, 0.61000001, 0.62      ,\n",
       "        0.52999997, 0.58999997, 0.58999997, 0.74000001, 0.74000001,\n",
       "        0.79000002, 0.68000001, 0.79000002, 0.80000001, 0.75999999,\n",
       "        0.75999999, 0.75      , 0.79000002, 0.83999997, 0.74000001,\n",
       "        0.77999997, 0.80000001, 0.76999998, 0.75      , 0.80000001,\n",
       "        0.82999998, 0.76999998, 0.82999998, 0.81      , 0.79000002,\n",
       "        0.81999999, 0.86000001, 0.81999999, 0.73000002, 0.82999998,\n",
       "        0.85000002, 0.80000001, 0.80000001, 0.85000002, 0.80000001,\n",
       "        0.82999998, 0.81      , 0.81      , 0.86000001, 0.81999999,\n",
       "        0.80000001, 0.92000002, 0.81999999, 0.87      , 0.80000001,\n",
       "        0.80000001, 0.81      , 0.82999998, 0.86000001, 0.89999998,\n",
       "        0.88      , 0.80000001, 0.87      , 0.86000001, 0.86000001,\n",
       "        0.82999998, 0.88999999, 0.82999998, 0.83999997, 0.88      ,\n",
       "        0.81999999, 0.88      , 0.82999998, 0.87      , 0.88999999,\n",
       "        0.85000002, 0.77999997, 0.76999998, 0.88999999, 0.76999998,\n",
       "        0.83999997, 0.86000001, 0.88999999, 0.83999997, 0.83999997,\n",
       "        0.77999997, 0.88      , 0.80000001, 0.87      , 0.81      ,\n",
       "        0.82999998, 0.93000001, 0.81      , 0.88      , 0.81999999,\n",
       "        0.80000001, 0.88999999, 0.88      , 0.85000002, 0.87      ,\n",
       "        0.82999998, 0.86000001, 0.88999999, 0.85000002, 0.88      ,\n",
       "        0.88      , 0.87      , 0.88999999, 0.88999999, 0.86000001,\n",
       "        0.88999999, 0.85000002, 0.81999999, 0.86000001, 0.87      ,\n",
       "        0.77999997, 0.86000001, 0.87      , 0.85000002, 0.88      ,\n",
       "        0.88      , 0.87      , 0.85000002, 0.94      , 0.87      ,\n",
       "        0.83999997, 0.83999997, 0.88      , 0.92000002, 0.91000003,\n",
       "        0.87      , 0.81999999, 0.83999997, 0.91000003, 0.92000002,\n",
       "        0.87      , 0.83999997, 0.88999999, 0.86000001, 0.85000002,\n",
       "        0.91000003, 0.89999998, 0.86000001, 0.88      , 0.92000002,\n",
       "        0.93000001, 0.85000002, 0.89999998, 0.88999999, 0.82999998,\n",
       "        0.88999999, 0.92000002, 0.87      , 0.87      , 0.87      ,\n",
       "        0.81      , 0.85000002, 0.86000001, 0.82999998, 0.83999997,\n",
       "        0.83999997, 0.89999998, 0.85000002, 0.88      , 0.89999998],\n",
       "       [0.09      , 0.11      , 0.12      , 0.12      , 0.08      ,\n",
       "        0.13      , 0.08      , 0.13      , 0.14      , 0.09      ,\n",
       "        0.11      , 0.09      , 0.09      , 0.1       , 0.13      ,\n",
       "        0.07      , 0.06      , 0.13      , 0.12      , 0.11      ,\n",
       "        0.11      , 0.1       , 0.09      , 0.12      , 0.17      ,\n",
       "        0.06      , 0.16      , 0.11      , 0.1       , 0.09      ,\n",
       "        0.14      , 0.12      , 0.15000001, 0.12      , 0.11      ,\n",
       "        0.13      , 0.15000001, 0.12      , 0.1       , 0.11      ,\n",
       "        0.09      , 0.14      , 0.12      , 0.14      , 0.16      ,\n",
       "        0.09      , 0.15000001, 0.09      , 0.15000001, 0.08      ,\n",
       "        0.11      , 0.08      , 0.1       , 0.12      , 0.08      ,\n",
       "        0.15000001, 0.08      , 0.1       , 0.13      , 0.12      ,\n",
       "        0.14      , 0.12      , 0.09      , 0.12      , 0.18000001,\n",
       "        0.11      , 0.13      , 0.08      , 0.13      , 0.1       ,\n",
       "        0.1       , 0.15000001, 0.08      , 0.08      , 0.1       ,\n",
       "        0.09      , 0.1       , 0.13      , 0.1       , 0.17      ,\n",
       "        0.11      , 0.1       , 0.1       , 0.14      , 0.08      ,\n",
       "        0.18000001, 0.11      , 0.13      , 0.16      , 0.13      ,\n",
       "        0.14      , 0.11      , 0.09      , 0.17      , 0.14      ,\n",
       "        0.1       , 0.15000001, 0.16      , 0.13      , 0.11      ,\n",
       "        0.18000001, 0.15000001, 0.12      , 0.08      , 0.14      ,\n",
       "        0.13      , 0.15000001, 0.17      , 0.14      , 0.11      ,\n",
       "        0.09      , 0.14      , 0.09      , 0.15000001, 0.16      ,\n",
       "        0.13      , 0.15000001, 0.12      , 0.18000001, 0.09      ,\n",
       "        0.15000001, 0.15000001, 0.17      , 0.18000001, 0.1       ,\n",
       "        0.12      , 0.13      , 0.12      , 0.14      , 0.07      ,\n",
       "        0.15000001, 0.12      , 0.22      , 0.16      , 0.1       ,\n",
       "        0.13      , 0.16      , 0.18000001, 0.2       , 0.19      ,\n",
       "        0.19      , 0.11      , 0.15000001, 0.1       , 0.12      ,\n",
       "        0.07      , 0.17      , 0.1       , 0.16      , 0.13      ,\n",
       "        0.09      , 0.12      , 0.19      , 0.12      , 0.13      ,\n",
       "        0.14      , 0.15000001, 0.17      , 0.15000001, 0.16      ,\n",
       "        0.15000001, 0.22      , 0.28      , 0.22      , 0.18000001,\n",
       "        0.23      , 0.13      , 0.18000001, 0.16      , 0.14      ,\n",
       "        0.25      , 0.22      , 0.28      , 0.18000001, 0.27000001,\n",
       "        0.19      , 0.2       , 0.18000001, 0.25999999, 0.33000001,\n",
       "        0.23      , 0.28999999, 0.20999999, 0.23      , 0.27000001,\n",
       "        0.31999999, 0.22      , 0.2       , 0.27000001, 0.22      ,\n",
       "        0.22      , 0.31999999, 0.33000001, 0.23999999, 0.31      ,\n",
       "        0.34      , 0.31      , 0.20999999, 0.33000001, 0.28999999,\n",
       "        0.28999999, 0.30000001, 0.25999999, 0.2       , 0.31      ,\n",
       "        0.31999999, 0.28      , 0.25999999, 0.14      , 0.30000001,\n",
       "        0.27000001, 0.28      , 0.23999999, 0.30000001, 0.31      ,\n",
       "        0.30000001, 0.31999999, 0.28999999, 0.31999999, 0.27000001,\n",
       "        0.19      , 0.23999999, 0.28      , 0.25999999, 0.25      ,\n",
       "        0.31      , 0.31999999, 0.25999999, 0.23999999, 0.31      ,\n",
       "        0.33000001, 0.36000001, 0.31      , 0.27000001, 0.27000001,\n",
       "        0.31999999, 0.28      , 0.37      , 0.31999999, 0.20999999,\n",
       "        0.36000001, 0.27000001, 0.36000001, 0.23999999, 0.28      ,\n",
       "        0.30000001, 0.31999999, 0.18000001, 0.31999999, 0.33000001,\n",
       "        0.23999999, 0.20999999, 0.25      , 0.30000001, 0.34      ,\n",
       "        0.20999999, 0.27000001, 0.2       , 0.31      , 0.34      ,\n",
       "        0.25999999, 0.23999999, 0.28      , 0.25      , 0.34999999,\n",
       "        0.34999999, 0.20999999, 0.30000001, 0.25      , 0.28999999,\n",
       "        0.31      , 0.34      , 0.33000001, 0.31      , 0.20999999,\n",
       "        0.36000001, 0.33000001, 0.40000001, 0.31      , 0.36000001,\n",
       "        0.38999999, 0.30000001, 0.27000001, 0.28999999, 0.34999999,\n",
       "        0.34999999, 0.37      , 0.31      , 0.44999999, 0.37      ,\n",
       "        0.43000001, 0.46000001, 0.63      , 0.60000002, 0.47      ,\n",
       "        0.47999999, 0.61000001, 0.54000002, 0.44      , 0.44999999,\n",
       "        0.61000001, 0.61000001, 0.5       , 0.50999999, 0.47999999,\n",
       "        0.61000001, 0.56      , 0.58999997, 0.58999997, 0.50999999,\n",
       "        0.55000001, 0.55000001, 0.60000002, 0.54000002, 0.57999998,\n",
       "        0.60000002, 0.66000003, 0.60000002, 0.50999999, 0.66000003,\n",
       "        0.67000002, 0.64999998, 0.54000002, 0.57999998, 0.56      ,\n",
       "        0.67000002, 0.62      , 0.63      , 0.56      , 0.66000003,\n",
       "        0.63      , 0.68000001, 0.51999998, 0.64999998, 0.46000001,\n",
       "        0.52999997, 0.63999999, 0.57999998, 0.51999998, 0.66000003,\n",
       "        0.64999998, 0.63      , 0.63999999, 0.69      , 0.61000001,\n",
       "        0.61000001, 0.67000002, 0.62      , 0.75999999, 0.81      ,\n",
       "        0.75      , 0.79000002, 0.75      , 0.74000001, 0.77999997,\n",
       "        0.69      , 0.69999999, 0.75      , 0.74000001, 0.73000002,\n",
       "        0.76999998, 0.80000001, 0.70999998, 0.70999998, 0.75      ,\n",
       "        0.72000003, 0.80000001, 0.80000001, 0.77999997, 0.80000001,\n",
       "        0.72000003, 0.76999998, 0.74000001, 0.75999999, 0.81      ,\n",
       "        0.77999997, 0.75      , 0.87      , 0.75999999, 0.80000001,\n",
       "        0.77999997, 0.66000003, 0.81      , 0.80000001, 0.80000001,\n",
       "        0.74000001, 0.74000001, 0.82999998, 0.79000002, 0.82999998,\n",
       "        0.87      , 0.83999997, 0.85000002, 0.81999999, 0.74000001,\n",
       "        0.77999997, 0.87      , 0.75999999, 0.82999998, 0.80000001,\n",
       "        0.81999999, 0.79000002, 0.77999997, 0.77999997, 0.82999998,\n",
       "        0.81      , 0.87      , 0.88999999, 0.85000002, 0.87      ,\n",
       "        0.91000003, 0.86000001, 0.82999998, 0.81      , 0.81999999,\n",
       "        0.79000002, 0.85000002, 0.80000001, 0.81      , 0.81999999,\n",
       "        0.75999999, 0.88      , 0.87      , 0.80000001, 0.83999997,\n",
       "        0.86000001, 0.81999999, 0.81999999, 0.81999999, 0.81999999,\n",
       "        0.92000002, 0.77999997, 0.86000001, 0.81999999, 0.75999999,\n",
       "        0.89999998, 0.81999999, 0.88999999, 0.86000001, 0.83999997,\n",
       "        0.80000001, 0.91000003, 0.85000002, 0.85000002, 0.86000001,\n",
       "        0.88999999, 0.75      , 0.86000001, 0.83999997, 0.82999998,\n",
       "        0.77999997, 0.83999997, 0.85000002, 0.81999999, 0.87      ,\n",
       "        0.87      , 0.87      , 0.85000002, 0.86000001, 0.81999999,\n",
       "        0.83999997, 0.88      , 0.82999998, 0.83999997, 0.81      ,\n",
       "        0.88      , 0.83999997, 0.85000002, 0.89999998, 0.87      ,\n",
       "        0.83999997, 0.85000002, 0.82999998, 0.81999999, 0.81      ,\n",
       "        0.88      , 0.87      , 0.81999999, 0.88999999, 0.91000003,\n",
       "        0.83999997, 0.81      , 0.86000001, 0.86000001, 0.85000002,\n",
       "        0.83999997, 0.81999999, 0.86000001, 0.85000002, 0.91000003,\n",
       "        0.83999997, 0.86000001, 0.82999998, 0.86000001, 0.91000003,\n",
       "        0.87      , 0.89999998, 0.85000002, 0.88999999, 0.80000001]])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "V_TINY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "7602a8d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_tracker = pd.DataFrame.from_dict({'V_TINY' : V_TINY.mean(axis = 0), 'T_TINY' : T_TINY.mean(axis = 0), \n",
    "                                     'V_BSbs' : V_BSbs.mean(axis = 0), 'T_BSbs' : T_BSbs.mean(axis = 0),\n",
    "                                     'V_BBbs' : V_BBbs.mean(axis = 0), 'T_BBbs' : T_BBbs.mean(axis = 0)})\n",
    "#df_tracker.to_csv('csv/df_tracker_TINY_vs_Big.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "427ad702",
   "metadata": {},
   "source": [
    "## Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "47fcaab5",
   "metadata": {},
   "outputs": [],
   "source": [
    "columns = ['V_TINY', 'T_TINY', 'V_BSbs', 'T_BSbs', 'V_BBbs', 'T_BBbs']\n",
    "#df_tracker = pd.read_csv('csv/df_tracker_TINY_vs_Big.csv')[columns].to_dict(orient = 'series')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "92b0bc83",
   "metadata": {},
   "outputs": [],
   "source": [
    "#V_TINY, T_TINY = np.array(df_tracker['V_TINY'])[None, :], np.array(df_tracker['T_TINY'])[None, :]\n",
    "#V_BSbs, T_BSbs = np.array(df_tracker['V_BSbs'])[None, :], np.array(df_tracker['T_BSbs'])[None, :]\n",
    "#V_BBbs, T_BBbs = np.array(df_tracker['V_BBbs'])[None, :], np.array(df_tracker['T_BBbs'])[None, :]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "fd154e78",
   "metadata": {},
   "outputs": [],
   "source": [
    "#V_TINY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "73c4d6a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "struc = str(list(np.array(strucs).mean(axis = 0).astype(int)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "503483b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "num = 15\n",
    "\n",
    "def mean_std(my_arr, my_T) :\n",
    "    V_smooth = torch.conv1d(torch.from_numpy(my_arr.mean(axis = 0)[None,:].astype(np.float32)), kernel, padding = 'same')[0]\n",
    "    T_smooth = torch.conv1d(torch.from_numpy(my_T.mean(axis = 0)[None,:].astype(np.float32)), kernel, padding = 'same')[0]\n",
    "    V_smooth_std = torch.conv1d(torch.from_numpy(my_arr.std(axis = 0)[None,:].astype(np.float32)), kernel, padding = 'same')[0]\n",
    "    T_smooth_std = torch.conv1d(torch.from_numpy(my_T.std(axis = 0)[None,:].astype(np.float32)), kernel, padding = 'same')[0]\n",
    "    return(V_smooth, T_smooth, V_smooth_std, T_smooth_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "981ff6eb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "4bf7a82a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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onYDNJTF3pqWTXXYZmjmZkZKdnHunuP4rXYlVsjCld+2UzGx10RmlcwiYkaY0GsCtxx4C08tfIoUT9s1ejsyEd3k4S9WUtqYP61XrEdNynR22hayJwE8CaT6hKMlEAgchG3aBhS1LD/YUGexR1ZLZ+rqvY7kh9plmNVRPPltf//Deh/Gd0XfoVkax/Q7hqv3upo3V7yJ39W287uj0ff/PuzpKbRg3T3HdvncztS5NDXs7devH5dddhlPPvlkbF/fvn1Zv349BxxwAD/++GPcueeffz4vvPACmzZtIjMzkwMOOIClS5eycOFCBg4cGHf866+/zumnn84111zDww8/3KH52baNZduARHkg2sLB2pwx+x3AKWeeS1Z2bvO5ps5/n/0P337xCevWrKKutoaU1DSG7zGMP197LSeeeGLcONOmTWP+/PnMmzePtWvX0qdPH9atW9ehuXaGUCjEiBEjWLt2bdx1B6cu9aWXXmLevHksWLCAUCjE888/z/nnnx831pAhQ3jxxReprKzkz3/+c7fPdWeny4miqqpy3XXXcd1113XbZPbdd1+eeuopZs2aFWfMZs2aRWJiIkOHDm3z/P333x+g1dW+pj4lOTk53TbfHZKiOS3erqy2GJLR0uldM+hQfqtdhhk0Y6uEPtXHCQNO4LfK37h01KVsqN9AqjeVkwaexPr69by54k0uHnkxKZ6UnS4VQzMsVpU3MGt1JfPW18ScLKOhGldmb8xgDeG1v+ApGAaAW5FJE6mDAoGgEWGbuploA1Qsjb0tCVjkJ7W0UxXpfZldtxIraiF5nAd3t+xm8qDJLKxYyBV7XsH6+vWk+9I5YcAJrK1by5sr3uTK0Vfid/l3WqGmXYEXX3yxxfulS5dy9913c/LJJzN58uQW+7KysqioqGh3vNmzZzNjxoy4czdHVVX++9//svfee3Peeefx3XfftVjwLysr48orr2TIkCFMmzatzXFMy0aRJcrrI/jcSosUwdacLNt0VAULe/fjuD+ciW1o2IYGtoWkevhtwXzye/XhkMOOJCU1nUBdLd999j4nnXQSt912GzfffHOL8W666SbS09MZM2YMtbW17V6XreHmm29u97p/9NFHPP744wwdOpTRo0cza9asNo/NysrinHPOYd26dcLRaoUuOVoXXnghl112Wcx4/J6ff/6ZJ598Mq6/1pY48cQT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adOmMXLkyK0eu6MsX76cp59+mnnz5vHLL79QV1fHLbfcwq233trmOdty3h0d++KLL2bChAnMmDGDt99+u8vff2vp0pVfuHAhf/3rX9vcv//++3Pfffd1eVKCDrDhJ2zbplaWWe5uqaynyirH9j+2hybW81Q1aLgUmSSvUBwUCASCHqNyBURqAZjti1/4OmngSdt3PoLtzumnn85xxx0HQDgc5tdff+WZZ57hzTffZNGiRfTu3RuAjRs3su+++xIIBDj77LO54oorAFi1ahUffvghDQ0NW+1oRTeLZnk72TfriCOOaDWCNm3aNKqqqthrr70IBoMUFRW1OYau6xx55JHMmTOHP/3pT4waNYpvv/2WG2+8keXLl/P888+3OP69997j5JNPZo899mDatGlEo1H+9a9/MXbsWH744YcWjkVnx+4MP/74I//85z8ZMGAAe++9N1999VW7x2/LeXdm7AMOOIADDjiAVatW7XyOVl1dHQkJCW3u9/l81NTUdHlSgg6wcTbFAZvqLD+2JGEEDNQk58c5eeBkMn2ZPTzBnqMmpJHmF06WQCAQ9CgbZgNQ3iiCsflK/wF5BzA8c3hPzUywnRg9ejTnnHNOi22DBg3immuuYcaMGVx77bUA3H///ZSVlfHee+9x/PHHtzj+oYceateB6Six/lkSeF3dk/Ezc+ZMevfujSzLHHfcce3O87nnnmP27Nk8+OCDXHfddYATdUlJSeGxxx7joosu4uCDDwbAMAyuuuoq8vPz+eGHH0hOTgbgtNNOY4899uDPf/4zX3zxRZfG7iwnnHAC1dXVpKamMnfuXPbdd982j92W8+7s2DsKXfpNKygoYP78+W3unzdvHrm5uV2elGALRANQuoiIAWsSnZosM2iiJDgrNGfvcXZPzq7Hqa4LkJGy+6ktCgQCwQ7FhtnYts06l7PwpVfruNKd1+cMO6e9MwW7ME1K1S5X84LoihUrANosOSksLGx1+/z585k4cSKJiYmkp6dz7rnnUlZW1uKYSCTCrbfeygFjRrH/oHzGjhjAhP33YsqUKVv9Xfr27Yssd+xR+uWXX8bn88WidU385S9/AWhR//Xtt9+yceNGLr744phDAdC7d2/+8Ic/8NVXX1FSUtKlsTtLeno6qampHTp2W867s2PvKHTJ0Tr22GOZPn16q+HDL774ghdeeIFJkyZt9eQE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",
      "text/plain": [
       "<Figure size 1000x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ft = 13\n",
    "plt.rcParams.update({'font.size': ft})\n",
    "\n",
    "kernel = torch.cat([torch.ones(num) / num, torch.zeros(num)])[None, None, :]\n",
    "fig, ax = plt.subplots(1, 2, figsize = (10, 3))\n",
    "\n",
    "for V, T, label  in zip([V_TINY, V_BSbs, V_BBbs], [T_TINY, T_BSbs, T_BBbs], ['TINY : ' + struc, 'BSbs [1000, 1000]', 'BBbs [1000, 1000]']) :\n",
    "    V_smooth, T_smooth, V_smooth_std, T_smooth_std = mean_std(V, T)\n",
    "    #if label == 'BBbs' :\n",
    "    ax[1].fill_between(np.arange(V_smooth.shape[0]), V_smooth - V_smooth_std, V_smooth + V_smooth_std, label = label)\n",
    "    ax[1].plot(V_smooth, '-', linewidth=.1, color = 'black')\n",
    "    \n",
    "    ax[0].fill_between(T_smooth, V_smooth - V_smooth_std, V_smooth + V_smooth_std, label = label)\n",
    "    ax[0].plot(T_smooth, V_smooth, linewidth=0.1, color = 'black')\n",
    "    \n",
    "ax[0].set_xlabel('time', fontsize = ft)\n",
    "ax[1].set_xlabel('step', fontsize = ft)\n",
    "\n",
    "ax[0].set_ylabel('Accuracy test', fontsize = ft)\n",
    "ax[0].legend()\n",
    "ax[1].legend()\n",
    "plt.savefig('figures/TINY_vs_Big.png', bbox_inches = 'tight')\n",
    "\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66b4d90b",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
