{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "id": "kIszDNScMWXQ"
      },
      "outputs": [],
      "source": [
        "import jax.numpy as jnp\n",
        "from jax import grad, jit, vmap, jacrev, jacfwd\n",
        "from jax import random\n",
        "import pylab as plt\n",
        "import numpy as np\n",
        "import seaborn as sns\n",
        "from jax.scipy.special import logsumexp\n",
        "from tqdm import tqdm\n",
        "import pandas as pd\n",
        "import matplotlib\n",
        "from google.colab import files"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def random_layer_params(m, n, key):\n",
        "  w_key, b_key = random.split(key)\n",
        "  return jnp.sqrt(2/m) * random.normal(w_key, (n, m)), 0 * random.normal(b_key, (n,))\n",
        "\n",
        "def init_network_params(sizes, key):\n",
        "  keys = random.split(key, len(sizes))\n",
        "  return [random_layer_params(m, n, k) for m, n, k in zip(sizes[:-1], sizes[1:], keys)]\n",
        "\n",
        "def relu(x):\n",
        "  return jnp.maximum(0, x)\n",
        "\n",
        "def predict(params, image):\n",
        "  activations = image\n",
        "  for w, b in params[:-1]:\n",
        "    outputs = jnp.dot(w, activations) + b\n",
        "    activations = relu(outputs)\n",
        "  \n",
        "  final_w, final_b = params[-1]\n",
        "  logits = jnp.dot(final_w, activations) + final_b\n",
        "  return logits - logsumexp(logits)\n",
        "\n",
        "def input_output(params, input):\n",
        "  activations = input\n",
        "  for w, b in params[1:-2]:\n",
        "    outputs = jnp.dot(w, activations) + b\n",
        "    activations = relu(outputs)\n",
        "  final_w, final_b = params[-2]\n",
        "  logits = jnp.dot(final_w, activations) + final_b\n",
        "  return logits\n",
        "\n",
        "elements = [0, 1]\n",
        "probabilities = lambda eps: [1 - eps, eps]\n",
        "rand_mask = lambda shape, eps: np.random.choice(elements, shape, p=probabilities(eps))\n",
        "\n",
        "jacobian_fn = jacrev(input_output, argnums=1)\n",
        "\n",
        "def jac_prunned(width, depth, sparsity, rn=0, n_targets=10, normalized=True):\n",
        "  layer_sizes = [784] + [width]*depth + [n_targets]\n",
        "  params = init_network_params(layer_sizes, random.PRNGKey(rn))\n",
        "  if normalized:\n",
        "    normalization = (1 - sparsity)**(-1/2)\n",
        "  else:\n",
        "    normalization = 1\n",
        "\n",
        "  masked_params = [(rand_mask(params[i][0].shape, 1 - sparsity) * normalization * params[i][0], params[i][1]) for i in range(len(params))]\n",
        "  jac_eval_in = jnp.ones(width)/ (width/10)\n",
        "  masked_J = jacobian_fn(masked_params, jac_eval_in)\n",
        "  return np.max(np.linalg.svd(masked_J)[1])\n"
      ],
      "metadata": {
        "id": "3upYtZktMXjK"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Varying width for different sparsities and fixed depth"
      ],
      "metadata": {
        "id": "39GcW0rfxVa2"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Without normalization"
      ],
      "metadata": {
        "id": "mzecXTjSPHe6"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "depth = 5\n",
        "widths = np.arange(500, 1000, 50) #[100, 500, 1000, 1500, 2000]\n",
        "sparsities = [0, .5, .95, .99, .991, .996, .999] #+ list(np.linspace(.85, .999, 5))\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'width', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for width in tqdm(widths):\n",
        "  for sparsity in sparsities:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=False)), width, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "mA-td5_ns022",
        "outputId": "102319cc-2843-484e-e526-43b002c5e2c9"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "  0%|          | 0/10 [00:00<?, ?it/s]WARNING:jax._src.xla_bridge:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n",
            "100%|██████████| 10/10 [07:39<00:00, 45.91s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_width_sparsity_nonorm.csv')\n",
        "files.download('df_width_sparsity_nonorm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "mn8BS132O6hl",
        "outputId": "0a9fff9e-ca8a-49e4-fc3e-562daef74b8e"
      },
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_a63be25e-dde6-434d-98f7-23e2da0be3db\", \"df_width_sparsity_nonorm.csv\", 25062)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3, 2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='width', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "ax.set(yscale='log')\n",
        "ax.set_xlabel('Width', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Sparsity', loc='upper right', fontsize=9)\n",
        "plt.savefig('J_versus_width_sparsity_nonorm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_width_sparsity_nonorm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "xu_PnKs7r96x",
        "outputId": "6b741c12-d7cc-40b0-d108-ecc0edd94900"
      },
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-9-2c21d0387e3b>:6: UserWarning: The palette list has more values (10) than needed (7), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='width', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_08232082-fbb5-4b09-99db-b5b5aabb1d75\", \"J_versus_width_sparsity_nonorm.pdf\", 17307)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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3Llz6devH0lJSQwYMID7778/au5pRy13MKaJ/eEPfyAvL4+kpCQmTpzIN9980ylsbxFh0WrmzZsnRowYIUpKSszXwYMHze1z5swRubm5YvHixWLt2rXipJNOEhMnTjS3q6oqjjvuODF16lSxbt068fHHH4usrCxx1113Jdz28vJykZeXJ6688kqxevVqsWvXLvHpp5+KHTt2mPv85S9/Eenp6eK9994T33//vTj//PNFv379hNfrNfc5++yzRX5+vli1apVYtmyZGDhwoLjssssSavuBAweiyvyzzz4TgFiyZIkQomOX+4MPPii6du0qFi5cKHbv3i3efvttkZKSIh5//HFzn45a7kII8Ytf/EIMHz5cfPnll2L79u1i3rx5Ii0tTezbt6/D294SlvjFwLx580R+fn6T2yorK4Xdbhdvv/22mfbjjz8KQKxcuVIIIcTHH38sZFkWpaWl5j5PP/20SEtLE36/P6G233HHHWLy5MnNbtd1XfTs2VM8+uijZlplZaVwOp3i3//+txBCiM2bNwtAfPPNN+Y+ixYtEpIkiaKiosQZ34Df//73YsCAAULX9Q5f7ueee6646qqrotJmzJghLr/8ciFExy53j8cjFEURCxcujEo//vjjxd13392hbW8NVrU3RrZv3052djb9+/fn8ssvp7CwEIBvv/2WYDDI1KlTzX2HDh1Knz59WLlyJQArV65k5MiRUcsqnnXWWVRXV7Np06aE2v3BBx9wwgknMHPmTLp3786YMWN47rnnzO27d++mtLQ0yv709HTGjx8fZX9GRgYnnHCCuc/UqVORZZnVq1cn1P4wgUCAV199lauuugpJkjp8uU+cOJHFixezbds2AL7//nuWL1/OOeecA3Tscg+vLNdwMfKkpCSWL1/eoW1vDZb4xcD48eN58cUX+eSTT3j66afZvXs3J598MjU1NZSWluJwOMjIyIj6To8ePSgtLQWgtLS00Xqy4c/hfRLFrl27ePrppxk0aBCffvop1113Hb/73e946aWXoo7flH2R9nfv3j1qu81mo0uXLgm3P8x7771HZWUlV155pWlTRy73O++8k0svvZShQ4dit9sZM2YMf/jDH7j88sujjt8Ryz01NZUJEyZw//33U1xcjKZpvPrqq6xcuZKSkpIObXtrsKK6xED4aQ0watQoxo8fT15eHm+99RZJSUntaFnL6LrOCSecwEMPPQTAmDFj2LhxI8888wyzZs1qZ+taz7/+9S/OOeccsrOz29uUVvHWW2/x2muv8frrrzNixAjWr1/PH/7wB7KzsztFub/yyitcddVV9O7dG0VROP7447nsssv49ttv29u0I8by/I6AjIwMBg8ezI4dO+jZsyeBQIDKysqoffbv30/Pnj0B6NmzZ6NeyPDn8D6JolevXgwfPjwqbdiwYWa1PXz8puyLtP/AgQNR21VVpby8POH2AxQUFPD555/z29/+1kzr6OV+2223md7fyJEj+dWvfsUf//hHHn744ajjd9RyHzBgAF9++SW1tbXs3buXNWvWEAwG6d+/f4e3vSUs8TsCamtr2blzJ7169WLs2LHY7XYWL15sbt+6dSuFhYVMmDABgAkTJvDDDz9EXQyfffYZaWlpjYQp3kyaNImtW7dGpW3bto28vDwA+vXrR8+ePaPsr66uZvXq1VH2V1ZWRj31v/jiC3RdZ/z48Qm1H+CFF16ge/funHvuuWZaRy93j8fTKKimoijmKmedodwBkpOT6dWrFxUVFXz66adccMEFncb2ZmnX7pZOxi233CKWLl0qdu/eLVasWCGmTp0qsrKyxIEDB4QQxpCLPn36iC+++EKsXbtWTJgwQUyYMMH8fnjIxZlnninWr18vPvnkE9GtW7ejMuRizZo1wmaziQcffFBs375dvPbaa8LtdotXX33V3Ocvf/mLyMjIEO+//77YsGGDuOCCC5octjBmzBixevVqsXz5cjFo0KCjMmxB0zTRp08fcccddzTa1pHLfdasWaJ3797mUJd3331XZGVlidtvv93cpyOX+yeffCIWLVokdu3aJf773/+K/Px8MX78eBEIBDq87S1hiV8MXHLJJaJXr17C4XCI3r17i0suuSRqnJzX6xXXX3+9yMzMFG63W1x00UWipKQkKo89e/aIc845RyQlJYmsrCxxyy23iGAweFTs//DDD8Vxxx0nnE6nGDp0qHj22Wejtuu6LubOnSt69OghnE6n+NnPfia2bt0atU9ZWZm47LLLREpKikhLSxOzZ88WNTU1Cbf9008/FUAje4To2OVeXV0tfv/734s+ffoIl8sl+vfvL+6+++6oITYdudzffPNN0b9/f+FwOETPnj3FDTfcICorKzuF7S1hhbSysLA4JrHa/CwsLI5JLPGzsLA4JrHEz8LC4pjEEj8LC4tjEkv8LCwsjkks8bOwsDgmscTPwsLimMQSPwsLi2MSS/wsfvIsXboUSZJYunRpi/ueeuqpnHrqqa3K99RTT+W44447MuMs2g1L/Cw6PG+99RaSJLFgwYJG2/Lz85EkiSVLljTa1qdPHyZOnHhExy4uLua+++5j/fr1R5SPRcfDEj+LDs/kyZMBWL58eVR6dXU1GzduxGazsWLFiqhte/fuZe/evUyePJlTTjkFr9fLKaecEvOxi4uLmT9/viV+P0GsYKYWHZ7s7Gz69evXSPxWrlyJEIKZM2c22hb+PHnyZGRZbhSK3cLC8vwsOgWTJ09m3bp1eL1eM23FihWMGDGCc845h1WrVpkx8sLbJEli0qRJzbb5PfvsswwYMICkpCTGjRvHsmXLorYvXbqUE088EYDZs2ebS2a++OKLUftt3ryZ0047DbfbTe/evXnkkUfie/IWCcESP4tOweTJkwkGg1GL3qxYsYKJEycyceJEqqqq2LhxY9S2oUOH0rVr1ybz+9e//sW1115Lz549eeSRR5g0aRLnn38+e/fuNfcZNmwYf/7znwG45ppreOWVV3jllVeiqs8VFRWcffbZ5Ofn87e//Y2hQ4dyxx13sGjRongXgUW8aeeQWhYWrWLTpk0CEPfff78QQohgMCiSk5PFSy+9JIQQokePHuKpp54SQhgx9BRFEVdffbUQQoglS5ZErfMbCARE9+7dxejRo6Pi6j377LMCEFOmTDHTvvnmGwGIF154oZFNU6ZMEYB4+eWXzTS/3y969uwpLr744nievkUCsDw/i07BsGHD6Nq1q9mW9/3331NXV2f25k6cONHs9Fi5ciWappkdJQ1Zu3YtBw4cYM6cOTgcDjP9yiuvJD09PSa7UlJSuOKKK8zPDoeDcePGsWvXrpjysTj6WOJn0SmQJImJEyeabXsrVqyge/fuDBw4EIgWv/Df5sSvoKAAgEGDBkWl2+12+vfvH5NdOTk5SJIUlZaZmUlFRUVM+VgcfSzxs+g0TJ48maqqKn744QezvS/MxIkTKSgooKioiOXLl5sLyycaRVGaTBdWgPQOjyV+Fp2GyPF+K1asYNKkSea2sWPH4nQ6Wbp0KatXr47a1pDwinXbt2+PSg8Gg+zevTsqraFXZ/HTwRI/i07DCSecgMvl4rXXXqOoqCjK83M6nRx//PE89dRT1NXVNVvlDefTrVs3nnnmGQKBgJn+4osvNlr/Nzk5GaBRukXnxxrkbNFpcDgcnHjiiSxbtgyn08nYsWOjtk+cOJG//e1vQPPtfWC07T3wwANce+21nH766VxyySXs3r2bF154oVFVecCAAWRkZPDMM8+QmppKcnIy48ePp1+/fvE/QYujiuX5WXQqwqIWruZGEq7qpqamkp+ff9h8rrnmGv7xj39QXFzMbbfdxrJly/jggw/Izc2N2s9ut/PSSy+hKApz5szhsssu48svv4zjGVm0F9bSlRYWFsckludnYWFxTGKJn4WFxTGJJX4WFhbHJJb4WVhYHJNY4mdhYXFMYomfhYXFMYklfhYWFscklvhZWFgck1jiZ2FhcUxiiZ+FhcUxiSV+FhYWxySW+FlYWByT/H+/yKSn9uqgngAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## With normalization"
      ],
      "metadata": {
        "id": "G5s9TTH_PMsr"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "depth = 5\n",
        "widths = np.arange(500, 1000, 50) #[100, 500, 1000, 1500, 2000]\n",
        "sparsities = [0, .5, .95, .99, .991, .996, .999] #+ list(np.linspace(.85, .999, 5))\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'width', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for width in tqdm(widths):\n",
        "  for sparsity in sparsities:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=True)), width, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "sBLByO1dPPHH",
        "outputId": "2aa65c9b-6c25-419b-cdb1-e428cdb405dc"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 10/10 [07:36<00:00, 45.69s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_width_sparsity_norm.csv')\n",
        "files.download('df_width_sparsity_norm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "XWYxokzPPXHQ",
        "outputId": "e6c4eda7-2b18-4d10-ad53-b9eac0cf769e"
      },
      "execution_count": 12,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_c59ede9f-87f9-4c3d-9861-23e5e512b181\", \"df_width_sparsity_norm.csv\", 23223)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3, 2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='width', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "ax.set(yscale='log')\n",
        "ax.set_xlabel('Width', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Sparsity', loc='upper right', fontsize=9)\n",
        "plt.savefig('J_versus_width_sparsity_norm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_width_sparsity_norm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "8ZfKqrcEPdB5",
        "outputId": "e2459c94-5ca1-4b85-abee-28e9dcf01142"
      },
      "execution_count": 13,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-13-18701e4a77a6>:6: UserWarning: The palette list has more values (10) than needed (7), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='width', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_cfc613ea-9db5-4d46-810e-fa16980f3e9f\", \"J_versus_width_sparsity_norm.pdf\", 16808)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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Ofsbw8ytHyDTISCh4RCQYXSEEAJheKXIFd1zOA0GlbqwsNAvMz5lyhQAPv30U7/MeHvMnj2bl19+2ac9XWY8jQMPPJB3333Xf3/OOedkfX7KKadwyimn+O/333//PiUI7AzDzK0PCAaCIIZmFZDMAoBDDUOZ9sHm6V24cCG33XYbBx54IAC333473/jGNzo9dsWKFX6p9eeee46HH36YV155xf98yZIlzJ49G9d1+fOf/+yXGU/jo48+Yu7cucTjcX7xi19QX18/oMxtcO10P+G5555jxowZTJs2jd/97ncDcg5VVZkxcRqqoralXA2BEBDwaN9jjz2GZH7mUKZdCEEoFBoUUlsaN910EwsWLGDWrFnMmjWLAw88kB/+8IcAXH755Vx+uddvVQjBM888w4QJEygsLORnP/sZTz31lN/4BeBXv/oVpaWljBgxgscee4xXX32VMWPG+J9ff/31FBUVMW7cOJYtW8Zrr71GJBIZsLX1uMz4YIdt28yePZvXXnuN/Px8vvSlL/Huu+9SXFzcre/3pMz41uWbKMovxDUdgqU56PlDQ6KQUlJXV0dxcfGgutG6g6FA+47KjNu2jaZpg5b2rrCrae+PMuNfOMntgw8+YI899mDs2LHk5ORw3HHH8a9//avfz+O6LhXVW3FsB6EMjRCQNFzXZfPmzUPS4ziUaQeyOl4NNQw12gcdc3vzzTc56aSTGDNmDEIInnrqqQ7H3H///UycOJFgMMj+++/PBx984H9WWVnJ2LFj/fdjx45l69atA0avl5UwXJhyGMMYbBh0zC0ajbL33ntz//33d/r5o48+yrXXXsuiRYv45JNP2HvvvTnmmGPYvn37LqbUg3Rc1LA2HAIyjGEMMgw6Xeq4447juOOO6/Lzu+++m0suuYSFCxcC8MADD/D888/z8MMPc9111zFmzJgsSW3r1q3Mnz+/y/mSyaTf7Abwgwp31nHedV1ywhEUTUUE1KyGJYOlO/sOac/JQQix27uz93S8N7QPho7z6b/TjpDOTN27uuP8jsbbj0kpfU/vrqAl/dqlHed3J0zT5OOPP+b666/3xxRF4cgjj+S997z0lvnz57N8+XK2bt1Kfn4+L774IjfddFOXc95xxx3ccsstHcZ31nFeSklRKBctqLOxYjOtsbaO84OlOzt03nE+vSZFUdi8efNu787emzUpikJl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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Varying sparsities for different widths and fixed depth"
      ],
      "metadata": {
        "id": "XLWI5Q7-xmAr"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Without normalization"
      ],
      "metadata": {
        "id": "TggXHBV7RWKI"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "depth = 5\n",
        "widths = [200, 400, 600]\n",
        "sparsities = np.linspace(.9, .999, 20)\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'width', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for width in tqdm(widths):\n",
        "  for sparsity in sparsities:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=False)), width, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "FCCGxJ4wxkpJ",
        "outputId": "9c7542f3-6b65-4cf7-a6d8-1f251b2648ce"
      },
      "execution_count": 14,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 3/3 [02:26<00:00, 48.82s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_sparsity_width_nonorm.csv')\n",
        "files.download('df_sparsity_width_nonorm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "PsrHo3HARdly",
        "outputId": "f737f2f4-fc06-4ead-a1fd-df50084d54d5"
      },
      "execution_count": 15,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_026f9a4f-2b48-4f09-bc51-a94711ab301d\", \"df_sparsity_width_nonorm.csv\", 28585)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3,2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='width', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "#ax.set(yscale='log')\n",
        "ax.set_xlabel('Sparsity', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Width', loc='upper right', fontsize=9)\n",
        "plt.savefig('J_versus_sparsity_width_nonorm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_sparsity_width_nonorm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "wCuWoD3jyKHt",
        "outputId": "5d8b0dfc-cd0e-4b27-bb5b-9837dbacdb39"
      },
      "execution_count": 19,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-19-db1b66f9e2e8>:6: UserWarning: The palette list has more values (10) than needed (3), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='width', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_c1afc235-801f-4429-9a19-458c1540fb00\", \"J_versus_sparsity_width_nonorm.pdf\", 14952)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## With normalization"
      ],
      "metadata": {
        "id": "HNey-hJxScYR"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "depth = 5\n",
        "widths = [200, 400, 600]\n",
        "sparsities = np.linspace(.9, .999, 20)\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'width', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for width in tqdm(widths):\n",
        "  for sparsity in sparsities:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=True)), width, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hXrCZCXmSfhM",
        "outputId": "c92e90ee-bc02-4d2b-86d1-63f83cd882d7"
      },
      "execution_count": 20,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 3/3 [02:26<00:00, 48.81s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_sparsity_width_norm.csv')\n",
        "files.download('df_sparsity_width_norm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "y1cRURLSSkG5",
        "outputId": "87e628d2-3c03-4276-c6ac-7df1692a08f7"
      },
      "execution_count": 21,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_ca2f06e7-4aae-49a0-861a-307109715090\", \"df_sparsity_width_norm.csv\", 27105)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3,2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='width', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "#ax.set(yscale='log')\n",
        "ax.set_xlabel('Sparsity', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Width', loc='upper left', fontsize=9)\n",
        "plt.savefig('J_versus_sparsity_width_norm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_sparsity_width_norm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "FM8LNWKWSnBV",
        "outputId": "82530599-6f5c-40e7-df9b-c18018b47f74"
      },
      "execution_count": 23,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-23-403a08cb890d>:6: UserWarning: The palette list has more values (10) than needed (3), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='width', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_acede870-0b18-443d-b927-c4c14ba5bae4\", \"J_versus_sparsity_width_norm.pdf\", 14935)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Varying sparsities for different depths and fixed width"
      ],
      "metadata": {
        "id": "212G6GBOzpwc"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "Without normalization"
      ],
      "metadata": {
        "id": "MVjr5_vPTcl_"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "width = 256\n",
        "depths = [5, 15, 50]\n",
        "sparsities = np.linspace(0, .999, 20)\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for sparsity in tqdm(sparsities):\n",
        "  for depth in depths:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=False)), depth, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BizCH_SFzyLB",
        "outputId": "04644e14-33bb-431b-ea17-e13ecc324b19"
      },
      "execution_count": 30,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 20/20 [03:05<00:00,  9.28s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_sparsity_depth_nonorm.csv')\n",
        "files.download('df_sparsity_depth_nonorm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "khKxIDODTkFf",
        "outputId": "93084c36-2a92-4e5f-e56b-ea9e984e4bfd"
      },
      "execution_count": 33,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_74a145a0-183d-43ae-bb5a-d7e3df4321db\", \"df_sparsity_depth_nonorm.csv\", 27450)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3,2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='depth', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "ax.set(yscale='log')\n",
        "ax.set_xlabel('Sparsity', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Depth', loc='lower left', fontsize=9)\n",
        "plt.savefig('J_versus_sparsity_depth_nonorm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_sparsity_depth_nonorm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "ioJMg0Eg0U6G",
        "outputId": "33e880e0-014b-41ef-8341-1424530a37cb"
      },
      "execution_count": 34,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-34-fc70dcc4d630>:6: UserWarning: The palette list has more values (10) than needed (3), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='depth', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_9a08d9ec-41f3-4c4b-bbd3-c0683acb2723\", \"J_versus_sparsity_depth_nonorm.pdf\", 15421)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## With normalization"
      ],
      "metadata": {
        "id": "bGNxftryW0eA"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "width = 256\n",
        "depths = [5, 15, 50]\n",
        "sparsities = np.linspace(0, .999, 20)\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for sparsity in tqdm(sparsities):\n",
        "  for depth in depths:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=True)), depth, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "fdYoEnFVW3Ev",
        "outputId": "6998c8ee-6321-4cee-b397-27c1b233c222"
      },
      "execution_count": 35,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 20/20 [02:58<00:00,  8.92s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_sparsity_depth_norm.csv')\n",
        "files.download('df_sparsity_depth_norm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "A2jxu-PzXAs7",
        "outputId": "d24056e6-5d34-4801-c71d-71d380404bae"
      },
      "execution_count": 37,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_5665c965-88e6-41d6-885a-60a8dc584afb\", \"df_sparsity_depth_norm.csv\", 26472)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3,2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='depth', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "ax.set(yscale='log')\n",
        "ax.set_xlabel('Sparsity', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Depth', loc='lower left', fontsize=9)\n",
        "plt.savefig('J_versus_sparsity_depth_norm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_sparsity_depth_norm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "QamdYEGOXBUl",
        "outputId": "8610ac17-bb74-400b-b46c-9fd50dfbe064"
      },
      "execution_count": 38,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-38-3cdeb9849ab2>:6: UserWarning: The palette list has more values (10) than needed (3), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='sparsity', y='jac_norm', hue='depth', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_bdbb0d12-4922-4fb1-b191-85d1f4ec089d\", \"J_versus_sparsity_depth_norm.pdf\", 14194)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAATsAAADwCAYAAAB/hMMEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACFOUlEQVR4nO29d3wc5bX//56yfbXqsiRblmVbbgRjwBicQIAEAhhSILQkXEpuCISWkJvcy/cmIeGmEW5uGhBI8ksg3HBpaYRgIIFgWgBTXHC3JUtWryttLzPz/P4Y7XpXWpVVsyTv5/XSS9Lss8+cM8/MZ85zznnOIwkhBDnkkEMOcxzykRYghxxyyGE6kCO7HHLI4ahAjuxyyCGHowI5ssshhxyOCuTILocccjgqkCO7HHLI4ahAjuxyyCGHowLqkRZgJsEwDFpbW8nLy0OSpCMtTg455DAIQgj8fj+VlZXIcna2Wo7sUtDa2kpVVdWRFiOHHHIYBU1NTSxYsCCr7+TILgV5eXmAeSE9Hs+IbXVdZ/v27axevRpFUaZDvClHTqfZgbmmUzb6+Hw+qqqqks9qNsiRXQoSU1ePxzMmsnO73Xg8njlxw0FOp9mCuabTePQZj5spF6AYJyRJwuPxzCnfXk6n2YG5ptN06SPlCgEchs/nIz8/n/7+/lEtuxxyyGH6MZFnNGfZjROJyK1hGEdalElDTqfZgbmm03TpkyO7cUIIQVtbG3PJMM7pNDsw13SaLn1yZJdDDkcIUS12pEU4qpAjuxxyOALoj/io9x4iFAsfaVGOGuTIbpyQJImSkpI5ExGDnE7TBU3XaPN30hvy4osGsv7+TNRpIpgufXLR2BTkorE5TAdafO0097dhU61YFSvLSxajyLM/X246kIvGHgEYhkFjY+OciYhBTqfpgC8aoCPQTZ7NhcviIBQPEYyFsupjNJ1CsTBxPT4Z4k4LpmuMcmQ3Tggh6O7unjMRMcjpNNXQDJ02fweG0LGrNhRZwRCC/og/q35G0knTNRq8TRzobaA/4pss0acU0zVGObLLIYdpQlewh76Ij3zb4emX0+LAG+mfNEvMFw0QiIcIx8LU9TTS7GubVVbeVCJHdjnkMA0IxIK0B7pwWZwoKaWJ7KqNiBbFHwtO+ByGMOgOebHICgWOfBwWGy397dT1No4rEDLXkCO7cUKSJCoqKuZMRAxyOk0VdEOnzdeJpms4Lfa0z2RJQpFkvOH+Mfc3nE7BWAhf1I/L6gTAptoodhYQjIU40HOQFl87mq5NXKFJhiRJyLZ8gpGplS1HduOELMvjKiA4kzGTdIrpcRq8zfSEvBPqZybo1B3spTfSR4E9c1kip8WBLxogHI+Mqb/hdPKG+xEIVPlwMSNZkil05GNXrDT72qjzNuKfYVaeQMLhLkI3cj67GQnDMNi/f/+MifJNBmaKTqFYmIO9h2j1tdMe6JqQNXKkdQrFwrQHOnGqjmHTS2yqlZgWIzDGqWwmnSJaFG+4D5dqz/gdu8VOsaMAfzTIgZ5G2nwdaIaevUJTgGgsTtOh+lw0dqZCCIHP55sRUb7JwkzQyRvu54DX9DGVuooIxIL0TSCqeCR1MgyDVn8HMUPDZXWM2NamWOgN9WGI0R/4TDr1h31EtBh2S2ayA9PKK3LkY1VUDvW3Ut97aMwEO5WIx3WCgUAuGpvD0QFDGLT7uzjYewjD0Cl2FqDICnbFSkewe0b6mkZDT9hLb7iPfNvoVXWdVgeBWHBcy8c0Q6c77MWu2sbU3mGxU+QooD/iY39PAx3+rjGR7FQhphkYUzyFhRzZ5TADoOkazf1tHOpvwaZa8djcyc9cVheBaBBvZOwO/JmAcDxCm78Du2pDHcPqCFVW0YVBfzS7nDsAfzRAMBYa1XpMhSLLFDsLsMgKjf0tHOprJXaEUlTiObKb2ZBlmerq6hnhzJ8sHAmdIvEIB71NtPk7ybe5cWSIVtpVG53B7nHlix0JnUwrtZOIFsM9EBkdCxyqDW+4f1RfWqpOQgh6Ql4USUaWstfRaXGQb8ujI9hFfW8jgej0T2vjmiC/pHzKx2juPKnTjLm2GBumXydfxE+d9xDeSD9FjgIsiiVjO5fVSSAaGpfv7kiMU2+4j+6Qd9jo63BwWOyE4+FR/WipOgXjIXwRf1akOhgWRaXYUUggFqKut4HuYO+0+jgjMQ2nO3/KxyhHduOEruvs3LkTXZ8ZEa3JwHTpJISgO9hLnfcQUS1KsaMgLdF2MCZi3U33OEXiEVr9nVgVS1oKyFhgWmbSqKSeqlNf2Icm9GFfFGM/t0SRIx9JkjnoPURzf9u0+EkNQxCOxOhoqZ/yMcrtLjYBRCKj50UZwsAb7ic2ECmzqVbsim3GTn/HotNgGMJACIHEwJs5+cv8I/WNrRs6bf5O2gKd2BUrrhT/3EhwWZ30hvvwRnyUuYqzkm88Oo0HhjBoD3QTiYcpdhSOqw+XxU5/xEdUi2FTrcO2i0QixLQYvWEvTku6r86u2nBZnQRjISJaNKvzu61OrIpKq7+DsBZlgaccZxa+wGwR1w00zSAem/pCpjmym0LEtBit/k66gj3mtEACVVawKlbcFicumxObasOuWLEolikz44UQhOMRYkYcj809Lt/OcAjFwxzqb01aXEnCG4CU/C2BJIEQ+GNBPDb3iA8zDH1o7aqVrkA3hXbPhC2ZqUBvuI+uYDf5trwxjWUmUrKpNvwhL4FYcNTr0x/1E9ailKQQa6LPZ/Zt4rxlZwBkTXhWxUqRowBvpJ+IbhJeoX1qpplxzUCbhuAE5MhuytAf8dHi68AfDVBg92BRzEsd1zViepzesJfOUDdIMjZZxa7acdmcOC0O7IoNuzpx6y+qxfDHAnhD/fhjQTShU5lXRmXevEkhvFA8TGNfM/5oEJfFweFb1vxLiORfyf8Bihz5o9Zvy/TQGkLQE/aOy7qbagRjIVp87dhU65iIeDhSkiQJi6LSG+qjyFEwLMEIIegO9WJTrMk2iT7v3/ww+3rqaexr4fp1n0n2nQ0UWabEWYg/GqC+9xDleaVUuMsmve5eXNPRDQN5GlyqObLLAF3Xk/4DSZKQZRnDMIY4bWtra5PtExAIOoPdtPZ3AFBg8yAjmdM8SUJGwq5YsSsDb21JQjPihKIh+kI+DAwssorD5sBjdWNXbThUO3bVhiRJKIqCEGJItnnieEyLJxNxfVE/MT2ORVKwqzYModLsbUPXdKoKKk15x6CTLMtIkpR2LByPcMjXQjAeJt+ah5zyUGZqnyqjYRhpnw3WyWGx40x7aJu5bt0VGIaBTbbQGejGY3VjSfGJZTtOw8mY7XFFUYhrcRq9zUSiUYqc+ei6nnGcJCRkRcamWAf0+11Sv+vXXWH6r+JhbLKV/rCfYDSE2+7KqNO8hRW0RDoosOWh6zoOiz2F6OoA2NdTx/2bf8f1664AIBhNr5sny7J5rS0OAtFgcrlaquxO1UFUi9LU20okHmWeuwSbbE0jvYy6DjMeg49HonEMISgum5+x/eDrPhG/Xq5SMXDvvfdy7733ous6+/btY9OmTbjdpi+ppKSE6upqGhsb6e7uTn6noqKCyspK9u/fj89nOpRjegxrkQPNJuhr6kZohy/t/EULcLldHNiVvsyneukiVItK3e4DyWO6YTC/dgGhSJjWgy0okoJFUXHZHBy/5nhi4RiH6huTb3Sb3cai2hqaWpvYf7BuYEopUeDxsGhJDb1dPfR09gz0rSO7LBxTuxLNG8Xbe3jtaSadAKqrqykpKWHnzp2mr0iP0xPy4qkopLKknPrdB0bVCWDJyqVocY3GAw3JY7Iss3RVLcFAkJaGZgrzC1m6ZCm/fPthDngbEcJA1w2WlyzhupM+Q1NLE1GXjitiJdp/2BeXzThl0imB2tpaPB4PW7ZsSdNp1apVWK1Wtm7dmqbTcccdR0N3E1vf24rL6kw+zKk6JWCz2Vi+cjkO1cF9b/4ve7tNUpIliRVltXx+7afYt38/3n5zGrt4/mJOWHlcRp2ido3d+/Ygx0hes1+9+3/s72lA1zVSn+qV82r5wror2LdvHz19vYePr1pJvjufjXv+wTlLT+dA3QG8/d6M44QExTVlxEJRelq6sStWrKqVPFcex71vNX3ePhobG5PNPR4PtbW1tLa20tbWNuw49foi9PmjeAqKWXf8crrbm0Ycp0AgwBlnnDGuSsU5sktBouRzb29v8kIO94YyDIMdO3bwvve9D0mS6A330eprJ2ZoFDo8SEJCMPwbarTjqW/LmB4npsWJ6jFkRcYiq9hkKx57Hoqs0BfqJ6SH0QwNm2zFYbEjS/KwsmuGhi8WpNRVzPy88mTSa6pOqVPoVBnD8QgNfU0Eo2GKXGYUdTw6ZTpuU6y47W5+MWDxHPb4mbIvK17MdeuuoCfoJRQLsbS4BuvAlHEs4zScTmORfbjj/VE/db0NOFU7VuWwjy2Trg6Lgzy7i/s3P8zeHvOlZE1OeSWWFddw3borCEQCdAV6sagWVpWZVmmqToFIkE2bX2Hx8hrsFjul7mKe3b+Jv9e9CkBUjyWvmSzJKJLCOUs/yLm1Z9AV6BmQxU6e3Z20BBPXNhAJEDPiw45TXNeIxiNEtTi6MJBlCbvFjlO147I4saumC8ZmsY3JstvX5KXfF6apYT9nfvBkijyOES07n89HUVHRuMhu3NPYQ4cOUV9fj9frzZiTc9FFF4236yMORVFQlHTfRCb/mWEYaEKnM9hNZ6Abm2pNcxYP1/dYjyemrQ5FwWE1k22FEMR0k/haA+ZU2SqruK2upF9wMAbLrigKBbJCV6gHWZJZ4ClHHfiuYRjIspxRnpgRp9nfRliLUuwuTE5dx6NTpuN5djfP7NvEvp6DAET1KKqsokhm+309B3l23ybOrT2D7lAvvqifeXmlI+o6mk7ZyD74eCgeptnXhlWx4sgQsRysa57dxTP7NrG3p46oFkORZTRDT6aoJPQ7b9kZhLUI/VE/gXgobUUJgC/mJ67FsVvsKIpCKB7mvGVn0tjXyu7u/ciShEW2AgJDGCwtXsSHl5zKpoY36Ar2sLJ0KceULU+6CUBiX89BfrH5Ya5f95lkwCTTNbAoKhbFTUIi3TCI6aZvuDfSjyRJWBULDtVOiauIIkdBxuuYSIiOa2C1WEiS8zB+6oQsw43LWJA12R06dIjPfvazvPjii8BQnw+Q8Q04FxHWotT1NhDUwuTb8lLe0lMHSZKwqdZRI3WDMTjyZ1FUCu0eOgLmusiq/ArkEdIuw/FIMhhR6MhP89FNFoKxEOctO4OGvibe69iLVbUQ1+PIioyExLLixZy37AyCsRAOi53OUA+FzoJpue6DoRk6Lf3tRPUYxcM80IMRjIU4p/Z09vc0cLDvEBISUT2KgjJEP0VWEMJMvE4lu7gepzfcl6ZzIvhw3brPcPcbD9LgPTTwicSKktokga2etwKLrOKyufj55ofY3bUfAIusIksK+3rquX+A8FL7HQmKLOOQ7cmVL4YQxPUY3nAfFkUdluxgIBKr66jK9CR8Z012V111Fa+//jq33XYbJ598Mvn5+VMh14xHd7CXrkA39piTYlfhpD38E8mRGq3PwZE/VVYpdOQPpMYYVOaVZ/x+ZBqILiFTs6+Nz554OQ+88xj7eg5iVSzE9BjHlq1MszpcFgfdIS+9oT7KB1l3IyEUD9MV7EEzdCrcZePKIRNC0B7opDfSR5G9YMzfO9TXQou/g5vXX80vBqwqq2IS+vvKVqTpB+Cw2OiN9DPPXZKM8PqiAULxyJCIb0SLsre7nhvXXcmv3n6EfT31LCtePKRPjz2PZ/Ztor73EDbFBgiiegyLLCFLMvt66pP3yXjuP1mSsKk2LGP4rkl2ApttenZWy5rs3njjDf7jP/6DO+64YyrkmTUIaxHKayoodA2fHpAtJiNHarg+h0tHUGWFIkc+3WEvumGwdNnStKlEJB6hoa8ZXzRAkaNgyojOEAavHXobp8XB/Lxyrl93RVLmVaXL+Nzay9MeWkmScFjsdIV6zLJFw1i6siyzatUq4oZGW7CT7mAvMT2OhEQwFqQyr5wiZ0FWqTjeSD/t/k48VveIKz9Scai/ld1dBzhr8QcIxUJcv+4zSf1WlCzh8yd9asgLzq7a6Q15CcRCFDryB8qu92JTrSyqXZQ2TsFYmL3ddSwvMQkucQ8N7jNhPTf2tSSnsDbFahKeYmFF8dLk96Yacc3A0A2sFhvz5i+eeWtjFyxYQGHh+LLD5xIkScKiTl4icCop/b3uFe7f/DAuq3PMZXtG69O8sUlOVVL7VmSFInsB3oiP1lBXsvrFWInOrtoodhaOSdZMbUPxCBv3vUhN4UJOrDyWqB4jOEAIZy85jRtPvpJXGjbTFexN68tlcRCKhekdoaS5buh4o/3s6zXLkltklRJnIcXOAkDioLeJQ32tRLWxZfCH4xFafO2osjpmV8K+noPU9zZy9pLTUGSFiBZN1++Uq3mh/rUhlYrlAWe+N9wHQCAWwh8N4La5UC1q2r33etM7rK86Mdl3JqID0s69rHjxwFGT8BYXVvP5kz49qbOKkRDXDEAyfZuqOmnP0nDImuy+8pWv8Otf/5pQaOqZfyZD13Wa9jeOyTc5GhmMlZSyQaY+E07gzIQnU2Bzs/O996jrMbfhGyvRJazR0WTN1LbV38EL9a9yZs16FngOT6MHP7RLixfxcuObQyJ7zgHfXWwQWRmGQU/Iy57OA/zz7TcQmkaJozCtqorb6sRjc9MR6OZA70GzrPkIyQm6odPiayccj5BndWXUb/A4b2vfTW+oj9MXnZJ2DVP1C8VCeKxudnTuHdKna6BkeyQewRvuQwiQBNTtPpC891r9HeTZ3OTZXMm+e0LeYQkrE+EtK17CzSdfzfN1r9A9wVL4Y0VM0xCS+Sy1Nu6beWtjr7vuOnRdp7a2losvvpgFCxYMiZBIksStt946aULOZow2Nc1MSibG4zBOIHFOs08zgmsIA6tiHdY3I0syLosTXyRAXDQT1WJjIrqxZOxnavu5tZfjjwbZUPuhjNPBiBZN9uO02FlevJit7bs4vuKYZBtnwncX7qc8rxQhBP1RP52BbvoiPlQUXBYnzoEcuMGwKColzgL80QB1vQ3Mc5VSnleacRVEe6CLnpB3YMF8el+Dx1kIwUsNb+CwODil6viM1y9Vv6XFi3hm/4vUFtekkaVNteGLBukOe/GG+4fUrDOE4J3W99hQe2bGcwyHxHkHT3lXldby97pX+MiS00asejwZiER11OlYOjGArMlux44d3HXXXbS1tXH33XdnbJMjOxNjIQPzAXmR3d370Q09mZuXGiEbj8M4LbLZuRerbEGWJCJ6DJtiYfkwvhlJkih05BMzsiM6GJ6ch7YVvNe5m1+89TA3nnzlmKdNS4sX8Xzdq3jD/RQ68pPyJqw7u2qlJ9xHX7gfCSi0e0BA5yjPkyRJeOx5RLUYrf4OgvEQlZ7ytChoX9j00+XZXEOWTGUa58+eeClLihdR6iwaVa8E1ledyOtN73Jmzfq04zbFgj8SIKaba5tTLaD3OvZwTNmycS3jSlzz1Cmvw2LnQ4vfz9/qXuHc2tPTcgcnE0IIwlENVZm+ghhZn+nzn/88/f39/OIXv2Dr1q0cPHhwyE99ff3oHc1xjDY11XSNd1t38OLB1/nwklNZVrwYi2LBptiwKVZ0YRDVo9QW14zLYRyMhXijaQufO/FTrC5bkSwfZFes1BRWc90IvhlZknBZnVkRnQmRXKLktDgQAnRh4LA4uG/z/7Kn+wC60IloMSyyhbrexqyn6h9ctI5XD72VVkbcaXEQjoWp9zbRG+rDbXVRMIb1t4NhU60pWw820ObvRDd0IgN+OlmSh8g5HJH/f+88yoqSJVm5IArsHqyKuRwuFQ6LA2+4H/sgH2FEi9Lm72Bx4cKs9Bzcx+Apr9vq4vRFp/DcgZfRjMNlnrLxzY4GTRfENQPLNJJd1isonE4nd9xxB1/96lenSqYjhsQKirFkZzd6m+nyd1PkHhqsGc5fpgsdzTBYUbKE60+6go5Al7n2NW1d42HyqC2u4V9PvIxt7buozp8/rEUxmLS6Q17+eeht1s5fzeLChWl9LytezHUnfZq/173CMaW1Q6YqiXWdI6HYWcgz+zbx97pXMIROTNcwefFwzZNza8/gzJr3A/DiwX/y3IGXMFswkER7mEjPXnIa5y07Y8zbJjb1t9Lq7+DkBYenh3FdQ2BktETGotNghOMRArFQ0rrtCfdRPGhhfiaiM9M4LMiSnDH1YzRohsYz+zdxwbIPp50rrsdR5cNOfF3XefnQZk6oOIZ8e3YrCcaKnlAfbza/yzlLT8dldaZN00fTSTN05rlLhpUtFImzs76XPIcFVZXp6PWzanEphXkjT52zeUYHI2tarampyfYrcxJCCDRNy+jQTvWXCUwLLTqwXtWmWDjobeL5uldZkG9udJzZYbyYL6y7grgex67a2Lj/RQ70NCTPkcnZbwjBWy3b2NGxh/Nqz6Qyb96QyN/16z5DKB5mecli/lb3CjH9sGNfCIEWz6xTKhJT5CVFC9EMHbtqTVqkVsXK+8pWcMHyD2MGRAQXLP8wx5QuxyJbUGULqUSXmkg7VlTlVxLRYnQGe5LHLIqakejGqtNgmJvS5OON9NMV6qXA7hnipxvsF43oMayKJZnGknBBJDatHgtUWWVFydIhwYrUEmBCCNr6O7HI6pQRHUCxs4C1lavZ2bU/WZhhLJkCdtVGqauYZ/ZvGrbMe1wz0A0dRTGLZOjDPEuTiazJ7o477uDee++lqalpKuSZNTAMg7aDLRn3ugzGQpy77AwWF1YR0zWsihWbYh1Y9iRlfMAzkVLi7VmZN48Lln2YsBZh475/ENPiQ9JUHBYHW9t3UuYq4Yya9WlLxzKlI5hTlZP524FXknseGIZB44GGUffvDMRCvNzwJteddAXvK1vBYPJKlT1zqkPmttngAwvX8kbTu+ij7NeQSaexTscUWaHEWUipsyjjpjmJa1pbXENEM32hUsojNR4iB6gtXkRTf9uw10TXdV7c8xprK1Zn1e94sLBgPh9cdDL3vPHgmDIFEi/hX7z1O/PefOt3GQkvrhlmZFmSMAyDjpap3zc262nsLbfcwssvv8y+ffs466yzqKqqyhiN/elPfzqpgk4HsjGRW/vakYWEJunEjMOlwoUQ7OzaR1zX+NDiD/DLt/4vbWo62gM+2goKRVZwWhz88q2HqfOaS440I05t8WJuOvlqQvHsiKM75OWtlq18ZMnpIAR1uw+wZOXSYad9voifTQ1vsL7qRKryK4ZMkYfTbfCUbyJEl0BHoIt9PQc5rXrdsNdN1/U0nQZHTSeaUyYE5Nlc/Obdx9k/sKYXJkbkYAZEtrTvGhKsANjRvpfOlg5OX/OBCa0V1Qyd/qgfm2LBPUwqTWLMEgG0VOt5sI6p7ff2HECSZFRJoba4hutPugK37fA52rqDNLT1U1rgRNd1tm/fypkfPIWSgqFypGIi09isyW4sWc6zdW1sNheyP+Lj6T0vsGHFhwkNDHazr50tbTtYWbKUJUXVQ3xxE30ABt9MMT2OEGBRFBRJHXf/7YEutrfv5sxF7+fgnjqWrFyKy+YcQh4Nfc3s7trPh2rej23gjZ4NeUw20YCZTPu+shUsKlyQsd9UskvoNFnjkSD+j6/4CEXOgkklcoDXDr1NbdEiytwlyWvXF/Hx5O6/URubz9JVteMmu1A8TCgeocDuoT/iJ9+eN8R6TfXNAuhCG7Lz2bm1Z3DGovW82/Ye66tO5BdvPcyebrO0l0W2JNfwDia8+pZ+evrCFHrs00Z2WU9jDcMY9Wc2El02CESD3L/5YZ7b/xK/2Pw7HBYH2zv20O7vZEPtmSwtXjTEFzd4ajoepPqIJGRsig27akWRElUzsvcRAZS7S1lZupSXGt9ILsNK9QfaFCtvNm+lzd/JOUvPSBIdZJ4iD4ds2o4Vp1evpyKvjPs3/25Yf1KiSOVkJm73hvt4qfFNzll6OgIxqeOcwMkL1vBmy1ZsijU5Hk6Lg7MWnzpukjOEQU+oD83Qqc6fz+Kiagod+fRHhu5XmxirhPtBkdQB36z5c2zZSj66/CxkSeL0RafwQt1rHPQ2YVNsA/vgHuaB/T0H2bjvRcJxcxPwcDSelnYiTeJWAcMhqzOEQiEuuugiHn744amSZ8YjEA1y/1u/Y39vPbKisKNzLz9/87ecsegUTq0+aUjEdDIf8ME3n4mJOfsTqMqvpKawCsotyTpnJnn8Dotqpba4hvVVJ2RMRxktY3+8bUeDXbWRZ3fxm3cfSzr0UwlMRsIb6ad08TwcVgf3vPlbdnTuIapHiekxBMaohJfJv9cV7OWfh97h3KWnJ5eMTQWRq7LK+qoTsVvs5su17iV++dbDzM8v532r35c14UW1KD2hPjx2N0uLFjEvrxRVVih3l6LICtExLS0zMdh6zXxvHkZtcQ0blp2Jw+JA0w3impEkO0VRmL9o+YSm5GNBVmTndDp5/vnnj9qlYkmi6zmIbujE9BiqrFLvbeIXb/3fsA/MZD3gE3H2x/U4feH+tPy0wVhVWsuJlau5583fsq+nHkMYbO/Yw2/eeZTa4kWTkl+VDQwhho3QpU7p9/c0IEnSQNQ7ynudu7n7jQdx2dwE42Eq8sp57sBL1PU2YB3IZbQoFrMQpR5ld/f+jBZxpoh3u7+Tt1q2cW7tGRkrj0wWkSfOv7xkMfdt/t9ksc967yHu3/wwTosD2xgTfoUQ9Ed8hOIR5ueXs6SwOs1/5ra5KHMV448Fh1zv4TIFBt9rI92bg6ewcc1A1wWKeji6HAkFZl409tRTT+X111+fCllmNMLxMBv3vZh0QsuSjIqStHTGO4UcjEAsRH/EP+zAj/XmS0Vc1+iPBrCrdrxhX8a+7aoNl83FLzf/H3u764jqUeJGHLtqZX9Pw6QUJsgGoXiEnpCX7lAf8Qz7l6anfZj+odQp1kFvEy/UvcrxFcfQWN/AhmUfYnnxUhKWsISUjJIvK17Mh5Z8gHdbdyRTcTIVZrBb7HSGejln6ekZo7OTidTz13sbzWKaA9H8fT11/PyN/8Vlc406HnFdozvUh1W1saSo2qxMnaHIa6mrGIfFQTA+1JAZqzsmtd3ykiXAUKIDk+xSLTvDMOjuaJryaGzWZHfPPffwyiuv8PWvf53m5ubRvzBH4LA42LDsTGqLE3mG6dO5iUwhwVxk3hPqAwQWxULvCIvSs/EFaoZOX8RHmauEhYXzcVodGTdhdlmdPLvvRfZ212GR1SR5JPScLDIfDYnroBkaCwvmM89dgi8aIDDouo42bUqMRyAaNPd0iASGsYiXcOPJV6LpcWyKhZca3mR3134cFkeaf293935+/uZDnFGzfsj61KnAYP/s4E2393bX8ey+F0ccj0AsiC8aYJ67hKVFiyjIsKY3AZtqpcJdRkSLoWcgnbFO0xPtrlv7Gc5ZevoQogNzRzEhxJSVCxsOWUdj8/Ly0DSN2MCmtqqqYrOlv10kSaK/f/iyOzMVY4n0JKayu7sOoGlxVFVlWfGSCTmlw/EIgXiIYkchlXnzEAga+1oIxIJjWp863Hl1Q6c33E+Zq5iqgvmosmJujec9BEKQl7L2067acFqd/Pz1h6jrayATmU+W4304BGNhQlqYInsBFZ4y3FYXhjDoDfXR6m8nosUotHuSftHhlq2lyhqMhrKKxtpVG06Lg3s3/5bdXQcGCEagG+bqjOm4DiPpZkKwpGARN6y/MpkJkArd0OkbSCnJpl6fbujU9TbijwaSa4/Hi75wP5WecsrzyoZ81t4T5GCrmXYCzNzUk6uvvnpMdaceeOCBrASZCRjrhQxEg9z75kPs6tjLqnnLuH7dFeO6+Y0BX4okyVTklVHmKk4+yIk9WQPR0LiqA+uGQW+kjxJnEdX589OmLt5wPwe9h7AqlrTd5K2yFafFzq/eeSS5DwRMPdHpho434sOmWCh3l1HiKhoS6AnFwrT42ukN95FndSaXuY2Wv2foBk31h6havBBZkUdNf0lPtxBoA8UZLPJh/1y2y9vGi+HJvIZrT/wUoXiEmJFe2iqqRfFFgxQ7C6jMK8+6EnN/xMeBngZcVueEyt03eJvoDfdx8fsuGPLZwdZ+urxhijwDpdwNnZ27dnPa+uNnFtnNZWSbZ7dx34tsWHbmuEggpsfojwTIt+cNqbCRQGLfB7OmXP6Yq+nqhkFvuI9iZyHVBfMzlivqDPbQ2NeM2+JMK0I5Fcm/IyEYCxHWohQ5CqjIKxtxWqYZOp2BLtoDXSAEHrsHWZKyzt8bySIe2aKaHgt3JHlGOr8/GiBu6FTklSUjrNlCCMGh/hY6Al2UZFGxZTBGIrvdB3sIR3U8rsP3XVdfiBWLiqZ0bWyO7FKQzYVs83WiSgoxIzawdd3YIITAHwuiGzplrpJha6clENGiNPY10xf2UeQoGLUMuCFMoiuwF7CoYP6w5cqFELT422nxtVNg82BRVIQQ+Lz9lJWW4ba5JjX5dzA0Q6c/4seqWqjIm0eJo3DMZbl9ET8t/nZ80UByo6PhCCyhk6dweH/VYIxlejxcICgUD2FJLA+cpDLjg8k8EA3S2dWZ1Mkc837sqo0F+RUU2seuayaE4xH29dSjSHKa5Z8NhiM7XTfYUd+DBDjt5n0vhKCxuY0T3ldDkWfk801rUnHihHfccQfr1q1j3rx5zJs3j3Xr1vFf//VfaRvczmWEY2Fe3fwqoVh4zN/RDI2esBeLrFJTtJAF+RUjEh2YN/qigiqKHAX0hvtGXAtqCEFvuJ98u4fqEYgOTL9qpXse81yl9EV86AMJ4R2tHYRi4UnPGUtFIBaiL9xPkbOA2uIaylzFWe0/4LHnsaRoEeXuUvyxIP5ocNi0j4RO2UT6xhPxDscj9Ed8pp8RQV/UR3fIiy/iJ6rFJpRWMTg4EIqFkzqZG5b3UWD3sLRoEUWDKrOMBw6LnXmuUoLx8IipSuNBXDPQUiKxYI6Rt7ttyqOxWRfvbG1t5bTTTuPgwYOsWLGCD3zgAwDs3buXb33rWzz00EO88sorVFRUTLqwsxmJ6Vqps5gKz7ysUjhsqpXqwgVIkkRP2EuhPX9I6oMQAm+4H4/NTXXBgjHtjyDL5p6xmqHRG/aSbz38pkytojsaDGGgGwYCA0OIgR8DIYyBXDkDA5H8zGmxUVO0kOIsrLnBsCoWFubPx2110eLvoDvkpcDumbSUkOEq+Wa6Jr5oAMMwqBqIHhuGQUiLEI6H6Yv4CMcj+GNBJCSzQoxqy1rOTOMRioWICY2KvDIq8+ZlTCkZL0qchXgjffijQfLteZPWb1w30HRjWot2JpD11fmP//gP2tvb+etf/8qGDRvSPnvmmWe45JJLuO222/jtb387aULOZpg5bmZkrKawatwPuFWxUF0wH0mS6A72UujwJFMRxIBF57Y5qS5YkBWRqopKVX4lmqHRFxq7VW4IQUSLmpvESKBIZs6hLMlmDqKkoChWVFkxN7qWFVRFRZZk8qyutL0gxgtJkih2mvtKtPo68Ib7UGQFt9U1KaSXqZJvKgxh4A37zJdR0YJkBFNWZDyKG4/NTZmrhKgeMyPu0SD9UT/+aABdGKiyWZjALJU/dmvMEIJQPIwuBIsKqyh2Fma1O9pYoCoq5e4yDvQ2oBkaqqxiGqdiQpZjXDNfgPI0lmNPIGuye/bZZ/nSl740hOgAzjvvPG655RZ+9atfTYpwMxmSJGF3OYYdeN3Q8UcDCKDUWUSZu2TCOWoWxUJ1/nxkJDpDPRTYTEvGG/HhtDqozl8wLhKxqVYW5s9nv3YQrNKIN3NMjxOKhdCEgV21UZFXhseeh1VWk0QnS/KUb4uXCqfFweLChfQ7C+kK9tAf9aMg4ba5zarLbte4H9DhLFzN0OiL+Mi3eajKrxw26ikNBFDsqo1CRz7zDYOQFh6Y9voJxkMEYqGBJGcLdtU6omvDtML7KcjPZ0lxNfmOqatnl2/PS7pPiuwe4t4OjGgQ2e5GtjqQLTYkizWrda3mjmLpkCQJm2P8YzRWZE12wWCQefPmDft5eXk5wWDmgn1zCbIsM6+qfMhDbQhBMBYkqsfJt+cxz11Kvi1v0gZSVVSqCuYjSTIdgS5kyVzkXl0wf1wbPifgtDpYVLgAA0FIi+BOIWbdMAjFw0T1KKpswWPPo8hRiNvmmlB6wmgwoqY/VLaNrpcsyxQ68sm35eGL+ukK9tIf9SEhMW/h0HGaCCJaFH8sSJmzmPn5FVldA1mWcVtduK0uSl3FxLQYIS1CMBbCF/UTjEfQooGBKLM9LdARiUcIxMOU55Uwf/77RvTJTgZkSabcXUp/uB9/dzNq0IdssaH7e9EMA1lRQLVkRX7RmD7EipVlmdLyhVP+gsya7FatWsUjjzzC9ddfj9WafrHj8TiPPPIIq1atmjQBZyoMw6Cv24tnfl5ykIKxMKF4GLfNxfyBqNh4wv+jQZUVqvIrkCUJXzTAooIFGeuRZYs8qxt7WCVgiaBIMhIQHJimOi0O5rlL8djcOCz2KX0LCyHQ/b3EupoAgZJXhJpXjGwf/e0vyzIFjnw89jx80QCd/i6aWprxFJnHLBP0a/mjQeKGRpWngnJ32YQfUKtqxapaKbB7qBBlSdeAPxrAFwvSF/UlVxvIyFTlV1LqKKKzs5Py8skl8UxwqjYK4zqH+toozStDVi2A+fIRho7Q4hnJT4sEERmqH4UjcVR1kIFgGPi8XRgLC6ZUl3H57C677DLWrVvHDTfcwLJlywAzQHH//fezfft2HnvssUkXdKZBCEF/dx+ismogkTOEw2KlumABxc6CUaOsE4UiKyzwVBA3tDFv1jwahBAEe/1ULJ1Pe7ALi6JS5i6mwO7BbR26q9ZUQBg6cW878d5WJMWKpFiIe9vRfd0o7kKT9Jx5o06dZEmmwO7BpTrorGvDY8vDHzNnHHlWZ9bjYwhBX8SHRVFZXLiQwhGWXo0X8kCqh9PioNhZiKZryUBHcGA/jAJHPrqu09bWNuIMazIghEGst5X8UBC3s5Cg0Mjj8HWTZAXJqoDVdJ2kkl8s0IlmSb9fdEMQietDghNCCHx93QixdEr1yZrsLrnkEoLBILfddhvXX399Wl38srIyfvOb33DxxRdPuqAzEboQ9Ib6sVgsVOaVUeoqmvK9NlMhyzI2eXKnMpIkMc9dgtvuwqHaJ41IxwIjHiXe00K8vwvF4UYeuJay1Y6hxdD6e9B8PSiufFRPKYrLgzQKAZvTfAdLiqoJaWG6Qr30hfvRhYEsSSiSgiLLyJKCIskosvk7lcg0Q8cb9pFvd7Mgv2JSrOixQFXUZKBjuiGEQby3jXhPCw53MRV6hB4RY2HJEjr6WvGHvMkovC7MHwOBBAhFQpYVxKBUkrimo+kGduvkRY2zwbjOevXVV3PFFVfw9ttv09jYCEB1dTVr165FVY+MItMOyXTkFzrzqcyfN20PwHQgYRVNJ/RwgFhXE3qoH9VdiDRouimrVmRPEULX0EM+9IAX2ZGHpaAMxZWPNIqlltgbNs/mxu8KEo6HB0o8xYhqMXRhluzSNQNNGJDIixMgEJS4iqjyVEy5n2wmQAhBvLedeHcziiMP2WKl2JlHsd2J761nqFh7LhE9RjjcjyorOGUbNsWCRVbN6LuksDcSol9PL96gaQaaLoZYdg6byqmnnDDl6SjjZiZVVTnllFM45ZRTJlOeWYMiZwErFtayuGjhpOY3HUlIkkRJScmYpmfC0DEiIfSwHz3Yj+LMQ3EVjMmvNhjagH9OxGOonuLkFFWy2pFtLoxoEBGLmMcUFdVdOHD+AJG2OmSbEzW/FNWZj2RN9ycO1kmSJDy2odaSbujoho4mzN/xeIRY2E8s1I+IhCjWFXS/n3Da9FmCZL+J/2UkVUVSLEiKapK2pCDJMsiKaYnK8sBvZVxT4WzGKVsIIYh7O4h3N5uBB4vdHAe7i66n7yPSvAet6xC1G75APOxH1jKvHrI78ymR0vPz4pqZuK6kpJ3YbQpuh4UnX67jE6dP7TR23MvFdu3aRX19PV6vN2N2+JVXXjlh4aYbE1mKcjRA6BpGJIgeCaAF+hDREMIwkC1WjHgMWVGQnfmonmIUZ96o1pbpn+sg3tOCpFhQnIcfjsQD5ntrI56TNmBEDhNeWh/CwIiEELGIGQm02FFc+cg2J7LNjBCOFUY8auoX8qEH+zHiESRkJIvVZLMh97lI+5XYOlIYBhgGIjGtY6CGjCSbpCeZxIcsm1HMRCRTtSKplqzTOSYTMW878a5DyFbz+qUSXbT58PaOtgXLKT3/CxnHRbLa6dBCbHvnKc4781oUhzmunb0h6lr6ktVOEkR39xPb2FXfw/sWF3PL5ceT5xzeep7WtbF1dXVcccUVbN68edglMEfDhjuGYdDU1ERVVdWoETExsMRrNP/SkUYmnZIEF/KhBfsQ0TACgWyxmw+DrCQtMD3Uj9bfhTB009rKK0Z15SPZnEOsEEOLEe9uId7XYfrnUtJmBj9gIz1Yad+xOdH6u9EDveYx1QpWB22+MAura1AdriEEbMSjGOEAeqgfPejD0KJIkklCktU2qaQjDAOEMfBbR7I6UN0FxL2dGGEfICGpFlBU5IFrapKgxfyRVZBlDAHNzc1juveyQby/k1hH48C5nZmJThgmWZOZ8BLf2fnUT9nrbeSDpSsoPf8LKI48mjr8tHQFKMl3pBHdnoZeNE3DalFZWVPEzZcOT3gTIbus51/XXXcd7733Hj/5yU847bTTKCwszLaLOQEhBN3d3SxYsCDtmNBi5k88Zj5I0SBGLALCnILJFps51VJVJPnwVEdSVFCUI/ZGB5Psujo6qCwtwjA0c4oa6EfEwyAEktWB4i5II+3BFpikqBiREEYsTKyrCc3bjuLKR8krQnGaAQUjEiTa1YQe7EN1FZgP+KD+Uh+waPNeup6+z3ywIKMlkSqDbHdiREMILYYWCtDR0ECpFEV1OFHsbtOClCT0YD96yIehxZBkBdlqR3W406fBGabS44Uky4CMpGSyXD2mzLqG0OIYIT+630vCLjSnw6ZFqAtBa10TJXIY1WoDWTVTQpKWo2LeXwlLcQz3lObrJt55CMliQ7aZlpdsM+WLNu81LVU9DrIMA1uHRhreo//Nv5K/9jy0aNi0pAfGLtZWB3aVaMu+5NghgarIQ4gOSBpOexu93P34lhEJb7zImuxee+01/vM//5Obb755UgWZbRCGjhGPovm9GEJLPuBCiyF0zXwDDtyksisf1V2I5u9FD3oRPrNGGmYLJEUBSQFFQXEWoLg8gDAfQIs9jQwmRXY9jtC0pKyGFkNEw8QjIeK9bUSaJCQMUzarHcVVOPCgpmMwMUU7G82bGvPBVuwujHgMzd+L5utGsruxFMwz+xICNa84rd/B/YmBcuySrAxLeCPJICQZRbagONwmSRsaWqDXtD4BSVGQbQ5UR+ak7yGExFCiHQ9GlDkWgUFBECEM0HWE0MEQoOugxzHCAbRI0LzXhHlHSUIgOfOwFswj3tuOoUVRrE5ku3OA/KzmNFmxJHXWfD3EOhtBsaDYDwfajGgQz0kbiLbVEWnajZRwCQy862wLlpN/0gZCB97FCAdwrXo/XX/5GZGW/ck2QJLwys69nkjUhtth4alXD6YRnW4cniXubfTy1CumDy9RGWUykDXZlZSUkJ8/sSqmcwGxnlbi3jYirRKKYjqgJcVivhnt7uRDPOSBsTnSHhghBvw7hmb6m5xufJufxnPSecS6WxDxKJLFhuLMM6dWFptpHQ4TFBFCgKGZFsLAD7qGocURWhQjGkFoMTD0ATIZ8CjJCgLZ9CPZXaguD4rdPaxFM1YLTLZYkS1F5lReMond99YzeNYN9cPJNhe+zU8TObjdbCurIJF8eUQObqf/zacGLImQ6ZcbRQbCZm6dJMvIFsdhP9Qo1tpwhDRRwhuX5SrJSE7nYZnDQWSrHcXpGbpBfer9tnYDmr8HLeBF+LoO96WY02LZ7kS22Ij3toOsoDgGBW38vQR3v07pBTfS9cwvhvXZ2cprUPKK8b29kWhbvemf1HUwTEsWINK8D99bTzN/7QX0huN89NQaGtp85hRWN0h91yyvLuSjpy2ZVKIjKUkWuP766/nd7343K31ykwlJGMwrKsCaX4LFU4zqLhzIDbMNIbqup+/D9+7f6Hr6PjNaaT2ci2fefCqKqwDVU0zXxvvxbfkbXRvvx1JYjuL0IGJh4t0tRFr3E2naRfjQLiIt+4n1tqH5eoj3dRDtajI/P7STcOMuIod2E2naQ6RlH9H2ejNi6vAMRAoVZJvTXJngKUH1FKO6C1CdbirL56E6PSgON763Nw6Rd7BeqQ8AHH5wB39PtrtQ80sP65fSRvN149++Cf/2f+A58VzsNatNf9uAM9902tuw16wm/6QLCDe8R6RhB5JioesvdxM9tHtYGRSbk/KSosPR2AQZDKPbcPoNp1dW98w4rlsmmQfrlKl/37t/o2vjfaieYixF5Vg8JVg8JWaajsWC0DXz3gn0YZ23CDW/NK2vWHczvq3PY6usxYiFKT3/C9gWLAcy++oSVqBtwfJk8CUVtvnLyFu7ge6AIBLVCYTj3HzJcaxYVIRuiGTC+vLqwimZwsI4AhRPPPEEd955J9FolM9+9rNUVVVl3O/xoosumjQhpwvZOD9jvW3IqhUjHhmz5QMjO3XH0tb06cQQWhysdqwF84j1dSAiQXM6LKtm0CCR2iDLY45sZpIlkwxKXiG+t56h/62NA9P11A7M9Iv8tefhWXsemr83zZeTpl/FEkrOu47wwe2oBWUoAw/6WK5FwpLwvfOcaTUm6vxJ8oBbQMZzwkfwrN2A7u8Zs24jEdJwY5J27UawGNNk1uOHo7tSIhVlfDJnew8N/k7qfWFEw4T2bUZocVwr3z/8DGWE/rqevo/m5p0ctCmcrFmwzV9GyYYvsLc9hi1lVYXdpuCyW/jxo++y/1DfzIvGjiX6czREY7VgH943n6Zw3flDbu6MvqckKUjYq8wIVbhpN5KsYJ+/nK6N95s3qcRA0pb51h7t5h6NwLKKbKo2sDnpfTZlyiKEebOe93mCO18j3tuKZd4i3MtPNqc2LfsGnVFgq1xG6YbrCe57ExGP4Vr5fro33k+keY+pm2EMTGlVbFUrRyWcrEhJCIShY5+/jJIN1xM+tJNmb4glq45DcbpHJ1F3Ib63MxB5YlqdgZDGMh5CCPRgH9bShXQ/cz/R1rpkjl5S5gXLKDnveoJ73wTAvmAFakFpRpmLzr0OoiHQouMi6IzXeMP1+Lf9A8WZj628Zkg/2Uz/d/7lx+ztbeCD846h9Pwv4NMs7GnwUlqQXtThYGs/J66Yx1Ovmj66fPfIqULTSnYvvfTSmNqdfvrpWQkyEzDWC6mH/XQ+dQ+Bhp24Fx0z1PJxF9L/1kZ8bz2d9pAMpOMDmA/MCecgEPjf/Rv97zybkrWfksEvK+Sv3YDnpMl/2+tBH1p/J0Y4AKoV+/xldDx1L/GWPYeVHYjw2RaupPT8G5LnyNoCe/dvA7oJGDT9Gg95jEm/cIBI20G6OtqoXnuGSbgt+0zLD2koyez6J1ituJdlJnKhayaJnn89sS5zdUGq5ZxpPPRAH+GD29B83VjnLcKx+HgUZ96I180I+TGiYSylC+h++j4iTbuT6R7mPSSwzF/BvAu+QHD3P3HWrsW/7R/43n5m6M06MH6eteclr3HG62YY2CqXUvqxm82o8AT9kh3xINvefYrzzvw8iiOPlk4/TR0BSgaR3VOv1vPJM5ZgUQwcDjsFeVNXln1O7kFx4YUXsmnTJj784Q/z+9//fszfG8uF1MN+M5P80C7imoZFVZNvxXD9NsKNO7CWLcK96v1DnLoJpN7YwMhv5fm1lJx7HYGdr6D1tmKvWoVj8Rq6nrl/+IclEjSjnfmldP3150Sad5skkzLU9qqVlJz/BcL12zBiYVwrTsH/7t/peWsjlmGW/M20aeFYZNB1HcNRQOy9503CNXRz2iuEuZJhIJ0jVbdRSTTQR7hhO7HOJqylC3Afcypdz/wyve38WkrOuZbg3jdR80uw5JeNWWYg80sCki+KuKZTvM4kMLPG3DDXWAhslbWUbLiO4M7XAIHrmFPp3vgLoq37QJKTU2pJtY4pp3Es2NG2i16LwtnHmnUvDzR56fPHKMg7bLn1B6Js3d/FqasrZuZWirMBmzZtwu/389vf/nZSyS5BdNGWfQhdIx6Po8qAYWBfuJLSC25Cj4YgPvzUYkI+O4sNxeai66/3EDm0y2yUktlvr1pJyQZzGuRceiL+bf/A/+5zplWQIbViyANuc9H+1L1obfuHtJ3IdHo8/qRsMJIMuq7T0Oll2bLldG2c4DQvUxubi66n7iFyaKfZmSyb03RZxl79vqz8ZWOxyhNQK2op/+iNyRdB1pb2288OpLIYZmQ/JXdy8EvNTE0KmSlLSEgJxlAUJFkd8BWn+Iklibf2v0azr5XLL7gNIQQ763vQNAN3ij/ute2trKgupMBtnRayO3IZrFOIM844g7y8yaubD2BEQ/S/tfHw1MYwUISOJClIFhvRtnp87zyLYjfD9yIWwYgER41iZdNWsbvxvfMM0bY6JIvN/FGtyb+j7fX4tz6P+5jTAEH+yRdgW7gqI9HZFiw3H7JoMCmDHgkw74IbkjKkth3uoU3I7ll72MEtBtJaDC2GEY+g+71ovh5KN1yPbf4yQAxYwxMnukwypKWzyDIFDgt6JJB2fUfTLXVMPCd8JGMb2eYaSLc4cHg8ZPN+kBQL0ea9+N7aiGwb+gCPJPPg82eSed4FN6BHAocDV2O8h5JR04Urk6lSqUSXuC/0UP/hFTHRMLIjD1v5Euzzl2OrXIJ1XjWqpwTZ5jAXycWjGGG/WdvO142IR5M+T003iGtD953o9UUozneYhVdLKqa8Nt+MI7uXX36Zj370o1RWViJJEn/+85+HtLn33ntZtGgRdrudk08+mc2bN0+5XLLNSf5JGwYeVkBRzHWX8uGlM6nkAQME4uul9Lzr8Rz/EUo3XG/m53U3E/eZ5Yq0gNdcitXfbbbdMPzDlRbez4BUGUZ7WDKSVzyKiIUyPjB6OGD6kmIR9MTysYAXrb+beHczkZa9xLqb0f295rrSgQdRxOPm+tVoCD3YT+n5N+A54RxKN1yP1mdW1tD6u9F8PejBPvM88YgZdR6wWIUwDq8siEfMviJB9JAfPdiHFvAS724h2nYAPeA1cxcHIEkSxQX5MLDudSwvn9TxG4mQMo5HymqFTPdEsm9dQ+vrIt7dlHRnDHf+TDKLmDmDSLYVBnqgD83bOXC/nW1e4/5u85oMXM9R74sN1xPrbkH3dSNZnVgrFmOvWoGtstYstuAuQPWUYCksxzZvEfYFy3FUH4N94SrsVSuxL1iOrWIpijufRJAtnqHaSW9/hKKBPWIlScKVVzDzyrJPNYLBIMcddxyf/exnM6avPPbYY3z5y1/m/vvv5+STT+YnP/kJ55xzDnv37qWsrCxDj8MjGo0SjR6+YRLbQOq6nowmS5KELMvmNm9WJ6UbvkDXRtNnp+k6atJn9wW0oN+MjkkSWjyGHuxHUixYHXnkn/IxkGWU/HmQV5K0fiTDTPrVohH0oA9Fi5N3wjnEe1rRwwGEbEG2mMt+CAdRgdLzvzDsdEUL+jEGtneUImaJnYTMh6NuX0AP9qOFAofXawqBYRjUN++hdsliSs+7Ht/bG/GsHUhujgQxJDm50kNWbSg2B4rNgTFQ7SPhDJcVFVlR0A2RTKlAklFVc2/a/FM+gZAVlMJKZE8ZMgZ6LGpWt41FEdEYGEFkxIBcHK4aIknIqsVcYq9aQHGaCbKKBUmPEQ/0owf9ydUfWKzUN7ezZOF8ZD2IrBuUbviCqdtJG9BCAYzo4VJEsmzWstM0zZy2Bf0gOlEdLlOn1CyDLMcDSUKWQA/50WJRFEceQtMg4kUG8zqqVuTEWlhJQo5F0A1xWOa1G4gFfezbt5/FlaVIWtxc7oaEYrWhqBZ0XcOz7gK0sB8tGkEyNKR4FC0WTwaIFFcBpRuuN7MAmvZgW7CM0vOuJ+b3YskvQba5EAMVqQXmul5FUZL3SSoURQHViiGrYDEpLvG+MQyDSDROPB4DhzIww5d5r66LY5cUmz5VQ6etqY7aqnwMw0hbc58Yj8R1n0iWx4wju/POO4/zzjtv2M9/9KMfce2113LNNdcAcP/99/P000/zm9/8httuuy2rc33/+9/njjvuGHJ8+/btuN3mdLSkpITq6mqampro7u7G7Xaz6CPX0rPxPuKHdqFW1FJ4zufZt28v/j4vC8pLKbQr7KlrRFNsyE4Psv8QtbW1eDxutu/am3azrFq1CqvVys6tWwdWU0QRzT2sXrGEmKSya/de0DVzcb0ksXr5YqKqg8JzPk/3xvsJN+3BMZDK4u3qoO7AgSSB5dmt1FSU0BeH4o9ci/+dZ8k78VxaD+6jxKHS3NlLry84kBsHZUWFRA042NqB0htg4XFns/9gI4X5HkoXLmT3vgNEonGQdSQpTm3tAjweD1u2bBmqk2pl+9atadd1zZo1xGIxdu06nAQsyzLHH388IZ+P/Y3tAytADOw2CyuXLqa7p5dDLa1IkgGSgSc/n9oly2hta6e9vR2IpIzTYlrrD9DVZ1qVRqyTEpedYJ+PuniUcNxAUhTyCgpZcsK5GJEge/ftIxyJmkELXaemogi3zcqOgy0ISRqY4knUVhRis9nZ2dSZttb02GWLMWLxjOMR8Pawd99h/6dVhmXlBfRGBW3+GLLdXHOc53CwZGElLU2NtB46ZC4NM3SKPG4Wzi+nubuFuGKj+tgPs3fne1i1EKF+Pwe1KKG4MPMYVSvVNQspq6hk586dRCKHrdClixeR53SyZcsWdC1upkK197FKVijdcD3ezU+Td+IGDhxqIRCOcPzx1eY4bds2ZJz8fj/79x/WyW63c8wxx9DT05OsbQnQ6zUNh/b2dvbXNdLZG6LfacVTUMS88vm0d/VS6eyjB3OXtoCvDzALjaTuPV1dXU1JSQl79uwhEokQCASGPK9jxYwOUEiSxJ/+9Cc+8YlPABCLxXA6nfz+979PHgO46qqr6Ovr48knn0we27RpE/fcc8+IAYpMll1VVRW9vb1J52eqZZd6qUTYj3fzXylcdwFayHx7G1oMEQ6g2F0oBWUo7sLkovnBb6gEhjueeIvquoaIRTFiEdNCiJp+MSxWbEUV+N5+Bs/a88zS5SE/QpJBNosKKFYbis0JisVciqYqGELCfIZVjEQayIBVJoRg+/btrF69Os1/kq3so+mUyTIY6/HhxiPTcWHoaKEA27ZtZeX8EiQtitDipiWoWsDQ0OJx0wpULaBasTjdKHYXQlYH/HBWczlf2I/W30Us4EVWrMgOF5KsJGVEtaE685LWlzEwToZhILQ4WsiHbLFiKypH8ZSYY5RBdkPXTP9XLIKIhRGRIHo0hBGPmT42qx3J4WZnfRPHHbcGxXZ4h7tsx0OSJCTDwNCikFJhezLG6Y3Nf6Cpu45Lz/8PWjr9HOr0U+IxZe3qi3CwtY+TVppl5XVdZ8eO7Xzo9PUUeRwjWnY+n4+ioqLpqXoC4PV6eeSRR4atZydJEr/+9a/H0/WI6O7uRtf1IbX3582bx549h3PDzjrrLLZt20YwGGTBggU88cQTrF+/fkh/NpsNm21oEqOiKENWhQx2nkYiQeyrz0IL+UGLQMSPZBhYiiuwFMxDHmZJUabVJsMdlyQJVbWY0zXn4XWLRjxq+sMMHc+6C8DQsRSWYy1ZkCwaiaJm9IGknmWwwzZxQ8mynFGebGQfSafJOD6cMzvtuKIgufNRXfk4q1ciazH0aNCs5KLFkO0FWO1OZNWWJLZhK4RYbah5hVgCfcT7OtHDPiRFRTjyzBeaHjN9eGsP+0wRJkkiDOxF88z7wj58tFGWZWTZChYrDNT2E0Ig4lFzjbRqRbLaMAyB0tKDandOfJxkGSVDqtFExylxGWVZJqYJrKqa/HzXwR7WrpyX3j6FsEeSfTjdxoKsye65557j4osvJhgM4vF4MpZ4mmpH42h4/vnnp/4kWoxgRzOe/AJEJIjs9GAtqkBxTb2jVbbYIIuilGPuV5apra2d1j1fpxoJnRRFHVj87sKSX4YQ2W/2LMmKWZjUXYAe7DdJL+AFWTXLRsUi6LGIaeVEghjxCIoz31zj7BrfBj2SNOB7TF1nLItZNU6RmJYMTgghCITjaUvCZFmmZN7k1ubLhKzJ7t/+7d8oLy/nj3/8I8cee+xUyDQsSkpKUBSFjo6OtOMdHR2Ul5dPqyySJOFSAC2OpbQKS37ZpJdimm5IkjTnKjQPp9NEXkiSrKDmFaG48tGDPuJ9HeiBPrNijMWOHgkg25zY5tWg5hUNW6Fm3OefReMU19LTTtq6g1SWpFu3kiRhd7qn3kjI9gsHDhzglltumXaiA7BarZx44om88MILyWOGYfDCCy9knKZOJQwBu7uCqPMWYy2eP+uJDsxp7JYtW2bluubhMJU6maRXiH1+Lbb5tWaFGj2OpbgS+/xlWArKJp3oYHaNk7mj2OG0k10He1m1qDitja7rtDTsnXJ9sh6J2tpa/H7/VMgCQCAQ4MCBA8n/Dx48yNatWykqKmLhwoV8+ctf5qqrrmLt2rWsW7eOn/zkJwSDwWR0drpgKa5EzutK2zdhLmCw83kuYKp1kmTFLPHl9CC0+LD+2snEbBmnuGagaQaqImEIQSSm4bAPpR0xuHrOFCBrsvvOd77DjTfeyKc//WkWLVo06QK9/fbbnHnmmcn/v/zlLwNmxPXBBx/ksssuo6uri9tvv5329nbWrFnDs88+O6kbBg+XZ5cWjUVCkuQhN91sjVzC4Qcop9MEdFIs6Lo+t3Qax/EEd8XiGrqhYRgGhzr8LChzJ2VP6KTrevLvGZVn98ILL1BaWsrKlSs5++yzM9azkySJn/70p+MS6Iwzzhh2I58EbrrpJm666aZx9Z8J9957L/fee2/yQo6UZ5dAcbFpih84cIBQ6HBSamVlJYWFhezfv59Y7PA2c9XV1bjdbnbt2pWm35IlS7BYLGnRZIAVK1YQj8epq6tLHpMkiVWrVhEIBNJymqxWK7W1tXi9XlpbW5PHXS4XixYtorOzk66uruTxgoIC5s+fT0tLC319fZOuUyJ3cOuweXa7kseyzd/yeDzU1tbS3t5OW1tb8vhw45R4CdbX16flaA3O30rAzIf0sH379oz5kDmdss+za21swOew8nZdmA+srgCgq7MNX59Zlt0QBpGBitIzKs/uaKhnN1yeXSAQoKWlZUQyTjhZM6XjHKnjmeQd7ngmjPWcTqeTefPmYbfbZ4xlB2Z+ptWaXhByJllBc1GnRJ7dScdfT5c3hMdl47k3Gjn/AzVD8yGFoKOnn2OXVVLgts2cPLvZ4iuYCDLl2QkhaG1txeVyUVpamiSLI51mM9kYj05CCGKxGF1dXRw6ZK4Wmax8ugnl2Q3AarVOSo7gcMdzOg2fZxeNGVgtFpo7gyyeX5DUZbBOqsWaJPeRZJzWPLujFfF4HCEEpaWlOBxmlncoFMLpHLon6mzFRHRyOBxYLBYaGxuJxWLY7VPvpB8LdF1n69atrFmzZkIPykzCbNBJwlxTG9N0LIrMvkNePnRSVca2uq7T2riP5dVFUyrT7MhKnEGYK8Q2FZgtSa45TA/MHSAFSAJDCKzqkSXmcd2dzzzzDGeffTbFxcWoA8tABv/kkEMORzeEEGi6QWO7nyXzj/z2q1mT3R/+8AcuuOACOjo6uPzyyzEMg0996lNcfvnlOBwOVq9eze233z4VsuYwQTQ0NCBJ0pDoWw45TAUMITAE1Lf0s3RBwZEWJ3uf3fe//33WrVvHq6++itfr5b777uOzn/0sH/rQh2hoaOCUU06hpmbozkSzCSPl2SV+wIw+wtgjoNdccw2//e1vAVBVlaKiIlavXs2nPvUprrrqqrRpYLZR1MHHr7nmGvr6+vjzn/+cFvXK9DsV2eqUenzw9ZkJkUtJklizZs2QqONMilzORZ2EIRAC4po2sG2AQNf1YXWqWLgURVFmVp7drl27+P73v4+iKKgD1RLi8TgAixYt4oYbbuAHP/gBV1555biFmm6MJc+ura2NeDxOOGyW7bFYLKiqSiwWSxsAq9WKxWIhEomkDX7CYX/22Wdz//33o+s6nZ2dbNq0iS9+8Ys89thjPP7448lr6nQ6EUIQDoeTfUiShNPpNAsiRtJLjzscDjRNS+bBaZqWlCsejydlT/wPZvqCpmnJfsajk6IohMNhhBBEo1Hi8TjRaHTG5KSVl5dTVFREU1NT2sqfmZSTNhd16vX6MIRgz4FWXFKQ+v1mHl2inl1qnh2AITsQi8umNM8OkSWKi4vFz3/+8+T/drtdPPDAA8n/77//fuFwOLLtdkagv79fAKK3t1domiY0TRO6rgshhAgGg2Lnzp0iFAoJwzCErusiEAgIXdeFYRhpP0KIIccMwxBXXXWV+PjHPz7k+AsvvCAA8ctf/lIYhiF6e3vFv/7rv4qSkhKRl5cnzjzzTLFly5Zk37fffrs47rjjxH333ScWLFggHA6HuOSSS4TX6xWGYYjbb7/dfJWm/PzjH/8Q9fX1AhC///3vxRlnnCEcDodYvXq1eO2118atU+rxUCiUvEZCiOQ1TPwk2k7keGI8dF0f0/FYLCbefvttEYvF0o4nZB98zmyP53TKfPztd/4q/vi3+8TDz+4SO+u6xJ6D3WLPwW6xt6FH7D/kFXsbepLHdh7oEI/9+e+iyxsYoutgGXt7ewUg+vv7s36+s/bZLV++PI3x16xZw//+7/+iaRqRSIT/+7//Y+HCheNn3xmA1EBLal6QJElpP8CQY6Mdz/TZhz70IY477jj+9Kc/IUkSl156KZ2dnTzzzDO88847nHDCCZx11ll4vd7k9w8cOMATTzzBU089xbPPPsuWLVu48cYbkSSJr371q1x66aWce+65tLW10dbWxgc+8IGkDF//+tf5yle+wtatW1m2bBmf/vSnk1OM8eg03PFMQatEPtZ4j6eOx0SODydjtsdzOg09LkkyTncFTZ1BPnxSNR63bcyyj0Wn8SJrsrvwwgt58sknkxV+v/a1r7Fp0yYKCgooLS3llVdeybo8eg7m8rCGhgZeffVVNm/ezBNPPMHatWupra3lhz/8IQUFBWlVlyORCA899BBr1qzhgx/8IHfffTePPvoo7e3tuN1uHA4HNpuN8vJyysvL07Ltv/KVr3D++eezbNky7rjjDhobG9OKL+SQw3gRiWr4gjH+uOkAh9r83P+HbbgdFuy2I5+hkTXZfeUrX+HQoUPJCr8XXHABmzZt4tprr+W6667jhRde4Oqrr55sOWckJjPnTgysXNi2bRuBQIDi4mLcbnfy5+DBg2nrZBcuXMj8+fOT/69fvx7DMNi7d+geo4OxevXq5N8VFeZaxc7OTmBu5hHOxfy/maaTrht4fRHCUY2fPbaFxjbT77avqY+7nxid8IatED2JmJQVFKeddhqnnXbaZHQ1a5AIFkwWdu/eTU1NDYFAgIqKCjZt2jSkTUFBwaScy2I5XHsvQW6GYUy6TjMBiqJw/PHHH2kxJhUzTSd/KIbXF8XttHDPE1vZe8iLM4W79jT0cvcT27j5kuMAiESHRn/nL1o+5fm5ueVi44QYCLUnfHkTwT/+8Q/ee+89br31VhYsWEB7ezuqqo5YQuvQoUO0trZSWVkJwBtvvIEsyyxfbu4FarVasw7TT6ZOMwVCCPx+P3l5eTmdJhlxzaCjJ0hHb4jqCg9Pv3aQ3Q29xOMGdivIKaLtaejlqVcP8tFTa4aQnRCCSCiAEEO3eJhMjEp2NTVmlYI9e/ZgsVioqakZ9QJLkpQ25ZqriEQiWVtC0WiU9vZ2dF2no6ODZ599lu9///tccMEFXHnllciyzPr16/nEJz7BXXfdxbJly2htbeXpp5/mwgsvZO3atYAZ8r/qqqv44Q9/iM/n45ZbbuHSSy9NlqdftGgRzz33HHv37qW4uJj8/LFlsI9Hp5kMwzDYv3//jF5Hmi2OpE6hSByHTaUvEKW1K0B/IEae00p/IMo5p1Sz/5CXA819KEo6R6xYVMRHT60hEI4P6dMwDLo7mjCWzx/y2WRiVLI7/fTT06oRJP6fyxhLUrEYITF3pPJJzz77LBUVFaiqSmFhIccddxw/+9nPkkQH8PTTT/P1r3+da665hq6uLsrLy/ngBz+Y3ARcCMHSpUu58MIL2bBhA729vVxwwQXce++9yfN+7nOfY9OmTaxdu5ZAIMA//vGPpKWYKvtwf49Vp5meVDwbCl3OFp1CUZ2/vFzH+R+oobXLTyAUw21XeWt3B8FwjLPWVnHrp0/gnie20dR0uK7iikVF3HTJcfgCUSIxfYhO01W8c0bvGztdSE0q3rdvH5s2bRqSVFxXV0cgEKCqqgqbzYbFYiEej6MoSsYE3ETycQKJBNxQKJQ2mA6HuZdmarFMGDmp+Pbbb+fPf/4zr7/+OnA4qTgej6cV11QUBbvdTiwWSyYSg7l6w2azEY1GhyQVT0SnaDRKU1MT1dXV5OXlZZWs6vP5Miardnd3Z0zAbW1tzZiA29jYOKTQZUdHB263O2Ohy8EbSicScDNu/J1lAu5s0anPF6S7sy3ZV6pOum5gd7pYsKCae/+4g1313SxbWMDNlxzHP17fw55D/Zz9/pVYpQid7S0UFeazdOkS7nvsaXyBXbjzz+HGi1dz4EAdvd7+ZFJxR3tLWvHOnt4+Npx7Ft6u1oxJxQmdAoEAZ5xxxrjq2eXILgUjFe8MhUI0NDRQU1OD3W5PPtw2m22IpTvRpV6jtf3mN7/Jk08+yZYtWyb1nBPVKRKJcPDgQWpqanA4HDPGCtq3bx/Lli1Li2DOdstusnQKhOP85eU6PnbaEpx2hWhcJ64JQpE4Xn8EVZYoKXRxz+Nb2d3QiySBphssX1jElz51PKFwjGhcJHUyDIGqSMQjDTz/9ib+5aM34g9GCUe1YXUyDJ3de/bywfefMPM2yY5Go/zqV79i48aNNDQ0AKaPaMOGDXzuc5+bMbXMxotMyYuZkoodDsewfQw31c/m+GhtMxHSRM45UZ0yJRVnajsZx8da6FJRFI455piMbYeTMdvjs1UnfyjGzx7bwp4GLwdbfdx4yXF09Ybo9UcQAgrz7JQWOrn7iW3sauhF100ys6gy9a39/PwP27n5kuOQQnH6/FGCkTiGAKddxd/bTFWZi05vCEUeuul6qk6KolBRtSQt6Xg42ac1qbi5uZk1a9Zwyy23sG3bNkpLSyktLWXbtm3ccsstrFmzhubm5nELNFsghEgW9JxufOtb35qSyiVHUqepghCC7u7uOaFTKGK6IsaiU6LtYOiGabX1B6L85NEt7KzvQdMNdtb3cPfjWyktdOJ2WGnpDOJyWPjzy3Vs3981YLHJ2G0qysC2iLsP9vKXV+qx21Rimk5xgYPl1YWsqilGkWP4/N14fdFR9RJCEPT3TfkYZU12N954I42NjTz++OO0tLTw0ksv8dJLL9HS0sJjjz3GoUOHuPHGG6dC1hmHbBIh9RlQzn4sMqT6/OYCDMOgsbFxxm4nMBwpDYY/FOPPLx3AH4qNqlNqW4BoXMfri9DU4aexrZ9ITOenj25h18EeBGYpprhusG1/Nz9+5F3mFTlZWpWPMAQXnr6E45aVYlFlZPnwniOGIVixqJCPnrYYRZFYVVPM0gUFFHnsWNSBJWEjBOpSYRgG3u62KR+jrMnuhRde4NZbb+Xiiy8e8tkll1zCF7/4xbRNrOcqDEPQF4xhGKMPpq4b9Pmj6PrYBnMqiDFbGbLuPwuZx/qATyWykWGq5E2SUjCGphtE4zqhSJxAKEZ/IEqvL0KfP0p/IMpPH93Cxtca+OmjWwiENWSLne6+ML2+CF5/hP5AlFAkji8Y5WePbeGZ1xv56aNb6PNHaGzrZ0+jl+auAPluG399tZ736rqJxQ3icXPcrKqM3apQ19LPs280sqjCQ0wz8AXj3HTxcSyvLsQwRPJ+P2ZxMV+6/HjyXTYK8+zYbUM9YgmXhjFDrOqsyS4vLy+ZApEJ5eXl5OXNrY2jB0PXDTq9Ifr9UTq8ITTdQNcN9AEHrZGWfmG29QVjdHpDo5LNZBOjEAJdN+jwhugPxJLyJmQ2DDHs23esBDaczIlzxzXzQY7GNHzBKH/aZD7gY8FUEM1gy2ey2sLY5I3GteQ08q+vHuTHj76LPxijobWfnfW97DzYy+6GHtq6AxhC8NOB6aZuCHbW9/DTR7dQVVVNpzfE3kYvexq8NHf6icR0fvLoFnakTE1/9vhWSgucGMLgnV0dvPh2M+e9fxHHLi3BblWwWRVU5XAS+fLqIi74QA1tXUG6vCHaeoJ094e55dI1HLO4GFWVOWZxMV+8/Hg8LlvS2ssESQKLKhPXZoZVnXWA4pprruHBBx/k2muvHZJ8GggEeOCBB/jXf/3XSRNwpkHXDbyBEOGYGR2KRHU6e0OUFTmJx03ykCSQZQlVken0hpIZ4+GoToc3RFmhmVZiCAYKGyaiVFKyfTSuU1boRAKQzCnB4ACBrhv0BaIUuG1JP4rZr8AwzL9lWaKzN0Qkg7wxzcAQAhlTXvNNLJtvYkMk+5YkCUEil27g5MKUC0jKHJQ1DEPQ0hkgHA+YRIppBbvs6oCz24zq1bX0c8tlxyNhPhB2qzrkwfGHYjz1Sh0fPW0Jec70bQPHCkmS8Hg8yWvnD8b42eOmU76+xcfNl67BMAQxLT3iaVFkVFXm7se3sqexl/oWH7dcugabVcGiKhkf8uHkNQxBOKoRDMeJxHXyHBbuTolumsuptnLzpWuwW2NEYzpOh4rbYeHuJ7ax95A37Xx7D3m59/fb+eLlJySTdJNtG73mZjfCLIm+bX8XP37kXb54+fEsKM0zXzwxnVsuXcPdT2xj98FewCy0uXIgH67XF8FuV1la6MRuU7BbVSyqzBcvPz6r8ZAlCYtFIa4Z2CwjrYuVsDlcU56/O2rqyR//+Me0/3Vd5zvf+Q5er5errrqKpUuXArB//34eeughioqK+M///E8uvfTSqZN6ipBIPckU1o5EItTV1ZNXNA9dqJh8MEBUgN2mUlboIBzVkSRwWFWTBGJDkyDtVsUkR80kR1mWsKhyGikNbpcoFKDIJilKkOzfblUoHSBQTTMwhLlUx2JRhvSZ7NumUFboHLBIzZtdCIGiSFjUw99LlUE3hMl2EihyejsAXYvR3dnC4poafCGDUERDliRcDpXCfDt3P76NvY29A4QpWFFdxE2XrqGzN0RcN/C4rLgdFlx2C3HN4O4ntrC30cvy6kJuvvT4UR+wUCSO025JO6YbgkhUS1oXP3t8C7sbehngbvMBv3QNbd1B/KEYQgg8LisVJe5kukUCKxcVcfOla+j1RQBTL5tVwWFVh8p7yfFIEvQHo/T5o4QiOg6bQmWpm589Zlpqg5+8VTVF3HTJGl7Z1sK6VeW88NYh/vrqwWH1veDUGj58kllObXBbSQJVOexnO3f9Ij56ag2t3UGiMR2rRaGixMU9T2xlT0Mvq2qKufnSNdgsChaLgjKMxZbpGmfC628+QWPnAdYefz1eX5TCvJEzNLr6QqxYVDRqu5Ge0dEwKtklUi5EigUymtMxU07PbMBIF9Lb76eu7iAFJRUoqtWsiCkEEodvCo/bSr7LfCD7A6bfZTjku214XFaC4Thup4VOb5hIVBvSzmFTKSt0mtPOMRCjNmCtWVSF/kB0VBny3TZz+jlgPcoSpiwZ+tYNgRiQIWExhlNk1rUY7a3NbD4Q5ZqPr6G+uR9FkVlU4eGeJw5bMiCReIknsuu7vWF6fBHynNbkQ7i30Ys80HDFokJuvnQNVlVBkgdIf8AahhSr6tQlWFSZYIrvKxYJsHhhpSlDYy/CGLCqARADFs0a3t7dgSEEJ60q557Ht7Lr4GGikwauz6qaIm669HjaewL4gjE8LluavJJkvg+WVxdy08Vr2FHfzf5DffjDMT55Zi0vvHWIjf9sSL60BiNBSoFwPGmt7Ukh3ASWLyzglsuOH2LZDWkrYPmiQm66ZA1t3QHCUfMFZo69FZD466sTs54zIUF2Z7z/Fg629lNaMPwSRMMwONjYxNrjainOH3mp4kTIbtRp7IsvvphVh3MBmZaL2SwKDpuK1SKjp9QAFpJJeHarQoHbRlwzkICCPBuxuD6sVVWQZ5JMnstcVxiN6RnN+HBMoy8QxeOyEopq5DktdPSGDhOjZMoRjmp09IZM6zJkWjIF7hFkGJA3GIkTielYVPlw3zE92S+k9x2IargcFvr8A4miEocJX5JAMjdY+eurBznnlGoQ8NSr9eyo705aMkKQnBZv3dfJky/V8eGTFtLc4eeDxy/gp4++y66DJjGaU2vYUdfDTx7Zwk2XrqHLGyIUjiFhvmAK853cM/CgH2ju56ZL1iSXM0kCFpQX8ZdX6th2oAsJKUnWA9mB7DvUxzOvN3D+B2qQgKdfO8iB5j6slsMu7YTlu/NgL0+9Ysq752AvS44v4MePvMuugz3J4TAEbNvfxU8efZdbLjueojybuVZUGHzi9CU0dQbY09A7JIF4xaIiLji1Bl/AvLbCENx8yXFDSGx5dSE3fvJY+nxhQhENQwiiUTOQkHATpFquN1+yhmhco7TAjsOmJl0GCUPmEx9cis0qJ+/5yUiUFgNvE1WRMIzhl1+C+bz1e7sQYumR3YPi9NNPH3fnswVj3YNC1zWK8uz4woJILPGgD1g+hQ4ikQiSJCPLCpFIlNJCx2GLbYAUbFaF0gIHoXAYTdOx2+3ku21EYnqaZZcgPodVpcBtJRKNkuew4gvGiMZSLEBxuH00pvEvV17NH3//WFqxzv97/EmOWX1i8n+HTTV9drE48WiQb/y/23jiiScAiY9+4mK+9s3vJffCMPuGaEynPxAj32UhGoumEalIYzHBkqoCPvbBxezbuw+ACz6whIOtXvY3+QaCFoflX1lTwidOX0JPr4/TjivjmX/Ws/tgNxID/kPDSAY+tu7r4M8vHeAjJy/i9S11lBfILDhuOT955B32NPQiywo767r4ySPvcMPFx/H2ew10+2LUVjr46KkraGjrY3eSlMyKurqusXJRERvWL2Tvnr0UlszjgtMWU9fiZXd9T1JORVGRZIkVC/P56KmLOHCgjlOPW8hzbzZS19yHKoskmSsyqKqFA819PP1aHeesW8Abb21FUa0sXrqcGz55LD97bMthWSSJYxaXcsNFx7J1+066e/oACVdeAdXVC7nhomPN6ffBHlbWFHPjJ1ezfedufIEY8Vh4wJ8LS5Ys5eZL1vCzx95l18FuVtWUcNMlx6JKGoXF7mGXi+3etT3teZisPSgA+r3dtB06QJ9NRZakjHtQGMIgEjb3qJjKPSgmtFxs165dSQWrq6tZtWrVuAWZCRjrcjGr1Uan15zCJaaZqVMSSZKSIXohhNk2puMY8K0ljoskUZnfSQ1mwOHpYyyuJ3171pH8cFaF275yIx5PPnf+4IcAKIqcNu01idlJXDf7/O63/4u/Pv0Uf/nLX1EUmXPPPY+PnHsBN9/6H+l9D/j4NM2MOiecz0N8dh0t1CyuwR80CEdjqKqC22Ehz21LWl8JJKawwXCccETDokrku+2mdXIwfTomSWb7mwd8fP2BKDWV+dz9+FZ2HkyQkmmtKbLEMUtMH5TPH2HXzvdYtmIVRfmuZGBgoHlyCtvZEyAQjiHJMh6njZICB3cP+LPS5V1DW7efPn8Ej8vG/DLPEN9eAgl/YGdvgEhUx25XcNltuBwqiiyb/rJGLyuqzSm6BMTiejLIZL5KJWQZLKrCU6/U89HTFqNpGrt2vseqY47Fopr+NUWRUBUFVVXwB2P85ZXDS8COxBK4Nzf/gUPddVx4zlfYcaAbiyJjs6nDWnY7dmznQ6evn9LlYuMiuyeffJIvf/nLyaViCdTU1PCjH/2Ij33sY9l2OSMwWoAise7TbrejaTqd3hD5bhvKKFVjdcOgPxAdta1uGHR5w0TiOnaLQmmhAwZ8QKm7qQ+OsMJhYrzmmqvJzy/gf/7nR8kpYMLvlYiuJiKkhhAsXVzDnXf9N5+48CJkSeIvf/4jX/nqV3n5jfeG9H04UGL2mYgAdw0EShRJw9/bgaeoHF/YSK6zNAwDj8tGZYlrgEC8pg/uEjMw4AtGMYRJzAVuK2WFTu75/Tb2NvQm9V9eXTgwPQ0QCMWoXVjIxtcO8uwbh62JVAgB562v5rz31/Dmu7som1dJcYGDonwH9z5uFphMBD7sNiURd0n6EiUkQlGNux9PD5JYVTnpPzWESF7bRNQ20U+CmC0WBXUgMj/RaHMiOGAYBk1NTVRVVQ27vGqsgYSpQsJnd/lH/x8767uJxUyXTSYYhsH++oOccsLKKfXZZU12Gzdu5GMf+xjV1dV8/vOfZ+XKlYBZafeXv/wljY2N/PWvf+Xcc8/NSpCZgGzILhLVuOQ/n5422Z743vlpiZuJ/L1Ua02WJa655hr+8pe/AGbJ9c9+9rPceuutyLKMbhhpZOv1eikqKmLv3n0sWbIEIWDf/n0cs2oluw80Y7W7kxYdHLZAEw94qix9gSh2VXDoUCM1NTXYbLZkfl0srhOOaOhC4HFaeerVej566mJ8wZiZdmBVsKqmBWqxKFgUM8CQRjSXHI9FlQlFNcLROJpu9jXYUkv6qmpMsonHDdSBhNmEryobkhlrW38oNoQYsyGwuYZUsmts66ejJ0xR/vCR1hkRjR2M9evXE41GeeWVV3C5XGmfBYNBTj31VOx2e7L80GxCNmQXjsS59Gsbp022wWQHmfPs3n33XaqqqigqKuKtt97i0ksv5dZbb+XWW28d0mdTUxMLFy6kq6uLkpIShBC0tLRQVVVFQ0Mj7oLStL5Hgm4YxGOxtGuUCZpuEI1p2G2WYdMbEhiNaDTNIBSNc/djJuElJn4rFxVx82XHk+e0IITIaAVlQzJjbTsZeYFjwVgsuyONVLLr7A1R19I3bER2uiy7rJOKt2/fzve+970hRAfgcrm4+uqr+c///M9su511sFkVHvz6mTgH6tFNx/kGQ1FkCvLSp8YnnHBC8u9TTjmF2267jYceeigj2SWCMP39/ZSUlADQ22taSQUF+bjzRp+iJ2WRZcay1kFVZFTH2Iggz2nlE6cvHZZoVFXGo9q45fLjh7WqDMOgu7ubBQsWpH03G2tqrG1Hk3eykCgEMFinmQqrRTGN7oFc0cEQQhCahkIAWZOd3W5PPhCZ0NvbO+tLPI0FkmSmm9gHnK5HCqOR0Uhv/sLCQhYsWMDWrVtZsmQJYL7MqqqqxlzGfaoxFuLIc1q5+dLssvunCnNxSjpRWC0yqqqg6QKLeuSelaxt4A996EP89Kc/zThNffPNN/nZz37GWWedNSnC5ZA9Hn/8cXw+M8Xj7bff5s477+STn/zksO2vueYavvvd79Le3k57ezs//OEPZ+Vyv4RVdSSJLofMsFmUgTWyR3ahQdaW3V133cX69es59dRTWbduXXI3q71797J582bKysr4wQ9+MOmCzkSkbkk4U3DPPffw+c9/Hk3TmD9/PjfccAP/9m//lvz8+uuvB+D+++8H4Bvf+AY9PT3JQNOnPvWpWeuGyGRVSZJERUXFEbW+JxuzQqcU2RTFDBAFQpkdHZIk4SkoOfJrYzOhs7OT73//+zzzzDNpeXYbNmzgtttuG7EqykxGNgGKHIYid41ySOD1zb+nsWM/l3/0/wHQ3OGnuStASX7mStjTEY0dV1n2srIyfvzjH/PjH/94PF+fExhpv4bZirmok2EY1NXVsWTJkhkbucwWs1Enu00dNgBhGAZd7YdYtrBgSmXI+kppmpa2nGMwfD5f2o5VcxmzsdjBaJhrOgkhkj7MuYLZqJPVoiCnrCxKhRCCaDg486Kxt9xyCy+//DI7duzI+PkHPvCBZBBjtmKq9o2drN3Fpur4RHUafG1myk5cqb8TmO27i810nUSKjEIIFFkgS4JoXMNhsxyRfWOzJrtnn32WK6+8ctjPL774Yn73u9/NKrIbayGAeDye3Ds1EZyIxWIZ91iNRCIZ91gNh8Npg5nYzSubfWMNw0jbFzSxb6ymaRn3jY3H4xn3jY3FYkP2jZ2ITtFolHg8TjQazXqP1bEuME/ssdre3p5xj9WmpqYhe6wC1NfXZ9xjNbHAPIHEHqvbt2+f8L6xR7NOvb3m7C+hkxCCtu4gTncBi6qrZ0chALvdzt133821116b8fNf/epXfPGLXxzy8M4GZLNvLJhT+tTqIAnMVssOJqbTTNw3FsxlcYWFhWnHZpIVNBd1evOtP3Coq45Lz/+PpOx1zX14/VGK851pOgkhaGrt4MRjF5trt6eoEEDWll1xcTF79+4d9vPdu3dnLcRMw1j2jYWRU0+mY9/YqTg+EZ1m4r6xQHJ1SCbMxn1jYebrJA3InCq7x22nZ2BrxcE6uT2FSXIfScZp3Tf23HPP5Re/+EXabvQJvPvuu/zyl7/kvPPOG7dAswWJKeZschKPhrmok67r7Ny5c04FXmarTlaLMqQUPYBh6LQ310+5Pllbdt/+9rd59tlnWbduHR/72MeSO5Pv2LGDp556irKyMr797W9PuqAzETN1L9KJYC7qlOq/miuYjTpZLeZOZrpupBWXEAK0+OibaU8UWZNdZWUlb7/9NrfddhtPPvkkf/rTnwDTyfqZz3yG733ve1RWVk66oDnkkMPshs1ilvGKaQaOMVTSmWyM64wVFRX89re/xev1JtdUer1eHnzwwRzRHWHcc889rF27FpvNxic+8Ym0z8444wxsNhtutzv509raOmxfPp+PT3/603g8HubNm3fUWOw5TA0sqoLVcuT2kR3XCooEJEmatUvDJgMzcUlUZWUlX//613n++edpbm4e8vkPfvADvvSlLw37/VSdbr75Znp7ezl06BCdnZ2cddZZVFdXj5h6NNMgyzK1tbWzZqXBWDCbdXI7LAQGZWrIskzJvKmvzTdusnvttdd499136e/vH+LnkSSJb3zjGxMWbqZD0uMIPVkcd2rPZRnbEq6LLroIgK1bt2YkuxHPkRJRC4VCPProo7z22msUFBRQUFDAzTffzK9//etZRXaJTbLnEmazTg6bBT1DmpXd6Z7yJYpZk11vby/nn38+mzdvThbjG7yn7NFAdkYsQuMPr5i28y366sNI1olbkt/5znf4r//6L6qrq7n11lvTiCsRjXU4HOzdu5dYLMaaNWuSn69Zs4bvfe97E5ZhOqHrOtu3b2f16tUTSluYSZjNOlktCjLphTx1XaelYS+1Veum9NxZ241f/epX2b59O//3f/9HfX09Qgiee+459u3bx/XXX8+aNWtG9APlcOTw/e9/n7q6Ojo6Orjzzju5+eabkwGmBBIvrkAggMvlSkswLigowO/3T6vMk4G5GGGerTrZrAoWVSGup8svxNTrk7Vlt3HjRq677jouu+wyenrMLexkWWbp0qXce++9XHTRRXzpS1/ikUcemXRhZxIki42yG3+FY5rKsksW24T7WL9+ffLvc845h+uuu47HHnuMCy+8cEhbt9tNKBRKW1HR399PXl7ehOXI4eiF1aKgqmaQInXHvOlA1mTX19eXzK1LrB9NXa/2kY98ZNYWf8wGkiQhWWzIVvusLYc0kkN4+fLlWCwWtm3bxoknmhtsb926lWOPPXa6xMthDkKRJRx2FV8gNnrjSUbW09jKykra29sBsNlslJWVsW3btuTnLS0ts/bhzxaJRfwzCZqmEYlE0DQtWTAgFovR19fHxo0bCYVC6LrOCy+8wP333z+kZHtCJ6fTyWWXXcY3vvEN+vv72b9/P3fffTef+9znjoRa44Ysy6xatWpWRi6Hw2zXyWVX06axsiwzb/7imReN/eAHP8jf//53vva1rwFw2WWXcdddd6EoCoZh8JOf/IRzzjln0gWdaUhdDzqT8J3vfIc77rgj+b/D4eD000/niSee4I477uDyyy8HYNGiRfzoRz/ikksuSbbdsGEDp556anJs77nnHq677joWLFiAw+HgpptumlWRWDDHx2q1zrhxmghmu052qwqDCh4o6tRvXJV11ZP33nuPv//979x4443YbDa8Xi+XXHIJ//jHPwCTDB955BEqKiqmROCpRDZVT1Ijl4MHabZWPZmoTjOx6olhGMnIZarlMJMqhMxFnTJVPUnoFIxo7DjQRYHbhiyb59+xYzsfOn09RR7HzKl6cuyxx6b5bQoLC3n++efp6+tDUZRZ6cDO1bMzkatnl6tnN1k6Da5nl6pTeeUCAn2ddLf6UBV5ZtWze/fdd7PqVFEUPB4P1dXVs8qvkLPs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4ahAjuxyyCGHowI5ssshhxyOCuTILocccjgqkCO7Adx7770sWrQIu93OySefzObNm0ds/8QTT7BixQrsdjvHHnssGzduTPtcCMHtt99ORUUFDoeDs846K20LuulANjr96le/4rTTTqOwsJDCwkLOOuusIe2vvvrqtE11JEni3HPPnWo10pCNTg8++OAQeRM7wyUw28bpjDPOGKKTJEmcf/75yTZHepxefvllPvrRj1JZWYkkSfz5z38e9TubNm3ihBNOwGazsXTpUh588MEhbbJ9RodA5CAeffRRYbVaxW9+8xuxc+dOce2114qCggLR0dGRsf1rr70mFEURd911l9i1a5f4+te/LiwWi3jvvfeSbe68806Rn58v/vznP4tt27aJj33sY6KmpkaEw+EZqdOnP/1pce+994otW7aI3bt3i6uvvlrk5+eL5ubmZJurrrpKnHvuuaKtrS3509vbOy36CJG9Tg888IDweDxp8ra3t6e1mW3j1NPTk6bPjh07hKIo4oEHHki2OdLjtHHjRvG1r31N/PGPfxSA+NOf/jRi+/r6euF0OsWXv/xlsWvXLnH33XcLRVHEs88+m2yT7XXKhBzZCSHWrVsnbrzxxuT/uq6LyspK8f3vfz9j+0svvVScf/75acdOPvlkcd111wkhhDAMQ5SXl4v//u//Tn7e19cnbDabeOSRR6ZAg6HIVqfB0DRN5OXlid/+9rfJY1dddZX4+Mc/PtmijhnZ6vTAAw+I/Pz8YfubC+P04x//WOTl5YlAIJA8dqTHKRVjIbt///d/F8ccc0zascsuu0ycc845yf8nep2EEOKon8bGYjHeeecdzjrrrOQxWZY566yzeP311zN+5/XXX09rD3DOOeck2x88eJD29va0Nvn5+Zx88snD9jmZGI9OgxEKhYjH4xQVFaUd37RpE2VlZSxfvpwvfOEL9PT0TKrsw2G8OgUCAaqrq6mqquLjH/84O3fuTH42F8bp17/+NZdffjkulyvt+JEap/FgtOdpMq4T5Hx2dHd3o+s68+bNSzs+b9482tvbM36nvb19xPaJ39n0OZkYj06D8R//8R9UVlam3WDnnnsuDz30EC+88AI/+MEPeOmllzjvvPOG7Cg/FRiPTsuXL+c3v/kNTz75JL/73e8wDIP3v//9NDc3A7N/nDZv3syOHTv43Oc+l3b8SI7TeDDc8+Tz+QiHw5NyP0Ou6kkOGXDnnXfy6KOPsmnTpjSH/uWXX578+9hjj2X16tUsWbKETZs28eEPf/hIiDoi1q9fz/r165P/v//972flypX84he/4Nvf/vYRlGxy8Otf/5pjjz2WdevWpR2fbeM0XTjqLbuSkhIURaGjoyPteEdHB+Xl5Rm/U15ePmL7xO9s+pxMjEenBH74wx9y55138re//Y3Vq1eP2Hbx4sWUlJRw4MCBCcs8GiaiUwIWi4Xjjz8+Ke9sHqdgMMijjz7Kv/7rv456nukcp/FguOfJ4/HgcDgmZewhR3ZYrVZOPPFEXnjhheQxwzB44YUX0qyCVKxfvz6tPcDf//73ZPuamhrKy8vT2vh8Pt58881h+5xMjEcngLvuuotvf/vbPPvss6xdu3bU8zQ3N9PT00NFRcWkyD0SxqtTKnRd57333kvKO1vHCczUp2g0yhVXXDHqeaZznMaD0Z6nyRh7IJd6IoQZ1rbZbOLBBx8Uu3btEp///OdFQUFBMk3hX/7lX8Rtt92WbP/aa68JVVXFD3/4Q7F7927xzW9+M2PqSUFBgXjyySfF9u3bxcc//vFpT2nIRqc777xTWK1W8fvf/z4tZcHv9wshhPD7/eIrX/mKeP3118XBgwfF888/L0444QRRW1srIpHIjNTpjjvuEM8995yoq6sT77zzjrj88suF3W4XO3fuTNN7No1TAqeeeqq47LLLhhyfCePk9/vFli1bxJYtWwQgfvSjH4ktW7aIxsZGIYQQt912m/iXf/mXZPtE6slXv/pVsXv3bnHvvfdmTD0Z6TqNBTmyG8Ddd98tFi5cKKxWq1i3bp144403kp+dfvrp4qqrrkpr//jjj4tly5YJq9UqjjnmGPH000+nfW4YhvjGN74h5s2bJ2w2m/jwhz8s9u7dOx2qJJGNTtXV1QIY8vPNb35TCCFEKBQSH/nIR0RpaamwWCyiurpaXHvttVndbNOt05e+9KVk23nz5okNGzaId999N62/2TZOQgixZ88eAYi//e1vQ/qaCeP04osvZryXEnpcddVV4vTTTx/ynTVr1gir1SoWL16cljeYwEjXaSzIlXjKIYccjgoc9T67HHLI4ehAjuxyyCGHowI5ssshhxyOCuTILocccjgqkCO7HHLI4ahAjuxyyCGHowI5ssshhxyOCuTILocccjgqkCO7HHLIgKuvvppFixYdaTFymETkyC6HKcd7773HxRdfTHV1NXa7nfnz53P22Wdz9913H2nRxoxQKMS3vvUtNm3adKRFyWGcyC0Xy2FK8c9//pMzzzyThQsXctVVV1FeXk5TUxNvvPEGdXV1M7bsUDwexzAMbDYbYBbaLC0t5Zvf/Cbf+ta3jqxwOYwLueKdOUwpvvvd75Kfn89bb71FQUFB2mednZ3TKkswGBxSvnw4WCyWKZYmh+lGbhqbw5Sirq6OY445ZgjRAZSVlSX/liSJm266iYcffpjly5djt9s58cQTefnll9O+09jYyA033MDy5ctxOBwUFxdzySWX0NDQkNYusY3iSy+9xA033EBZWRkLFiwAwO/386UvfYlFixZhs9koKyvj7LPP5t13301+P9Vn19DQQGlpKQB33HFHcnvCb33rWzzwwANIksSWLVuG6Pe9730PRVFoaWkZz6XLYZKRs+xymFJUV1fz+uuvs2PHDt73vveN2Pall17iscce45ZbbsFms/Hzn/+cc889l82bNye/+9Zbb/HPf/6Tyy+/nAULFtDQ0MB9993HGWecwa5du3A6nWl93nDDDZSWlnL77bcTDAYBuP766/n973/PTTfdxKpVq+jp6eHVV19l9+7dnHDCCUPkKi0t5b777uMLX/gCF154IRdddBEAq1evpqamhhtvvJGHH36Y448/Pu17Dz/8MGeccQbz588f9/XLYRIxjnJVOeQwZvztb38TiqIIRVHE+vXrxb//+7+L5557TsRisbR2DNQ8e/vtt5PHGhsbhd1uFxdeeGHyWCgUGnKO119/XQDioYceSh574IEHBCBOPfVUoWlaWvv8/Py0bfky4aqrrhLV1dXJ/7u6utLq+6XiU5/6lKisrBS6riePvfvuuwLIWJcthyOD3DQ2hynF2Wefzeuvv87HPvYxtm3bxl133cU555zD/Pnz+ctf/pLWdv369Zx44onJ/xcuXMjHP/5xnnvuueTOWA6HI/l5PB6np6eHpUuXUlBQkDYNTeDaa69FUZS0YwUFBbz55pu0trZOio5XXnklra2tvPjii8ljDz/8MA6Hg09+8pOTco4cJo4c2eUw5TjppJP44x//iNfrZfPmzfy///f/8Pv9XHzxxezatSvZrra2dsh3ly1bRigUoqurC4BwOMztt99OVVUVNpuNkpISSktL6evro7+/f8j3a2pqhhy766672LFjB1VVVaxbt45vfetb1NfXj1u/s88+m4qKCh5++GHA3B/hkUce4eMf/zh5eXnj7jeHyUWO7HKYNlitVk466SS+973vcd999xGPx3niiSey6uPmm2/mu9/9LpdeeimPP/44f/vb3/j73/9OcXExhmEMaZ9qCSZw6aWXUl9fz913301lZSX//d//zTHHHMMzzzwzLr0UReHTn/40f/jDH4hEIrz44ou0traOaTOcHKYPuQBFDkcEid3L2traksf2798/pN2+fftwOp3JaOjvf/97rrrqKv7nf/4n2SYSidDX15fV+SsqKrjhhhu44YYb6Ozs5IQTTuC73/0u5513Xsb2kiSN2N+VV17J//zP//DUU0/xzDPPUFpayjnnnJOVTDlMLXKWXQ5TihdffBGRIW9948aNACxfvjx57PXXX0/zuzU1NfHkk0/ykY98JOl3UxRlSH933333mHe713V9yHS3rKyMyspKotHosN9LRHmHI9XVq1ezevVq/r//7//jD3/4A5dffjmqmrMlZhJyo5HDlOLmm28mFApx4YUXsmLFCmKxGP/85z957LHHWLRoEddcc02y7fve9z7OOeectNQTMHPbErjgggv43//9X/Lz81m1ahWvv/46zz//PMXFxWOSx+/3s2DBAi6++GKOO+443G43zz//PG+99VaatTgYDoeDVatW8dhjj7Fs2TKKiop43/vel5ZOc+WVV/KVr3wFIDeFnYk40uHgHOY2nnnmGfHZz35WrFixQrjdbmG1WsXSpUvFzTffLDo6OpLtAHHjjTeK3/3ud6K2tlbYbDZx/PHHixdffDGtP6/XK6655hpRUlIi3G63OOecc8SePXtEdXV12paDidSTt956K+370WhUfPWrXxXHHXecyMvLEy6XSxx33HHi5z//eVq7waknQgjxz3/+U5x44onCarVmTENpa2sTiqKIZcuWjft65TB1yK2NzWFGQJIkbrzxRu65554jLcq40d3dTUVFBbfffjvf+MY3jrQ4OQxCzmeXQw6ThAcffBBd1/mXf/mXIy1KDhmQ89nlkMME8Y9//INdu3bx3e9+l0984hO5OngzFDmyyyGHCeK//uu/+Oc//8kHPvCBWVWj72hDzmeXQw45HBXI+exyyCGHowI5ssshhxyOCuTILocccjgqkCO7HHLI4ahAjuxyyCGHowI5ssshhxyOCuTILocccjgqkCO7HHLI4ajA/w9AiTFODEH2rwAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Varying depths for different sparsities and fixed width"
      ],
      "metadata": {
        "id": "D06ldcQNhEXG"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Without normalization"
      ],
      "metadata": {
        "id": "ci09fykLYVwk"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "width = 256\n",
        "depths = np.arange(10, 100, 20)\n",
        "sparsities = [0, .5, .95, .98, .985, .99]\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for sparsity in tqdm(sparsities):\n",
        "  for depth in depths:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=False)), depth, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "V_1_ihjqhMXN",
        "outputId": "5dd65e1d-ce72-473a-cce1-69cccb5d7b7a"
      },
      "execution_count": 40,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 6/6 [03:22<00:00, 33.78s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_depth_sparsity_nonorm.csv')\n",
        "files.download('df_depth_sparsity_nonorm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "SBdJX24jYbPV",
        "outputId": "39030a3b-cab9-46d3-8d16-c7ed9d5504b5"
      },
      "execution_count": 44,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_7291fa2e-a1c6-4903-b416-3e22b60e40ef\", \"df_depth_sparsity_nonorm.csv\", 8524)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol = pd.read_csv('df_depth_sparsity_nonorm.csv')"
      ],
      "metadata": {
        "id": "0Gxf75EBZzH_"
      },
      "execution_count": 47,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3,2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='depth', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "ax.set(yscale='log')\n",
        "ax.set_xlabel('Depth', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Sparsity', loc='lower right', fontsize=9, ncol=2)\n",
        "plt.savefig('J_versus_depth_sparsity_nonorm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_depth_sparsity_nonorm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 294
        },
        "id": "_80GTqU4hofg",
        "outputId": "029603bd-9436-4432-f857-5357cd5b5bd7"
      },
      "execution_count": 49,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-49-9f502b717dfe>:6: UserWarning: The palette list has more values (10) than needed (6), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='depth', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_b9c39f2e-cfb0-42f0-8a00-f7b495a72d4a\", \"J_versus_depth_sparsity_nonorm.pdf\", 15483)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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9/Jd+BkzZniUZbVasXLlSkRERECpVOLWW29FbW1tQLUL9A7BKAoMWu655x4AwPbt2wEAZ86cwaRJk3Du3DmsWrUK//3vf6FUKjF//nxs3Lix3edXrFiBc+fO4bnnnsO9996Lzz77DPPnz+fjGq9duxbx8fEYMWIEPvnkE3zyySd4+umnPcp46KGHkJOTg2effRYPPPAANm/ejBUrVgRYuUBvELrPAoOW+Ph4aLVaFBYWAgAeeeQRJCYm4ujRo5BKpQCABx98EFOnTsWTTz6JW2+91ePzEokEO3fuhFgsBgAkJSXhiSeewObNmzFv3jzMnz8ff/vb36DT6XD33Xd7rUN4eDi2b98OiqIAOGO1vP7662huboZWqw2UdIFeILQUBQY1KpUKBoMBDQ0N2LVrF373u9/BYDCgrq4OdXV1qK+vx+zZs1FQUIDy8nKPz9533328QQSABx54ACKRCD/++GO3z3/ffffxBhEApk2bBpZlUVxc3HtxAgFBaCkKDGqMRiMiIyNx4cIFEEKwevVqrF692mvempoaxMXF8e/T0tI8jqtUKsTExODSpUvdPn9iYqLH+9DQUADwGJsUGFgIRlFg0FJWVobm5mYMHTqUD6b0+OOPY/bs2V7zDx061O91YBjGa7rg8H7gIhhFgUHLJ598AgCYPXs2UlNTAQBisRizZs3q1ucLCgpwzTXX8O+NRiMqKysxd+5cPs29aywwOBDGFAUGJbt27cI//vEPpKSk4K677kJkZCRmzJiBd999F5WVle3ye1sm895778Fut/Pv33nnHTgcDsyZM4dPUyqV7eJPCwQ3QktRIOjZunUr8vLy4HA4UF1djV27duHnn39GUlISvv/+e8hkMgDAW2+9halTpyIjIwPLli1DamoqqqurcejQIZSVlSEnJ8ejXJvNhpkzZ+J3v/sd8vPz8fbbb2Pq1KmYN28en2fcuHF455138MILL2Do0KGIjIzEtdde26f6BfyLYBQFgp5nnnkGgHMJTVhYGDIyMrB27VosWbIEarWaz5eeno5jx47h+eefx/r161FfX4/IyEiMHTuWL8OdN998E5999hmeeeYZ2O12/P73v8frr7/u0WV+5plnUFxcjH/9618wGAyYPn26YBSDHCHEqYBAG9avX48lS5bg6NGjHtsHBX4bCGOKAgICAm4IRlFAQEDADcEoCggICLghjCkKCAgIuCG0FAUEBATcEIyigICAgBuCURQQEBBwQzCKAgICAm4IRlFAQEDADcEoCggICLghGEUBAQEBNwSjKCAgIODG/w+MXDXuN36BQwAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## With normalization"
      ],
      "metadata": {
        "id": "geMQTihPZBuO"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "width = 256\n",
        "depths = np.arange(10, 100, 20)\n",
        "sparsities = [0, .5, .95, .98, .985, .99]\n",
        "\n",
        "evol = pd.DataFrame(columns=['jac_norm', 'depth', 'sparsity'])\n",
        "\n",
        "runs = 10\n",
        "\n",
        "for sparsity in tqdm(sparsities):\n",
        "  for depth in depths:\n",
        "    for rn in range(runs):\n",
        "      evol.loc[len(evol.index)] = [float(jac_prunned(width, depth, sparsity, rn, normalized=True)), depth, sparsity]"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "8EkNKMvmOaF8",
        "outputId": "f511bd26-cfcf-4318-a4ce-69e1a1e3407a"
      },
      "execution_count": 53,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "100%|██████████| 6/6 [02:58<00:00, 29.78s/it]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "evol.to_csv('df_depth_sparsity_norm.csv')\n",
        "files.download('df_depth_sparsity_norm.csv')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "Mi6abTghZqdo",
        "outputId": "920f28d2-2e6b-470c-ff43-331fcc9b298c"
      },
      "execution_count": 55,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_4ef441a3-9bc3-48cf-9439-f2f5887b7f75\", \"df_depth_sparsity_norm.csv\", 9741)"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig = plt.figure(figsize=(3,2.25))\n",
        "\n",
        "cmap = sns.color_palette('deep') #[sns.color_palette('deep')[1], sns.color_palette('deep')[0], sns.color_palette('deep')[2]]\n",
        "edge_color = matplotlib.colors.colorConverter.to_rgba('black', alpha=.01)\n",
        "\n",
        "ax = sns.lineplot(data=evol, x='depth', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n",
        "ax.set(yscale='log')\n",
        "ax.set_xlabel('Depth', fontsize=12)\n",
        "ax.set_ylabel('Jacobian norm', fontsize=12)\n",
        "ax.grid(True, which=\"both\", ls=\"--\",c='gray', alpha=0.4) \n",
        "plt.legend(title=r'Sparsity', loc='lower left', fontsize=9, ncol=2)\n",
        "plt.savefig('J_versus_depth_sparsity_norm.pdf', bbox_inches='tight')\n",
        "files.download(\"J_versus_depth_sparsity_norm.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 292
        },
        "id": "-fdTlw5TZtjn",
        "outputId": "59515257-d0d1-4d00-eca2-be05ff5a217a"
      },
      "execution_count": 56,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-56-91d6deb7210c>:6: UserWarning: The palette list has more values (10) than needed (6), which may not be intended.\n",
            "  ax = sns.lineplot(data=evol, x='depth', y='jac_norm', hue='sparsity', linewidth=0.4, alpha=0.9, marker='D', markersize=5,palette=cmap)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_e9162d97-cacf-4ec1-b2e0-21a1bd577859\", \"J_versus_depth_sparsity_norm.pdf\", 15707)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x225 with 1 Axes>"
            ],
            "image/png": "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+XKuvPJKrr76apYtW8aSJUsGUp8tesFQdqRfeOGFVFZW8uqrr/K1r32N5cuX85WvfCXJ2dBxadH49441v+eee44TTjiBwsJCvF4vP//5z6moqEjapqysjLy8vMT32bNnc8YZZzBz5kwuvvhiHn/8cZqamlIqe3FxMeeeey5PPPEEAK+99hrhcJiLL744pf30hfg1Sq4RtjeNJYnYIuBDVyMsKJ2Iy5PGns1rk9JVmy0xD7i1sa7b7UfzuNYBKflJJ53E7373O/77v/87KQS9xdAw1N5eMOM6nnXWWdx+++188sknLFmyhF/84he92nbFihVccsklnHPOObz++uusWbOG2267LcmpIUkSXm9ytBVFUXjnnXd48803mT59On/4wx844ogjUu5j/vd//3eeffZZgsEgTz75JN/+9rcHfVZOd9eoKyFUVXsnIRSDKIQlk44EYP/OzUnp8RiBjbWV+Jo7O7MUReHoo48+fLy9FiMPEVvkezAfkEMxffr0hOMB4NNPP036/dNPP+XII82H7JNPPqG8vJzbbruNuXPnMmXKFPbu3ZuUP27LwTZJksQJJ5zAXXfdxZo1a7Db7bz00ktdlslut3cZYOOcc87B4/Hw8MMP89Zbb3HFFVekbnCK9OYatQuhrZMQikEWwvFHziHo91FdsTMp3e5wotrsNNTsx9/a3Mmm1tbWUevtPeTc3gkTJiDLMlu2bMFmszFhwoRD1jAkSWLnzp095rEYWEKh0JDMKW5oaODiiy/miiuuYNasWaSlpbF69Wp++9vf8o1vfCOR74UXXmDu3LmceOKJPP3006xatSqxqNWUKVOoqKjg2Wef5dhjj+WNN97oUsAO9iKuXLmSZcuW8dWvfpX8/HxWrlxJXV1dQlQPZvz48axcuZI9e/bg9XrJzs5GlmUURWHJkiX89Kc/ZcqUKZ2a6INFKtcosTawoiCEas43NoxYBBoDgQBJTniyB4LJM49lyxcfY7M7koKqmvOA2zrNAzYMg+3bt4/asX6HFL9TTjnFfCPF2vbx7xaHJ16vl/nz5/O73/2OnTt3Eo1GKS0t5corr+RnP/tZIt9dd93Fs88+yw9+8AOKiop45plnmD59OgCLFi3ixhtv5PrrryccDnPuuedy++23c+edd/Z47PT0dD744AMeeOABWltbKS8v53/+539YuHBhl/lvvvlmFi9e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0tLSRoyLv7W1ldLSUvbt2zdmPNBjzaaxZg+MTJuEEPh8PoqLiw85pMiq+aWILMuUlJQMdzG6JD09fcTchAPFWLNprNkDI8+mQ9X44lgODwsLi8MSS/wsLCwOSyzxGwM4HA5+8Ytf4HCMvNXM+spYs2ms2QOj3ybL4WFhYXFYYtX8LCwsDkss8bOwsDgsscTPwsLisMQSPwsLi8MSS/xGCffeey/HHnssaWlp5Ofnc/7557N169akPKFQiOuuu46cnBy8Xi8XXnghNTU1w1Ti1Pn1r3+NJEnccMMNibTRaNOBAwe49NJLycnJweVyMXPmTFavXp34XQjBHXfcQVFRES6XizPPPJPt27cPY4m7R9d1br/9diZMmIDL5WLSpEn88pe/TJo7O5rsSUJYjArOPvts8eSTT4oNGzaItWvXinPOOUeUlZWJtra2RJ5rrrlGlJaWimXLlonVq1eL4447Thx//PHDWOres2rVKjF+/Hgxa9Ys8eMf/ziRPtpsamxsFOXl5WLJkiVi5cqVYteuXeKf//yn2LFjRyLPr3/9a5GRkSFefvllsW7dOrFo0SIxYcIEEQwGh7HkXXP33XeLnJwc8frrr4vdu3eLF154QXi9XvHggw8m8owmezpiid8opba2VgDi/fffF0II0dzcLGw2m3jhhRcSeTZv3iwAsWLFiuEqZq/w+XxiypQp4p133hGnnHJKQvxGo0233HKLOPHEE7v93TAMUVhYKO67775EWnNzs3A4HOKZZ54ZiiKmxLnnniuuuOKKpLQLLrhAXHLJJUKI0WdPR6xm7yilpaUFgOzsbAA+//xzotEoZ555ZiLPtGnTKCsrY8WKFcNSxt5y3XXXce655yaVHUanTa+++ipz587l4osvJj8/n6OPPprHH3888fvu3buprq5OsikjI4P58+ePSJuOP/54li1bxrZt2wBYt24dH330EQsXLgRGnz0dsQIbjEIMw+CGG27ghBNO4KijjgKguroau91OZmZmUt6CggKqq6uHoZS949lnn+WLL77gs88+6/TbaLRp165dPPzww9x000387Gc/47PPPuNHP/oRdrudxYsXJ8pdUFCQtN1ItenWW2+ltbWVadOmoSgKuq5z9913c8kllwCMOns6YonfKOS6665jw4YNfPTRR8NdlH6xb98+fvzjH/POO+/gdDqHuzgDgmEYzJ07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\n"
          },
          "metadata": {}
        }
      ]
    }
  ]
}