{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "45aeef37",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "from src.utils import load_pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "13c726ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.style.use('../style/plots.mplstyle')\n",
    "palette = ['#a4c8ffff', '#ffa5acff', '#d7d7d7ff']\n",
    "\n",
    "seaborn_props = {\n",
    "    'boxprops': {'edgecolor':'black', 'linewidth': 1.5},\n",
    "    'medianprops': {'color':'black', 'linewidth': 1.5},\n",
    "    'whiskerprops': {'color':'black', 'linewidth': 1.5},\n",
    "    'capprops': {'color':'black', 'linewidth': 1.5}\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "87288b98",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_name = 'simclr'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "737a243b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_models = os.path.join('../../models')\n",
    "assert os.path.exists(path_models), path_models\n",
    "\n",
    "path_output = os.path.join(path_models, f'{model_name}_random_projections.pickle')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6129febc",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_results = load_pickle(path_output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "37763e50",
   "metadata": {},
   "outputs": [],
   "source": [
    "effective_dim = dict_results['effective']\n",
    "intrinsic_dim = dict_results['intrinsic']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2306de7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "subset_layers = np.array(list(dict_results['effective'].keys()))\n",
    "total_layers = dict_results['layers']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "af115018",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_layers = len(subset_layers)\n",
    "mean_effective = np.zeros((num_layers, ))\n",
    "mean_intrinsic = np.zeros((num_layers, ))\n",
    "\n",
    "std_effective = np.zeros((num_layers, ))\n",
    "std_intrinsic = np.zeros((num_layers, ))\n",
    "\n",
    "depth = np.zeros((num_layers, ))\n",
    "\n",
    "for i_layer, layer in enumerate(subset_layers):\n",
    "    mean_effective[i_layer] = np.mean(dict_results['effective'][layer])\n",
    "    std_effective[i_layer] = np.std(dict_results['effective'][layer])\n",
    "\n",
    "    mean_intrinsic[i_layer] = np.mean(dict_results['intrinsic'][layer])\n",
    "    std_intrinsic[i_layer] = np.std(dict_results['intrinsic'][layer])\n",
    "\n",
    "    depth[i_layer] = total_layers.index(layer) / len(total_layers)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c8c89965",
   "metadata": {},
   "outputs": [],
   "source": [
    "layers = effective_dim.keys()\n",
    "num_layers = len(layers)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6650277f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_svg = os.path.join('svg', model_name)\n",
    "os.makedirs(path_svg, exist_ok=True)\n",
    "path_figure = os.path.join(path_svg, f'{model_name}_effective_random_projections.svg')\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(4, 3))\n",
    "ax = plt.gca()\n",
    "plt.plot(depth, mean_effective, color=palette[1], markersize=5)\n",
    "plt.errorbar(x=depth, y=mean_effective, yerr=std_effective, fmt='o', color=palette[1], markersize=5, capsize=5, capthick=1.5)\n",
    "\n",
    "plt.xlabel('Relative Depth')\n",
    "plt.ylabel('Effective Dimensionality')\n",
    "\n",
    "plt.xlim(0, 1)\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0c72ff16",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEiCAYAAAD9DXUdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABOZUlEQVR4nO3deVhUZfsH8O9hGZZh33cEEXdxQcXcd00M18xwr9deM5dMf5llZWbLq2VpmZn1opbpW6SmmQsquKSiqLlrKquAKCIwINvw/P44zsDIDAxn9uH+XNdcMnPOzNyHkXPPeZb74RhjDIQQQsgTFkKeVF5eru04CCGEGAlBicHHxwevvvoqkpOTtR0PIYQQA+OENCW5urqisLAQHMehdevWmD59OiZNmgRvb29dxEgIIUSPBCWG8vJy7NixA5s2bUJCQgKkUimsrKwwfPhwTJ8+HdHR0bCystJFvIQQQnRMUGKoLScnB5s3b8amTZtw/fp1cBwHd3d3TJo0CdOmTUOHDh20FSshhBA90Dgx1JaSkoL4+Hjs2rUL169fBwB06tQJL7/8MiZNmgQHBwdtvRUhhBAdEdT5rEpgYCCaNWsGf39/cBwHxhjOnTuHV199FYGBgVi9erU2344QQogOaJwYysrK8PPPP+PZZ59FQEAAZs2ahUOHDqF///7YunUrMjIysGrVKtja2mLhwoX44IMPtBG3VjHGUFJSgpKSEtC0DkJIUye4KenIkSPYsmUL4uPjIZFIwBhDUFAQpk2bhunTpyM4OFhh/8uXL6NDhw7w8vJCbm6uVoLXlpKSEnkzl0QigVgsNnBEhBBiOIKGDgUHByMrKwuMMdjY2GD8+PF46aWXMGjQIHAcp/Q57dq1g62tLX0jJ4QQIycoMWRmZiIiIgIzZszApEmT4Orq2uBzysrK8Prrr6Nz585C3pIQQoieCGpKOnfunFmd4KkpiRBCagjqfF64cCE++eSTBvdbsGABWrZsKeQtCCGEGIigpqTExEQEBAQ0uN/FixeRnp4u5C0IIYQYiFqJYeLEibh7967CYwcOHECfPn1UPqewsBCXL19GSEiIZhESQgjRK7USQ0xMDF588UX5fY7jkJeXh7y8vHqfZ2lpiffee0+zCAkhhOiV2p3Px44dQ3V1NRhjGDBgAAYPHowlS5Yof1GOg62tLUJCQuDp6anVgHWBOp8JIaSG2n0MvXv3lv88depUPPPMM+jbt69OgiJEXVVSYc+zstRuHISYE60W0TNVdMVgun46Lex5sd21Gwch5kStK4Z3330XADB//ny4ubnJ76uD4zgsW7ZMWHSEEEL0Tq0rBgsLC3Ach2vXriE8PFx+v76nyrZzHAepVOD1vp7QFYPpUtaUVCUF4s/zP4/tpLzZiJqS1ENNdU2T2lcMHMfBw8ND4T4hhtbQCcjKkk5Smth+VtjzqKnOtFEfA+iKwdxUSWtOaBMiG04M9K1YNWPpw6HPSL9oYWbS5NG3YtUmRNZ9TJ2mOm2jz0i/1EoMP/zwg0ZvMmPGDI2eTwgRRtNv2tRU1zQ1qvNZKOp8JqrooolAG01J5tKBrYumIEM01ZnzZ2SM1LpimDJlCnU2E50whiYC+lasW9r4jOkz0i+1EkNcXJyOwyCE6IKx9BEQ00Kdz8Sg6MSlW8bwTZs+Y9OjUWI4efIkUlNTUV5erjDZrbq6GmVlZcjNzcWePXtw4cIFTeMkZsoYTlxEt+gzNj2CEkNhYSGGDBmCs2frbzyUzXwmhBBiOgQt7fnxxx/jzJkzcHR0RExMDDp06ACO4zBp0iSMHDkS7u7uYIyhbdu2DSYPQgghxkXQFcPvv/8Oa2trJCcnIzw8HDt27MC4ceMwd+5cdOnSBSUlJXj++eexb98+FBQUaDtmQpoEmu1LDEVQYsjIyECPHj0QHh4OAIiMjARjDKdOnUKXLl0gFouxefNmBAUFYc2aNRgwYIBWgyakKTCGobykaRLUlCSVSuHt7S2/HxgYCDs7O1y6dEn+mLu7O3r27IkrV65oHiUhhBC9EXTF4Ovri5ycHIXHQkNDcfnyZYXHnJyckJ2dLTw6QpowGuZJDEXQFUPPnj1x8uRJJCcnyx9r27YtUlJSkJeXB4C/qkhJSZGX6iaENI5sGOfTN3W3EyKUoMTw+uuvAwD69u2LpUuXAuDXgS4vL8fw4cOxdu1aREdHy/siiHmqkgq7EUKMm6CmpM6dO2Pr1q2YPXs20tPTAQDDhw9HdHS0fEIbYwxOTk5Yvny5VgMmxsNYO0eLy2p+vpgFhHkDTra6fU9CzIngmc/jx4/HqFGjkJubK39s165d2Lx5M06dOgVPT0+89NJLCA4O1kqghKjj9n3g1J2a+9dzgWu5QFQo0NzTcHERYko0KolhbW2NwMBA+X2O4zB16lRMnTpV48CI8TO2ztGiMsWkAACyQi2n7gBejoAjXTkQ0iCNi+jl5eWhtLQU1dXVKvcJDQ3V9G2IETK2Gji38wAONcmgNg7ArTygU5D+4iHEVAlODKtXr8ann36K+/fv17sfx3GoqqoS+jaE1Isx4GEpkJEP3LynPCkA/OM5hUA7KWDdxEfuUB8MaYigxBAXF4c33ngDAGBjYwMPDw9YWVEFb6IdDZ24aieDjIeApFy91y0oBXaeB1p4Ay29ATuRduM2BdQHQ9Qh6Gz+1VdfgeM4rFmzBjNnzoS1tbW24yJNlMoTVwjgKgbSlSQDSwvA3wXwdABSMlS/tlgElFQAV7KBazlAMw+gtQ/gYq+zwzEq2uqDoSsO8ycoMVy9ehU9evTA7NmztR0PacLqPXGlKj4uSwZBbvy/sr4MayvF15D1OUSFAqEeQFYBnxTuS4A79/mbnzPQ2hfwdgJkVeI1PfkZYwG8+vpgAOB0KhDmBdhZA/Yi/t+n4zGmKw5KULojKDGIxWKa0Uy0rqETFwcg0K1uMqituSfgZg/sfVKdpZUP33Qk+yYc6Mbf7hfzCSKzAMgu5G9u9nyCqJICp9NqXlPIyc8Y53gUl6n+3QLAvSL+Vpu1JZ8g7ESAlQVw95HidkON+jKmBGWOBCWGvn374sSJEygtLYW9fRO5Dic6V1JR/4krwA3o3aLh16l9cuoQoDyBeDryt+Iy/qRy+z7fb3Hidt19zWHIa+ZDPvnVx8kWsLUGHlcCpRWAtBqolPK3orL6nwsA/9wDOuth2hINS9Y9QYnho48+QteuXTFjxgx88803cHV11XZcpAkS19MZzAFwtNH+ezraAl2bAR38gZt5wJW7gFRFdmrMkFdjmeNRVgmcTQPSHza8b7+WNSdUxvh4SyuBxxV8sriaAzwqVf3867l8og14ckVnq4Oux2rG9xGpQsOStUNQYli/fj26deuGX375BTt27ECLFi3g6uqqdBlPjuOQlJSkcaDEvDHGn8RUbgff/q0rNtZAe3/+xJdRz0m0pEK91zOGOR7p+cCZNKC8ij9htvEDxDZAcq3+mtp9MLW/ZXMc31/jbAU42/GPPSoFCkvrHxKc9Yi/cQA8HIFAVyDAte43eHX7ByqlQL6Eb/q7LwEeSPjH6qPuZ0RUE5QYvvjiC/nPlZWVuHr1qsp9ac1n0hDGgL+zgDsP6m5TdeLSFQeb+vs56ruqMRaPK4EzqXz/CQC42AFRzQF3MX/fQ6y6D6Y+zb34qwZV+oYDBSV8B//D0icn82LgXAYfQ4ArfzVRUMJ3dMvUHnnm41yTBO4X88no6c+ivs8HMI3PyNgJSgxHjhzRdhykCbucXdM80LUZP+xUyIlLG+o7+TEAbmL9xCEEY/xVwtn0J1cJHNDOD2jrx4/iklGnD0YZJ1s+Qasa9RXw5OqgfQA/nPhuAZ+c8oqAR4/522UlzUCqRp7JiEX81YenA98vZGkB7Lmo4ncA3V5ZNhWCO58J0YYr2XxTAgB0DgLCvRWHejbmxKUN9Z38AOCvJ53Twe76i0kdjyuA5DT+2zoAuNrzx6HtRNbQqC8ZBxugpQ9/K6/ik0TWk1t93/YBPmbPWonAXskVwNOfUe3HqeNZcxpPVy4tLcXp06eRk5MDGxsbeHt7IzIyEra29OmQ+l3PBS5k8j9HBPBDRY2BspNfMw8+gd19BBy/xbeRt/WrmfegL0+3zTf34tvgU9KBCilgwQHt/IG2voCFoNVWGtbYKw4bKyDUk78d+6f+PpwgNUeePf0ZAUDvMCDIyBK2qRKcGCorK7FkyRKsW7cOZWWKY9nEYjFeeuklfPLJJ7Cx0cFQEmLy/snjT2YAfyJr52/YeJ6m7OTXJxw4n8EntL+z+JN0txDFZhpdUjV2X8ZNzH9jdjXiEeT19eFwT7ar6+krg/sSSgzaIigxSKVSREdHIyEhARzHoVu3bggJCQFjDHfu3EFKSgrWrFmDK1eu4MCBA9qOmZi4O/drRsa09uWHipoCCw7oEsyfkM6m8Z3lJRX8N1wbHZcKq2/sPsBf1XQK4mM0Zg314WjSP5DxkG+OpPEumhP0XWf9+vU4ePAgIiMjcfPmTZw8eRJbt27Fzz//jNOnT+PGjRvo0qULDh06hO+//17bMRMTlpZfc4Jr6Q10CjS9P+Rwb6BvS34m8L0i4MAVxSYeXZDNCleGA58QjD0pADV9OLXJwtakf8DKgp+Ud1+iUXjkCUGJYdOmTXB0dMQff/yhdK2F5s2b448//oCDgwN++OEHjYMk5iHzIfDXrSffDD35b9+mlhRk/F2AIW34jtGiMmD/FSCvWHfvJymvv9PWlMbuN/cEnm1Xc7+VD/BchGalLAKezLFNz9csNsITlBiuXr2Kfv361VsvydPTE/369at3jgNpOmSdtgxAiAffNm+qSUHGVQwMa8u37ZdXAYeuAWlK5mJo6mFJw0nH1MbuP92Ho+lIokA3/t+MfH52NNGM4G4zxhr+7TPGaJEegtxC4OhN/g82yI1vMjD1pCBjJwIGt+a/sVYzvtbSpbv8nAJNVVXznd37Lht2Vrgp8HEERFZAWVXdQoCk8QQlhlatWiEpKQn5+aqv2/Lz85GUlIRWrVoJDo6YvrwiIPFJUghwBXo2N4228MawsuQ7oFv78PcvZgEn7/BF6ITKLQT+uMh31DLwCbXLU/V/tNE2by4sLPjfEUDNSdogKDFMnToVxcXFiI6ORlpaWp3taWlpGDlyJCQSCSZPnqxpjMSE1O6EPXUHOHydP0H6OgO9wnQ3tt7QLDi+smjXZvwJO/UBf+zljbxgLq/ik8qh63y/gp01X2qidwugla/22+bNSfCTxJD5ULOkTAQOV3311Vfx22+/ISkpCS1atEDnzp3RrFkzcByH1NRUnDt3DlKpFH379sWrr76q7ZiJkXp6nL2soqeTLT8HQF/j/Q0p3Jsfi3/sH75fYP8VoH/Lhr/RM8b/vlLS+OYQAGjhxY/asq71Vyq0nEVT4OXEV3Qtq+SvuPyp6LNggv5ULS0tsW/fPsyfPx8ikQhnzpzBL7/8gv/97384c+YMbGxsMH/+fPz555+0FnQToWycfe1tj3U0aqZKqvym7nZd8HMBhrTlRywVqzFiqaScb247cYtPCk62/IinbiGKSYHUz4KruWpIo+YkjQj+b2djY4PPP/8cH3/8Mc6cOYPs7GwwxuDn54fIyEjY2dlpM05i5OpbfU2XNfIbWilNtv7B03S5UhrAzz4e1pY/4T8s4Ucsta81kU9WziK3kC8LUlXNn9jaKil6pwllSfDpxKmMqV6JBLsDN+7xNZmqqvn5DaTxNP4+YmNjg169emkjFmLCGlp9zZTG2WuLbMTSX7f5KqN/Z9Vse7qchYcDX3baWcvlLIw1ceqKhwN/pVZaAWQ/qumQJo2jVmKQTVIbP348HB0dGz1pbcaMGY0O7NKlS1i2bBmSkpJQWFgIPz8/jBo1CsuWLYOzs7N8v7///htLly7F6dOn8fjxY3Tt2hVLlizBwIEDG/2eRLiGxtGr2q7pN1plK6UZEytLICKwZm0EmdpJtL0/fzOXIbyGxHH8VcO1HH50EiUGYdRKDC+//DI4jkOvXr3g6Ogov6+uxiaGGzduoEePHrCyssLs2bMRFBSEkydPYu3atTh8+DBOnjwJsViM8+fPo2fPnnBzc8Prr78Oe3t7bNy4EYMHD8a2bdvw/PPPN+p9zZnQdnV1mxTqK+9c3zh7Tb/RmkKTx5379TezSat1lxSMPXHqQrMnieHuI361N2sT+D9ibNRKDFOmTAHHcfJv6rL7ujJ37lxUVFTg1KlTaNeOH5/3yiuvoHPnzpg3bx7WrVuHRYsWYf78+eA4DseOHUNISAgAYPr06WjVqhXeeOMNjB8/nlaQe6KhE7Aq6jQplFfxE7Gepu/V14yVIZvZTCFxapurPf//rbiM72sIUV2ggaigVmKIi4ur9742VVRU4NixY+jdu7c8KchMmTIF8+bNQ1JSEubNmwcnJyfExsbKkwIAODo6okePHoiPj8f9+/fh5dXEp4TqGGP8aKSSCn6YZo9Q4OA1fps6q681hW+0YpHpLxdqSrgno5MuZ/PNSZQYGs/oBsNZWVnhypUrqK6uO0Pl3r17APjhsiKRCLt3766zT1VVFS5dugQnJye4uVEDo4yyE3CVtKapZmwnYd8uZSNALDigVwvAuZHj7JvCN1pdlpomygW784khp5C/otV1WXRzI3gwV2VlJbZu3Yp//vlH/tiePXvQpk0bODo6YtCgQfj7778bH5CFBUJCQtC8efM621atWgUA6N+/f51t+fn5OH78OEaNGoWbN2/igw8+qHcORUlJicLN3FlZKr+pu12ZfElNE1LnoJrF5okiXZWa1gdjnCeiDhd7wNmOL8WSVdDw/kSRoDz66NEj9OrVC9euXcN3332HFi1a4NatWxg7diwqK/lqX4cPH0bfvn1x4cIFNGvWTONAt2zZgo0bNyIwMBAvv/xyne2DBw/G+fP8199Ro0bhpZdeqvf1HBwcNI6pKauo4qulVjMg0JWf8UtUU3etZGNjLMNdhYxeC3QFCh/zzUlUNqRxBCWGlStX4urVq4iKikLHjh0B8Iv3VFZWYvLkyVi7di22bNmCOXPm4OOPP8a3336rUZCbNm3CSy+9BLFYjPj4eKUn9TfffBMikQiJiYlYt24dunfvjuPHj8PVlebFa5usX0FSzvcrmHq1VH1NAqNyFsIJTVAAP4mwrJIvl0HUIygx7Nq1Cz4+Pjhy5Ih8TeedO3eC4zi8/fbbcHJywuzZs7Fx40aNl/Zcvnw53n33XTg7O2PPnj3o2rWr0v0mTJgAABg9ejTCwsIwd+5crFmzBu+9957S/SWSmqWeSkpK4O1NX3nVdfMePy7fguML44lMvP3WWL4VGyNTHxzgJuZnnmc8pKvaxhD0J52amoqhQ4fKk8KtW7dw584dBAcHIzw8XL5fixYt8PvvvwsKrLKyEjNnzkRcXBz8/f2xd+9edOjQQa3nxsbGYu7cuTh7VvVfvFhMDeJC5JcA5570K3QKAtypRc6sGctVjdAEdTOPTwzp+ZQYGkNQYrCzs1NYgGffvn0AgEGDBins9+DBA3nyaAypVIqJEyciPj4eHTp0wN69e+Hvr7hi/KVLlzBq1CiMHj1a3iktU1xcLI+TaE9FFXD8n5q1FVqayR+aqX8rbgqEJqhgN36ARF4xXybDnoYGq0XQqKQWLVrg1KlTKC0tBWMMP/74IziOw8iRI+X73Lx5E8ePH0fbtm0b/fpLly5FfHw8unXrhqNHj9ZJCrIYCgsLERcXh5wcxbGAH330EQC+WYloB2PA6VS+X0EsMv1+hdpUjchq6EbUY8iRTWIbwPPJVW0GVVxVm6ArhgkTJmDBggXo0qUL3NzckJycDH9/fwwfPhwA8PHHH+OLL76AVCrFtGnTGvXaGRkZWLlyJTiOw5gxY5TOVfD29sbgwYPx9ddf48UXX0RUVBRmzZoFsViM33//HQkJCRg/fjxeeOEFIYdHlPgnj2+n5Z7MV6Bx4bpnLpVRDd2HE+wO3Jfwpbhb+WrnNc2doD/v+fPnIz09HV9++SUAwM3NDT/++COsrflu/x9++AH379/H/PnzMXPmzEa9dmJioryZavHixUr36du3LwYPHowJEybAy8sLK1aswIcffoiqqiq0bt0aX331FWbNmkXlMLTkYQmQks7/3CmQr2BJdM/QJ1RzEeTG///NLwEkZYCDkQ8RNgYcY8KXLc/MzERubi7atWun0J6/fft2tG7dWu3OYkMrKSmRD4GVSCRNpmO6Slpz8pkQqfybZmUVP/ZeUg4EuPArsdWXb9V5zaaqsb+bn04Lex9jSwy6LuCojoRrwL0ioGMgv94FqZ9GDQKBgYEIDAys87hs6CgxbbX7FexFQFRz8+lXMAXm0iluDF8OmrnziSE9nxKDOjRKDEVFRbh+/TpKS0uV1jaSGTBggCZvQwzknzx+HWKOA3qHUb+CvhnDCdVcBLoCyWlAQSk/G9qZBizWS9CfenV1NV5//XWsX79eYdiqMhzHNbgPMT61+xU6BgIejoaNhxBN2FgDvs78qm7p+fzMc6KaoMTw5ZdfYu3atQCAkJAQ+Pn51VuwjpiWSmlNHSR/F6C1j6EjIkRzwW41iYFWzKufoLP5999/D0tLS+zcuRMjRozQdkzEgGT9CsVlfL9CDzOar0CatgBXvoxLURnw6DG/oA9RTtAEt9u3b6Nv376UFMzQ7fv8NyoOfB0kGyo8Joiplqs2ZyIr/goY4P+PE9UEXTG4uLjA1pYGA5ubglLgbBr/c0Qg4En9CoLRHATjFOzOF4BMzwfa+gq7Gm4KgwIEJYZhw4Zh165dePjwIa2SZiYqpcCxfwApA/xcgDZqzBA1l5m5pOnwdwGsLPgh2P9LEfYaTSF5C5rglpOTg27duiEsLAxr166tszazqWmqE9wKSmoWjnGy5dte7ayBZ9urV7veXCZg6YIxTOoiyh2/pVlTUu3/v+b6OQu6Ypg9ezYCAgJw9OhRREREwN7eHi4uLkpLUHAch/T0dI0DJdp1+z6/2I5MURn/b6gnLWiiDcb+h9+UBbvxicHWCnguQrE5qbHroDfUZKiKsX85EpQYdu7cqXC/vnWTqV6R8SkqU0wKtV3J5pdBVGfJSXOZmUuaFj8XwNoSKKvi+9W8nJTv15Sr6ApeqIeYrtt5/KgjZW2IHIBbefwiPA1pqn80xLRZWvAzoe884CuuqkoM6lD25aixVx3GSFBiCA4O1nYcRI9KKpQnhdrbCTFnwe58Ysh4CEQ24+c3CNHQSd9Urzo0nq6ck5ODY8eOITMzE2FhYYiJicHZs2cREREhL8NNjItYpPqKQbadEHPm48TX/iqv4ovr+TobOiLjImiCGwAUFhZiypQpCA4OxsSJE/F///d/iI+PB8Cv19CsWTOcOnVKa4ES7WnupTopMABhXvqMhhD9s7AAAp+MtKfJbnUJSgylpaUYMGAAfvzxR7i5uWHcuHGoPerV1tYWOTk5GDJkCO7cUdHLSQzGyRZweGopbtmVdFSoeh3PhJi6Zu78v5kPAanq4tBNkqDEsHLlSpw/fx7Tpk1Damoqtm/frrA9ISEBS5YsgUQiwaeffqqVQIn23C/mJ/jU1sqHH7rX3NMwMRGib56O/LydCimQU2joaIyLoMSwfft2+Pv7Y8OGDQort9W2fPlyhIaGIjExUZP4iA5czeH/DfGoeaxDAF0pkKbFggOCnlw1UHOSIkGJITU1FVFRUfWW2uY4DhEREcjMzBQcHNG+osdAVgH/c0sqp02auGZP+hmyCqiIYW2CEoNYLEZOTk6D+2VnZ8PenmrbGpNrTz42fxfAma4QSBPn7sCPwquq5tdqIDxBiaFr1644c+YMLl26pHKfCxcuICUlBd26dRMcHOGpKtHc0O1pjyv5sduAekXyCDF3HMfPaQD4ZWwJT9A8hgULFmD//v2Ijo7GF198obCmc2VlJfbv34/XXnsNUqkUs2fP1lqwTZW26rHcyOVXZfNw4DveaCQGIXxiuJoD3C3gqwwTgVcMgwcPxvLly5GZmYlx48bBzc0NHMfh119/hb29PWJiYpCRkYGFCxfSYj5GolIK/HOP/7m1wDr0hJgjV3t+4IWUAXcfGToa4yB45vPbb7+NqKgorFq1CseOHUNpaSnKyspgbW2Nnj174vXXX0dMTIw2Y22ytFGP5fZ9flieow2/xCEhhMdx/JyGS3f5EhlEw5IYAwcOxMCBA1FdXY38/HxIpVK4u7tTKQwt07QeSzUDrj/pdG7lK7wuDCHmKtiNTwy5NJ8BgBZqJQGAhYUFPD1pZpSxysjnC+PZWPHrLRBCFDnbAy52wKPHho7EOAhODI8fP8bu3btx69YtlJWVqdyP4zgsW7ZM6NsQDTFWM6GtpTe/rCEhpK5gd+BRlqGjMA6C12Po3bu3fC6DstVBOY4DY4wSg4HdK+IXI7G0AFp4GzoaQoxXsDvwd63EcDELCPPma4s1NYISwxtvvIHs7GyEh4dj2LBhKpf1JIYnu1poTkt2ElKvvGLF+9dzgWu5fGHJplZDTFBiOHHiBIKCgnDu3Dma2WzECkr54mAc+CJ5hBDllC13K2sHOXUH8HJsWrXEBLU4V1RUoEuXLpQUjJys/EWgW9P6T01IY8mWu1XlYhY/uq+pEHTF0KtXL/z999+orq6GhQX1ZhqjknJ+PVuAyl8Q0pCGlrtNy+drKfm5AP6u/IpvNirOnsW1xuKYaj+FoLP6J598gnv37uGVV15BUVGRtmMiWnAjlx+R5O3IFwojhKgmW+5WFQuOnyCalg+cuAXEpwAJV/mr8qJaQ1xv3wf2Xq65fz0X2P03/7gpEXTF0LZtW3zxxRf417/+hZ9++gnNmjWDh4eH0n05jkNSUpJGQZLGqagC/snjf27tZ9hYCDEFzb1qBmoo82x7fn3ouwV82YzCx8C9Yv52LoNvqvV0qClSKWOq/RSCEsO+ffswa9YsAEBZWRmuX7+ucl8araR//+TxZYSd7QC/J4ucK6u2WvsxVbXoG5p1TYg5cLLlRx/V7oDmwJ/Yo0L5vyWAP7l3CuKbi+4+4hNFXjF/v1j1dC5wAG7l8c81BYISw/vvv4+qqiqMGjUKEydOhKenJyUAIyGt5puRAMVieQ1VaJXVXXra0xVaCTFXzT0BN/uapqBWPvzcH2Xf8h1t+e2tfIDKKiCnCDiXzvdVqFLfNmMjKDFcvnwZERER+O2337QdD9FQWj6/7oKddc1i54QQ9dROAh0C1LtitrYCgtyAfAnf56CqE1ss0kqIeiEoMdjb2yM0NFTbsRANMVYzRLWlDz/bWUZZhVZCiPbU10/BAIR56TUcjQgalTRkyBAcP34cjx9TxSljkv2I7xSzsgBaPPWfUFaBtbE3Qoh6ZP0UykSFmk7HMyAwMXz88cfgOA7R0dG4cOGClkMiQsm+rbTwBkRaqZtLCGmM5p7As+1q7ltwQHQH0yupIbhWUrNmzZCYmIguXbrAxsYGzs7OStdh4DgO6enpGgdK6vdAwo+O4DigFRXLI8Rgal8ZVDN++LipEZQYfv31V4X7ZWVlKktv02gl/ZD1LTRzB+xtDBsLIaTG3Uf8GuumRHDZbWI8isuAzCdLEram8heEGJWsAqBjoKGjaBxBiSE4OFjbcRAN3LjHj3rwdeYXNieEGI/Cx4CkHHAwoSt5qoBnBlKfTMOnYnmEGBfPJ3XK7hYYNo7GUuuKISgoCBzHITExESEhIQgKUn9eN3U+60bt6ffVDHC2BbydDBcPIaQuPxfgvoRvTmppQmuiqJUYsrKywHEcKisr5ffVRZ3P2nf7ft1FRQrL+AJepjYsjhBz5ufCLxeaV8yXzrA2kWHkaoUp62z29/dXuE/0T9lKUzKmVsGREHPnZMv/PRaX8aspBplImRq1EsPTnc3U+Ww4spWmlNVjMbUKjoQ0Bf4u/LoMWY/MLDEoU1lZiaysLDx48AAcx8HNzY3qJ+lBQytNmVIFR0KaggBXPjFkP+L7Ay1MoHW90aOSdu/ejeHDh8PV1RVhYWGIiopC9+7d0aJFCzg7O2P06NE4cOCALmIlaHilKVOq4EhIU+DpAIgs+YV+HkgMHY161E4MJSUlGD58OEaNGoX9+/ejtLQU9vb28PPzg4eHB6ytrVFcXIxdu3Zh+PDhGDt2LEpKSnQZe5PU3Ev1FYOpVXAkxJCqpMpv6m5Xl4UF4OvC/2wqw1bVakpijGH48OE4fvw4/P39sWTJEjz33HPyzmjZPlevXsXvv/+Or7/+Gjt37sSYMWOwf/9+nQXfFDnZAt2aAclpNY/VXmmKOp4JUY8+F68KcAHS8/nyGKbQB6hWYvjpp59w/PhxREVFYffu3XB3r9uDwnEc2rZti7Zt22LWrFmIjo5GQkIC4uPjMXbsWK0H3pTZPdVcVN9KU4QQw/N14b/AFT7mRygZ+9+qWolh69atEIlE+PHHH5Umhae5uLggLi4OrVq1wtatWykxaNndR4r31V1pihBSQ5+LV9lY8UPJ7xXzf7+tjHyym1p9DBcvXkTnzp0bNeooLCwM7dq1Q0pKiuDgSF2MmU47JSHGTN+LV/m78v+awt+vWonh4cOHCAgIaPSLh4SEIC8vr9HPI6oVlPJrOluawJA3QkgNWWK4V2z8azSolRjKyspga9v4RjEHBweUl5c3+nlENVkzkrezQcMghDSSky1/Y4yfBW3MqLqqiZFdhvpRYiDE5MiuGrKMvDmJEoMJeVwJ5D+ZGuJLiYEQg2vsXAifJxWQswv5WdDGSu2SGPfu3cPRo0cb9eL37t1rdEAyly5dwrJly5CUlITCwkL4+flh1KhRWLZsGZyda86Kx44dw0cffYRTp06htLQUwcHBePHFF/HWW2/BxsaEVsZQQ/Yj/l83MWBPM5wJMTihcyEqqoAHxYCXkZbKVzsxJCQkICEhQZexyN24cQM9evSAlZUVZs+ejaCgIJw8eRJr167F4cOHcfLkSYjFYiQlJWHgwIHw9vbGggUL4OHhgYMHD2LZsmU4ceIE9u/fDwsL87kokjUj+bsYNAxCiBZkPTLxxCBbqEdf5s6di4qKCpw6dQrt2rUDALzyyivo3Lkz5s2bh3Xr1mHRokWYOXMmnJyckJKSAh8ffmDwrFmzsGDBAqxevRrx8fEYP3683uLWJWl1TYcVJQZCjIOQuRDpD/kS+XcLgM5GOgtarcSQlpam4zBqVFRU4NixY+jdu7c8KchMmTIF8+bNQ1JSEl544QXcvHkTM2bMkCeF2vutXr0aSUlJZpMY8oqBqmrA1ppvSpJWGzoiQoiQeQ2BrsBpjl9bpaBE2CxoXU9oNbr1hKysrHDlyhVUV9c988n6LCwtLeHr64ubN28qHUZbez9zIRum6u8C0KJ4hJgukWwWdBGw97Kw1xBSr6kxjC4xWFhYICQkROm2VatWAQD69+8PKysrtGjRosH9VKld+dXYq8DWnu1MzUiEmL4AFz4xGCujSwyqbNmyBRs3bkRgYCBefvlllft9+OGHSEhIQJcuXfDcc8+p3M/BwUEXYepEURkgKecX+PChYaqEmDx/VyAlg/95dEf+KkKmSlozmmlsJ8PUQTOJITubNm3C9OnTIRaLER8fr/Kk/uGHH2Lp0qXw9vbGL7/8YjYjkuSznZ0Aa/NpHSOkyXJ8MgsaAPIkqusxabtek7qM/sy5fPlyTJs2DQ4ODti3bx+6du1aZ5+qqiq88sorWLp0Kfz9/XHkyBGVzVEyEolEftNkvoU+UDMSIeYnwIiL6hltU1JlZSVmzpyJuLg4+Pv7Y+/evejQoUOd/SQSCcaPH499+/ahbdu22Lt3L4KCGh4DJhaLdRG21pVXAfeL+Z8pMRBiPvxdgas5xrkWtFEmBqlUiokTJyI+Ph4dOnTA3r17FVaLkykpKcGwYcNw4sQJDBgwAL/99pvCrGhzkFPIr87mbAc4GPniHoQQ9Xk48Os0yL78eRvRZDeNm5IqKyuRnJyM+Ph4nDhxAgCQkZGh0WsuXboU8fHx6NatG44ePao0KQDAv/71L5w4cQIjR47En3/+aXZJAaBmJELMlQUH+LnwPxtbc5LgK4aqqip88MEH+Oqrr1BYyE/JjY2NRc+ePTFlyhRIJBJs27YNYWFhjXrdjIwMrFy5EhzHYcyYMdi9e3edfby9veHg4ICff/4ZIpEIw4cPx//+9786+zVv3hw9evQQdoBaJGQBcYBfRDybZjsTYrb8XYDUB3x5jM7Bho6mhqDEUFVVhejoaBw8eBDW1taIjIzEmTNn5NuLi4tx/vx59OnTB+fPn4e3t7far52YmIiqKn4Vi8WLFyvdp2/fvhgwYAAAfqb0q6++qnS/qVOnGkViaKjQliqD2/DFtqwtABf7ulUblf1cGy33SYhx83PmrxyKy4Cix4CTnaEj4glKDF9//TUOHDiAoUOH4ocffoCvr6/C0NDjx49j1qxZ2Lx5M1atWoWVK1eq/dpTpkzBlClT1Nr33XffbXTspkR2eVlZDfxSzwqpqio46np2JCFEM9ZPZkHnFvHD0k06McTFxcHd3R2//PKL0jkFdnZ2+O6775CQkIC9e/c2KjGYI2WFttSZxLLvim7jIoQYnr8rnxiyCoDWvoaOhicoMdy8eRNDhw6td/awtbU1unXrhgMHDggOzlw01KSjbNKKpBwofAxwAGI68qMXCCHmJ8AFSEnnRyaVVxnHeu6CTjfW1tZ49OhRg/vl5+fD2tpayFs0ebJmJE9HQGxe6w0RQmpxsOWHoxc+5uc0BLoaOiKBw1U7duyI5ORkpKenq9znzp07OHPmDCIiIgQH15TVrqZKCDFvsr9z2d+9oQlKDLNmzUJpaSliYmJw/nzdns9Lly5h7NixKC8vr7fgHVGuUlpTedHfCL49EEJ0S1YeI/sRoGTFAb0T1JQ0YcIEJCQk4Pvvv0dkZCScnZ3BcRz27duHoKAg3L17F4wxvPDCC5g0aZK2YzZ7uU8WCnewqSm0RQgxX+61Z0FLDB2NBjOfv/vuO2zcuBHh4eF49OgRGGN48OABsrKyEBgYiNWrV+Onn37SZqxNBi3KQ0jTYsHVNCdlPzJkJDyNxrrMmDEDM2bMQG5uLjIzMyGVSuHr64vgYCOawmdiGKv5j0HNSIQ0Hf6uwJ0HJpwY1q1bhxdeeAFubm4AAB8fnzrrLhNhHpYCjysBKwt+4gshpGnwfTILWlJh6EgENiW99tpr8PPzw+jRo7Fjxw5UVlZqO64mSzZM1dcZsDT61TIIIdpibWk8XwYFj0pydnbGrl27MG7cOPj4+GDWrFn466+/tB1fkyNvRnIxZBSEEEMIMJLmY0GJ4euvv0Z2djb+/PNPxMbGoqqqCt9++y169+6NsLAwLFu2DLdv39Z2rGbvcQWQX8L/LCvHSwhpOoylX1FwY4WlpSWGDh2KzZs3Iy8vD9u3b0dMTAzu3r2LZcuWITw8HD179sS3336rzXjNmuxqwV0M2IkMGgohxAAcbABxrb/9i1lAUZn+4+AYY0ybL1hcXIz4+Hi8++67yMrKAsdxkEoFLkigJyUlJfK6TxKJRC/LflZJa8pxT4jkayUdvQlkFgAd/IH2AToPgRBiZG7fB07dqbnPgV/BMSoUaO6pvzi0VpqtoqICf/zxB3755Rf8+eefKCwsBMdx6Nmzp7bewqxJq/llPAHjuZwkhOhPUZliUgD4pADwj3s5Ao56mvCqUWKQSqU4cOAAtm3bhl27dqG4uBiMMYSFheH111/HlClT0KxZMy2Fat7yioCqasDOGnC1N3Q0hBB9u51Xc4XwNA7ArTygU5B+YhGUGI4cOYJt27bht99+w8OHD8EYg6urK2bOnIkpU6YYxapppoZmOxPStJVUKE8Ktbfri6DEMHDgQAB8+e2RI0diypQpGDlyJJXYFoixWomBmpEIaZLEItVXDLLt+iIoMURGRmLq1KmYOHGifPYzEa6ojF+Yx4IDfJwMHQ0hxBCaewFXc5RvYwDCvPQXi6DEkJycrO04mjTZ1YKPU8OrvRFCzJOTLT/6SNWoJH11PANqJobDhw8DAJ555hnY2trK76trwIABjY+sCaHRSIQQgB+S6mYP7L3M32/lA7Tw1m9SANRMDIMGDQLHcbh27RrCw8Pl99XBcRyqqqo0CtLcPXhSf51mOxNCaieBDgGGaUVQKzH06dMHHMfB3t5e4T7RHmc7ftYjIYQYmlqJITExsd77RHNUNI8QYiwE1Uo6evQobty40eB+p0+fxsaNG4W8RZND/QuEEGMhKDH069cPH330UYP7rVq1Cm+88YaQt2hSrC0BDwdDR0EIITy1mpKOHDmCp2vt5eTk1Ds6qbCwECdOnKjzPMIrrlUx0c6an8fgpOeRB4QQooxaieGHH37A1q1b5fc5jsOhQ4dw6NChep/HGENMTIxmEZqhpysoFpUBu//WfwVFQghRRq3E8J///Ad3796Vf/tPSkqCl5cXWrdurXR/juNga2uLFi1aYOnSpdqL1gwoq6Aoo+8KioQQooxaicHX11eh2cjCwgJDhgzB5s2bdRaYuTKmCoqEEKKMoJIYqamp8oVtqqurYWFR04ddXFyM6upqODs7aydCM2NMFRQJIUQZQaOSgoODUVpaijFjxiA6Olph2759++Dl5YWxY8fiwYMHWgnSnMgqKNa3nRBCDElQYrh79y66d++OnTt3IjMzU2GbjY0N3N3dsWPHDkRGRiIvL08rgZqL5l6qrxj0XUGREEKUEZQYPvzwQ+Tm5uL//u//kJKSorDtueeeQ1ZWFv7v//4PGRkZWLZsmVYCNReyCoq1ya4g9F1BkRBClOGYgIkGLVq0gI2NDS5fvlzvfq1atUJpaSkyMjIEB6gPJSUl8j4TiUQCsVis8/csKKmpoNjaQBUUCSHGp0oKbD/L/zwh0jBF9AQ3JbVt27bB/dq3b4979+4JeQuz93QFRUoKhBBjISgxeHt749q1aw3ul5qaCg8PDyFvQQghxEAEJYahQ4fiypUr+Oabb1Tu89NPP+HcuXMYNGiQ4OAIIYTon6A+htu3b6Nz586QSCR49tlnMXLkSAQF8bOysrKy8Oeff2Lnzp2wt7dHSkoKwsPDtR64Nhmij8EY2hEJIcbHGM4Ngia4NW/eHDt27MCUKVPwxx9/YO/evQrbGWPw8vLCzz//bPRJgRBCiCJBiQHg13G+ceMGdu3ahcTEROTk5KCqqgq+vr7o1asXJkyYoJdv3oQQYqqqpPU/pmw7oPurCEFNSeaGmpIIIYbw02lhz4vtrt04nib4ikEmJycHx44dQ2ZmJsLCwhATE4OzZ88iIiIC1tbW2oiREEKIHglODIWFhZgzZw62bdsGqZS/3omNjUVMTAzmz5+P1NRUxMfHIyoqSmvBEkKIOZkQaegIlBM0XLW0tBQDBgzAjz/+CDc3N4wbN05hpTZbW1vk5ORgyJAhuHNHxeIDhBDSxFlZCrvpmqDEsHLlSpw/fx7Tpk1Damoqtm/frrA9ISEBS5YsgUQiwaeffqqVQAkhhOiHoMSwfft2+Pv7Y8OGDbCzs1O6z/LlyxEaGorExERN4iOEEKJnghJDamoqoqKiYGWluouC4zhERETUKctNCCHEuAlKDGKxGDk5OQ3ul52dDXt7eyFvQQghxEAEJYauXbvizJkzuHTpksp9Lly4gJSUFHTr1k1wcIQQQvRPUGJYsGABKisrER0djR07dqCwsFC+rbKyEnv27MGoUaMglUoxe/ZsrQVLCCFE9wTPfF6xYgWWLl0KjqtZwdjGxgaVlZWorq4GYwyLFi0yiVFJNPOZEEJqCLpiAIC3334bBw8exJAhQ2BnZwfGGMrKymBhYYHevXtjx44dJpEUCCGEKFJr5vPixYvRpUsXjB8/XuHxgQMHYuDAgaiurkZ+fj6kUinc3d2pFAYhhJgwta4Y1q9fj/j4ePn90NBQLFy4sOZFLCzg6ekJHx8fSgqEEGLi1EoMlZWVSE1Nld9PS0tDXl6ezoIihBBiOGo1JbVt2xZnz55FWFgY/Pz8AAAHDhxAnz59Gnwux3FISkrSLEpCCCF6o9aopCNHjiAmJgYSiYR/EsdB3cFMHMfJq68aKxqVRAghNdS6Yujfvz8yMzNx7do1lJWVYcCAARg8eDCWLFmi6/jMgrGu0kQIIcqolRgmTZqEHj16KExW8/b2Rt++fXUW2KVLl7Bs2TIkJSWhsLAQfn5+GDVqFJYtWwZnZ2elz/n1118xfvx4pKamolmzZjqLrbFkVwaqxJ9X/riuV2kihBBl1EoMu3btQlVVld5mMd+4cQM9evSAlZUVZs+ejaCgIJw8eRJr167F4cOHcfLkyTrNPadOncKMGTP0Eh8hhJgztRIDx3G4fPkyKioqIBKJdB0T5s6di4qKCpw6dQrt2rUDALzyyivo3Lkz5s2bh3Xr1mHRokUAAMYYNmzYgPnz56OsrEznsQlhrKs0EUKIMmp1Pvfv3x9Hjx6FnZ0d3NzckJWVBbFYDFdX14bfgOOQnp6udkAVFRVwcXFBjx49cOjQIYVtjx49gqurK0aMGIE9e/agrKwMvXr1QkpKCnr27AlHR0fs27ev0U1Jhuh8JoQQY6XWFcOXX36JkSNHIjMzE6WlpeA4DiUlJSgpKWnwubVrKakVkJUVrly5gurq6jrb7t27BwCwtOR7ZcvKypCbm4v169fjX//6FzUlEUKIFqiVGDp06ID09HTk5uairKwMoaGhGD16ND7//HOtB2RhYYGQkBCl21atWgWAv4IBACcnJ6SmpgqabV07qamT4AghpKlQKzHI+Pj4AACCgoLQrFkzBAcH6yQoZbZs2YKNGzciMDAQL7/8MgA+iVhYCKsDKGs6IoQQoqhRiUEmLS1Ny2HUb9OmTXjppZcgFosRHx9PJ3VCCNEhtb5uHz16FDdu3Gj0i3/33Xcat/svX74c06ZNg4ODA/bt24euXbtq9HoyEolEfpP1XRBCCFHziqFfv36YPHkyNm3aVGfbjBkz8Mwzz8ibd2o7evQotm7dih9++KHRgVVWVmLmzJmIi4uDv78/9u7diw4dOjT6dVSpPfKo9sAs6m8ghJgCe3v7Rg/uUZfaTUmqRrXGxcWhqqpKaWIQSiqVYuLEiYiPj0eHDh2wd+9e+Pv7a+31n1ZaWir/2dvbW2fvQwgh2qLLofWCV3DTpaVLlyI+Ph7dunXD0aNHdZoUALpKIISYHl2etwR1PutSRkYGVq5cCY7jMGbMGOzevbvOPt7e3hg8eLDW3tPDw0P+c25urtl3bpeUlMivjO7du2f2E/roeOl4zUXtY7W3t9fZ+xhdYkhMTERVVRUAfklRZfr27avVxFB7yKuDg4NZ/8d6mlgspuM1Y3S85ktX/QuAETYlTZkyBYyxem+JiYlKnxsXFwfGmFFVViWEEFNjdImBEEKIYRldU5IhiMVitVekMwd0vOaNjtd86etY6YqBEEKIArXKbltYWMDBwUFh9I5Meno6xGKx0m0PHjxASUmJ0a/5TAghpIbaiUHwG3AcJQZCCDEhap3xjxw5Ivh2+PBhXR9DvfLz8zFnzhwEBwfDzs4OERERjSrRsWnTJnTq1AlisRi+vr6YPXs2CgoKdBixZjQ53tLSUrzzzjsIDw+HSCSSL4p0+vRpHUctnKafb23ffvstOI5DXFycdoPUIk2P98yZM4iOjoarqyucnZ3Rq1cv7N+/X4cRa0aT462oqMAHH3yAsLAwiEQieHl5YerUqcjOztZx1Jo7ffo0LC0tVY7AVEar5ypmxiQSCevcuTOztrZm8+fPZ+vXr2cDBw5kANiKFSsafP5HH33EALCBAweyr776ir3xxhtMJBKxiIgIVlpaqocjaBxNjre6upoNHjyYAWDjx49n69atY++//z7z9vZm1tbWLCEhQU9HoT5NP9/arl+/zuzt7RkA9t///lc3AWtI0+P9888/mUgkYiEhIWzlypXss88+Y2FhYYzjOLZz5049HEHjaHq8o0ePZgDYsGHD2Lp169iCBQuYSCRigYGBLC8vTw9HIMzNmzeZr68vA8COHDmi1nO0fa4y68TwySefMADs559/lj9WXV3Nhg0bxkQiEcvIyFD53MzMTCYSidjw4cOZVCqVP75161YGgH366ac6jV0ITY5XdlxvvfWWwuMZGRnM2dmZtWnTRmdxC6XJ8dZWUVHBunTpwmxsbIw6MWhyvCUlJczX15cFBwcrnBTz8/OZm5sba9mypU5jF0KT4z179qw8KdS2adMmBoAtXrxYZ3Fr4rfffmOurq4MgNqJQRfnKrNODK1bt2b+/v51Hj98+DADwD755BOVz/30008ZAHbgwIE624KDg1mrVq20Gqs2aHK806dPZwCU/rHFxMQwAOz+/ftajVdTmhxvbW+++SZzdHRk7777rlEnBk2OV3aSiIuLq7Nt8+bNbPny5ay8vFyr8WpKG8f71VdfKTxeVFTEALChQ4dqPV5NPfvsswwAa9OmDZs4caLaiUEX5yqzHa5aWFiI69evo3v37nW2yR6rr+381KlTAICoqKg627p164br16+jsLBQS9FqTtPjXblyJc6ePYuAgIA6255ea9sYaHq8MklJSVi5ciW+/PJLlUvKGgNNj1fW1zdixAgAQHV1NSQSCQBg8uTJeOeddyASibQdtmCaHm/r1q0BAFeuXFF4XLaujK4Lcwpx/fp1fPTRRzh37hzCw8PVfp4uzlVmmxju3r0LxhiCgoLqbLO3t4erqytSU1NVPj8rKwsuLi5wdHSss0128tT3Snb10fR43d3d0aVLlzr1V06cOIFTp04hIiICrq6uWo9bKE2PFwAePXqEyZMnIyYmBtOnT9dVqFqh6fFeu3YNjo6OkEgkGD9+POzt7eHo6IjQ0FCl66wYmqbH27FjR8yZMwffffcd1q5di7S0NCQmJmLKlClwcnLCggULdBm+IFevXsVbb70FGxubRj1PF+cqs00MsgypqlKqvb19vWVrCwsL630uYFzlujU9XmXu3r2L2NhYAMCyZcs0C1DLtHG8//73v1FRUYENGzZoPT5t0/R4CwoKwHEcevbsCYlEgv/+97/4/vvvIRaLMW3aNKxZs0YncQuljc93/vz5iIqKwty5cxESEoL+/fsjIyMDe/bsQdu2bbUes6YamxBkdHGuMtuSGOzJ9AymYpoGY6zephH2pGBffa9tTE0rmh7v09LS0jB48GCkp6dj0aJFiImJ0Uqc2qLp8W7evBnbt2/HH3/8oXRyprHR9HjLy8tRVFSEfv36YdeuXfLHJ0yYgDZt2mDJkiWYOnUqnJ2dtRu4QJoe79WrV9GrVy+UlpZi0aJFeOaZZ5CVlYXPPvsMw4YNw65duzBo0CCdxK5vujhXme0Vg+yyqvbqbLWVlpbW+0fg6OhY73MBGM0fEaD58dZ25swZ9OjRA7du3cIbb7yB//znP1qLU1s0Od60tDTMmTMHL774Irp164YHDx7gwYMH8jZ3iUSCBw8eoLKyUjfBC6Dp5ysrRT1nzpw6j0+dOhUlJSX466+/tBSt5jQ93hUrVqCgoACbN2/Gf/7zH4waNQqvvfYazpw5A0dHR0ydOhUVFRU6iV3fdHGuMtvEEBISAo7jkJWVVWdbSUkJHj16hMDAwHqfX1BQoPQSLCsrCxYWFkbVgaXp8crs2rUL/fr1w71797By5UqsWrVKF+FqTJPjTUxMRFFREbZu3QpPT0/5TXbSnDNnDjw9PXHixAmdHkNjaPr5yrb5+PjU2SZ7zJgGU2h6vH///TccHR0xfvx4hcc9PDwwevRoZGdn49q1a1qP2xB0ca4y28Tg4OCA1q1bIzk5uc422WiGZ555RuXzZSMflD0/OTkZ7dq1U9rZYyiaHi8AxMfHY+zYsZBKpfjf//6HhQsX6iRWbdDkeIcOHYqDBw/WuS1atAgAsGjRIhw8eBARERG6O4BG0vTzlY1YuXjxYp1tt27dAgCjGpWl6fHa2NiAMaa0HI/sMVXNL6ZGJ+eqRg9wNSGy2YDKJsjY2Niw7Oxslc9NS0tj1tbWbNiwYay6ulr+uGx89Oeff67T2IXQ5Hj//vtvZmtry2xtbdWebWlomhyvMv/973+Neh6DJsd7584dJhKJWPv27ZlEIpE/npOTw1xdXVloaKjC/3NjoMnxLl26lAFg33zzjcLjd+/eZe7u7szX15dVVlbqLHZNvffee2rPY9DFucqsE0NpaSlr06YNE4lEbOHChWzDhg1s0KBBDABbuXKlfL/bt2+zLVu2sL/++kvh+e+//z4DwAYNGsQ2bNjAFi5cyEQiEevatatRlsTQ5HiHDBnCALARI0awLVu2KL3VPqEYA00/36cZe2LQ9HjXrFkjn0C1evVq9vHHH7OAgAAmEomMsuSJJsdbVFTEIiIimIWFBZs6dSrbsGEDe++995iXlxezsrJie/bsMcQhqU1VYtDXucqsEwNjjOXl5bGXX36ZeXl5MTs7O9axY0e2efNmhX1kJ4SpU6fWef4333wj/88ZGBjIXnvtNfbw4UM9Rd94Qo63srKSiUQi+TR8VbfU1FT9H1ADNP18le1nrImBMc2Pd8+ePax3795MLBYzZ2dnNnToUHby5Ek9Rd94mhxvUVERe/PNN1loaCiztrZmrq6ubOTIkez06dN6PAJhVCUGfZ2r1Cq7TQghpOkw285nQgghwlBiIIQQooASAyGEEAWUGAghhCigxEAIIUQBJQZCCCEKKDEQQghRQImBEEKIAkoMpMmjOZ7aQb9H80GJgWgsMTERHMepvIlEIvj4+GDw4MH47bffNH6/tLQ0cByndH3qxpBKpfj6668xb948hcfj4uLAcRwmTZqk0etrw/vvv6/yd+rq6orOnTtj6dKlyM3NNViM2dnZmDRpknxdaZl+/fqB4zgkJCQYKDIilNmu4Eb0TywWY9SoUXUef/jwIa5evYqEhAQkJCRgxYoVWLJkif4DfMpPP/2E1157Tb58qTELDQ1Fjx495Perqqrw8OFDnD9/Hh9++CG+/vprxMfHo3///nqPbdKkSThy5AimTZum9/cmukGJgWiNh4cHfvzxR6XbqqursXr1aixcuBDvvfceJk+erNbCQbpUXV2t9PHRo0cjKirKqFbo6927N+Li4uo8XlFRgWXLluGjjz7CqFGjkJycjJYtW+o1NlW/R2K6qCmJ6IWFhQXeeOMNdO3aFVVVVdi3b5+hQ1LJ2dkZrVq1gq+vr6FDaZBIJMKKFSswc+ZMFBUVYfHixYYOiZgBSgxEr4KCggAA+fn5dbadOXMG48aNg5eXF2xsbBAaGooFCxbgwYMHar/+oUOHMG7cOAQEBMDGxgaOjo7o2LEjVqxYgfLycvl+/fr1w/Tp0wHwTUocx8mbQp7uY1i3bh04jsPkyZOVvueZM2fAcRwiIyMVHr958yamTp0Kf39/iEQiBAQE4OWXX0Z6errax6Oujz/+GLa2tti5cyeys7MVtkmlUqxfvx7du3eHo6MjHBwc0KNHD2zatKlOh7Hs2FetWoXDhw/jmWeegb29Pfz8/DBp0iT8888/8n1lfT1JSUkAgMGDB4PjOCQmJiq8ZnV1NdasWYN27drB1tYWPj4+mDp1ap04iRERVKybkFqOHDnCALDg4OB69yssLGQeHh4MANu9e7fCtri4OGZpack4jmNdunRhY8eOZc2bN5e/bu21IFJTUxkA5u/vr/Aan332GQPARCIR69+/Pxs3bhzr3r074ziOAWCjR4+W7/vhhx+yHj16MAAsJCSExcbGsm+//ZYxVlPzPjY2ljHGWH5+PhOJRMzR0ZE9fvy4znHNnz+fAWBffPGF/LH9+/cze3t7BoC1a9eOjRkzhrVv354BYG5ubuzs2bNq/W5ldfkbWkuCMcYGDhzIALAtW7bIH6uoqGDDhw9nAJiTkxMbPHgwGzFiBHNwcFD6urJjHz58OLO0tGT+/v5s7NixrE2bNgwAc3V1lcd+//59Fhsby7y8vBgANnDgQBYbG8uuXr3KGGOsb9++DABr1aoV4ziOPfPMM+y5555j7u7uDAALCgpihYWFav0eiH5RYiAaqy8xSKVS9vDhQ5aQkMC6d+/OALAuXbqwqqoq+T5Xr15lIpGIOTg4sEOHDik89+2332YAWM+ePeWPK0sM2dnZTCQSMTc3N3bz5k2FGI4ePcqsrKwYAJaZmSl//OkEUN/jo0ePZgDYr7/+Wuf4/Pz8mJWVFbt37x5jjD9hurq6MktLS4VlKRlj7Ntvv2UAWGhoKCsvL1f5O5VpTGKYPXs2A8Deeecd+WOyJS779evH8vLy5I/n5uayTp06MQDsu+++q3PsANiYMWPkibC6upq99dZbDADr0KGDwucnSwAHDx5UiEf2uL29PUtKSpI/fv/+fRYUFMQAsI0bNzZ4XET/qCmJaE16enqdYZWWlpZwc3PDoEGDcPr0aQwbNgx79+6FpaWl/Hlr1qxBRUUF3nvvPQwYMED+uIWFBZYvX4727dvjxIkTOHXqlMr3zs3NxejRo/Huu++iRYsWCtt69+6Ndu3aAeCbP4SQNSNt27ZN4fHExERkZ2dj6NCh8PLyAgB8//33KCgowL///W+88MILCvvPnDkTI0aMwJ07d7QydLc2FxcXAJA3vVVUVGDNmjUQiUT48ccf4enpKd/X29sbGzZsAACsWrWqzmu5ubkhLi4Otra2AACO47BixQq0a9cOFy9exIkTJ9SOa+bMmejTp4/8voeHh7zZ7uLFi406RqIflBiI1ojFYsTGxiI2NhYvvvgievfuLd82YcIEXL9+HX/++af8BCojG/8+cODAOq/JcRyGDRsGAHXarmvr1KkTtm3bpjAnobq6Grdu3cLPP/+Mhw8fAoBCP0NjjBgxAu7u7vjjjz8gkUjkj//8888AoND/UN/xAMCzzz7b4PEIUVFRAYD/nQFASkoKCgsL0apVK/j7+9fZPzIyEl5eXrhx40adeRDR0dFwdHRUeIzjOMTExAAAjhw5onZctYfZyshGpD169Ejt1yH6Q8NVidYoG6564sQJPPvss9i+fTs6deqEN998s87zMjMzAQCdO3eu9/Vl+6kilUrx66+/Ytu2bbh69SrS0tLqnCyZwNm5IpEIEyZMwLp167Br1y7ExsaioqIC8fHxcHJywnPPPVcnzjFjxmh0PI0lS35ubm4Kr3/x4kX58dcXi4+Pj/z+01ddMrITemM6jmVXMrVZWfGnHqlUqvbrEP2hxEB0qmfPnti8eTNGjRqFxYsXIyQkBM8//7zCPrKTwwsvvKDQxPS0iIgIldtKSkowYMAAJCcnQywWIzIyEoMGDUL79u3Rq1cvzJ49G0ePHtXoWCZPnox169Zh27ZtiI2Nxb59+1BQUICXXnoJdnZ2dY4nOjq63rkQbdq00Siep124cAEA0KFDB4U4goKCFK7elHn66kDV5yBLrLITuzosLKhhwtRQYiA6FxMTgxkzZuCHH37Av//9b/Tp00fh26mvry/S09OxfPlyhIWFCXqPVatWITk5GYMGDZJ/i69NG00WUVFRCA8Px4EDB1BUVCTvb3h6GKuvry9u3ryJefPmYdCgQRq/rzqysrJw4cIFWFlZoV+/fvI4AP5bvqqJh6rcvXtX6eOyobaGnpxIdItSOdGLzz77DD4+PigoKMCCBQsUtvXt2xcAsHfvXqXPnTJlCqKiorB7926Vr3/y5EkAwGuvvVYnKdy9exdXr14FoDhLt6HmFWUmT56MiooK7NixA7t370ZwcLBCx6o6x/PWW28hMjISGzdubPT7q7JixQpIpVKMGTNG3ofTtWtX2NnZ4cKFC8jJyanznOzsbLRu3RqDBw9W6DcBgH379tVp5qmursauXbsAQN7vAwj7PRLjRomB6IWLiws+++wzAHyH7aFDh+Tb5s6dC0tLSyxdulThcQD49ttvsWXLFly4cAHdunVT+fqyETe7d+9W6EfIyMjAmDFjUFVVBQAoKyuTb5ONuCksLFT7OCZNmgSO4/DOO+9AIpHI79c2c+ZMiMVirF27ts4opj179uDzzz9HSkpKnQlxQjx+/BjLli3D+vXr4eLigk8//VS+TSwWY+bMmSgpKcGkSZOQl5cn3yaRSDBt2jRcv34dDg4OcHBwUHjd27dvY/HixfJEWl1djcWLF+PatWvo168fOnbsKN9XyO+RGDkDD5clZkDdCW6M1UzCCg8PVxjHv3btWvlEtE6dOrExY8awtm3bMgDM0tKS/fLLL/J9lc1jOHXqFLO2tpZPqBo3bhzr06cPs7KyYpaWlqxly5YMgHwSG2OMpaSkMACM4zg2YsQItmLFCsaY6vkNMn369JGP9b9+/brSfeLj45lIJGIAWOvWrdno0aNZZGSk/HmrV69u8HfFWM08htDQUBYbGyu/jR8/nvXr1485OjoyAMzd3Z0dO3aszvNLS0vl8To6OrIBAwawkSNHMjc3N/nnkJubK99fdux+fn6M4zjWsmVLNn78ePnvr1mzZuz27dsK7zFnzhwGgPn4+LCxY8eyv/76izGmen6DOr9jYliUGIjGGpMYbty4wWxsbBgA9sEHHyhsO378OBs9ejTz9PRkIpGINWvWjD3//PPs3LlzCvupmvmcnJzMhg8fzry9vZm9vT0LDw9nzz//PEtOTmbx8fEMAIuOjlZ4zieffML8/Pzks6UZa/iktXHjRgaAde3atd5jvXjxIps0aRLz8/Nj1tbWLCAggI0YMYIdOXKkwd+TjCwxPH2ztLRkbm5uLCoqin3wwQfswYMHKl+jvLycffnll6xr165MLBYzBwcH1r59e/b++++zgoIChX1rH/uuXbtY586dma2tLQsODmbz58+XT+KrLS8vjz333HPy15YlX0oMpotjjFbXIITw4uLiMH36dMTGxja6w5qYD+pjIIQQooASAyGEEAWUGAghhCigPgZCCCEK6IqBEEKIAkoMhBBCFFBiIIQQooASAyGEEAWUGAghhCigxEAIIUQBJQZCCCEKKDEQQghRQImBEEKIgv8HLtR6+FfuL0wAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "path_figure = os.path.join(path_svg, f'{model_name}_intrinsic_random_projections.svg')\n",
    "\n",
    "fig = plt.figure(figsize=(4, 3))\n",
    "ax = plt.gca()\n",
    "plt.plot(depth, mean_intrinsic, color=palette[0], markersize=5)\n",
    "plt.errorbar(x=depth, y=mean_intrinsic, yerr=std_intrinsic, fmt='o', color=palette[0], markersize=5, capsize=5, capthick=1.5)\n",
    "\n",
    "plt.xlabel('Relative Depth')\n",
    "plt.ylabel('Effective Dimensionality')\n",
    "\n",
    "plt.xlim(0, 1)\n",
    "fig.tight_layout()\n",
    "fig.savefig(path_figure, transparent=True)\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "src",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
