{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f93d2112-fae7-434a-9ef1-0d090ffd703f",
   "metadata": {},
   "source": [
    "## DEMO MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "02610df0-55cb-4e89-9947-7c7264616334",
   "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": 2,
   "id": "718c5f2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.set_default_dtype(torch.float64)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7886e29f-45bd-448e-b2f8-d0dfdbfe09e5",
   "metadata": {},
   "source": [
    "We define the name of the layer by \n",
    "- 'L' for a linear layer\n",
    "- 'CB' for a convolutional followed by a batchnorm\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d4f40206-5b63-4af0-9dd1-c9c75dab2953",
   "metadata": {},
   "outputs": [],
   "source": [
    "layer_name = {1 : 'L', 2 : 'L', 3 :'L'}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "00f75e5a-408a-421a-b435-b316b9e1d8d8",
   "metadata": {},
   "source": [
    "We define the starting size of the model by the number of neurons in the starting architecture. In this example we start with 5 neurons by hidden layers.\n",
    "The last layer should be of the size of the prediction. For the MNIST dataset there is 10 classes so the size of the last layer is 10."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "ba81adb4-a438-445b-aa61-858cdb503540",
   "metadata": {},
   "outputs": [],
   "source": [
    "skeleton = {0: {}, 1 : {'size' : 5}, 2 : {'size' : 5}, 3 : {'size' : 10}}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c806ed47-ef1d-4a09-b78e-c127d2125469",
   "metadata": {},
   "source": [
    "We select the activation function for all layers. In this notebook as we use the CrossEntropy loss https://pytorch.org/docs/stable/generated/torch.nn.CrossEntropyLoss.html we choose the Identity for the activation function at the last layer."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "8ad9e113-de06-4cda-a8b5-64327ace6429",
   "metadata": {},
   "outputs": [],
   "source": [
    "fct = {depth : torch.nn.ReLU() for depth in range(1, 3)}\n",
    "fct.update({3 : torch.nn.Identity()})"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "24d4e928-6ead-4bdb-ae80-5c4774850052",
   "metadata": {},
   "source": [
    "We define the loss function :"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "e6238d6f-7a6b-4f3a-921f-280a9f323d3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "### Loss function ###\n",
    "def Loss_entropy(x1, x2, reduction = 'mean') :\n",
    "    #print(x1.shape, x2.shape)\n",
    "    return(torch.nn.CrossEntropyLoss(reduction = reduction)(x1, x2))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3f67c9d3-6212-4e24-9994-e8da24f78281",
   "metadata": {},
   "source": [
    "## MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "a58059ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "dico_parameters = {\n",
    "                 'skeleton' : copy.deepcopy(skeleton),\n",
    "                'Loss' : Loss_entropy,\n",
    "                'fct' : fct,\n",
    "                'layer_name' :layer_name,\n",
    "                'init_deplacement' : 1e-8, # min amplitude factor\n",
    "                'batch_size' : 64,# batchsize for training\n",
    "                'lr' : 1e-2,# 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' : 1e-4,# 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 per layer\n",
    "                'lu_lin' : 2,\n",
    "                'max_batch_estimation' : 100,\n",
    "                'gradient_clip' : 1e-3,\n",
    "                'max_amplitude' : 1., # 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 them\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "a4ff47de",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "After layer 1 : x.shape=torch.Size([1, 5])\n",
      "After layer 2 : x.shape=torch.Size([1, 5])\n",
      "After layer 3 : x.shape=torch.Size([1, 10])\n",
      "Time to build the model: 0.02 seconds\n"
     ]
    }
   ],
   "source": [
    "MLP_model = TINY.TINY(dico_parameters)\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.batch_size, shuffle=True))),  iter(UTILS.cycle(DataLoader(MLP_model.test_data, batch_size=MLP_model.batch_size, shuffle=True)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "5893e8e2-9e18-4047-b55b-148df39145f3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{1: {'L': Linear(in_features=784, out_features=5, bias=True)},\n",
       " 2: {'L': Linear(in_features=5, out_features=5, bias=True)},\n",
       " 3: {'L': Linear(in_features=5, out_features=10, bias=True)}}"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MLP_model.layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "74caa1e3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<generator object cycle at 0x7f34286827b0>"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MLP_model.tr_loader\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba4d7049",
   "metadata": {},
   "source": [
    "The starting performances are :"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "3ae0c7d5-77c9-4a59-a7c7-db5c9b31ce90",
   "metadata": {},
   "outputs": [],
   "source": [
    "X, Y = MLP_model.get_batch(data = 'tr', device = my_device_0) # parametres par défault\n",
    "X_te, Y_te =  MLP_model.get_batch(data = 'te', device = my_device_0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "cfac5430",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loss on train : 2.4015295611811665  || Loss on test : 2.4537338457076068\n",
      "Accuracy on train : 0.0625  || Accuracy on test : 0.125\n"
     ]
    }
   ],
   "source": [
    "with torch.no_grad() :\n",
    "    print('Loss on train :', MLP_model.Loss(Y, MLP_model(X)).item(), ' || Loss on test :', MLP_model.Loss(Y_te, MLP_model(X_te)).item())\n",
    "    print('Accuracy on train :', UTILS.calculate_accuracy(Y, MLP_model(X)), ' || Accuracy on test :', UTILS.calculate_accuracy(Y_te, MLP_model(X_te)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2df4851f-e3cf-437f-913e-9b87d78205c0",
   "metadata": {},
   "source": [
    "You can acces the basic functions of your model in the module TINY\n",
    "- count_parameters, count_parameters_layer, get_parameters, ....\n",
    "- get_batch, train_batch, ..."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "9904b37f-3514-4f61-91fd-eee2d8ffb231",
   "metadata": {},
   "outputs": [],
   "source": [
    "optimizer = torch.optim.SGD(MLP_model.parameters(), lr = 1e-4)\n",
    "L_tr, L_te, _, A_tr, A_te, _, T = MLP_model.train_batch(optimizer = optimizer, nbr_epoch = 0.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "c1de4c9f-e15b-4ebe-8136-d984a70d00ad",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(L_tr, label = 'L_tr')\n",
    "plt.plot(L_te, label = 'L_te')\n",
    "plt.xlabel('step')\n",
    "plt.ylabel('Accuracy test')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "00f7cef8-90a5-46f1-a01b-298f10058ce7",
   "metadata": {},
   "source": [
    "## architecture growth and training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "35d45f49-df3a-4d75-819f-ee6b2040fdc1",
   "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",
    "to_add = [1, 2] ##  depth where neurons can be added\n",
    "nbr_pass = 20\n",
    "#nbr_epochs_betw_adding = 0.5 ## Epochs of training between adding\n",
    "nbr_steps_betw_adding = 100\n",
    "\n",
    "name_file_expe = 'results/' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "fa48d48e",
   "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) : [ MLP_model.valeurs_propres[i].item()] for i in range(len(MLP_model.valeurs_propres))}\n",
    "    \n",
    "    dico_tracker.update({'depth_add' : best_depth, 'nbr_added_neuron': MLP_model.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' : [MLP_model.count_parameters()], 'nbr_parameters_avant' : [nbr_parameters_avant],\n",
    "                        'T' : [T[-1]], 'len_L_tr' : [len(L_tr)], 'lu_conv' : [MLP_model.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",
    "    \n",
    "    \n",
    "def AugBatchSizeLearning() :\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": 51,
   "id": "67107318",
   "metadata": {},
   "outputs": [],
   "source": [
    "#MLP_model.tr_loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "8a9e2255",
   "metadata": {},
   "outputs": [],
   "source": [
    "count = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "ca985679",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/json": {
       "ascii": false,
       "bar_format": null,
       "colour": null,
       "elapsed": 0.0076313018798828125,
       "initial": 0,
       "n": 0,
       "ncols": null,
       "nrows": null,
       "postfix": null,
       "prefix": "",
       "rate": null,
       "total": 5,
       "unit": "it",
       "unit_divisor": 1000,
       "unit_scale": false
      },
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "054ba735db4f453fba095a4ef2494ad5",
       "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 : 50000\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: 75.7818505568624\n",
      "norm_x_over_norm_DE_depthp1 :  5412.57259428076\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -2.174182721081941e-07, -4.3481016526181193e-07]  ... [-0.0005875432605257358, -0.0006385258979269559, 0.0004072505028638318]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [3.0517578125e-05, 6.103515625e-05, 0.0001220703125]\n",
      "rate of decrease : 0.0019248807879457025 ampli_fct : 6.103515625e-05 L[0] : 0.3317223081687112\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 4900\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\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: 121.86722754499525\n",
      "norm_x_over_norm_DE_depthp1 :  113.52866884774997\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -7.018631181798796e-08, -1.4037093487573316e-07]  ... [-0.0009266012441462301, -0.0013757611587057461, 0.0005708732035680786]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.0001220703125, 0.000244140625, 0.00048828125]\n",
      "rate of decrease : 0.004258148853202917 ampli_fct : 0.000244140625 L[0] : 0.32308902439399667\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.765156499710843\n",
      "norm_x_over_norm_DE_depthp1 :  0.0065595601692341726\n",
      "amplitude factor for the new neurons : 0.000244140625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.878\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 70.448390752325\n",
      "norm_x_over_norm_DE_depthp1 :  5336.61181024149\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, 1.0936158872931756e-07]  ... [0.0, 1.0936158872931756e-07]\n",
      "betas :  [0.0, 7.450580596923828e-09] ... [0.0, 7.450580596923828e-09]\n",
      "rate of decrease : 0.0 ampli_fct : 0.0 L[0] : 0.33849387880873005\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5100\n",
      "*** SINGULAR MATRIX ***\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\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: 122.25236773780593\n",
      "norm_x_over_norm_DE_depthp1 :  124.45553734373773\n",
      "L_plus < L_moins: 0.28707827199464137 < 0.2870783974866715\n",
      "Delta Loss :  [0.0, -8.916533805747306e-07, -1.7833040907855313e-06]  ... [-0.0207598409609695, -0.02262667978633509, -0.012666293224225411]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.000244140625, 0.00048828125, 0.0009765625]\n",
      "rate of decrease : 0.06113517717961692 ampli_fct : 0.00048828125 L[0] : 0.370109008106041\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.6961285358391464\n",
      "norm_x_over_norm_DE_depthp1 :  0.005348173066280988\n",
      "amplitude factor for the new neurons : 0.00048828125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.8840000000000001\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 65.83553788488456\n",
      "norm_x_over_norm_DE_depthp1 :  4976.3346489747555\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -8.474225993149176e-08, -1.6941753910870716e-07]  ... [-3.461707983631879e-05, -4.329850795375956e-05, -8.441539818992982e-06]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [3.814697265625e-06, 7.62939453125e-06, 1.52587890625e-05]\n",
      "rate of decrease : 0.00013462765945414899 ampli_fct : 7.62939453125e-06 L[0] : 0.3216167326187975\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5300\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\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: 122.60593076088547\n",
      "norm_x_over_norm_DE_depthp1 :  119.62257020379377\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -1.2445454250498145e-07, -2.4889375699332916e-07]  ... [-0.000593977258988021, -0.0006283153556648213, 0.000326619454558863]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [6.103515625e-05, 0.0001220703125, 0.000244140625]\n",
      "rate of decrease : 0.0019024852809203636 ampli_fct : 0.0001220703125 L[0] : 0.33026029791981454\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.0250133097807022\n",
      "norm_x_over_norm_DE_depthp1 :  0.008254036142216014\n",
      "amplitude factor for the new neurons : 0.0001220703125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.89\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 71.48958267437398\n",
      "norm_x_over_norm_DE_depthp1 :  5025.233584775587\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -1.2901993462488548e-07, -2.5802071884628575e-07]  ... [-0.00019599467840836216, -0.0002804194000119997, -0.00021716082145917248]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [1.52587890625e-05, 3.0517578125e-05, 6.103515625e-05]\n",
      "rate of decrease : 0.0009268384401191791 ampli_fct : 3.0517578125e-05 L[0] : 0.3025547796398491\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5500\n",
      "*** SINGULAR MATRIX ***\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\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: 109.2003671115092\n",
      "norm_x_over_norm_DE_depthp1 :  69.55981479816487\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -2.6020651150426843e-07, -5.204085740118103e-07]  ... [-0.007165103975991571, -0.008927295800069679, -0.006281986844721199]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.000244140625, 0.00048828125, 0.0009765625]\n",
      "rate of decrease : 0.029102781618323772 ampli_fct : 0.00048828125 L[0] : 0.30675060264510423\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.9665968746636642\n",
      "norm_x_over_norm_DE_depthp1 :  0.010958009029399845\n",
      "amplitude factor for the new neurons : 0.00048828125\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.8959999999999999\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 62.85094797696898\n",
      "norm_x_over_norm_DE_depthp1 :  4186.067343344818\n",
      "L_plus < L_moins: 0.27444073897680643 < 0.2744408296268271\n",
      "Delta Loss :  [0.0, 1.0545470935374723e-07]  ... [0.0, 1.0545470935374723e-07]\n",
      "betas :  [0.0, 7.450580596923828e-09] ... [0.0, 7.450580596923828e-09]\n",
      "rate of decrease : 0.0 ampli_fct : 0.0 L[0] : 0.33788725238553613\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5700\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\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: 120.90871915871917\n",
      "norm_x_over_norm_DE_depthp1 :  123.36412549866802\n",
      "L_plus < L_moins: 0.2744414784366176 < 0.2744416123406916\n",
      "Delta Loss :  [0.0, -7.709821797652339e-08, -1.5419369009395112e-07]  ... [-0.0008842493023628051, -0.0009695590419955269, 0.001645103618920507]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.0001220703125, 0.000244140625, 0.00048828125]\n",
      "rate of decrease : 0.002950543478472863 ampli_fct : 0.000244140625 L[0] : 0.3286035434046034\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.970628507818449\n",
      "norm_x_over_norm_DE_depthp1 :  0.008138627567966895\n",
      "amplitude factor for the new neurons : 0.000244140625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.902\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 69.03030697341939\n",
      "norm_x_over_norm_DE_depthp1 :  4719.522792016143\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -1.5456947993763848e-07, -3.091226790652435e-07]  ... [-0.00046564484651262505, -0.000613545671448279, -4.9161849849876926e-05]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [3.0517578125e-05, 6.103515625e-05, 0.0001220703125]\n",
      "rate of decrease : 0.0022943088047134436 ampli_fct : 6.103515625e-05 L[0] : 0.26742070212510477\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5900\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3000\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: 45.040808807965654\n",
      "norm_x_over_norm_DE_depthp1 :  7.220080817098675\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -1.2236875457372065e-08, -2.4473253812384854e-08]  ... [-8.337590455387289e-05, -0.00013248196673387724, -0.00012770110605925256]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [6.103515625e-05, 0.0001220703125, 0.000244140625]\n",
      "rate of decrease : 0.000487510079786387 ampli_fct : 0.0001220703125 L[0] : 0.2717522615982157\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 3000\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.0170328529027726\n",
      "norm_x_over_norm_DE_depthp1 :  0.01395767170802839\n",
      "amplitude factor for the new neurons : 6.103515625e-05\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.932\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 74.74678003761471\n",
      "norm_x_over_norm_DE_depthp1 :  5631.7078100659965\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -2.8524947071062456e-08, -5.70351462725327e-08]  ... [-2.376557514047195e-05, -3.838689105883919e-05, 5.574634884542018e-06]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [7.62939453125e-06, 1.52587890625e-05, 3.0517578125e-05]\n",
      "rate of decrease : 0.0001664233070046181 ampli_fct : 1.52587890625e-05 L[0] : 0.23065814368040402\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5900\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3200\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.866375687165173e-05\n",
      "norm_x_over_norm_DE_depthp1 :  1.5068908388137316e-12\n",
      "L_plus < L_moins: 0.25881054762520805 < 0.2588105476252366\n",
      "Delta Loss :  [0.0, 2.55351295663786e-15]  ... [0.0, 2.55351295663786e-15]\n",
      "betas :  [0.0, 7.450580596923828e-09] ... [0.0, 7.450580596923828e-09]\n",
      "rate of decrease : 0.0 ampli_fct : 0.0 L[0] : 0.28402915224499764\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 3200\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 1.1385984026971063\n",
      "norm_x_over_norm_DE_depthp1 :  0.013832959171521799\n",
      "amplitude factor for the new neurons : 1.52587890625e-05\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.962\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 0.5312321548800364\n",
      "norm_x_over_norm_DE_depthp1 :  46.00888179504485\n",
      "L_plus < L_moins: 0.26410072517231153 < 0.2641007251889498\n",
      "Delta Loss :  [0.0, -7.705613924713361e-12, -1.5411283360577954e-11]  ... [-0.00014420919491925366, -0.00020629590064979997, -6.354086997623076e-05]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.25, 0.5, 1.0]\n",
      "rate of decrease : 0.0007860609858040818 ampli_fct : 0.5 L[0] : 0.262442614982061\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 5900\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3400\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: 57.39727400705851\n",
      "norm_x_over_norm_DE_depthp1 :  129.60681727555865\n",
      "L_plus < L_moins: 0.2641006819459084 < 0.26410070461320145\n",
      "Delta Loss :  [0.0, -1.9752615432189202e-08, -3.950478141834246e-08]  ... [-0.0002628008325075981, -0.00040196438619266583, -0.0002983022918086331]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.0001220703125, 0.000244140625, 0.00048828125]\n",
      "rate of decrease : 0.0016523683642574655 ampli_fct : 0.000244140625 L[0] : 0.24326560280842638\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3400\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 2.3183509126262023\n",
      "norm_x_over_norm_DE_depthp1 :  0.019746261550355863\n",
      "amplitude factor for the new neurons : 0.000244140625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  2 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.968\n",
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 60.35220351910821\n",
      "norm_x_over_norm_DE_depthp1 :  4653.402089343642\n",
      "L_plus < L_moins: 0.258697224227656 < 0.2586974921855882\n",
      "Delta Loss :  [0.0, -2.130225676966191e-07, -4.260398495659068e-07]  ... [-0.002292530745748922, -0.0028301190445648716, 0.0028424657589337654]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.0001220703125, 0.000244140625, 0.00048828125]\n",
      "rate of decrease : 0.00956753985484033 ampli_fct : 0.000244140625 L[0] : 0.2958042597683125\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 6100\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3400\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: 102.61757010332877\n",
      "norm_x_over_norm_DE_depthp1 :  105.48526883827795\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -4.997301089604278e-08, -9.994393895818021e-08]  ... [-0.0005556320498897871, -0.0006354510923560208, 0.00047689113502785707]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [0.0001220703125, 0.000244140625, 0.00048828125]\n",
      "rate of decrease : 0.0022144992394703827 ampli_fct : 0.000244140625 L[0] : 0.28695024185603\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 3400\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.9172157510711545\n",
      "norm_x_over_norm_DE_depthp1 :  0.015182964732762186\n",
      "amplitude factor for the new neurons : 0.000244140625\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 0.996\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "*** started  NG at  2 ***\n",
      "Batch size for estimation : 50000\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: 75.7848199324092\n",
      "norm_x_over_norm_DE_depthp1 :  5729.811428047741\n",
      "(alpha, omega) <-- (-alpha, -omega)\n",
      "Delta Loss :  [0.0, -6.874472019413602e-08, -1.3745819588129038e-07]  ... [-5.157369167729797e-05, -6.322513652740058e-05, -2.132340422594803e-05]\n",
      "betas :  [0.0, 7.450580596923828e-09, 1.4901161193847656e-08] ... [7.62939453125e-06, 1.52587890625e-05, 3.0517578125e-05]\n",
      "rate of decrease : 0.00024539565875702726 ampli_fct : 1.52587890625e-05 L[0] : 0.2576457010187025\n",
      "\n",
      "\n",
      "*** started  NG at  3 ***\n",
      "Batch size for estimation : 6100\n",
      "\n",
      "\n",
      "*** started  Add at  2 ***\n",
      "Batch size for estimation : 3600\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: 48.20251685737661\n",
      "norm_x_over_norm_DE_depthp1 :  4.336548616541651\n",
      "L_plus < L_moins: 0.24956660919724827 < 0.24956662156241943\n",
      "Delta Loss :  [0.0, 1.7502330695862156e-09]  ... [0.0, 1.7502330695862156e-09]\n",
      "betas :  [0.0, 7.450580596923828e-09] ... [0.0, 7.450580596923828e-09]\n",
      "rate of decrease : 0.0 ampli_fct : 0.0 L[0] : 0.2757809953717458\n",
      "\n",
      "\n",
      "*** started  Add at  1 ***\n",
      "Batch size for estimation : 3600\n",
      "*** ADD : THRESHOLD SELECTION ***\n",
      "*** normalize NewNeurons acc. ||functional udpate|| ***\n",
      "norm_x_over_norm_DE_depth: 0.9989250441846201\n",
      "norm_x_over_norm_DE_depthp1 :  0.013672346075414498\n",
      "amplitude factor for the new neurons : 1.52587890625e-05\n",
      "(alpha, omega) <-- (sqrt(ampl) x alpha, sqrt(ampl) x omega)\n",
      "*** Added neurons at  1 ***\n",
      "\n",
      "\n",
      "equivalent epoch : 1.024\n",
      "Acc test : 0.9216176470588234 Acc train : 0.9224609375 lr : 0.010000000000000005\n"
     ]
    }
   ],
   "source": [
    "for j in tqdm(range(5)) :\n",
    "    for k in range(len(to_add)) :\n",
    "        ## search for the best depth to add the new neurons ##\n",
    "        nbr_parameters_avant = MLP_model.count_parameters()\n",
    "        gc.collect()\n",
    "        torch.cuda.empty_cache()\n",
    "        depth_ajout = to_add\n",
    "        depth_in_decreasing_criterion, dico_EB = EB.where_is_EB_best_solved(MLP_model, depths = depth_ajout)\n",
    "\n",
    "        best_depth = depth_in_decreasing_criterion[0]\n",
    "        dico_EB_bd = dico_EB[best_depth]\n",
    "        alpha, omega, bias_alpha, vps = dico_EB_bd['alpha'], dico_EB_bd['omega'], dico_EB_bd['bias_alpha'], dico_EB_bd['vps']\n",
    "        lambda_method = dico_EB_bd['beta_min']\n",
    "\n",
    "        MLP_model.alpha, MLP_model.omega, MLP_model.bias_alpha, MLP_model.valeurs_propres = None, None, None, []\n",
    "        MLP_model.TAB_Add = None\n",
    "\n",
    "        \n",
    "        if lambda_method > 0 :\n",
    "            MLP_model.dico_w, MLP_model.lambda_method = dico_EB_bd['dico_w'], dico_EB_bd['beta_min']\n",
    "            EB.add_neurons(MLP_model, best_depth, alpha = alpha, omega = omega, bias_alpha = bias_alpha, valeurs_propres = vps)\n",
    "            MLP_model.lambda_method = torch.tensor(0., device = my_device_0)\n",
    "        #########################################################\n",
    "        \n",
    "        \n",
    "        ## Training Loops ##\n",
    "        AugBatchSizeLearning()\n",
    "        MLP_model.tr_loader, MLP_model.te_loader =  iter(UTILS.cycle(DataLoader(MLP_model.training_data, batch_size=MLP_model.batch_size, shuffle=True))),  iter(UTILS.cycle(DataLoader(MLP_model.test_data, batch_size=MLP_model.batch_size, shuffle=True)))\n",
    "        optimizer = torch.optim.SGD(MLP_model.parameters(), lr = MLP_model.lr)\n",
    "        scheduler = torch.optim.lr_scheduler.LinearLR(optimizer, start_factor=0.0001, total_iters=25)\n",
    "        MLP_model.scheduler = scheduler\n",
    "        l_tr, l_te, l_va, a_tr, a_te, a_va, t = MLP_model.train_batch(nbr_step = nbr_steps_betw_adding, optimizer = optimizer)\n",
    "        #####################\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",
    "                                             'BatchSize' : np.ones(A_te.shape) * MLP_model.batch_size})\n",
    "    df_tracker.to_csv(name_file_expe + '/df_tracker.csv')\n",
    "    df_performance.to_csv(name_file_expe + '/df_performance.csv')\n",
    "    MLP_model.T = T[-1]\n",
    "    MLP_model.len_L_tr = len(L_tr)\n",
    "    del MLP_model.tr_loader, MLP_model.te_loader\n",
    "    UTILS.save_model_to_file(MLP_model, path = name_file_expe + '/' , name='model_' + str((j + 1) * (k + 1)))\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "b20adf83",
   "metadata": {},
   "outputs": [],
   "source": [
    "#UTILS.save_model_to_file(MLP_model, path = name_file_expe + '/' , name='model_' + str((j + 1) * (k + 1)))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "224e315c",
   "metadata": {},
   "source": [
    "### Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "1ad9d6b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "path = 'results/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "74fd6c46",
   "metadata": {},
   "outputs": [],
   "source": [
    "### Loss function ###\n",
    "#def Loss_entropy(x1, x2, reduction = 'mean') :\n",
    "#    #print(x1.shape, x2.shape)\n",
    "#    return(torch.nn.CrossEntropyLoss(reduction = reduction)(x1, x2))\n",
    "#####################\n",
    "\n",
    "#df_tracker = pd.read_csv(path + 'df_tracker.csv')\n",
    "#df_performance = pd.read_csv(path + 'df_performance.csv')\n",
    "#MLP_model = UTILS.read_model_from_file(path = 'resultats/', name = 'model_20')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "d1c8abe0",
   "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",
    "coef = 5\n",
    "ax.plot(UTILS.lisser_courbe(df_performance[['A_tr', 'A_te']], coef = coef), label = ['A_tr', 'A_te'])\n",
    "ax.legend()\n",
    "ax_nbrp = ax.twinx()\n",
    "ax_nbrp.plot(df_tracker['len_L_tr'] / coef, 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', fontsize = 15)\n",
    "ax.set_ylabel('accuracy', fontsize = 15)\n",
    "ax.set_xlabel('gradient step', fontsize = 15)\n",
    "\n",
    "ax_nbrp.set_ylabel('nbr of parameters', fontsize = 15)\n",
    "\n",
    "ax_nbrp.tick_params(axis='both', which='major', labelsize=12)\n",
    "ax_nbrp.tick_params(axis='both', which='minor', labelsize=10)\n",
    "plt.ticklabel_format(axis=\"y\", style=\"sci\", scilimits=(0,0))\n",
    "\n",
    "\n",
    "ax.tick_params(axis='both', which='major', labelsize=12)\n",
    "ax.tick_params(axis='both', which='minor', labelsize=10)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "d069d659-4c83-4774-b4a9-b31d485a5522",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkEAAAHQCAYAAACm1r7WAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB1GklEQVR4nO3dd3xTVeMG8OcmaZKudEFpCx0UaBltWSKg7Fm2gMgQRMDxooIgii+iIC5AxY2++gOhClRQQFEB2YooiCJLkVFWpS1075Xk/P5IExo6k7YkaZ/v55NP2jvPTXq5D+eec64khBAgIiIiamBkti4AERERkS0wBBEREVGDxBBEREREDRJDEBERETVIDEFERETUIDEEERERUYPEEEREREQNEkMQERERNUgMQURERNQgMQQRkU1JkmT2kslk8PT0RM+ePbFq1SpwUHsiqisSH5tBRLYkSRIAYOrUqQAAnU6HuLg4HD58GEIITJgwAbGxsbYsYhkhISG4cuUKAxqRg2MIIiKbMoagW/8p2r17N4YOHQqtVotvv/0Ww4cPt0XxysUQRFQ/8HYYEdmlgQMHYsqUKQCAr7/+2raFIaJ6iSGIiOxWx44dAQDx8fEAgIyMDLz//vsYPHgwgoODoVKp4OPjg+joaOzevbvcbfTp0weSJOHy5cvYsGEDunXrBnd3d3h6epqWEUIgJiYGvXr1gqenJ5ydnREVFYU333wTxcXFpuUOHDgASZJw5coVAObtmUJCQsz2m5qaimeeeQatWrWCWq2Gt7c3oqOjsWvXrlr8hIioJhS2LgARUUWys7MBACqVCgBw+PBhzJ49G4GBgQgLC0P37t1x9epV7Nq1C7t27cKqVaswffr0cre1dOlSrFq1CnfffTeGDx9uClZ6vR4TJkzAl19+CY1Ggy5dusDNzQ1HjhzBM888g/379+Pbb7+FTCaDn58fpk6diq+++gq5ubmmdkwA0KhRI9PP165dQ69evXDx4kUEBQXhnnvuQXJyMvbs2YMffvgBb731FubOnVtXHxsRVZcgIrIhAKK8f4r0er3o3r27ACAWLlwohBDi4sWL4tChQ2WWPXbsmPD09BQajUZkZ2ebzevdu7cAINRqtThw4ECZdZcvXy4AiIEDB4obN26Ypufk5IgRI0YIAOKDDz4wWyc4OLjcMhsNHz5cABBTpkwRRUVFpukHDx4ULi4uQi6XixMnTlS4PhHdHgxBRGRTt4YgrVYrzp07Jx588EEBQKhUKnHhwoUqt7Nw4UIBQGzbts1sujEEPf7442XWKS4uFo0aNRLu7u4iOTm5zPykpCShUqlEZGSk2fTKQlBcXJwAIDQajUhPTy8z/6mnnhIAxKOPPlrlMRFR3eLtMCKyC8ZeYqW5u7sjJiYGLVq0ME3T6XTYu3cvfvnlFyQlJaGgoAAAcP78ebP3W40cObLMtD///BMpKSkYMmSI2e0soyZNmqBVq1Y4ffo08vPz4ezsXOVx/PzzzwCAoUOHmrU7MpoyZQreeustHDx4sMptEVHdYggiIrtgbF8jk8mg0WgQGRmJMWPGwMvLy7TMv//+i+HDh+PEiRMVbsfYjuhWQUFBZaZdvnwZALBjx45yQ1hpaWlpaNq0aVWHgYSEBAAo01DayDjduBwR2Q5DEBHZhbVr11a5zEMPPYQTJ05gzJgxePbZZxEeHg53d3fIZDJ88sknePTRRyscu0etVpeZptPpAACtWrXCXXfdVem+jY2zq6uiUGWcXlXoIqK6xxBERA4hNzcXu3fvRpMmTbBp0ybI5XKz+RcvXrR4m82aNQMAREREVCuEVUdAQAAA4NKlS+XON9Y++fv718r+iMh6HCeIiBxCZmYm9Ho9/P39ywQgrVaLrVu3WrzNLl26wMPDA/v370dWVla111Mqlab93qpHjx4AgO+//x4ZGRll5q9btw4A0LNnT4vLS0S1iyGIiByCr68vPDw8cPr0aRw6dMg0XafTYf78+Th37pzF21SpVHj66aeRkZGBsWPHmgZBLO3kyZPYuHGj2TRjbc/Zs2fLLB8aGophw4YhOzsbTz75pNlgi7/++is++ugjyOVyPPbYYxaXl4hqF2+HEZFDUCgUmD9/PhYuXIjevXujX79+8Pb2xpEjR3D9+nU8/vjjWLlypcXbfe655/D3338jNjYW4eHh6NSpE4KCgpCSkoKLFy/i0qVLGDVqFMaPH29aZ+TIkfjxxx/Rv39/9O3bF66urmjUqBGWLVsGAPj444/Rs2dPfPbZZ/jxxx/RvXt3JCcn48CBA9DpdFixYgWioqJq7bMhIuswBBGRw3juuefQrFkzvPPOOzh06BCcnZ3Ro0cPvPTSSzh27JhV25TJZNiwYQPGjh2LVatW4ffff8fvv/+ORo0aITg4GFOnTsWECRPM1pk9ezbS09MRGxuLzZs3o7i4GMHBwaYQ1LRpUxw9ehRLly7F119/jS1btsDFxQX9+/fHvHnzMGjQoBp/FkRUc3yKPBERETVIbBNEREREDRJDEBERETVIDEFERETUIDEEERERUYPEEEREREQNEkMQERERNUgcJ6gSer0eCQkJcHd358MOiYiIHIQQAtnZ2QgICIBMVnF9D0NQJRISEhAYGGjrYhAREZEV4uPjTQ9KLg9DUCXc3d0BGD5EjUZj49IQERFRdWRlZSEwMNB0Ha8IQ1AljLfANBoNQxAREZGDqaopCxtGExERUYPEEEREREQNEkMQERERNUhsE1QLdDodiouLbV0Mh+Hk5AS5XG7rYhARUQPHEFQDQggkJSUhIyPD1kVxOJ6envDz8+P4S0REZDMMQTVgDEC+vr5wcXHhBb0ahBDIy8vDjRs3AAD+/v42LhERETVUDEFW0ul0pgDk4+Nj6+I4FGdnZwDAjRs34Ovry1tjRERkE2wYbSVjGyAXFxcbl8QxGT83tqUiIiJbYQiqId4Csw4/NyIisjWGICIiImqQGIKIiIioQWIIaqB++eUXyOVyREdHV3udAwcOQJIkDglARET1AkNQA/Xpp59i1qxZ+Pnnn3H16tVa3XZRUVGtbo+IiOqfgmIdziZlo6BYZ7MysIt8A5Sbm4tNmzbh6NGjSEpKwtq1a7Fo0aJK17l8+TL69u0LAPDy8gIATJ06FWvXrkWfPn0QEREBpVKJzz77DO3atcOPP/5Y58dBRET2Ta8XSMjMx8XkXFxKycXF5BxcTMnFxeRcJGTmQwhg88y70DnYyyblYwiqJUII5NsozTo7yS3qbbVx40aEh4cjPDwckydPxqxZs/DCCy9Uuo3AwEBs3rwZY8eOxdmzZ6HRaEzj/QBATEwMZs6ciUOHDkEIUaPjISIix5KRV4S4UkHnUkqu6VWo1Ve4nrtagfRc2909YAiqJfnFOrRd9INN9v33S4Phoqz+V7l69WpMnjwZABAdHY2cnBzs3bsXAwYMqHAduVwOb29vAICvry88PT3N5rds2RKvv/665YUnIqolm47G49NDlzCgTRNM7BqEpp7OVa/kKIoLgMIswKURILNNS5aCYh2upObhUkpOmcCTnlfxmG9KuQzBPi5o3sgVzRu7ItxThnCnRATprsIt6yKkoI638SjMMQQ1MGfPnsVvv/2GLVu2AAAUCgXGjx+PTz/9tNIQVJU77rijtopIRGSxHacS8eyWkxAC+CcpGx8euIABbZrg/m7B6NGyEeQyOxubTK8HCjKA3OSbr5xk899zU4DcG4b3wiwAQI5bCI753Ycd8r44nwEU6wXkEqCQySCTAXKZBLlMBrlk/NnwkkkSFDIJMpkEuSRBITdMMy1T+udS01JzixBXEnSuZRhuX1UkwEON5o1dEdrIDc0buaKVphitpAT4Fl6GLOUckPwP8M85IDPefMXmPYGW/evso64MQ1AtcXaS4++XBtts39W1evVqaLVaNG3a1DRNCAEnJyekp6eb2vtYytXV1ar1iIhq6ujlNDy58TiEAIZG+iE9txi/XkzFrr+vY9ff1+HvocbYTs1wb+dmCGlUR/9WCQEU5wN5KaUCTDKQc+Pmz7cGG2F5Ewq3nMvodeF1dBTv40tdb/yuD0M63JEu3JEm3JEBNxTBqQ4O0MBdrUBoYze0aORqqNlp5IIw1zwE6eOhTr8ApJwFks8C588ajrMirr5A43DDy823zspbFYagWiJJkkW3pGxBq9Xis88+w4oVKzBo0CCzeWPHjsX69evxxBNPVLi+UqkEYHhuGhE1LKk5hTiblA1/T2c0r6sgYYULN7LxUMzvKNLqMbBtE7w/sRPkMgkXbmQj9pc4/HD8Iq5navHB/gv4YP8FNNGo0MZXjbY+CrT2lqGFp4RgjR5uKAKKcoGinJL3kldxqZ9N8/LKX05U3PalQmpP6F0bI1fhiWS9Bv8WueJcrgsu5zsjRXggVWiQCg1ShAdUSifM0PyG0UXfoUnRVUxX7MR07CyzyWK5C4qUXih08kCB0hOFTp7IV3gYXk6eyFV4IF/ugRy5B/LkGuQoPFAIJfR6AZ0e0On10AkBnV5Ao3ZCaGNXhDZyQQtlOrxyL0FKOWYIOpfOAkfPAgWZFR+fpllJ2GkNNA4zvDcKA1y8Lf+s6oB9X7WpVn333XdIT0/HjBkz4OHhYTbv3nvvxerVqysNQcHBwZAkCd999x2GDh0KZ2dnuLm51XWxieg20ur0uJSSi78Ts3AmMRtnErNwJjELN7ILAQBqJxm2PnY32iiTgVNfAk7OgNrjlpen4V2lARRKi8vw4YEL+PFsMnw1avhpVAjwdMbQSH800ajNlotLzsFjqw/AvSAFdzb1xHtDfSFP/hu4eAAtL+zFC1cO4QUUAGpACznyhRKqwiIo/9UB/9bGp1UOudJQy+HaCHBtbHi5NTb9rHduhGtaN5xIc8LRGxL+uJaLfxKzodWb32eSSUBYE3d0CPTE2EBPdAzyQktfN8hlowH9q8DF/cCJWCDzGpCXCuSnAXlpgNDBSZcHp/w8uOZfq365nVwAFx/A2cvw7uJjCCoFmcCxs0DKOaA4r/x1JRngFXIz4BgDT6MwQOVu/Wd5G9htCMrJycHzzz+PTZs2IS0tDa1bt8Z///tfTJgwocp1f/jhB7z00ks4duwYlEolevXqhWXLlqFdu3a3oeT2a/Xq1RgwYECZAAQYaoJee+01HDt2DJ06dSp3/aZNm2LJkiX473//i2nTpuGBBx7A2rVr67jURI4tM78Yl1NyEdLIFR7OdXebwhqZ+cWmkHOmJPScu55dYW8ed7UC2QVa/Oezo9jnvgjyG6er3omivJBU2csTW3cfxxWdD4rghL6yP3GPYhP27w6H9+D/YlD3zgCAn0/HIe6rRfhO7IBSpQNSAXxQSTGgg7uUbzatGE7IgwrZQo08oUIeDO+5UCMPauQKFeQqNzi7aeDm7gFPTy808vZGEx9vqFw0gNK1nJcbUKqnbVpuEY7Hp+P41Qz8eSYDJ+IzkFWQWqZ8vu4qdAj0RIcgT3QM9EJkMw+4qSq4RMtkhjY0t7aj0esNbYfyUg2BKD/t5s+moGT8vdQ0vdYQcDLzyrbXMduvE+DT8uZtrMbhQKNwwzQndcXr2TFJ2Gl/5kGDBuHo0aNYtmwZwsLCsGHDBqxatQrr16/HpEmTKlzvm2++wejRozFq1Cg8/PDDyMzMxJIlS3Djxg0cPXoULVq0qHYZsrKy4OHhgczMTGg0GrN5BQUFuHTpEpo3bw612jG/fFvi50cNgRACw9//GX8lGBq1NtGo0MrXHS193dCqiRvCmrijla8bPF0sry2xhF4vcCUtr0zguZaRX+7yLko5wv3c0cZfgzb+GrT1d0e4nwZanR4jPvgZbTN+wsfKtyGUbpBaDzfUFtz6KsquUZn/FY2Q2DQaXRLWmaYVCgWOeg2D5NMSbS58DG8pBwAgFM6QIAC9zlATE9QNaNHP8PJpYbjAF+UB2gJAob4ZWOSGUJqZV4zzN7Jx7noOzl3PNv2cXFL7VZ5mXs6G76+JG8J83RHWxB1BPi64lJKLP6+m43h8Bo7HZ+BKatnaE7WTDJFNPQyhJ9ALHYM84e+hts2DpYUoCU5p5YclJ+ebt7O8Qkyfmb2r7Ppdml2GoO3bt2PYsGHYsGEDJk6caJo+aNAg/PXXX7h69Srk8vIbA7du3RoqlQrHjx83/UFduXIFYWFhuPfee7F+/fpql4MhqO7w86OG4PfLabj3f79WuVwjNxValQSjVr5uaOnrjrAmbvBxU1W5rl4v8PnhK9j993UEerugnZ8L2iiv40K+O06kAGcSs3A2KRt5ReW35Wvq6WwKOq1LQk+wtwtkFfSm+utaBqRPeqOtdBm/Np2GztPeglJRTpdtndZwcS3MKj8klfsqWTbTfBR7fYfJuHbxDAKz/jCbnqQKgfeY16EMr5tOKRl5RTeD0XVDMDp/IxspOZaNaxPa2BUdA71Kank8Ee7nDic5H9hQl6obguzydtjWrVvh5uaGcePGmU2fNm0aJk2ahCNHjuCuu+4qs15qairOnj2LZ5991ixRBwcHIyIiAl9//TV0Ol2FAaqh+89//oN169aVO2/y5Mn43//+d5tLROTYNh413FoY17kZXhjRFhdu5OBCyYX0/I0cnL+eg2sZ+UjJKURKTiF+vWh+m8TbVYm2jRW4U5OBSHUyQmVJ8C3+F+rMS5BSL0CvK8JRWXuczm6HQr0fWl3+DYPlv6KxlInOAPoLDS4Kf1zU++OqU1MUeYZC5dcavkFhaN3UB639NRbfomuX9TMgXUaOUGNmXDdkPL8DCpkEZ6UcrkoFXJRyuKjkcHFSGN6VcrgoFXBResNZ2fjmMi4KuHjenO+slMO1ZL2g9/1v7nDsasgi70UggLOHtyNn12sI0F3DpdaPovt98yDVYc2Ep4sSdzb3xp3NzRvxpuUWmQUjQ+1RDtJyi+Dl4oQOJW14OgR6on0zT3i4OEbtSUNklyHo9OnTaNOmDRQK8+JFRUWZ5pcXgozPrFKpyv7vSaVSIS8vD3FxcQgLC6uDUju+l156CU8//XS58ypL0kRUVk6hFt+fSgQA3NclEBq1EzoFeaFTkFeZ5eKS0pF4+RyyEv6B7sZ5qLMvoXFRPJprk9A0KRVIKn8fMgBdcQhdnQ6ZTS+EEioUoZGUhUZSFu6UnTXMyC55xSkAr+ZAo1aG9hyNWgE+rQwNWV19Kj4oIYAflwEA/gqciJyLGkAvoNULZBdokV2gteKTKuttp7sRKCWj+fTV8AmJMk0P7zYUxV2ikZVfjLuqUUtWV7xdlegW6oNuoeafVXZBMdxUCtvc1iKr2GUISk1NRWhoaJnpxhGLU1PLNioDgCZNmsDb2xuHDpn/g5CRkYHTp09Xui4AFBYWorDw5j3grKwsi8vuyHx9feHra7vxGojqjZwbOPbjLngU6eHXKBB3BHsZAkR2IpB6oeQVB6RegFvqBbRPv4z2+lsCRKm7JflyDRIUTXFe54fTBY1xUe+Hy8IPCugwyfsfjHY9DVXWZaDlACBqPFQt+hnav6ReAFIuAKnngZTzhvfUOEMbmdSS32/l7FUSiG4JSN6hwIXdQNIpQOmGrpMW4YzKE3lFOuQX6ZBbpDW8F2qRV6xDXqEOeUVa5BXpSl7aW95L/VyoQ16xtmQdHeYWP472zTywJSiyTPGc5LJq3Sa0BXc1a3wcjV2GIACVJumK5slkMjz++ON4+eWX8fLLL+PRRx9FVlYW5syZg7y8PNMyFVm6dCmWLFlSs4ITUcOWlwasHohe6ZfxqxrIK/KB9D9/IO1ixV2MAUMvKp+WgE9oyfvNl7OLN1oAaAGgT7EOF5Nzcf5GNpRyGQa18yt/NGS5ExDQ0fAqTa8HshNKQtEFQ9dn48+Z8UB+OvDvb4ZXaZLc0OgYAO58GHDxhhMAD2dZrfd60+sFJKny6wBRbbDLEOTj41NujU1aWhqAmzVC5Vm0aBFycnLwyiuvmJ6MPmzYMEybNg2rVq0yGyn5VgsWLMBTTz1l+j0rKwuBgYHWHgYR2aMb/wBH/w/QFQNuTQyj1bo2vvmzm2+Zbs7VptcBmx8C0i8jV6igQjFcilKB6yX/nklyQw8bU8BpcfNnd/9qPRNK7SRH2wAN2gZYeYtaJgM8mhleLfqazyvKA9LiSgWkktqilAuG3l7afEDlAXSfZd2+q11Ehh+6PewyBEVGRiI2NhZardasXdCpU6cAABERERWuq1Ao8NZbb+Gll17CpUuX0KhRI/j7+2Pw4MFo3rw5mjVrVuG6KpWq3PZEROTg9DrDc4t++QA4+UXVI/sqnG8GIrcmpUJSyburb6nAVGr05H2vAHF7USxT4d78FxES1h4fDXAC8jMMt5O8gu27i7HSBfCLNLxKEwLIuW4IRh6BlbcbInIgdhmCRo8ejf/7v//D5s2bMX78eNP0mJgYBAQEoGvXrlVuw83NDZGRhhP52LFj2Lt3L1asWFFnZSYiO6HTGm7xJB4HEk+UvE4aHmtg1Hq44UKfc8Nwcc9NNrznJBuW0+YDGVcMr6oo3QwhycUHuPY7AOCZoodxRgRjXteWQGCTujnO20mSAHc/w4uoHrHLEDRkyBAMHDgQM2fORFZWFlq2bInY2Fjs3LkT69atM3VxnzFjBmJiYhAXF4fg4GAAwIEDB3D06FFERUVBCIHffvsNy5cvR3R0dKWPhCCiqhVqdSgo0kOtlEEpl9VZmw2tzlBTo6hqLBVdMXDjTEnQOW54TzptCDG3cnIBQnoip/s8fH3DDwXFOrj6KuAaqICbytC921WlgEZWCDddGlyL06DMT4ZkfAim8ZVb6mdtfskzpHKA9EsAgDViOL7W3oV7OzdD/zbsaEBkz+wyBAHAli1bsHDhQixatMj02IzY2Fizx2bodDrodDqUHu9RqVRi8+bNeOWVV1BYWIhWrVrhpZdewuzZszk+EJEFLtzIxulrWYiO8IPaSY7vTibgv5tPIafQ0ItJkgBnJzmcneRQO8mhdpLBWVn6d7lpvrNSDpWTzOx3tUIOtVIOV6UcXZp7Q1PSs+aPK2m4f9URFBTroZTf3KbGSY82sni0wUWE6eMQqo1Ds6KLUIjiMmUvlrsi07MNcrwjkN8oAsW+7QGfFth1JgUxMZeRXZhSrc9ALnOCqzIQbqrmcFMbQpKbSgFXHwVc/eXwURahsZQBH2TCS5+Onaev48u8DujZqhGWjolkw14iO2eXI0bbi/o8YvQvv/yCnj17YuDAgdi5s+xTiMtz4MAB9O3bF+np6fD09KzR/h3986vPkjIL8Pbuc/jyj3johWFE4V5hjRH729WqV7aAHDooUQwF9GjRzB+bH7sbMgm4Z+Uh/PNvMtpIVxEhu4QI6RIiZZcQJv0LJ6nsqMeZwgWn9c1xWoSUvDfHZdEEAhXXIoU1cUMbfw1yC7XIKXnlFupK3rUVjq5cHW38Ndj0aDd2lyayIYceMZrq3qeffopZs2Zh1apVuHr1KoKCgmxdJLKx7IJifPzjRaz6+SIKig23ozycnXAtIx+xv12FK/LxZqu/MLCZDrriAuiKC6EvLoS+uAA6bRFEcSGEthDQFQLaIki6Qki6Ikj6Ish0xZDpiyAXRZDri6EQxZDhZuPkf5Mb4eyagZB5NsMz17ejq+qfcgNPsdITmZ5tkerRFjdcWyPBJRw3ZH7I1+qRV6SDa7EOkUU6tCw2jF2TX2wYd6ag2DAmTVNPZzzSqwUGtW1SaQ8knV4gr+hmMDKGI+O74WfdLSFKC08XJ8wZEMYAROQgGIIaoNzcXGzatAlHjx5FUlIS1q5daxpOoCKXL19G376G7rReXoYRb6dOnYq1a9dCCIE33ngD//vf/5CYmIiwsDC88MILuPfee+v8WBxOfjpwPBZoPwFwqXioh9upSKvHhiNX8N6+C0jLNYy6fkewFxYMbY22/h5YffACcHQVHtJ/CXV8OhBf+/9wNJNSgPhYIB6A8a61a2PAvwPg3x4IMLw7eQSikSShEYDwWi5DaXKZBHe1E8MMUT3HEFRbhKh8ILS65ORi0ZgmGzduRHh4OMLDwzF58mTMmjULL7zwQqXtFwIDA7F582aMHTsWZ8+ehUajgbOzMwDg+eefx5YtW/DRRx+hVatW+OmnnzB58mQ0btwYvXv3rvHh1SsH3wJ+eQ+I2wvc/5V1Y9HUEiEEtp9Kwus//GN60nVoY1c8G90ag9o2Mf09POG8Cyj4xLCSdwsgLBpQKAG5quS99M+l3uXKKqYZftfr9Xjj41UISfkRPlIm/lS0x8yH/wM3/9Y2/XyIqP5jCKotxXnAawG22fdzCeZjlVRh9erVmDx5MgAgOjoaOTk52Lt3LwYMGFDhOnK53DRIpa+vr6lNUG5uLt566y3s27cP3bt3BwCEhobi559/xscff8wQdKtLPxneL+wBzu0EwofYpBiHL6Zi6Y5/cCI+A4DhKeZzB7bC+DsCzXtkCQH8EWP4uec8oM+CWh/nRgZg7KSHMeTd1ijWCjw/qA3cAso+NoeIqLYxBDUwZ8+exW+//YYtW7YAMAwuOX78eHz66aeVhqCK/P333ygoKMDAgQPNphcVFaFjx44VrNVAFWZDJJ2EqW5j538BbSHgGWQYRdjZq85rPs5dz8byHf9g7z83AAAuSjke6RWKh3uGwlVVzj8HiccNIwYr1MDdc+psoL+Wvu54b0JHnLyWiQe6h9TJPoiIbsUQVFucXAw1MrbadzWtXr0aWq3W7PEhQgg4OTkhPT3d1N6nuvR6Q+PW77//vswjSTj69i3if4Mk9EgU3pBLgG/6ZeDLqTfnK90NgcgzyDCysPFnz5KfnT2t3vX1LEOPr02/G3p8yWUSJt4ZiNn9W8HXvZLeeSe/NLyHDwHUVj6moZqGRPpjSKR/ne6DiKg0hqDaIkkW3ZKyBa1Wi88++wwrVqzAoEGDzOaNHTsW69evr3RASaXS8PBEne5mr522bdtCpVLh6tWrvPVVhazzB6EB8Ku+LT7WDsfLjfbgDo9MyDKuGkYrLsoGbvxleJVH7VEqFAWXDUwq9zKrlNfja3C7Jpgf3RotGrtVXmC9Djj9leHnqPGVL0tE5IAYghqQ7777Dunp6ZgxYwY8PDzM5t17771YvXp1pSEoODgYkiThu+++w9ChQ+Hs7Ax3d3c8/fTTmDt3LvR6PXr06IGsrCz88ssvcHNzw9SpUyvcXkOT9c9P0AC45BKFC9nBuC95OmQpQDMvF7RsKkd792yEq9MRIk9BE/11aAoTIM+MB9KvAHkpQEEmkHTK8CqPs7ehx5mTC/ROLkjMk+GfVB2a65zwvFDB3dsDXVo1Q0BjH+DiMeBfF0MtotK15N0FcHK9+X7td0M4c/YCWvS/rZ8VEdHtwMESK1HfBkscMWIE9Ho9vv/++zLzjh07hs6dO+OPP/5Ap06dKtzGyy+/jA8//BDXr1/HAw88YOoi//777+PDDz/ExYsX4enpiU6dOuG5555Dr169yt2OI35+NSG0hSh6pRlUKMKuPtuQpArGsh3/VDoon0wCAjydEeLjilZeEtq5ZKKFUyqaScnwKkqEIiu+5PlWVw1d7+vKHdOB4W/X3faJiGpZdQdLZAiqRH0LQfakPn5+ablF+CcpC/8kZuNKai4y8osR6uOK2U5bkfvXDrgl/4k04Q71c5fgonKCEAI3sgtxOSUXl1NzcTk1D1dSc3EpxfBeWUCSJCDAwxkhjVwQ7OOKVh56BMpSse/Pc0hIToUzCuGr1mFYaw06+6sg1+YbHgxalGfoyViUW/KeV/50nWG8ICjUwEN7yj5VnIjIjnHEaKI6UqjV4cKNHPyTmI2z17NxJjELZ5OycSO7sMyyd8tOQVIuhbH1zV+aXuipMvSwkiQJTTRqNNGo0TXUx2w9IQSScwpxOSUPl1NzcSU11/Tz5ZRc5BbpcC0jH9cy8nHoQmqpNQPhogzBwz1D8XCvULiV1+OrOnRaQziSKwEnZ+u2QURk5xiCyOQ///kP1q1bV+68yZMn43//+99tLpFtCSFwLSMfZ5Oy8Y/xlZiFiym50OnLr0AN8nZBuJ87Wvq6YcepREzJ2gMAOOnRFwtuDETfbv3Qsxr7liQJvu5q+LqrcWdz85GlhRBIzS0qqUEy1h7l4t/0fEQ188ATfVvCV1PD2jW5ApB7VL0cEZEDYwgik5deeglPP/10ufMqq050ZEII5BUZngF1NS0PZ5KycbbkltbZpGxklzwx/VYezk4I93NHGz93hPtp0NrfHWFN3M1qXvQZ/2LAmT8AAGsU4/GX0ODhJjX/HCVJQiM3FRq5qXBHiH08eoOIyBExBJGJr68vfH19bV2MaruSmovk7ELkFumQV/IQy7wiHXKLjA+5NDw0M7ck5OQVlppXsk5esQ6VtYpzkkto0dgNrUuFndZ+7vDTqCt9zAgARBf+AIWkxzl1FA6k+wAoRkvfKrqlExHRbcMQRA7p2xMJmBX7Z61tT5IAP43aFHba+Lsj3M8doY3coFTIqt7ArVLjEHFtEwDg08L+SM8vhiSh6rF5iIjotmEIqiHjiMlkmZp+bn9cMXQJ93Jxgr+HM1xVcrgoFXBTKeCilMO11LurUg4XVdl5ht8VcFXJ4ewkr7Jmp1p0xUDaRSB2ApyKMnBKH4LNRYbHhzT1dIazUl7FBoiI6HZhCLKSUqmETCZDQkICGjduDKVSWTsX0XpOCIGioiIkJydDJpOZRqG2VEJGPgDgqYFhmHI7nzWl1wHZiYaxedKvGMbpSS8ZqyfjCpB1DRCGgCc8gzA74zkUl5xmvBVGRGRfGIKsJJPJ0Lx5cyQmJiIhwUbPDHMkeq3hieQlD+B0cXFBUFAQZDIrbjUBSMwsAAD4edRy920hgNyUknBzuWzIyYgH9MWVb0OhBvyiIN3zIXy+TMalklqrlrwVRkRkVxiCakCpVCIoKAhardbseVp0CyGAT6OB/FQgpDfkdz8BhV9QjWrOEjMNNUH+HlZ2BdfrDLetrp8Grv8FXP8bSIszhJ3ivMrXlSkAj2aG53eZHnQaUvJzMODma3oafKsm+fjdGIJYE0REZFcYgmpIkiQ4OTnBycnJ1kWxX4U5QPJxw8+n1wF/bQDaTwT6LAA8Ay3fnFaHlBzDiMYBntWoCcpNMQ87108Dyf8A2oIKVpAAd/+bocar1ANLvYIB9wDDODrV0Mr35kNNGYKIiOwLQxDVvcIsw7skA8KHAv98BxxfD5z6EujyMNBzHuDqU/k2SkkquRWmUsjg5VIqfBYXAClnS8JOqVfujfI35OQCNG4NNGkHNIkAGrUCvEIMtTwKlZUHay6sCUMQEZG9YgiiuleYbXhXaYAJ64F/fwf2vAhcPggcXgn8+Tlw12yg20xAVXVQSMwsgAQ9RrmdhXSwVNhJvQCI8m5LSoB3c8C3rSHsNGlneHmFALK67a0V2dQDbioFmno6w9PFukbgRERUNxiCqO4VlNQEqUtGS252BzD1WyBuryEMJZ0C9r8C/PYJ0Hs+0GkqoKg4MCRm5uN++V68UrAG2HfLTLWnedBp0s5Q21ONcFUXPFycsP/pPuwaT0RkhxiCqO4VZhreVaWeRSVJQMsBQGg/4K8twL6XDb2xtj8N/PoB0Pd5IGIsUE7vsYSMAvSQnTb8EnQXEDb4ZuBx9zc1SrYXjd1r59YaERHVLuv6JxNZwnQ7zL3sPJkMiLwXePwoMPRNwNXXEIa2PAR83As4vxu3PtciMSMPnWTnDb/0XwT0mAO0GghoAuwuABERkf1iCKK6d+vtsPIolMCdDwOz/wT6PW9oP3T9FLD+XmDtcCD+qGnRwtSr8JUyoJcUgH/7Oi48ERHVV7wdRnXP2DtMVY0nqKvcgF7PAJ2nQxxcARxdBenKz8DqAfjT9W68rZ8ATeY5QAnkeLaGRulSt2UnIqJ6iyGI6l5lt8NKZOQV4Z+kbPyTmIV/krJxJikb55J6was4HHMUmzFW/hM65h7CGvELEhSNDJtr3u12lJ6IiOophiCqe6VuhxXr9LiUkoszJWHHGHqMj8G4lV7hi8+bzMcVzxkYl7UGIcn7ESglAwBUIV1v1xEQEVE9xBBEda/kdtiaP9KwdP8PKNKV/wT5pp7OaOPvjtZ+GrQueQ/xcYFCbmy6NgqI/w3Y/yqQn2FoDE1ERGQlhiCqc9r8TCgAxGXJUKTTw1UpR7ifO1r7a9Cm5D3czx0adTUePRJ4J/DAN3VeZiIiqv8YgqjOFWSnww2AXumOn57oi2ZezpDJ2JWdiIhsiyGI6lxxnmGwRHcPbwT5sDcXERHZB7sdJygnJwdz5sxBQEAA1Go1OnTogC+++KJa6+7fvx8DBw6Er68v3NzcEBUVhffeew86XXnPlaK6JkoaRnt7V/8hqURERHXNbmuCxowZg6NHj2LZsmUICwvDhg0bMHHiROj1ekyaNKnC9fbs2YPBgwejV69e+L//+z+4urpi27ZtePLJJxEXF4d33333Nh4FAYCi2NBFvpFPYxuXhIiI6CZJiFueSWAHtm/fjmHDhpmCj9GgQYPw119/4erVq5DLy38g5eTJk/HVV18hNTUVrq6upumDBw/G4cOHkZmZWe1yZGVlwcPDA5mZmdBoqjHQH5Wr4MXGUKMIvwzfh7vu6Gzr4hARUT1X3eu3Xd4O27p1K9zc3DBu3Diz6dOmTUNCQgKOHDlS4bpOTk5QKpVwdnY2m+7p6Qm1Wl0n5aWKaYsKoUYRACDQv4mNS0NERHSTXYag06dPo02bNlAozO/WRUVFmeZX5D//+Q+Kioowe/ZsJCQkICMjA59//jm2bt2K+fPn12m56SYhBHb/fR0PfLDdNC2gCUMQERHZD7tsE5SamorQ0NAy0729vU3zK9K1a1fs27cP48aNw8qVKwEAcrkcS5cuxbx58yrdb2FhIQoLC02/Z2VlWVP8Bu+XuBSs3n4Id1z/Eh/J9wISUOSkgVJRjXGAiIiIbhO7DEEAIEkVjyNT2bw//vgDo0ePRteuXfHxxx/D1dUV+/btw/PPP4+CggK88MILFa67dOlSLFmypEblbshOxGdg47fb0TlxPf4n+xVOCkNvPJ1XKJQDX7Rt4YiIiG5hlyHIx8en3NqetLQ0ADdrhMrz+OOPo0mTJti6daup8XTfvn0hk8nw4osv4v777y+3lgkAFixYgKeeesr0e1ZWFgIDA2tyKA3C+aRM7Px6HTpdW4/X5H8BJW3Wi5p2h7LnbMjDogGZXd55JSKiBswuQ1BkZCRiY2Oh1WrN2gWdOnUKABAREVHhusePH8fEiRPL9B7r0qUL9Ho9zpw5U2EIUqlUUKlUtXAEDcO/N1Lxy9YP0fFaLGbJrgFyQAc5CsJGwrX3bCibdrJ1EYmIiCpkl/89Hz16NHJycrB582az6TExMQgICEDXrhU/PTwgIAC///57mYERf/31VwBAs2bNar/ADUxyUjz2fTQXzis74L7EN9FKdg35Mlekt38U8jkn4DppLcAAREREds4ua4KGDBmCgQMHYubMmcjKykLLli0RGxuLnTt3Yt26daZanhkzZiAmJgZxcXEIDg4GAMydOxezZ8/GiBEj8Oijj8LFxQV79+7FihUrMGDAALRv396Wh+bQsuJP4+K219Hmxnb0k4oBCUiR+6LwjkfRtO8jcFZzLCUiInIcdhmCAGDLli1YuHAhFi1ahLS0NLRu3RqxsbGYMGGCaRmdTgedTofS4z3OmjULTZs2xdtvv42HHnoI+fn5CAkJweLFizF37lxbHIpjEwL55/bj+g9vIiTtEDoAgAScV4RBdH8CYX3uB+R2+2dERERUIbscMdpeNOgRo7VFKDr5FbL3vQOfnLMAAL2Q8KuyK5Q9ZuOOnkMgsbEzERHZoepev/lfeCpLr0PW+z2gyTwLHwB5QoWdTv2h6fME+t11F2SyiocoICIichQMQVRGfvo1aDLPQickfKKYiMZ9HsOou9rBSc6aHyIiqj8YgqiM7NTrcAaQCg9M++8HUDuV/7BaIiIiR8b/2lMZRVk3AAAZkoYBiIiI6i2GICqjODsZAJAt87BxSYiIiOoOQxCVoTOGILmnbQtCRERUhxiCqKy8FABAvpOnbctBRERUhxiCqAwpz/Dw2nwnLxuXhIiIqO4wBFEZigJDCCpSedu4JERERHWHIYjKcCpIAwBo1QxBRERUfzEEURmqonQAgN7Zx8YlISIiqjsMQVSGc7EhBAmXRjYuCRERUd1hCCJzQkCtywEAKFzZMJqIiOovhiAypy2EDHoAgNLZ3caFISIiqjsMQWSuOM/0o7OLmw0LQkREVLcYgshcSQgqFAq4uqhtXBgiIqK6wxBE5ooMISgfKripFDYuDBERUd1hCCJzxQxBRETUMDAEkbmSEJQnGIKIiKh+YwgiM8UFuQCAAiihUTvZuDRERER1hyGIzOTlZhneoYK7mjVBRERUfzEEkZn83GwAgFamhkwm2bg0REREdYchiMwU5hlGi9bKnW1cEiIiorrFEERmCvMNIUinYAgiIqL6jSGIzBSXhCDBEERERPUcQxCZ0RYaeofBycW2BSEiIqpjDEFkRlcSgiQVQxAREdVvDEFkRpQ8NkOudLVxSYiIiOoWQxCZKxkxWqHmE+SJiKh+YwgiM1JxPgDASc2aICIiqt8YgsiMTGuoCVI6syaIiIjqN4YgMuOkM9QEqV0YgoiIqH6z2xCUk5ODOXPmICAgAGq1Gh06dMAXX3xR5Xp9+vSBJEkVvpKSkm5D6R2XQl8IAFC5uNu4JERERHXLbp+QOWbMGBw9ehTLli1DWFgYNmzYgIkTJ0Kv12PSpEkVrvfhhx8iKyvLbFpeXh6io6PRuXNn+Pn51XXRHZpaFAASoObtMCIiqufsMgRt374du3fvNgUfAOjbty+uXLmCZ555BuPHj4dcLi933bZt25aZFhMTg+LiYjz00EN1Wm5Hp9MLqFEAgDVBRERU/9nl7bCtW7fCzc0N48aNM5s+bdo0JCQk4MiRIxZtb/Xq1XBzc8P48eNrs5j1Tl6RFq4lIcjZzcPGpSEiIqpbdhmCTp8+jTZt2kChMK+oioqKMs2vrvPnz+PgwYOYMGEC3Nx4i6cyuQXFcJMMIUjporFxaYiIiOqWXd4OS01NRWhoaJnp3t7epvnVtXr1agDAjBkzqly2sLAQhYWFpt9vbVtU3+Xm3DxeScXbYUREVL/ZZU0QAEiSZNW80rRaLWJiYtCuXTt069atyuWXLl0KDw8P0yswMLDa5a0PCnIyAQA6yAAnPkWeiIjqN7sMQT4+PuXW9qSlpQG4WSNUle3btyMpKanaDaIXLFiAzMxM0ys+Pr76ha4HCvMMIagAaqCaQZOIiMhR2WUIioyMxJkzZ6DVas2mnzp1CgAQERFRre2sXr0aSqUSU6ZMqdbyKpUKGo3G7NWQFOcZbofly1gLRERE9Z9dhqDRo0cjJycHmzdvNpseExODgIAAdO3atcptJCUlYfv27bjnnnvg4+NTV0WtV4whqFDmYuOSEBER1T27bBg9ZMgQDBw4EDNnzkRWVhZatmyJ2NhY7Ny5E+vWrTONETRjxgzExMQgLi4OwcHBZtuIiYmBVqvl2EAW0BYYQlCRnCGIiIjqP7sMQQCwZcsWLFy4EIsWLUJaWhpat26N2NhYTJgwwbSMTqeDTqeDEKLM+p9++ilCQkIwYMCA21lsh6bLzwYAFMv5BHkiIqr/JFFegiAAhi7yHh4eyMzMbBDtg3Z/vgwD45bib01PtH3qO1sXh4iIyCrVvX7bZZsgspFCQ02Q3ok1QUREVP8xBJGJVJQDANArObI2ERHVfwxBZCIrCUFgCCIiogaAIYhM5NpcAICkYggiIqL6jyGITBTaPACATM3nhhERUf3HEEQAgLjkHGjzDeMEqVw9bFwaIiKiuscQRMgt1OI/n/8BtcgHADQPaGLjEhEREdU9hqAGTgiB+V+dRPqNa2gnuwoAkLv72rhUREREdc9uR4ym22P1z5fw/alEvKn8Am7IA/zbA0HdbV0sIiKiOseaoAbs17hULN3xDzpK53Gv7EfDxKFvAjK5bQtGRER0GzAENVCJmfmYFXsMQq/Dex4bDBM73A8E3mnbghEREd0mDEENUKFWh8fWH0NKThHmeB9GYMFZQKUBBrxo66IRERHdNgxBDdAr353Bn1czEKjOx+P69YaJfZ8D3NggmoiIGg6GoAZm8x//4vPDVwAAX7TcC3lBOuDbFujysI1LRkREdHsxBDUgp69l4rmtpwAAr3bVoemFWMOMIa8DcnYUJCKihsXqEBQeHo4333wTycnJtVkeqiMZeUWYuf4PFGr16BvWCJNSPwAggIixQPOeti4eERHRbWd1CDp//jyeffZZNGvWDPfddx92795dm+WiWqTXCzz5xXHEp+UjyNsFKyMvQPr3CODkCgx82dbFIyIisgmrQ9ClS5fw3HPPwdfXF1999RWio6PRvHlzvPrqq0hISKjNMlINvbP3PH48lwyVQoaP72sFlwMvGmb0fgbwaGrTshEREdmK1SEoODgYL7/8Mq5cuYJt27Zh+PDhuHbtGl544QUEBwdj1KhR+O6776DX62uzvGShvWeu47295wEAS8dEos3Zj4DcG4BPS6DbYzYuHRERke1IQghRWxtLSkrCp59+itWrV+PSpUuQJAn+/v6YPn06pk+fjpCQkNra1W2RlZUFDw8PZGZmQqPR2Lo4FruckosRH/yM7AItHugejJe6y4GP7gaEDpi8GWg5wNZFJCIiqnXVvX7Xau8wPz8/PPfcczh37hzmzJkDIQQSEhLwyiuvoGXLlhg1ahROnDhRm7ukCuQX6fCfdX8gu0CLTkGeeH5oG2DHfEMAaj2cAYiIiBq8Wg1B8fHxWLJkCUJDQ/Huu+8CAO68804sWLAALVq0wLfffosuXbrgm2++qc3d0i2EEFiw5ST+ScpGIzclPry/M5TntgGXfgIUamDwq7YuIhERkc3VOATpdDps3boVQ4cORWhoKJYsWYKMjAw88sgj+PPPP3H48GG8+uqrOHv2LDZu3Ai5XI4XXnihNspOFYj55TK+Pp4AuUzCB5M6wc9ZB/yw0DCzx1zAK8Sm5SMiIrIHVo+Qd+HCBaxatQoxMTG4ceMGhBDo2LEjHn30Udx///1wdXUts864ceOwadMmbNu2rUaFpoodvZyGV74/AwBYMKQ1uoX6AHtfArKuAZ5BwN1P2riERERE9sHqEBQWFgZJkuDs7IwHH3wQ//nPf9ClS5cq1/Pw8EBxcbG1u6VK3MgqwGPrj0GrFxge5Y8ZPZoDqXHAL+8bFoheBjg527aQREREdsLq22Ft27bFu+++i4SEBKxevbpaAQgAVq1axW7zdaBYp8cTG/5EcnYhwpq4YfnYKEgAsONZQFcEtOgPhA+1dTGJiIjshtU1QadPn67NclANvbb9DH67nAZ3lQL/m9wZrioFcHYHcGE3IHMChiwHJMnWxSQiIrIbVtcEFRYW4urVq8jOzq5wmezsbFy9ehVFRUXW7oaq4Zvj17Dm0GUAwIr72iO0sRtQXGCoBQKA7o8DjVrZroBERER2yOoQ9NZbb6F58+aVjvtz4sQJNG/e3NRdnmpfsU6P57821Mo91qcFBrXzM8z45T0g4wrg7g/0esaGJSQiIrJPVoegr7/+Gs2bN0ePHj0qXKZHjx4ICQnB1q1brd0NVSGvUIfsAi0A4MkBJbU96VeAgysMPw96BVC52ah0RERE9svqEBQXF4e2bdtWuVy7du0QFxdn7W6oCrpSTz1xkpV8nbsWAtoCILgHEDHWRiUjIiKyb1aHoNzc3HLHArqVi4sLsrKyrN0NVUGnvxmCZDIJiNsHnPkWkOTA0NfZGJqIiKgCVoegwMBA/P7771Uu98cff8Df39/i7efk5GDOnDkICAiAWq1Ghw4d8MUXX1R7/W+++Qa9e/eGRqOBq6sr2rVrh08++cTictg7fUlNkFwmAdqim42h73wEaNLOhiUjIiKyb1aHoEGDBuHixYt4//33K1xm5cqViIuLw+DBgy3e/pgxYxATE4PFixdjx44d6NKlCyZOnIgNGzZUue6yZcswZswYREREmEaofuyxx+plLzVTCJIk4Mj/gJRzgGtjoM9/bVwyIiIi+yYJUapRiQXi4+MRGRmJ7OxsjBgxAo888ghatGgBSZJw4cIFfPLJJ/j222/h7u6O48ePIyQkpNrb3r59O4YNG4YNGzZg4sSJpumDBg3CX3/9hatXr0Iul5e77h9//IE777wTS5cuxfz58605NJOsrCx4eHggMzMTGo2mRtuqK/+m56HH8v0IVGTgoMt8oCgHGPUh0PF+WxeNiIjIJqp7/bZ6sMTAwEBs27YN9957L7Zt24Zvv/3WbL4QAo0aNcKmTZssCkAAsHXrVri5uWHcuHFm06dNm4ZJkybhyJEjuOuuu8pd94MPPoBKpcKsWbMs2qejMg6+PV++wRCAmnUB2k+sfCUiIiKq2VPke/XqhXPnzmHZsmUYMGAAwsPDER4ejgEDBmD58uU4e/Ys+vTpY/F2T58+jTZt2kChMM9oUVFRpvkV+emnn9CmTRts3rwZ4eHhkMvlaNasGf773//Wy9thOiFwp3QGI6SfAUjA0DcAWY2+ViIiogbB6pogI09PT8yfP7/Gt55KS01NRWhoaJnp3t7epvkVuXbtGpKTkzF79my8/PLLaNu2Lfbu3Ytly5YhPj4e69evr3DdwsJCFBYWmn53hF5tOp0ei50+M/zS+UEgoKNNy0NEROQoahyC6opUSdfuyubp9XpkZ2cjNjYWEyZMAAD07dsXubm5eOedd7BkyRK0bNmy3HWXLl2KJUuW1Kzgt1thFtrJrhh+7rvQtmUhIiJyILV23yQjIwPx8fG4evVquS9L+Pj4lFvbk5aWBuBmjVBF6wIo0yNtyJAhAIBjx45VuO6CBQuQmZlpesXHx1tUblvQ67Q3f3HxsV1BiIiIHEyNaoKSkpLw/PPP45tvvjEFlPJIkgStVlvh/FtFRkYiNjYWWq3WrF3QqVOnAAAREREVrhsVFYWkpKQy042d4GSVtJdRqVRQqVTVLqc90GmLb/7CtkBERETVZvVVMzExEXfccQc+/fRTqNVqNG7cGEIIdOvWDb6+vqbQ0b17d/Ts2dOibY8ePRo5OTnYvHmz2fSYmBgEBASga9euFa47dqzhMRE7duwwm759+3bIZDJ06dLForLYPb0OAKCtvUo9IiKiBsHqK+crr7yChIQEvPTSS4iPj8eQIUMgSRIOHTqExMREHDhwAK1bt4YkSWUCSVWGDBmCgQMHYubMmfi///s/7N+/H4888gh27tyJ119/3TRG0IwZM6BQKHDlyhXTutOmTUOnTp3w2GOP4b333sOePXvw3//+FytXrsRjjz2G4OBgaw/ZLulLQpAO5Y+bREREROWzOgTt3LkTzZs3x/PPP1/u/F69emHXrl34888/8fLLL1u8/S1btmDKlClYtGgRoqOjceTIEcTGxuL++28OAqjT6aDT6VB6vEcnJyfs3r0bEyZMwGuvvYahQ4di69atWLZsGd59913LD9TOGdsE6VkTREREZBGrR4xWq9UYNmyY6ZbVQw89hDVr1iAvL8+sXc2IESPwzz//4Pz587VT4tvIEUaMPnnyGKK29EUOXOD2YqKti0NERGRz1b1+W119oNFozGpgPD09ARjG6SlNrVaXmUa1hzVBRERE1rH6yhkUFITLly+bfjf22Nq+fbtpWl5eHg4dOmTVU+SpeoQxBEkMQURERJawuot8v3798M477+D69eto0qQJRo4cCVdXVzz99NOIj49Hs2bNsG7dOly/fh0zZ86szTJTKcaG0Xo2jCYiIrKI1SHo/vvvR3x8PM6cOYMmTZrA29sbH3/8MaZNm4Y33ngDkiRBCIF27drh1Vdfrc0yU2l63g4jIiKyhtUhqH379oiNjTWbNnHiRNx9993Yvn070tPTERYWhpEjR8LJyanGBaXyCV1JTRBvhxEREVnE6hB08uRJyGSyMqM3BwUF4T//+U+NC0bVw3GCiIiIrGN19UGHDh0wa9as2iwLWUHoDY/NEKwJIiIisojVV05vb28EBATUZlnIGjo2jCYiIrKG1SGoW7dupgeaku3ojQ2jJYYgIiIiS1gdghYvXoyzZ89ixYoVtVkespDQs2E0ERGRNaxuGH3mzBlMnjwZ8+fPx+eff47hw4cjKCgIarW63OUfeOABqwtJleA4QURERFaxOgQ9+OCDprGATp48iZMnT0KSpDLLCSEgSRJDUF0pGTFa8HYYERGRRawOQYsWLSo39NDtpReGmiD2DiMiIrKM1SHoxRdfrMVikNXYO4yIiMgqrD5wdMJ4O4xfJRERkSV45XRwxsdmsE0QERGRZWr0FPnqkiQJe/futXZXVBmOE0RERGQVq0PQgQMHqlzG2HuMDajrkGBNEBERkTWsDkGXLl0qd7per0d8fDx++OEHvPvuu3j88cfx2GOPWV1AqoJpsESGICIiIktYHYKCg4MrnNe8eXP06tULffv2xZAhQ9CtW7dKlyfrGUeMZsNoIiIiy9TplXPAgAHo3Lkzli1bVpe7adh4O4yIiMgqdV59EBgYiL/++quud9Nw6RmCiIiIrFGnISg/Px9Hjx6t8HliVAv0fGwGERGRNaxuE3T16tUK5+Xk5ODcuXNYsWIF4uPjMXHiRGt3Q1XR6w3vbBNERERkEatDUEhISJVd34UQCA8PxxtvvGHtbqgKknHEaJnVXyUREVGDZPWVs1evXhWGIKVSCX9/f/Tu3RsTJ07k7bC6xN5hREREVqnTwRLpNjD1DmNNEBERkSVYfeDgpJKG0WwTREREZBmrr5zp6en46aefkJCQUOEy165dw08//YSMjAxrd0NVESUNo2XsHUZERGQJq0PQihUr0LdvXyQnJ1e4TEpKCvr27Yt33nnH2t1QVXg7jIiIyCpWh6Dvv/8erVu3Rvv27Stcpn379mjdujW+/fZba3dDVZBKGkazJoiIiMgyVoegy5cvIzw8vMrlwsPDceXKFWt3Q1UpqQkCB0skIiKyiNUhqLi4GHJ51RdehUKBvLw8a3dDVZDx2WFERERWsToENW/eHL/++it0Ol2Fy+h0Ovzyyy8ICgqyePs5OTmYM2cOAgICoFar0aFDB3zxxRdVrrd27VpIklTuKykpyeJy2D3B22FERETWsDoEDR8+HImJiXjuuecqXGbhwoVITEzEyJEjLd7+mDFjEBMTg8WLF2PHjh3o0qULJk6ciA0bNlRr/TVr1uDXX381e/n4+FhcDrunZ+8wIiIia1jdpejpp5/G559/jjfffBO7d+/GQw89hBYtWkCSJFy4cAGrVq3CiRMn4Ofnh2eeecaibW/fvh27d+/Ghg0bTM8d69u3L65cuYJnnnkG48ePr/JWXEREBO644w5rD89hyIRxnCCGICIiIktYHYJ8fHywa9cujB07FsePH8esWbPM5gshEBYWhs2bN6Nx48YWbXvr1q1wc3PDuHHjzKZPmzYNkyZNwpEjR3DXXXdZW/T6heMEERERWaVGg8u0bdsWp0+fxpYtW7Bnzx7Ex8cDAAIDAzFgwACMGTOmWo2nb3X69Gm0adMGCoV58aKiokzzqwpBw4cPR3JyMjw8PNCnTx+89NJLiIiIqHSdwsJCFBYWmn7PysqyuOy3m8Q2QURERFap8Qh7crkc48aNK1NrUxOpqakIDQ0tM93b29s0vyJ+fn5YuHAhunXrBo1Gg1OnTmHZsmXo1q0bDh06VOm4RkuXLsWSJUtqfgC3kbF3mMQQREREZBG7HWa4oifUVzUvOjoa0dHRpt979eqFYcOGITIyEosWLcI333xT4boLFizAU089Zfo9KysLgYGBFpb89pI4YjQREZFVrO4dtn79eoSGhmL37t0VLrNr1y6EhoZi48aNFm3bx8en3NqetLQ0ADdrhKorJCQEPXr0wOHDhytdTqVSQaPRmL3snWRsE2TFbUciIqKGzOoQ9PnnnyM3Nxd9+/atcJl+/fohJycHMTExFm07MjISZ86cgVarNZt+6tQpAKiybU95hBCQyerfk9aNNUESe4cRERFZxOpUcPr0aURFRZVpvFyaQqFA+/btcfr0aYu2PXr0aOTk5GDz5s1m02NiYhAQEICuXbtatL1Lly7h0KFD6Natm0XrOQJTw2g5b4cRERFZwuorZ0pKCnx9fatcztfXFwcPHrRo20OGDMHAgQMxc+ZMZGVloWXLloiNjcXOnTuxbt06U4+zGTNmICYmBnFxcQgODgYADBgwAL169UJUVJSpYfTrr78OSZLw8ssvW36gdk4GNowmIiKyRo3GCYqLi6tyubi4OHh6elq8/S1btmDhwoVYtGgR0tLS0Lp1a8TGxmLChAmmZXQ6HXQ6HYQQpmmRkZHYuHEj3nzzTeTn58PX1xf9+vXDCy+8gLCwMIvLYe9kfIAqERGRVSRROkFY4L777sPmzZtx4MAB9OzZs9xlfv75Z/Tq1Qv33HMPtmzZUqOC2kJWVhY8PDyQmZlpt42k/3qtJ9oVncQfXVag87CHbF0cIiIim6vu9dvqNkFz584FAIwcORLvvPMOcnNzTfNyc3PxzjvvYNSoUZAkybQs1T4JhgzL22FERESWsToEde/eHStWrEBWVhbmzZsHjUYDf39/BAQEQKPRYN68ecjIyMAbb7xRYU0R1Zyxi7xUD3u+ERER1aUaXTnnzJmD/fv3Y/DgwVCr1bh+/TqSkpKgVqsRHR2N/fv3mw0+SLVPQsk4QWwTREREZJEa96vu1asXevXqBb1ej5SUFABAo0aN6uWYPPbIVBMk8fMmIiKyRK0NLiOTyarVZZ5ql7FNEBg6iYiILFKjECSEwPr16/HNN9/g/PnzyM7ORnmdzSRJqlZ3erKc8XYYR4wmIiKyjNUhqKioCMOGDcO+ffvKDT6AIfxY2QOfqkkSrAkiIiKyhtVXzhUrVmDv3r0YPnw4zp8/jylTpkCSJBQWFuLMmTN48cUX4erqimeeeQZ6vb42y0yl3KwJYggiIiKyhNU1QRs3boS3tzc2bNgAV1dXU0NoJycnhIeHY9GiRejbty/69u2L8PBwTJ8+vdYKTTfJhHGcIIYgIiIiS1h95bxw4QLuvPNOuLq6GjZUchHW6XSmZXr27Im7774bH374YQ2LSRVhTRAREZF1rL5yyuVys6GojWEoOTnZbLmmTZvi7Nmz1u6GqsARo4mIiKxjdQhq2rQprl69avq9ZcuWAIDDhw+bLXfy5Em4ublZuxuqgqkmiLfDiIiILGL1lbNbt27466+/kJ+fDwAYOnQoAODJJ5/Ejh07cOrUKcyaNQtnzpxB165da6e0VIaxd5iMt8OIiIgsYvWVc+zYsXBxccHu3bsBGGqC5syZg/j4eAwfPhwdOnTAypUr4eLiguXLl9dagcmc6bEZrAkiIiKyiNW9w4YNG4bExESzaStWrECXLl3w9ddfIz09HWFhYZg9ezZatWpV44JS+WRsGE1ERGSVWntshtGECRMwYcKE2t4sVeBmF/la/yqJiIjqNVYfODg2jCYiIrIOr5wO7mYXeX6VREREluCV08HJ+ABVIiIiqzAEOThTTZBcsnFJiIiIHAtDkIOTwThOEGuCiIiILMEQ5ODYMJqIiMg6vHI6OBkbRhMREVmFV04HJ7FhNBERkVUYghyccbBEGWuCiIiILMIrp4O7OU4Qa4KIiIgswRDk4OSm22HsIk9ERGQJhiAHZ2oTJOezw4iIiCzBEOTgOE4QERGRdRiCHNzNLvK8HUZERGQJhiBHJgRkEhtGExERWYMhyIEJoTf9zC7yRERElrHbK2dOTg7mzJmDgIAAqNVqdOjQAV988YXF23n++echSRIiIiLqoJS2JfSlQxBrgoiIiCxht12KxowZg6NHj2LZsmUICwvDhg0bMHHiROj1ekyaNKla2zh+/DjefPNNNGnSpI5Laxt6vc6UYnk7jIiIyDJ2GYK2b9+O3bt3m4IPAPTt2xdXrlzBM888g/Hjx0Mur/yir9VqMW3aNDz66KM4ceIEUlJSbkfRbyt9qZogNowmIiKyjF3eDtu6dSvc3Nwwbtw4s+nTpk1DQkICjhw5UuU2li1bhrS0NLz66qt1VUyb0+t1pp95O4yIiMgydhmCTp8+jTZt2kChMK+oioqKMs2vzN9//41XXnkFH330Edzc3OqsnLZm3ibILr9KIiIiu2WXt8NSU1MRGhpaZrq3t7dpfkX0ej2mT5+OMWPGYOjQoRbtt7CwEIWFhabfs7KyLFr/dmNNEBERkfXstvqgsmdhVTbvrbfewvnz5/HOO+9YvM+lS5fCw8PD9AoMDLR4G7dT6RAksSaIiIjIInZ55fTx8Sm3tictLQ3AzRqhW129ehWLFi3C4sWLoVQqkZGRgYyMDGi1Wuj1emRkZCA/P7/C/S5YsACZmZmmV3x8fO0cUB0xux3GZ4cRERFZxC5DUGRkJM6cOQOtVms2/dSpUwBQ4Zg/Fy9eRH5+Pp588kl4eXmZXocOHcKZM2fg5eWFBQsWVLhflUoFjUZj9rJnovTtMMkuv0oiIiK7ZZfVB6NHj8b//d//YfPmzRg/frxpekxMDAICAtC1a9dy1+vQoQP2799fZvqcOXOQmZmJNWvWoFmzZnVW7tvN2EVeLyTI2EWeiIjIInYZgoYMGYKBAwdi5syZyMrKQsuWLREbG4udO3di3bp1pjGCZsyYgZiYGMTFxSE4OBienp7o06dPme15enpCq9WWO8+RmUIQJCgqaSdFREREZdllCAKALVu2YOHChVi0aBHS0tLQunVrxMbGYsKECaZldDoddDodhBA2LKntGG+H6cEAREREZClJNNQEUQ1ZWVnw8PBAZmamXbYPSr4Wh8b/1wmFwgmqJfVvRGwiIiJrVPf6zda0Dow1QURERNZjCHJgpdsEERERkWUYghyYXmcIQYJfIxERkcV49XRkgjVBRERE1mIIcmDGx2YIdo8nIiKyGEOQAzM2jNbxayQiIrIYr54OzPjsMLYJIiIishyvng5MiJLbYWwTREREZDGGIAd2s4s8v0YiIiJL8erpwG7eDmNNEBERkaUYghyYniNGExERWY0hyJHpDY99Y8NoIiIiy/Hq6cBMDaM5ThAREZHFGIIcmGDDaCIiIqvx6unA9IINo4mIiKzFEOTIjI/N4NdIRERkMV49HZgQJQ2j2SaIiIjIYgxBDkzotQDYJoiIiMgavHo6MD47jIiIyHq8ejoyY8No3g4jIiKyGEOQA2MXeSIiIuvx6unABLvIExERWY0hyIHdHDGaXyMREZGlePV0ZCW3w8CaICIiIosxBDkwtgkiIiKyHq+eDkywdxgREZHVGIIcmDEE8WskIiKyHK+ejsw4WCIbRhMREVmMV09Hxi7yREREVmMIcmCi5Cnyeklu45IQERE5HoYgRybYRZ6IiMhaDEGOTLBNEBERkbXs9uqZk5ODOXPmICAgAGq1Gh06dMAXX3xR5Xp79uzBwIEDERAQAJVKBV9fX/Tr1w/bt2+/DaW+vW4+NsNuv0YiIiK7ZbdXzzFjxiAmJgaLFy/Gjh070KVLF0ycOBEbNmyodL3U1FS0a9cOb7/9Nnbt2oWPP/4YTk5OGDZsGNatW3ebSn97CD3HCSIiIrKWJIQQti7ErbZv345hw4Zhw4YNmDhxomn6oEGD8Ndff+Hq1auQy6vfGLi4uBjNmzdHaGgofvrpp2qvl5WVBQ8PD2RmZkKj0Vh0DLfD75vfwh2nluCYy93oNL/+1XQRERFZo7rXb7usCdq6dSvc3Nwwbtw4s+nTpk1DQkICjhw5YtH2nJyc4OnpCYVCUZvFtD12kSciIrKaXYag06dPo02bNmVCS1RUlGl+VfR6PbRaLRISErB48WKcO3cO8+bNq5Py2opgw2giIiKr2WXVSGpqKkJDQ8tM9/b2Ns2vytChQ/HDDz8AADQaDTZu3Ihhw4ZVuk5hYSEKCwtNv2dlZVlS7NuPj80gIiKymt1ePaVKGvtWNs/o/fffx2+//YZvvvkGgwcPxvjx4xEbG1vpOkuXLoWHh4fpFRgYaHG5bys2jCYiIrKaXYYgHx+fcmt70tLSANysEapMq1at0KVLF4wcORKbNm1C//798fjjj0Ov11e4zoIFC5CZmWl6xcfHW38Qda04H8FJhpquQrmLjQtDRETkeOwyBEVGRuLMmTPQarVm00+dOgUAiIiIsHibd955J9LT05GcnFzhMiqVChqNxuxll3Ra4Mtp8M04jizhgh+97rV1iYiIiByOXYag0aNHIycnB5s3bzabHhMTg4CAAHTt2tWi7Qkh8OOPP8LT0xM+Pj61WdTbTwjguyeBczuglZR4qGgerqua27pUREREDscuG0YPGTIEAwcOxMyZM5GVlYWWLVsiNjYWO3fuxLp160xjBM2YMQMxMTGIi4tDcHAwAGDUqFFo3749OnToAB8fHyQkJGDt2rX48ccfsXLlSsfvJr93CfDnOghJhqfEk/hNtMHiIE9bl4qIiMjh2G0i2LJlCxYuXIhFixYhLS0NrVu3RmxsLCZMmGBaRqfTQafTofR4j3fffTe++uorfPDBB8jKyoKnpyfuuOMOfPfdd1X2DrN7v34I/Pw2AGCN1xxsS+iI9s08MKVbsI0LRkRE5HjscsRoe2FXI0af3ARsedjwY/iTGHmiK5QKGb6f1QOtmrjbtmxERER2xKFHjKZbnN8DfD0TAJDT4WFM+ucuAMC8gWEMQERERFZiCLJ3//4ObJoC6LUQkeMwM3kscgp16BzshYd6lh1QkoiIiKqHIcieJZ8D1o8DivOAFv2xwf+/OBiXBrWTDG/cGwW5jIMkEhERWYshyF5lXgM+Hw3kpwFNOyN+wMd4decFAMD8wa0R2tjNxgUkIiJybAxB9igvDVg3Bsj6F/BpBf3ETXh62wXkFenQtbk3HrwrxNYlJCIicngMQfamKA+InQAk/wO4BwBTtmDt8WwcuZQGF6Ucb9zbHjLeBiMiIqoxhiB7oisGvnwQiD8CqD2AyZtxsdgbr//wDwBgwdA2CPLhc8KIiIhqA0OQvRAC2DYbOP8DoFADkzZB17gNnv7yBAqK9ejRshEmdw2ydSmJiIjqDYYge7F7EXBiAyDJgXExQFA3rDp4EceuZsBNpcDye6MgSbwNRkREVFsYguzBL+8Dv7xn+Hnk+0B4NM5fz8aK3ecAAC8Mb4Omns42LCAREVH9wxBka8djgV3PG34esAToeD+0Oj3mfXkCRVo9+oY3xn13BNq2jERERPUQQ5AtndsFfPO44efuTwB3PwkA+N+PcTj5byY0agWWjuFtMCIiorrAEGQr8b8Bmx4AhA6IGg8MfBmQJPydkIV3954HALw4sh38PNQ2LigREVH9xBBkC/npwIb7AG0+0HIgMGolIJOhSGu4DVasExjYtglGd2xq65ISERHVWwxBtpB40hCE3P2B+2IAuRMA4IP9F3AmMQteLk54bXQkb4MRERHVIYYgW9BrDe8ujQClKwDg1L+ZWLnf8Gywl0ZFoLG7ylalIyIiahAYgmxBrzO8y+QAgEKtDvO+PA6dXmBYpD9GtA+wYeGIiIgaBoYgWzDWBMkUAIC3d5/Hues5aOSmxMv3RNiwYERERA0HQ5AtlApBx66m45Of4gAAr9wTCW9XpQ0LRkRE1HAwBNlCSQjSS3I8/eUJ6AVwT4cAREf42bhgREREDQdDkC2UtAm6nF6Ii8m58HVX4cWR7WxcKCIiooaFIcgWhCEExWcWAQCWjY2EpwtvgxEREd1ODEE2UFxsCD9aIce4zs3Qr3UTG5eIiIio4WEIsoH4lGwAgEyuwAsj2tq4NERERA0TQ5ANGGuClEonaNRONi4NERFRw8QQZAM6XUkXeUlh24IQERE1YAxBNqDTFgMARMmI0URERHT7MQTZgF5nCEHGEaOJiIjo9mMIsgFhvB3GmiAiIiKbYQiyAZ3W/NlhREREdPsxBNmAKHlshsQQREREZDMMQTag17EmiIiIyNYYgmzA2CZIkjMEERER2YrdhqCcnBzMmTMHAQEBUKvV6NChA7744osq19uyZQsmTpyIli1bwtnZGSEhIbj//vtx/vz521Dq6jH2DmMIIiIish27vQqPGTMGR48exbJlyxAWFoYNGzZg4sSJ0Ov1mDRpUoXrLV++HH5+fli4cCFCQ0MRHx+P1157DZ06dcLhw4fRrp0dPK29pE2QjLfDiIiIbMYur8Lbt2/H7t27TcEHAPr27YsrV67gmWeewfjx4yGXl9+9/Ntvv4Wvr6/ZtH79+iEkJARvv/02Vq1aVeflr4rQGZ4iL8n5yAwiIiJbscvbYVu3boWbmxvGjRtnNn3atGlISEjAkSNHKlz31gAEAAEBAWjWrBni4+NrvaxWMdYEVRDkiIiIqO7ZZQg6ffo02rRpA4XCvKIqKirKNN8SFy9exJUrV6q8FVZYWIisrCyzV10QphDEmiAiIiJbscsQlJqaCm9v7zLTjdNSU1OrvS2tVosZM2bAzc0Nc+fOrXTZpUuXwsPDw/QKDAy0rODVZQpBdnk3koiIqEGwyxAEAJIkWTWvNCEEZsyYgYMHD+Kzzz6rMtQsWLAAmZmZpldd3T4TekObIJmCIYiIiMhW7PIq7OPjU25tT1paGgCUW0t0KyEEHnroIaxbtw4xMTEYNWpUleuoVCqoVCrLC2yhEC8VkAc08XSr830RERFR+eyyJigyMhJnzpyB1viMrRKnTp0CAERERFS6vjEArVmzBqtWrcLkyZPrrKzWaOZhaAvUxMPVxiUhIiJquOwyBI0ePRo5OTnYvHmz2fSYmBgEBASga9euFa4rhMDDDz+MNWvW4OOPP8a0adPquriWK7kdxsdmEBER2Y5dXoWHDBmCgQMHYubMmcjKykLLli0RGxuLnTt3Yt26daYxgmbMmIGYmBjExcUhODgYADB79mysXr0a06dPR2RkJA4fPmzarkqlQseOHW1yTGb0fHYYERGRrdntVXjLli1YuHAhFi1ahLS0NLRu3RqxsbGYMGGCaRmdTgedTgchhGnat99+CwD49NNP8emnn5ptMzg4GJcvX74t5a8UQxAREZHNSaJ0giAzWVlZ8PDwQGZmJjQaTe1teMME4OJ+YNRKIPLe2tsuERERVfv6zaoIW5hU9YNgiYiIqG7ZZcNoIiIiorrGEEREREQNEkMQERERNUgMQURERNQgMQQRERFRg8QQRERERA0SQxARERE1SAxBRERE1CAxBBEREVGDxBBEREREDRJDEBERETVIDEFERETUIDEEERERUYPEEEREREQNksLWBbBnQggAQFZWlo1LQkRERNVlvG4br+MVYQiqRHZ2NgAgMDDQxiUhIiIiS2VnZ8PDw6PC+ZKoKiY1YHq9HgkJCXB3d4ckSQAM6TIwMBDx8fHQaDQ2LmHtqs/HBvD4HFl9PjaAx+fI6vOxAY57fEIIZGdnIyAgADJZxS1/WBNUCZlMhmbNmpU7T6PRONQfhCXq87EBPD5HVp+PDeDxObL6fGyAYx5fZTVARmwYTURERA0SQxARERE1SAxBFlKpVFi8eDFUKpWti1Lr6vOxATw+R1afjw3g8Tmy+nxsQP0/PjaMJiIiogaJNUFERETUIDEEERERUYPEEEREREQNUoMLQTk5OZgzZw4CAgKgVqvRoUMHfPHFF9Va98aNG3jwwQfRqFEjuLi4oHv37ti7d2+5y+7Zswfdu3eHi4sLGjVqhAcffBA3btyozUMpl7XHt2XLFkycOBEtW7aEs7MzQkJCcP/99+P8+fNllu3Tpw8kSSrzio6OrotDMrH22NauXVtueSVJQlJSUpnlHe27q+j7KO8YbfXdAYaRW+fPn49BgwahcePGkCQJL774YrXXt+fzrybH5gjnXk2OzxHOv5ocn72ff/v27cP06dPRunVruLq6omnTphg1ahT++OOPaq1vz+ddbWhwgyWOGTMGR48exbJlyxAWFoYNGzZg4sSJ0Ov1mDRpUoXrFRYWon///sjIyMC7774LX19frFy5EtHR0dizZw969+5tWvbHH3/EkCFDMGzYMHzzzTe4ceMGnn32WfTv3x+///57nbayt/b4li9fDj8/PyxcuBChoaGIj4/Ha6+9hk6dOuHw4cNo166d2fKhoaFYv3692TRPT8+6OCQTa4/NaM2aNWjdurXZNB8fH7PfHfG7+/DDD8s83y4vLw/R0dHo3Lkz/Pz8zObZ4rsDgNTUVHzyySdo37497rnnHqxatara69r7+VeTY3OEc68mx2dkz+dfTY7P3s+/jz76CKmpqXjyySfRtm1bJCcnY8WKFejWrRt++OEH9OvXr8J17f28qxWiAfn+++8FALFhwwaz6QMHDhQBAQFCq9VWuO7KlSsFAPHLL7+YphUXF4u2bduKO++802zZLl26iLZt24ri4mLTtEOHDgkA4sMPP6yloymrJsd3/fr1MtOuXbsmnJycxIwZM8ym9+7dW7Rr1652Cl1NNTm2NWvWCADi6NGjVe7HEb+78qxdu1YAEKtWrTKbbovvzkiv1wu9Xi+EECI5OVkAEIsXL67WuvZ+/tXk2Oz93BOiZsfnCOdfTY6vPPZ0/pX395WdnS2aNGki+vfvX+m69n7e1YYGdTts69atcHNzw7hx48ymT5s2DQkJCThy5Eil64aHh6N79+6maQqFApMnT8Zvv/2Ga9euAQCuXbuGo0ePYsqUKVAobla03XXXXQgLC8PWrVtr+ajMy2jt8fn6+paZFhAQgGbNmiE+Pr7Wy2qpmhxbdTnqd1ee1atXw83NDePHj6/NYtaIserfGvZ+/tXk2Oz93ANqdnzVZcvzr7aPz57Ov/L+vtzc3NC2bdsq/77s/byrDQ0qBJ0+fRpt2rQx+5IAICoqyjS/snWNy5W37l9//WW2jYqWrWwfNVWT4yvPxYsXceXKlTLV8QAQFxcHb29vKBQKtGjRAgsXLkR+fr71ha9CbRzb8OHDIZfL4e3tjTFjxpRZp758d+fPn8fBgwcxYcIEuLm5lZl/u7+72uAI519tsqdzr7bY8/lXmxzh/MvMzMSxY8fK/fsqrSGcdw2qTVBqaipCQ0PLTPf29jbNr2xd43KVrWt8r2jZyvZRUzU5vltptVrMmDEDbm5umDt3rtm8Hj16YPz48WjdujXy8/OxY8cOvP766/j555+xf//+Sp/Ya62aHJuxvUW3bt2g0Whw6tQpLFu2DN26dcOhQ4fQvn17s204+ne3evVqAMCMGTPKzLPFd1cbHOH8qy32du7VlCOcf7XJEc6/xx9/HLm5uVi4cGGlyzWE865BhSAAlVZ5VlUdasm6FS1b11XKNTk+IyEEZsyYgYMHD2Lz5s0IDAw0m//KK6+Y/T506FCEhITg6aefxjfffIPRo0dbXvBqsPbYoqOjzXpf9OrVC8OGDUNkZCQWLVqEb775plrbcoTvTqvVIiYmBu3atUO3bt3KzLfVd1cbHOH8qyl7PfdqwlHOv9rgCOffCy+8gPXr1+P9999H586dq1y+vp939vffhjrk4+NTbiJNS0sDUH6KtXRdY2+HipatbB81VZPjMxJC4KGHHsK6deuwdu1ajBo1qlr7njx5MgDg8OHDFpS4+mrj2EoLCQlBjx49zMrr6N8dAGzfvh1JSUl46KGHqr3vuv7uaoMjnH81Za/nXl2wt/Ovttj7+bdkyRK88sorePXVV/HEE09UuXxDOO8aVAiKjIzEmTNnoNVqzaafOnUKABAREVHpusblKlvX+F7RspXto6ZqcnzAzX+E16xZg1WrVplOTkvUVXVuTY+tPEIIs/I68ndntHr1aiiVSkyZMsXiMtjjrRQjRzj/asKez726Yk/nX22x5/NvyZIlePHFF/Hiiy/iueeeq9Y69f28A9Cwushv375dABBffPGF2fTo6OgquyF/+OGHAoA4fPiwaVpxcbFo166d6Nq1q9myd955p4iIiDDb3q+//ioAiI8++qiWjqasmhyfXq8XM2bMEJIkiU8++cTifS9fvlwAEF9//bXF61ZHTY6tPBcvXhRubm7innvuMZvuiN+dUWJiolAoFOK+++6zaN91/d2Vx9JuyI5w/hlZemz2fu7dqja6kNvb+Veatcdnz+ffSy+9JACI559/3qL1HOm8s1aDCkFCGMZd8fLyEp988onYt2+fePjhhwUAsW7dOtMy06dPF3K5XFy+fNk0raCgQLRr104EBgaK9evXi927d4vRo0cLhUIhDhw4YLaP/fv3C4VCIUaPHi12794t1q9fLwIDA0VERIQoKCiwy+N74oknBAAxffp08euvv5q9jh07Zlrup59+EoMHDxb/+9//xK5du8S2bdvEzJkzhVwuF/369RM6nc7ujq1///5iyZIlYuvWrWLv3r3inXfeEQEBAcLd3V2cOnXKbB+O+N0ZLVu2TAAQu3btKnf7tvzujLZv3y6+/PJL8emnnwoAYty4ceLLL78UX375pcjNzRVCOO75Z+2xOcK5V5Pjc5Tzz9rjM7LX8+/NN98UAER0dHSZv69ff/3VtJyjnnc11eBCUHZ2tpg9e7bw8/MTSqVSREVFidjYWLNlpk6dKgCIS5cumU1PSkoSDzzwgPD29hZqtVp069ZN7N69u9z97Nq1S3Tr1k2o1Wrh7e0tHnjggXIHrapt1h5fcHCwAFDuKzg42LTc+fPnxdChQ0XTpk2FSqUSarVaREZGildffbXO/9CtPbY5c+aItm3bCnd3d6FQKERAQICYPHmyOHv2bLn7cbTvzigsLEyEhISYBn27lS2/O6PK/s6Mx+So55+1x+YI515Njs9Rzr+a/G0KYb/nX+/evSs8rtI3gxz1vKspSQghLLl9RkRERFQfOFZLOiIiIqJawhBEREREDRJDEBERETVIDEFERETUIDEEERERUYPEEEREREQNEkMQERERNUgMQUQOTJIkhISE2LoYVfrjjz8waNAgeHp6QpIkSJKEy5cv27pYRGQjP/30E0aMGIGAgABIkoSvv/7aovUvX75s+rek9Gvnzp0WbYchiIjqVHZ2NkaOHIk9e/agU6dOeOCBBzB16lS4ubnZumj12tq1ayFJEl588UVbF4WojNzcXLRv3x4ffPBBjbazZ88eJCYmml79+vWzaH1FjfZORFSFo0ePIiEhAVOmTMFnn31m6+IQkR0YMmQIhgwZUuH8oqIiPP/881i/fj0yMjIQERGB5cuXo0+fPmbL+fj4wM/Pz+pysCaIiOrUv//+CwAIDQ21cUmIyFFMmzYNhw4dwhdffIGTJ09i3LhxiI6Oxvnz582WGzlyJHx9fXH33Xfjq6++snxHtn54GREJcenSJQFA9O7dW+Tl5Ylnn31WBAUFCaVSKVq0aCGWLVtW7oMZUfKQzcLCQrFo0SIRGhoqVCqVaN68uXjhhRdEfn5+mXWMD1S8dOmSWL9+vejatatwc3MTHh4e1SprcXGxeO+990SnTp2Eq6urcHV1FV26dBEffvih0Gq1ZY6pvNfUqVOr3E/pcn7++eeiU6dOwtnZWTRu3Fg88MAD4t9//y2zTnp6unjvvffEoEGDTJ+ft7e3GDx4cIVP967O5/Hdd9+JadOmidatWwt3d3fh4uIioqKiKnz45Zo1awQAsXjxYnHhwgUxbtw44ePjI9zd3UV0dLT466+/TJ/lq6++Klq1aiVUKpVo0aKFWLlyZYWfyaVLl8QjjzwigoODhVKpFI0aNRJjx44VJ06cKPeYynutWbPGbNmTJ0+KSZMmiYCAAKFUKoW/v7948MEHy31I6OLFi03bOHLkiBg2bJjw9vYWAMSff/4phBAiJSVFLFiwQLRt21a4uroKjUYjWrVqJaZMmSKOHDlS4bFRwwVAbN261fT7hQsXhCRJ4tq1a2bL9e/fXyxYsEAIIURycrJ46623xJEjR8TRo0fFCy+8IGQymfj8888t23eNS09ENWYMDN27dxc9evQQXl5eYvDgwWLw4MFCrVYLAGLhwoVl1gMggoKCxIgRI4Szs7MYPny4GDNmjPDw8BAARP/+/c2CiRA3L5CPPPKIkMlkomfPnmLChAni7rvvrrKcWq1WDB06VAAQGo1GjBo1SowaNUq4u7sLAGL06NFCp9MJIQz/SE2dOlXcfffdAoBo3769mDp1qpg6dar4v//7vyr3ZSzn448/LiRJEr169RITJkwQISEhAoBo1qyZiI+PN1tnx44dAoAIDAwU/fv3F+PHjxfdu3cXkiQJSZLE6tWrK9xPZZ9HkyZNhJubm+jatasYN26cGDx4sPDy8hIARL9+/cp8xsYQZHz6dmhoqBgzZoyIjIwUAETjxo1FYmKi6bMbNGiQGDx4sFAqlQKA+OSTT8qU8+DBg0Kj0QgAol27duLee+81HZuzs7PYt2+fadmlS5eW+7lPnTpVHDx40LTcV199Zdpn586dxb333is6duwoAAgfHx9x+vRpszIYQ9C0adOEk5OTaNeunZgwYYLo1auXOHHihMjOzhYtW7YUAESrVq3EmDFjxJgxY8Qdd9whFAqFWLx4cZXfOzU8t4agTZs2CQCm/2QZXwqFQtx3330VbueJJ54QkZGRlu3b2kITUe0pXWvSs2dPkZycbJp39OhRoVAohIuLi8jOzjZbz7hOs2bNRFxcnGn6jRs3REREhAAg3n33XbN1jBd9tVotDhw4YFE533zzTQFAREZGiuvXr5umJyQkiPDwcAGgTE1G6VoRSxjLqVAoxPfff2+aXlRUJO6//35T6Crt4sWL4tChQ2W2dezYMeHp6Sk0Gk2Zz7A6n8fWrVtFTk6O2bSsrCwxfPhwAUDExMSYzTMeMwDx1FNPmYKhXq8XDz74oAAg2rZtKyIiIsyC3J49e0y1e6VlZmYKPz8/4eTkJL788kuzebt37xZKpVI0bdpUFBYWlilDRZ/7xYsXhYuLi/Dw8BA//vij2byYmBgBQHTp0sVsujEEARDLly8vs03jPmfNmlVm3vXr18WpU6fKLQs1bLeGoC+++ELI5XLxzz//iPPnz5u9EhMTK9zOunXrhFqttmzf1haaiGqPMQTJZDJx9uzZMvNHjBghAIj9+/ebTTdekMqrOTDWioSFhZlNL13DYqmgoCABQOzdu7fMvG3btgkAIjw83Gx6TUPQpEmTysxLSUkRrq6uQiaTlXtbrDwLFy4UAMS2bdvK3Y81n8f58+cFADFmzBiz6cZjbtGihSguLjabd/LkSdP3Vrr2xshYE1P6dtTbb78tAJhuBdxqzpw5AoDYvHlzmTJU9Lk/+eSTAoD4+OOPy51/zz33CADijz/+ME0zhqCIiIhyb88uX768zAWNqCq3/s2cPXtWABA//fSTRduZN2+eaN68uUXrsHcYkR0JCQlBWFhYmenGaYmJieWuN2HChDLToqOj4eXlhXPnziE5ORmNGzc2mz9y5EiLynb16lVcvXoVfn5+5XZDHT58ODw9PXH27Nly92et8o7Nx8cHAwcOxNdff41ffvkF48aNM83T6XTYu3cvfvnlFyQlJaGgoAAATA0qb21YaVTV53H+/Hls374dFy5cQG5uLvR6PQz/fle8zT59+kChMP9n1thAXKlUonfv3mXWadGiBf78808kJiaaxoDavXs3AOCee+4pdz89evTAO++8g6NHj2LMmDGVHoeRcZujRo2qcJtff/01jh49ik6dOpnNGzFiBCRJKrNO586dAQDPPfccFAoFBgwYALVaXa3yUMOSk5ODCxcumH6/dOkSjh8/Dm9vb4SFheH+++/HAw88gBUrVqBjx45ISUnBvn37EBkZiaFDhyImJgZOTk7o2LEjZDIZvv32W7z33ntYvny5ReVgCCKyI82aNSt3unFMncLCwjLzvLy84O7uXu56wcHBSE9PR0JCQplQEhQUZFHZEhISAKDCwRklSUJwcDAyMjLK3Z+1goODy51uLIexXIChJ9rw4cNx4sSJCreXnZ1d7vSKPg8hBJ5++mm8/fbbptBT3W02bdq0zDRXV1cAgJ+fH2Sysh10jfNLf9fGgSW7du1a7n6MUlJSKp1fmnGbVXUvLm+bFX1W/fv3x9y5c/HOO+9gxIgRUCqV6NChAwYNGoQZM2Y4xMCedHv8/vvv6Nu3r+n3p556CgAwdepUrF27FmvWrMErr7yCefPm4dq1a/Dx8UH37t0xdOhQ0zqvvPIKrly5ArlcjrCwMHz66aeYPHmyReVgCCKyI+X977omKrpoA7D6f+jVKWNtH0d5yju2hx56CCdOnMCYMWPw7LPPIjw8HO7u7pDJZPjkk0/w6KOPVviZVPR5bNy4EW+99RaaNWuGd955B927d0fjxo3h5OSEoqIiqFSqCrdZ2edgyWek0+kAAOPGjYOLi0uFy1UVkm7dpiRJeOCBBypdrl27dmWmVfa389Zbb+HRRx/FN998g7179+LQoUP47bff8Prrr2Pjxo0V1mZRw9KnT59K/31ycnLCkiVLsGTJknLnT506FVOnTq1xORiCiBxceno6srOzy60Nunr1KgDA39+/xvsJCAgAYKi2rkht7s/oypUriIqKqnBfxnLl5uZi9+7daNKkCTZt2gS5XG62/MWLF63a/9atWwEAH330EYYPH14r27RUs2bNcPbsWTz//PPlfhbWbjMuLg7vvfceNBpNrWzTKDw8HPPnz8f8+fNRUFCAlStX4umnn8ajjz7KEER2hYMlEtUDGzduLDPthx9+QHp6Olq1agVfX98a7yMoKAhBQUFISkrCvn37ysz//vvvkZ6ejvDw8Fq7FQaUf2xpaWnYtWsXJElC9+7dAQCZmZnQ6/Xw9/cvE4C0Wq0pzFgqPT0dABAYGFhm3qZNm6zapqUGDBgAABY9X0mpVAIwHHttbdMaarUa8+bNg7+/P27cuIEbN27U6f6ILMEQRFQPvPTSS2YPJE1JScH8+fMBAI899lit7WfWrFkAgLlz5yI5Odk0PSkpCc8884zZMrVl06ZN+OGHH0y/a7VazJ07F7m5uRg5cqSpHZWvry88PDxw+vRpHDp0yLS8TqfD/Pnzce7cOav2b2yU/sknn5hV3x88eBBvvPGGVdu01KOPPorGjRvjtddew5o1a8rcRsjNzcVnn31mGp0buFlDdvbs2XK3OW/ePDg7O2Pu3Ln49ttvy8xPS0vDhx9+iPz8/GqX8+uvv8bhw4fLTP/zzz9x/fp1uLu7w8vLq9rbI6prvB1G5OCCgoIQFRWFdu3aoX///nBycsK+ffuQkZGBvn374oknnqi1fc2dOxf79u3Djh070KpVK/Tr1w9CCOzduxfZ2dm45557MHPmzFrbHwA88sgjGDJkCHr16oWAgAAcPnwYly5dQkBAAN577z3TcgqFAvPnz8fChQvRu3dv9OvXD97e3jhy5AiuX7+Oxx9/HCtXrrR4/7Nnz8batWvx4Ycf4sCBA4iKisK1a9fw888/Y968eXjzzTdr83DL5eXlha1bt2LkyJGYPn06lixZgoiICKhUKly9ehVnzpxBbm4u/vzzT1Mo7NatG3x9ffHVV1+hT58+CA0NhUwmw/Tp03HXXXehVatWWLduHSZPnoyRI0ciPDwcbdq0gRACV65cwd9//42ioiJMmjQJzs7O1SrngQMH8O6776Jp06bo2LEjNBoNEhIS8PPPP0Ov1+Pll1+Gk5NTXX5URBZhTRCRg5MkCV999RXmzJmDU6dO4bvvvoOHhwcWLlyI77//vkwX7ZqQy+XYtm0b3n33XYSGhuKHH37Arl27EB4ejpUrV+Krr74qt8dTTTz99NNYs2YNMjMzsXXrVmRlZWHKlCk4cuRImV5Kzz33HGJiYhAVFYVDhw5hz549aN++PQ4fPow77rjDqv2HhYXh6NGjGDFiBFJSUrBt2zbk5OTg448/vm01QQBw991349SpU6YanH379mHXrl3IysrC8OHDsXHjRrRt29a0vFqtxvfff4+BAwfi+PHjWLt2LVavXm1WIzZmzBicOHECjz76KIqLi7Fjxw4cOHAAhYWFuP/++01/S9X14IMPYt68eQgICMBvv/2GzZs349KlSxg6dCj279+PJ598slY/E6KakkRlzbOJiGykT58++PHHH3Hp0iV2rSaiOsGaICIiImqQGIKIiIioQWIIIiIiogaJbYKIiIioQWJNEBERETVIDEFERETUIDEEERERUYPEEEREREQNEkMQERERNUgMQURERNQgMQQRERFRg8QQRERERA0SQxARERE1SP8Pajcme0tEv6UAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "coef = 10\n",
    "plt.plot(df_tracker['nbr_parameters_apres'], UTILS.lisser_courbe(df_performance['A_tr'].values, coef = coef)[(df_tracker['len_L_tr'].values /coef).astype(int)], label = 'A_tr')\n",
    "plt.plot(df_tracker['nbr_parameters_apres'], UTILS.lisser_courbe(df_performance['A_te'].values, coef = coef)[(df_tracker['len_L_tr'].values /coef).astype(int)], label = 'A_te')\n",
    "\n",
    "\n",
    "plt.xlabel('nbr of parameters', fontsize = 15)\n",
    "plt.ylabel('accuracy', fontsize = 15)\n",
    "plt.title('Pareto', fontsize = 15)\n",
    "plt.tick_params(axis='both', which='major', labelsize=12)\n",
    "plt.tick_params(axis='both', which='minor', labelsize=10)\n",
    "plt.ticklabel_format(axis=\"x\", style=\"sci\", scilimits=(0,0))\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "e4b4288d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "A_tr    0.920996\n",
       "A_te    0.922886\n",
       "dtype: float64"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_performance[['A_tr', 'A_te']][-20:].mean(axis = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "80fca557",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0: {'size': 784}, 1: {'size': 190}, 2: {'size': 305}, 3: {'size': 10}}"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MLP_model.skeleton"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e74fe5b7",
   "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
}
