{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np \n",
    "import pickle \n",
    "from include.plot_utils import *\n",
    "from pathlib import Path\n",
    "import torch\n",
    "from mpl_toolkits.axes_grid1.inset_locator import inset_axes\n",
    "import pickle\n",
    "import scipy.special as sp\n",
    "from scipy.optimize import brentq\n",
    "from numpy.polynomial.legendre import leggauss\n",
    "plt.style.use('./include/plt_style.pstyle') \n",
    "\n",
    "colors = plt.rcParams['axes.prop_cycle'].by_key()['color']\n",
    "\n",
    "\n",
    "fontsize = 10\n",
    "scatterSize = 8\n",
    "\n",
    "plt.rcParams.update({'font.size': fontsize})\n",
    "plt.rc('font', size=fontsize)          # controls default text sizes\n",
    "plt.rc('axes', titlesize=fontsize)     # fontsize of the axes title\n",
    "plt.rc('axes', labelsize=fontsize)     # fontsize of the x and y labels\n",
    "plt.rc('xtick', labelsize=fontsize)    # fontsize of the tick labels\n",
    "plt.rc('ytick', labelsize=fontsize)    # fontsize of the tick labels\n",
    "plt.rc('legend', fontsize=fontsize)    # legend fontsize\n",
    "plt.rc('figure', titlesize=fontsize)   # fontsize of the figure title\n",
    "\n",
    "figsize = (6.6, 2) #(15,3)\n",
    "figsizeTwoR = (6.6, 4) #(15,6)\n",
    "figsizeM = (6.6, 1.5)\n",
    "\n",
    "plotLabelsABC = [\"(a)\", \"(b)\",\"(c)\",\"(d)\",\"(e)\",\"(f)\",\"(g)\"]\n",
    "colors = ['#0C5DA5', '#00B945', '#FF9500', '#FF2C00', '#845B97', '#474747', '#9e9e9e']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_folder = Path(\"../data/\")\n",
    "figures_folder = Path(\"../figures/\")\n",
    "\n",
    "\n",
    "# definition of the Marchenko Pastur Curve\n",
    "def MP(x :np.array , n , m , sigma):\n",
    "    largerVal = np.max([n,m])\n",
    "    smallerVal = np.min([n,m])\n",
    "    sigmaT = sigma * np.sqrt(largerVal)\n",
    "    max =  sigmaT*(1+ np.sqrt(smallerVal/largerVal))\n",
    "    min = sigmaT *(1- np.sqrt(smallerVal/largerVal))\n",
    "\n",
    "    x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
    "    x_err[x_err < 0] = 0.0\n",
    "    x_err[np.imag(x_err) != 0] = 0.0\n",
    "    x_err[np.isnan(x_err)] = 0.0\n",
    "    return x_err\n",
    "\n",
    "\n",
    "def compute_mp_normalization(gamma, zs, ws):\n",
    "    lam_minus = (1 - np.sqrt(gamma))**2\n",
    "    lam_plus  = (1 + np.sqrt(gamma))**2\n",
    "    a, b = lam_minus, lam_plus\n",
    "    ts = 0.5 * (b - a) * zs + 0.5 * (b + a)\n",
    "    fs = np.sqrt((lam_plus - ts) * (ts - lam_minus)) / (2 * np.pi * gamma * ts)\n",
    "    return 0.5 * (b - a) * (ws * fs).sum()\n",
    "\n",
    "def mp_cdf_gauss(x, gamma, zs, ws, Z):\n",
    "    lam_minus = (1 - np.sqrt(gamma))**2\n",
    "    lam_plus  = (1 + np.sqrt(gamma))**2\n",
    "    if x <= lam_minus:\n",
    "        return 0.0\n",
    "    if x >= lam_plus:\n",
    "        return 1.0\n",
    "    a, b = lam_minus, x\n",
    "    ts = 0.5 * (b - a) * zs + 0.5 * (b + a)\n",
    "    fs = np.sqrt((lam_plus - ts) * (ts - lam_minus)) / (2 * np.pi * gamma * ts)\n",
    "    integral = 0.5 * (b - a) * (ws * fs).sum()\n",
    "    return integral / Z\n",
    "\n",
    "def find_mp_median(gamma, n=128):\n",
    "    # Gauss-Legendre nodes & weights\n",
    "    zs, ws = leggauss(n)\n",
    "    # normalization constant ∫_{λ_minus}^{λ_plus} f(t) dt = Z\n",
    "    Z = compute_mp_normalization(gamma, zs, ws)\n",
    "    lam_minus = (1 - np.sqrt(gamma))**2\n",
    "    lam_plus  = (1 + np.sqrt(gamma))**2\n",
    "    eps = 1e-6 * (lam_plus - lam_minus)\n",
    "    a = lam_minus + eps\n",
    "    b = lam_plus  - eps\n",
    "    # Find m(γ) s.t. CDF(m) = 0.5\n",
    "    return brentq(lambda x: mp_cdf_gauss(x, gamma, zs, ws, Z) - 0.5, a, b)\n",
    "\n",
    "def estimate_sigma_med(W, n=128, discard_largest=0.0):\n",
    "    \"\"\"\n",
    "    Estimate σ_med via median-of-squares MP matching using Gauss-Legendre quadrature.\n",
    "    \n",
    "    Gavish, M. and Donoho, D. L.(2014) The Optimal Hard Threshold\n",
    " For Singular Values Is 4 3. IEEE Trans. Inform. Theory., 60, no.8,\n",
    " 50405053.\n",
    "    AND\n",
    "    https://arxiv.org/pdf/1801.10015.pdf\n",
    "\n",
    "    \"\"\" \n",
    "    l , m = W.shape[0], W.shape[1]\n",
    "    scaler = 1/ np.sqrt(np.max([l,m]))\n",
    "\n",
    "    gamma = np.min(W.shape) / np.max(W.shape)\n",
    "    # empirical median of squared singular values\n",
    "    S = np.linalg.svd(W, compute_uv=False)\n",
    "    n0 = int(discard_largest * len(S))\n",
    "    med_s2 = np.median(S[n0:]**2)\n",
    "    # get theoretical median m(γ)\n",
    "    m_gamma = find_mp_median(gamma, n=n)\n",
    "    # invert to get σ\n",
    "    return np.sqrt(med_s2 / m_gamma)*scaler\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Intro Plot\n",
    "1-2: Explaining that there are not finite size fluctuations and that square and non-square have different properties\n",
    "\n",
    "3-4: Focus on outliers to the right in the one case, to both sides in the other\n",
    "They are not due to regularisation as regularisation shifts the whole spectrum"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.02718022329694776\n",
      "0.02116856246292178\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjAAAAB4CAYAAADsZchHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFfUlEQVR4nO2dd1hT1xvHvzfsDaIILoYKqDipWnCgOKhVqQW1goITVFSqrbYuqrZYR6s/96oWVCrFjatuEBVUFAdOlOFEURARgUCS8/uDkhIIkECSm4TzeZ48yr3nnvPe3DfvPeM978sQQggoFAqFQqFQVAgO2wJQKBQKhUKhSAvtwFAoFAqFQlE5aAeGQqFQKBSKykE7MFJw7do1tkVgjcePH+Pt27dsi6H0fPr0Cffv32dbDJnA5/Px+vVrtsVQeajdqH92Q53sgCKora1R+Q7MsWPH0KJFCxgbGyMgIAC+vr4YMGAA4uPjZdYGn8/H3Llz0b17d5nVWRVZWVmYMmUK+vbtC39/f7i6uoJhGNjY2Mi97arYvn072rRpg3v37rEmgzz5559/0Lx5c5iZmWHy5MkYPXo0Bg8ejOvXr0tVz8uXL9GvXz+sW7dO7PmoqCh4enpKVWdCQgLc3NzAMAwWLVqEN2/e4OXLl/Dy8oKJiQlWrFgh0xdEaGgoGIYBwzDQ0tJCUVGRzOpWJqjdkD+qZjeU2Q4cOHAANjY2MDQ0xJYtW1C29+bGjRvo378/OnTogPPnz0tVZ1paGkaOHAmGYeDl5YVJkyahb9++2Lx5M/h8vlR1AUBBQQHs7OyQkZEhUXmZ2BqiBowePZq4ubkJ/962bRvR1NQk9+/fl1kb6enpRN5f15s3b4itrS2ZNWsW4fP5wuPbt28nNjY2dar706dPJDIystbXN2/enMTExNRJBmWmog5t2bKFaGtrS6RD27dvF/5/0aJFZPLkyWLLPX78mOzfv19q2f744w8CgJSUlBBCCCksLCQeHh7k5s2bUtdVHcXFxWT8+PEkMTGRJCYmkkePHsm0fmWD2o2aqW92Q5ntwJgxY0iPHj0qHT969ChZv3691PURQsiZM2cIAJKenk4IIeTVq1fEzMyMhISE1Kq+tWvXkoKCghrLycrWqPwMDABoamqK/P3NN9+Ax+Ph9OnTLElUO77//nvw+XwsX74cHM5/j2bixIkYOnRoreslhGDatGl4+PBhresoL486Ik6HiouLcerUqWqvCw8PR0REhERttGrVCt7e3rWWTVNTE1wuFxMmTEBoaCg6deokdV3VsX//fhQWFoLL5cLZ2Rn29vYyrV/ZoHajeuqj3VBmO6ChoVFJPgAwNDSEoaGh1PUBle/XysoKvXv3xpEjR2pVX3BwMPT09GosJytbo1raJSHv378HAOjo6AiPbd68GcuWLcPSpUsxY8YMAMCjR48wfPhw/Pzzz5gwYQIsLS0REhIivObhw4eYOHEi1q5diw0bNoi0kZycjPnz52PNmjUYOnQoYmJiAAAxMTHC6cPRo0fDzs4OixYtQlxcHDw9PdGkSROxBjI/Px9RUVEYMWIEtLW1K50PDg4GAKGh2rJlC7799ltMnToVhYWFyMnJwezZs+Hr64vQ0FC0bNkSHh4e4PF4SE1Nxe3btxEXF4c1a9bg6tWrGDNmDDZt2oTevXvj66+/BlA6TVn2HQ0bNgxPnz6ty2NQaQoKCgAABgYGmDRpEhiGES4vPHr0CO3bt8fTp09x4sQJZGRkIDQ0FNnZ2QAAHo+HqVOnwtbWFl9++aVwOvb27dtYuXKlsI2DBw9i4cKFWL9+PXx9fVFSUlKtTFwuF35+fpg+fTo+++yzSue3b9+OBQsWoE+fPliyZAkAICwsDAzD4NdffwUA5OTkwMXFBVeuXKl0/aNHj3Dz5k307NkTnTp1Qnp6urRfm0pD7Qa1GxVRRjtQFQKBAKtWrYKjoyP27t2L1q1bo0WLFjh69KjU92xqaorTp09j2LBhiIiIgJOTE2bNmgUA2LJlC9auXYv58+fDx8dHeL8ZGRlYvnw57t69W2MbMrM1tZq3UTLGjh0rnPbLy8sjI0eOJM2aNSPv3r0jhBBSUFBAOBwOef36NSGEkMaNG5M7d+4QQgj55ptvyJdffkk+ffpEbt++TbS0tEhhYSHh8XjEycmJPH36lBBCyKVLl4RTwXl5eaR169YkLy+PEELInTt3iL6+vnAaztnZmUyePJnweDxy//59oqWlRQ4fPkwIIWTjxo1kwIABle4hMTGRACAbNmyo9l5XrFhBFi1aJPx7+PDhZMqUKYQQQjZv3kxsbGxIWloaKSoqIlZWVuTs2bPC76jsOh6PRzp16kSGDx9Onj9/TqKjo8mVK1dI3759hfVu2LCBtG/fXrhsYW1tLdOp4OLiYpKfn1/lMkh2drbM2pKE8jrE5XLJuHHjiI2NDcnLyyM5OTnEwMCAxMbGEkIIuX//Plm1ahUhhJCwsDCRKedFixaR9u3bk1evXpGioiJiaWlJzp8/T7KyssicOXOItbW1sKylpSW5cuUKIYSQ7t27kyNHjoiVLSwsjAAgX3zxBXF1dRU+k/JcuXKF/PLLL4QQQl68eEEAkMuXLxNCCHFxcSGLFy8mhBDC5/NJYGBgtd/FtWvXiL29PencuXMN35pqQ+2G6tkNQv6zHeXJyckRLkPUxXYosx0oL1t5YmJiSFhYGCGk9LcLgJw9e5bw+Xzy/fffExMTE/L+/XuxdcbExIgsIZ04cYJoamqSI0eOkKKiItKwYUMya9YskpKSQs6fP0+ioqLI2LFjhdfPnj2bfPHFF4QQQi5cuEB0dXWlet51tTVyn4EpKSnBp0+fxJ7LycmRWTtpaWnw9fVFkyZN4OjoiNu3b8Pc3BwAoKenh4SEBDRu3BiXL18Gn88Xtq2rq4uuXbtCX18f7du3R0lJCbKysnDq1CkwDIMWLVoAAJo2bSps6+jRozAzM4ORkREAoH379mjXrh3++usvAKVTep9//jk0NDTg4OCAkpISdOzYEQDg6Ogo1smJx+MBqHnKdfv27SJOgePHj0dYWBgEAgF0dXVhbW0NW1tb6OjooHXr1nj58mWlOjQ0NGBiYgJXV1c0a9YMnp6e2LFjB7p27SosM27cONy9exdXr16t/ouvBVlZWVi+fDlGjhyJhQsXii1z5MgRqZ3n6kpKSgoCAwPh7e0NPT09XLp0CUZGRjAzM4O/vz82btwIoHTEOXLkyCrr6dChA6ysrITP4MWLF2jUqBG+/PJLkXLHjx+Hs7Mzbt26hQ8fPtT4e+jevTvi4+Mxffr0SufCwsKEI6Ddu3fDw8MDmZmZAICZM2di27Zt4PF4uHTpEnr37l1tO127dkV0dDTu3LmDBw8eVFtWXlC7Qe2GOLKysrBixQqR2abbt2/js88+w549ewDU3XYoux0QB8MwAIBGjRoBAPr16wcOh4OFCxfi48ePSEhIqPb6hQsXwsfHB9u2bcORI0cwdOhQ6OjowMDAAL169ULr1q3Rt29fsXp08uRJvHz5Er1790bjxo2lkruutkauHRhxylaey5cv17i2KCl2dnbYunUrmjZtiuvXr8PU1FTkPIfDwbx589C4cWMYGBgIvbjLU6YEAoEADx48gL6+vti2Xrx4IZxaLMPGxgavXr2qVLaiYeFwOCguLq5UrmXLlmAYBk+ePKn2Piu2bWNjAy6XK5zGq3g/AoGgyrrK7ldcvQYGBmjYsKHYe6oLJSUlmDJlCmbNmoXhw4dXWW7cuHEIDw9HVlaWTNuvDnt7e2zbtg1Hjx7Fpk2bRF4+3377LaKjo/Hq1StkZmaiWbNmEtXJ4XCq9Og3NjbGggULQAhB48aNxepkeRYvXoyff/4ZW7duxf/+9z+Rc0+fPsXw4cMxd+5czJ07FydPnhSus3t7e0NTUxOHDh3CiRMn8NVXX9Uot6OjIxwcHPDhwweJ7lOW1GQ3Hjx4gL///lsmbVG7oRp2A/jPdsycORNaWlrC4x07dkSvXr2Ef9fVdiirHdDR0RH7XPh8vsj3UR5TU1M0atQIhYWFGDFihNBfZsSIESLlQkNDERkZiUOHDmHQoEEi56p73mW73OryvOtia+TWgalK2cozdOhQxMfHy2yUZ2RkhIMHD+LChQtYvHix8PiLFy/g6emJkJAQtGrVSqK6DA0NkZqaKlbpbGxs8PTpUxGDwuVyYWdnV2vZGzVqhH79+uHQoUNi10DL5LCxscHjx49F2jUyMhL2vGtLxXrL6q7LPYlj+fLlGDBgAAwNDUV+GOKYNm0avv32W5m2X1scHBzQv39/zJkzB23btq1zfYWFhejTpw+CgoLQuXNnia8LCQnBpEmTMHv2bBw7dkx43NzcHLGxsSJlk5KSAJSOnKdPn47169eDy+VK5fAn6e9FVkhiN3r06IHc3Fypt41WBbUbtUdRdgMQtR01IS/bwaYdsLa2FtvhfP78ebUdqfz8fLRp0wb79u1Dfn4+8vPzsW/fvlrJK06PAMDW1rZW9ZWnNrZGbh0YSZVt5syZCAoKqlNbxcXFwh9q27ZtsWPHDoSGhiI6OhoAcPXqVXz8+BE8Hg8ZGRl49+4dPnz4AB6PJ9KjLW90Bg4ciA8fPmDLli0AgNTUVAClPc2hQ4fC1NRUqARcLhf37t2Dv78/AIjtQZcdq26UvWnTJnz8+BFBQUFCxQBK4wrMmTMHPB4PQUFBCA8PF8odExMjXFKo2Dsvfz8GBgbIzs5GYWEhPn78CEKIiCyTJ09GTEyM0AEvKSkJTk5OcHZ2Flt3bRAIBNi6dSu++OIL4TEejwc/Pz8YGxujX79+wmUPAGjTpg3i4+Px5s2bOrddEzweTzgdXxXBwcGIiooSmTkq+16B0pkDgUAg8l0JBALh91z+3P379/Hy5Uvw+XxkZ2cjLS1NqJMVKXvhlZ3btGkTXF1d4ePjI+ykeHp6Yt26dYiKisKbN2+wfv16kfgwkyZNwvXr19GjRw+x95abm4uVK1cKrzl79izc3NzQsGHDar8TWSOp3Zg4cSJCQkLEzkpICrUbqmE3yuqpaDt++eUXhISEYPXq1bhz545I+draDmW2AyNHjsSTJ09EBi5v3rxBdHQ0XFxcRMqWLb/GxsaiR48eaNOmTZX3W/7filR83kFBQYiKikJ+fj6AUj3y8fERaydiY2MrObEDMrY1tfKcqQE+n0+aNm1K0tLSCCGle8unTp1KduzYQby8vEhSUpJIeVdXV3L9+vVatfXPP/+Qpk2bEhMTE7Jz507h8W+//ZYYGBiQtWvXkjdv3pA2bdoQa2trsnLlSuLr60u6dOlCYmNjiYODA3F3dyfPnj0j27ZtIwDIihUrCCGE/P3338TGxoY4OzuTZcuWEVdXV6Gz1P3798nQoUPJ0qVLSXBwMLlw4QIhpNQpycLCgowdO5ZkZWWRv//+mwAgP//8M3n79i2ZNm0a0dPTI2fOnBF7P+np6cTPz484OTkRLy8vMnHiRLJo0SLy8eNH4Xf7888/kwkTJpDly5eT2bNnEy6XS3Jzc4m3tzexsrIiiYmJ5Nq1a8TU1JSMGjWKfPjwgZw5c4aYm5uT77//nly4cIFYWFiQ/v37k7t37wrbPnz4MPHy8iLLli0j06ZNI8+fPyeEEBIZGUk0NDRIcHAwefv2ba2eEyGE3Lx5k+jq6gr/DgsLI40bNyYpKSnk3bt3xNnZmXh6eopcM2DAALJ169ZatykJp06dItbW1sTIyIiEh4eT4uJiseV4PJ7QYa2M169fk+bNmxMvLy/y4sUL0rNnT9KyZUty584dEh8fT8zNzcnw4cPJs2fPSFBQENHS0iLR0dGksLCQuLq6EgsLC/LDDz+QH3/8UXhdea5evUrc3NwIAPLTTz+Rd+/ekaysLDJlyhQCgJibm5MdO3YQgUBA5s2bRxo2bEiaNm1KNm3aVEn+oUOHVhmj4fXr16RDhw7E2tqaLFmyhKxbt47weLxafqO1o6LdIKTUKXT58uXE39+fLFy4UKS8r69vreJpEELthirZDUIq246IiAgSEBAg/Lt///4iTsqESG87lNkOlHHmzBni4uJC+vXrR4YNG0b8/PxIamqq8HxZ3KGQkBASEhJC/Pz8SGZmpti6UlNTyejRowkAMn36dPL48WOR84cPHyba2trE19dX5De5detW4uPjQ5YvX05mzJhBcnNzheesra2FTs6rVq0iXl5eldqVpa2RSwemorLNnTtXxOO94k0FBASQefPmyUMUihIRHR1NGjduLPy7ouf+3r17CYfDIVwuV3jM29ub/Pjjj4oUs0piYmJIeHg422LUiry8PDJjxgy2xaiWinZj06ZNwp1VmZmZRFtbm7x69Up4funSpcTHx0fhclIUT0Xb0bVrV3LgwAHh3+V3S5UhL9uhzHZAEYETq6NFixZVdr7kQeWoODLg2bNnMDExEf49Y8YMCAQC5OTkIDk5uZKXtbGxMdLS0uQhCkWJ4HK50NDQqPJ827ZtIRAI8PHjR+FOEF1dXeTl5SlKRLGEh4cDAPbt24f9+/ezKou0xMXF4datW0hKShLGBFFWKtqN9evXC3eWWFpaIisrS+Q8tRv1h4q2ozpn6TJkbTtUyQ4QQmr0MZQV2dnZePDgAXr27AltbW20bt1aIe0CcvKBqahsFhYW2LlzJ/755x906tSp0nquMrykKPKnWbNm1XqaFxcXo2HDhsLOCwDk5eWJ7AJgg3/++Qfz58/HzJkzJYoyqUzcunULixcvhqOjI7p06cK2ONVS0W6kpqaKGOHynReA2o36REXbYWhoiEePHlV7jaxth7LbgeLiYmEna/PmzQrbQZiWloYxY8Zg3rx5WLVqFXR1dRXSLgDIZQamorL98MMPMDExwejRo4VfcHmU4SVFkT8dOnQAwzDIzs4WdlLKO7qdOnUKc+bMEbnm9evXrL94o6KiWG2/LgQHByv9zEsZFe1Go0aNEBsbK4yFwuPx8OrVK2GMFWo36g8VbceQIUOwadMm+Pv7w8TEBBkZGTAwMACPxxOGx5e17VB2O6CtrY3FixeL7KRTBF27dpU4gaOskcsMTHllA4AzZ86Az+dDIBDgxo0blbysleElRZE/BgYG8Pb2Fobidnd3h6GhIYKCgvDTTz+hqKgIs2fPFpYvLCxEVlYWBg4cyJbIFAVS0W54e3tj8eLFOHDgAB4/foxffvkFFhYWwvLUbtQfKtqOFStWoF27dmjXrh38/PyE8XDKdkNR21FPkJdzzdixY4UhkX/77TdiYGBAvvjiC3Lw4EFiamoqDMFMCCGtWrUiOTk58hKFokSkp6eL9UwXx5o1a0hUVJScJaIoE+XtRl5eHvHx8SHGxsakW7duIjtfCCGkV69e5N69e2yISWEBajsoFWEIqSH8Zy3JyMjA999/jwMHDlRbLjo6Go8ePcIPP/wgDzEoSsi+fftQWFgojH8hjrt37+L48eP48ccfFSgZhW0ktRu3bt3C9u3bxcaZoKgv1HZQyiO3DgxQs7K9fPkSGzZswK+//qowj2mKchAfH4+2bdtWCt1exrlz59CvXz/FCkVRCmqyG3l5eViyZAmWLl2qUIdBinJAbQelDLl2YIDqle38+fNwd3ev9vp3797h1KlTsLGxUUrPb8p/FBYWIiMjAx4eHgqJ4Ep1Q3WQVjeqsxtxcXFwcXGpMtUAQHVDlaB2g1IVNeoGm+tXkhAREUEA0I8KfSIiIqhu0A/VDfqhukE/ctUNuWyjliVl2S4jIiKqzOdQHTNnzsSaNWsUdl19bvPBgwcYM2aM8JnJG6obqtOmquiGtPdcm++o4jV8Ph+EEOH2X2WQSZHl2dKNzp07Y/jw4SL5lcQhzb1WLFtSUoKsrCzo6emhQYMGMqtX0WXZaP/kyZPYv38/bt68WbVuKKTLWwdu3LhBAJAbN27U6vo9e/Yo9Lq6XDt06FCFtynL+6zrs6qJgoICkbwbVDfk26Yq6UZFatuetPdcm+9o9+7dZO/evSQ/P58QQsiIESMIAKKnp0c6d+5MJk+eTBITE2vdRm10Rd73XV15ZdcNae61rGx2djYJCgoiBgYGwlkEX1/fOtcrCdI8f0nrlZesNZWt6VmpTAfm5MmThBBCDEZuJfrD/kcMfMLYFUwO1OUlpQzIyxDx+XwSFhZGmjVrRmJiYiq1p/dlKDH0+0umbSobVDeUuz1JiY6OJtbW1qV66/ETMfT7i+h5LCI6roFE23kM0WzVhzBGjcmff/5JCCHk2bNn5MOHD1K1oWq6oo668ffffxNTU1OyePFicvr0abJ3715y8eJFQkhpEsWKiRNliao9/+qo6Vkp/RJSGefOnYOHhwdKMuJRfG0nAMDk+LewtLTE4MGDsXr1avD5fMTHx6Nz584wNDRkWWLp8fHxYVsEpeTdu3fo27cvXrx4wbYorEF1Q7UxHLMbxYm7UJJyFhpNOkJv8GRoNLAGAGhY2EPDwl5YlhCCGecIgmP2oOjSJvAzk6HdaSQKLm8Fh1Nz7FGqK+xB/s1B9M0332DAgAGVlo0A4Pvvv0dcXBxOnDiB7t27y1yG+vT85RKJVx6su1IEI/890GzeFbr95kKnx1SEhIRg8ODBwvWxZ8+eoXfv3jAyNoZGAxtoOfRHZGSkSNRfZaY+KZ40WFhYwNramm0xWIXqhmrDe3oFJY9joNN9AnTd5wg7L+JgGAbMvx0V7c7fQMOqPbhXtmPgwIF4+fJljW1RXWGPWbNm4eeffwYAsZ0XAPjzzz/Rpk0bDBo0CHfu3JG5DPXp+avMDAyjqQ0A4OibgaNvBgBYcgcAmgDvgAX+e0AEfOgNWQbBuyfgv30C/usHGD1xGgJOCMAwDFb3+oRevXrB0dGRvRuhyA0j/z3C/3/c5cuiJBRlYebMmZg6dSrrRl3Ltgc0GrYGx8ii5sLl4BiYQ7dnEHgte+PB/Z1wdnbG48ePYWRkJCdJFUtkZCQ2b97Mthgy4d69e1i3bh1Wr15dbTkzMzMcP34cffv2xZAhQ5CUlKSQ7ePqiMp0YCSB4WhAw6wFNMxaQKt1aXwZUlIIhmFASooQOG0mUFKALl26wNfXF76+vrCysmJXaEqd4V6PAKOtDwDQtHGBlq0ryxJRgNKXU2RkJAAgNzeXFRnWrFnDar6kqKgo5OXlgRB9qTsv5dG0csKdv+8gMTERRkZGwqUKVcfHxwcODg5wdnZmW5Q68+uvv6JZs2YICgqqsayJiQmio6PRo0cPXL9+vcadUBTxqEwHhpscDVJSJPXLidHS+/dfXRiM2Aj+i1uwafgc8+fPR2hoKDIzM2k0TxnA5khK57Mx0DC3ZaVtStX4+PgIZz6SkpLU4iUlDS9fvsQov/HQbNYFuj1rfqnVhM2sU6X/2bMHk8wTYW5ujoULF9a53vqKLGfnMjMzERUVhdWrV0NbW1t4vGxWWNyMcPPmzZGSkkLfP1UgyTtFZXxgdLuNq/PImtHQhqZ1N5w28IbWsA0o+mwqGgUehKHPDmhatkV0dDSIfAMTqy0+Pj61jhkiCwQFORAUvKfPr55CCMGrV6/YFkOE+fPng+FoQafbWJnXbW5ujpCQEKG/RUWM/PdU+lTF69evMWHCBPz+++8AgISEBPj6+krkb1PGd999J9P6FMGaNWtktrQYExMDLS0t+Pn5SfSdl6Grq4tPnz5hzpw5ePbsmUxkUSQPHz7Exo0b5VK3JO8UlenAEMKXaX2MjgE0rZxK6+bmAwCGDRuGLl264PDhw/RFqEIQAQ/cKztQcGA6PkVOQMGRH6Fl6wr9LxaxLRqlFqSnp2PKlCnYtm0b/P398fTpU7HlIiIiSh1eGQYcDgdPnjxRsKRVk5SUhF27dkG7kzcYbQOZ178ixQ7anUZi0aJFWLVqVZ3qsrS0xOjRo3HhwgUAgLW1NebPn4+mTZtKdH1qaipu3rwps/pUEV9fXzx//hxmZmZiz1fXqeHxeIiMjMSsWbPkJt+BAwfAMAzu3bsncvyzzz5D3759MX78eDg7O2PdunUYN24cLl26JFJuyZIlCAoKQmBgIOzs7PDLL7+gbdu2aN68OdavXy83uWtC6TowVY6kivLl1ibHsBH0Bi5EbGwszMzM8PXXX0u0jklRHAKBoMpz5NM7aHceBd0+s6DdaSQ0GjtCkP9W2DE9cOAApk6dipiYGNoxhXxHTXVFIBDA09MTI0eORGBgIPz8/DBq1CixZWNjY5GYmIjExEQkJyejd+/eCpa2anbv3o1WrVpBs1VfubWh3f4raDl5Yvbs2dAbML/W9eTn58PIyAi9evVCTEwM7t27h3bt2gnP79u3TxjCIDIyEu/evRO5PiMjQ2SXYE31qRs8Hg+EkFo74pqYmGDZsmU4ePAgEhISZCxdKd7e3rCzs8O6deuExxITE6GlpQU3Nze4ubmhffv2CA4OxowZMxAcHCxyfZ8+fbBp0yb4+vqiRYsWCAkJwZYtW2BgIPvOuTTItQOjaiOpITteIrHZJOj2n4cJEyYAAB49elTpB0tRLG/fvsXy5csBlOrKw4cPK5XRMGsOzeafQbvtIOh0Hw/9QUug2dwZRv57MHrVaWzdfQDu7u5wdHTE6tWrkZeXp+jbkBp1HTVVx6lTp/DkyRP06tULAODu7o47d0qdV8uTkJCAp0+f4v379+jUqROcnJzYELdKVq1ahZiYGDAcDbm2o91pBHS6T4CGRe13ViYlJaFjx44YO3Ys/vzzz0oOwiNGjMD58+exdetW9OzZU+RFnZCQgG7duklVn7oRHh4OW1tbcLlcicqLm4kZPXo0OnbsiB9++EFug6yAgADs3bsX79+/BwCcOXMGAwcOrFQuPT29UtgKNze3SuXKBgxcLherVq2Ci4sLbt68CUIItm3bhs2bN2PcuHEghOD48eOIiorC/PnzER0djbS0NLi6umLdunUIDAyEu7s7tm7dCgCYPHmyxE7/cnPiLRtJrV27Fu7u7rC1tcWoUaPE9jDLRlJA6Zog28ZI08oJ7usfA3iMwnMr0KAkE5s3b4a3tzerctVXGjVqhPnz52P+/NqNMrVauUGzZW8cn9QMW7duxbx582BkZISAgAAZSypbyo+ayn7c5UdNNjY2IIQgODgYN27cQEBAAJKSkoTX9+nTB25uboiNjUVKSgpCQkLg5ubG+qipOhISEmBnZyfMNK2hoQE7OzvExMSga9euwnK3bt1CVlYWPDw80KJFCxw8eJDV3Ublyc3NhampKZo1ayb3thiGAy37fgBKv5PmzZvD3Nxcqjq4XC50dHTQuHFjlJSUiO3cl3VAKnZEMjIy8ObNGzx79gwxMTHo27evRPWpE6dOnYKVlRUaBhyodR0cDgfLly/HoEGDcP36dRFdr4rMzExkZmaKHDMzM4OtrfgNDWVBX7dv345JkybBzMwMb968EZ5/8OABVqxYgZycHOzYsUNi2blcLmbNmgVDQ0OcOnUKr169QmpqKjp37gxNTU28evUKq1evxrlz5zBs2DA4OTnh0aNHePHiBfz8/GBqaoqYmBjs3r0bgYGB6Nixo9gs9OKQ2wyMuoykdFynIEfXGsOHD4eWzefIzs5mWyRKJWoe3TEMAzc3N+zZswepqakYO7bUsXLhwoX466+/lHZpSR1HTdXx5s0bGBsbixwzMTGp5AA6depU3L59Gw8ePIClpSWGDBmCwsLCOrdfV/h8Pho0sYWO82iJnDhlBeGXYMiQIfD39692ubUiFy9eRHh4uPBF5ufnV8lXZf/+/XB3d8fkyZMRHx8vMiPt4+OD9u3bo7CwEAUFBRLVpyzMnDlTuM2/thBCEBcXh379+tVZHg8PDyQnJ0vUeQGArVu3wtnZWeQTEhJS7TXBwcHYuHEjIiMj8c0334ica9OmDX788UesWLECDRo0wLp16zBs2LAaB47a2trgcDjQ0dFBUVER7t69i169emHUqFHYvn07tLS0hLZBR0cH5ubmePfuHTgcDszMzMAwDNzd3XH//n0cPXpU2GeIjIzEzJkzq21bbjMw6jCSAgCOngl03WaCl3EF3Gvh6NOnD27fvi1RSO/aUJXRE7cN7/Xr15g/fz7atm2L2bNnIyEhAevXr8dvv/0mkdGo6/WqStnIWCAQIDU1FUuXLsUff/yBsLCwKkcvsoKOmqpHS0tLaDPKEAgEVb6UHRwccOTIETg6OiI2NhaDBg0SOT9z5kyhXOW3dcuLc+fOgRTmQqOxYoNlMhpayHbwxYkTv2HdunX4uGumRNf16tVL+MIAgMGDB1cqM3z4cOH/R44cWel8y5YtRWbWa6oPUJ8YQc+ePUNWVhY+//xzrH0m3UxTxcCbDMPAyckJhBB8/PixUke+IpMnT4anp6fIsaqciAkhEAgE6NatGxo3box79+5VGSm4jODg4Eq+MJLQvHlz/PXXXxgyZAjS09ORn5+PDx8+ID8/H4aGhtDV1UWjRo0qXRcYGIjVq1cjNjYWgGQxguQ2AyPrkVTxvaMojFmFwphVKEmPl5fYYmEYBlq2LtAf8iueWHrCZNzfMBwdzvqova7e/rLYLRAZGQlPT094enrW2FuWFxyjxrW7jsNBZGQkTp8+jWfPnqFjx46IiIiQsXSiqPuoqa5YWVlVWnL48OFDtTppYWEBFxcXfPjwodK5NWvW4MiRIzhy5IhCovFGRkaCMbYCx9xO7m1VRLNpJ2g5DMT8+fOVakeWOHx8fITPhc3wC3WlbEWhoh9QXZB0E4mVlRW6dOki8qlqIBQeHo7Tp08jOzsbwcHBGDduHDIzM3HlyhXEx8fjwoULSE5ORlpaWpXtFRUV4ezZs0hPT8fdu3cBADdv3kROTg6ePn2KW7du4cGDB/D29kZeXh66d++Ov//+G+3bt8eGDRuwdOlS7Ny5EwsWLEBaWhpyc3Nx+fJlkfuWdiZLbjMwsh5JKUOwMo6BOTgGpevL3PhtGD8+Ftu2bRMJXKRIKnr783g89O/fX3h+3759cHFxQbNmzRAZGYkBAwaIOODVdL0kqFKwsqqCSg0YMAC3bt3C9OnTcenSJYwZM0ZuMqj7qKmu9OnTBytXrhQ6fpaUlCAjIwN9+1a/m4fP58PBwUEmMtQWgUCAEydOQLN5d9acVrU7f4OCl7fg2Pcb6PX9nqbUkDPe3t548uQJLCxqH2W5Iq6urvjpp5+wbt26Gn/vkjJ+/HiMHz8eQKnDcBknT56UuA5dXV2EhoYiNDRUeKxz587CAUf5jujx48dFrv3iiy8qRRsuP/OWl5eHU6dOwd/fX2J5ADnOwMh6JEWKP8lcxrqg0awLdu7+C/otOgn9ExRNXXYPSHK9qlB09c86z8oZGxtj165d2LBhAwDg9OnTePv2rSzEE6E+jpokWcsuw8XFBU2aNMHFixcBAHFxcbCxsUG3bt2wZMkSJCcng8fjYeXKlUhPTwdQuoymo6ODzp07S9SGvHj69Cm4XC40m3ZkTQZGSxe6bt9Cp/sE1mSoTxiPjUSnJVfr7O9UfmfSuHHjIBAIsHv3blmIqPQQQtCuXTs8fPhQ6qS9cpuBkflISgrHNEWgZesKjn4DFMb+Dz169MDZs2fRpEkThcpQl90Dkl6vCui0HQJNG9mkpdfU1ASXy0VAQAB0dXVx7tw5hewmEYe6jJqkyXfD4XAQHR2N0NBQJCcnIyEhAYcOHQLDMDhy5Ajat28Pe3t7HD16FL/99humTJkCY2Nj7NmjOIfZqrC1tcXbt29hNj6KVTk0GtgAKB30ffz4UW0SPyojhTGroGXXC5rWsltCsrCwwLBhw/DHH38gODhYJQeV0sAwDJ4/f16rayWagXn37h1Wr16Nnj17okmTJjA0NISDgwN8fHxw6tQpsdeo8khKUjQaO0J/0GLk5+cjPDxcoW3XdfeAKu0WqBEZ/751dHRw/vx5FBUVoXfv3sjIyJBtA2pAXUZNNWFvb49du3Zh2rRpiIiIgL29PQDgxo0b8PLygo6ODi5evIi3b9/il19+wZw5c5Ria7jhmN1oMHEfGDk5+EsDEfBQcHwBFi9ezLYoasvHjx/Bf5EEwpcs/os0TJgwAbm5uSIO+5TK1DgDEx4ejsjISHTt2hXTpk2DsbExdHV1kZeXh9evX+Ovv/5CWFgYNm7cKBJ/QJVHUtLAMbbC9evXhf4BPB4Pmpq1n9iSdM26rrsHJLm+PtOyZUtcvHgR7u7ucHNzQ3x8vOp28ORAXUZN6khJSQk+7ZsCna5joWXXk21xwHA0odWqL9atW4dp06bBzk7xTsXKTl2TOT569AgAwDGW/cz7wIED8ezZM7ntdpWUY8eOoaCgQOzuM3kjSTLHat+0mzdvhp2dXZWzLEDpLqLXr1/j999/R0hICPT19YXnykZSADBt2jTh8Rs3bgj/XzZDUyNKPItW5sB19OhRzJ8/H+fPnxfr8EiRF9IpR8Xti1XRokULXLhwAf7+/igqKqq1dBT1586dO0BxQa13xMkDrTZfwDDzApYuXSrVFnt1gxCCzMzMSkv8dd1GXRYRnGMi+w5MWcfl1atXsLKykskyUkJCAqKiotCuXTukpqaiT58+lZaIy3j37h0aNmyI4uJinDhxQpja44cffkCrVq3qLIsk1Gkb9fv379GnTx94eHgIj126dElsuGRLS0v88ssvlUKeyxRN5U05XuaANerPJ8jKysLgwYORny+/3E2UCujUfo2/psyxTZs2xblz59CyZUt8+vQJJSUltW5LURw7dgx79+5lW4x6xeXLlwGOFjj/+p8oA4ymDubNm4edO3cq/bZqSVGm9DQpKSlg9EzBaOnJvG4AuHLlCpo2bSqSKLO2vHjxAuPHj8eyZcsQEBCAX3/9FYsWLUJycnKlsnFxccIAleV3QW3YsEFhnRdJqbIDY2ZmhjZt2ogc2759O+zt7cX25jU1NSWOIFgbGA2tmguxDMeoMT5+FozEm8kwdegJPl+2GbQp4mG05N+55fF46N27N+bMmSP3tsqTkJCAmTNn4o8//sDcuXOrdeAt83EqGzUBpduc1eXlVRtkEW1VEq5duwaOuY3S2akFV00Aq05KO6CSZoeasiX69Pb2hk7XsTKts/yAytnZGaampjhy5EjlggUFQFJS9Z+CAmHx3bt3w8XFBXp6pZ0tDoeD/v37w9PTE3369EFubq4w7ciJEydw8+ZN3L9/X3h9bm4utmzZgnfv3qGwsBCbN2/G77//jjlz5iArKwsDBw7EunXrFL7UJNUCW3h4OJKSknDv3j1MmTJFXjKJpejaLoUHsKsNGua20HX7FvzMO1i2bBnb4igMaQyRrCEl8g8hr6mpiQkTJmDt2rUKeSEC6jtqUiRr1qxRSAC7O3fugGPWQu7tSAujqQ29vt+hU6dObIsiFh8fH4kD2SlbepqOHTvKdPdRRbS0tDBgwAD8888/lU8+fAg4O1f/KZf09vnz55WW0KytrdG2bVsAgKmpqTCcg6OjI5ycnITngNIwE3FxccjPz8eff/6JT58+oVmzZnj58iVMTU1RVFSEXr16ISpKsTvwpPY2NTc3x+rVq3H8+HH89ttvChuR6nT0gmaT9gppq65oNukAnR5TMW7cOLZFURjSbJWVOQqKERQUFIQrV64gMDAQn3/+ufRpBwoKRIyKWBwdgX/9yKobNVlbW+Pw4cP46quvsGTJEpw8eRJPnjypNGratWsXfH19YWBggPDwcHz69Alv3rzBnDlzMGbMGAwZMgSXLl2iS0515NKlS7Ca+BfbYlSJ3sCFIAXvoWXXQ2WD2ylbeprNmzeDn50j1wCrgwYNwsSJE4U+KUIcHYFyvqRicfwvnYW1tXWleFE5OTkSR5PncDgwNDQEANy9exfTpk2Dk5OTcAasfIRuRSLVDEz5RIaDBw+GhYUFUlNTZS6UOqBl2wPNmjXD+/fv6W4NNYFhGGzatAnm5uYYP3689Kkk6KhJbTE2NgZHz4RtMaqE//wGuNd3gfCK2Ral1sg6Pc3MmTOFaVCknVUlhOC7774DP+uR9DciBR4eHjA0NKzsX6qvD3TpUv2n3IYaPz8/XLhwAQX/LisRQnDixAnMmzdP+N0UFRWBEAIOh1NtQtCyqN0AcP369Uq53eqKNOlppJqBadGiBWxsbODu7o6+fftiyJAhOHjwIFq2bFkXedWar7/+GsXFxYiLi6vT9mpK1XCTo0H4JdCyda1TPVWlGhApY2SEnTt34v3799KPNurpqEmS7ZCqzLFjx7Bt2zYQ4+FgOMr5G9dyHIiSh6fAe5oAYBzb4tQKWaenqcsupHfv3qGoqAi6BuY1F64DTZo0QXZ2dqX7rk09YWFhWLBgAZycnPD8+XPMnTsXrq6u0NDQwJw5c6Cnp4e0tDQ4Oztj/fr1GDx4MC5fvoyMjAxkZ2cjLS0NiYmJCAwMhKenJ9zc3ODv7y8cFF2+fBk2NjZ1vmdp0tNI9WtbunQpPDw8EBMTg7///htBQUEwMjJCQEBA3SSWBBWMRmjkvwd83T4ojPsZy5cvx8KFC9kWSS3RaT8Mmi0+U1h7bm5uwv8XFxdLngurbNQkIX5+fnB3d0dBQQH09fWFo6alS5di9uzZAKQfNS1btgzXr19XaEwbVpcXFcC1a9dw/fp1MP3FO5QqAxyjxtCwbIuSVAnDVighVlZWuHTpksixuqSnqQtlsz6MvmxyFVWHlpaWdHamClxcXODi4lLpeHx8Zd/SMr+i7t27Y8GCBQBK/eyquubx48d1kq22SLWENHPmTLRp0wZBQUHYu3cvXr9+LdztIHcYDcW0I2M0LOyh1c4TIT8thv7QFXXOmUERgwY7yTTHjRuHyZMny63+8qOmHTt2YMmSJVWOmjp06IB//vkHV69erXLUdOHCBbi5ueH27dtgGEY4aqLUjbS0NJVwlNZs2RuCNw+qzZ2lzPTp0wfp6enCGUg2E32W5Ulj6hDCoSbKdiOdPXsWxsbGNCqvGKqcgSksLIS2tjY0NKrvOLRu3Vr4/7y8vEprlLJCEVtl5YV2h6/Be3YN3MSd0BuwgG1x1A5GV7ZGRNJAd59//jmmTp2KqVOnols3+exGUMdRk7qRlpaG1q1b46aULlGKRrNFV5CiPJiamrItSq0on56md+/eldLTeHl5oU2bNli9ejVGjBgBW1tbuaWnMTY2xtChQ3FeVz7vu/I4OjqCy+Xi0qVL8Pb2lnt7qkSVMzBaWlpYsWKF0OmnJiIiIkR2QMgaqR0mlQhGQwu6LgHQ6TRC7RNzsQFbuhEQEAAnJyeEhISw0j5FOUhLS1OJUP2Mpg60234pss1elShLT7N9+3Zs3LgRYWFhIulpHj9+DD6fj6NHj6Jbt24ICQnBsWPH5JKepnv37jhy5IhCBtbNmjWDjY1NpeUzSjUzMJqamggICICfnx8GDhyIL774olLStvfv3yM+Ph7h4eEYNWoUPv/8c/lJypN/rA95omFROoVJCEFJSUmdnbIo5Sh8L7eqq3Ps1dDQwKJFizBixAjEx8fD1bVuTsQU2VPXfDc1QQjB6tWr4eTkhN9/vyuXNmQJ4X7C999/j4CAADiWcxhnC2kdvGWanqYOGH6zFQADRsdQ7m0BpbO9FePdUGrwgWnUqBGioqLw9u1b9OzZEwYGBmjSpAmaN28OY2Nj2NjY4MCBA/j999/lPrXFvblXJQLZVQcRCFB4+hesWrWKbVFkDpuB7NjEy8sLLi4uSElJYVsUihjkHciOYRj4+vqiQ4cOcmtDpmhq448//sC+ffvYlgSAdIHsZE1dojRzb+1H4ZmlMpaoajp37ow7d+5U66ivbkjyTqlxF5KmpiYWLlyIBQsWICkpCZcvXxbufAgODhYG2ZI3Op2/gaZl25oLKjEMhwMNsxZYuXIlpkyZorJr0eJQ950mVcHhcHD58mW6NFhPSUlJwblz5zB+/Hi2RZEIRkMLX375JQ4fPlzvlz7rlMyR+xGMjvz9X8oICAhAYGAg69mpFUmdkjlW5M8//4SLiwt+/fVXHDp0CBEREejevXu9zrNSG7ScvkJRURHWrl3LtigUKagu6SPDMMjJycGZM2dYkIzCJh3GrUJQUBAaTlSdSMZfffUVkpKSZB6ArD5BivJkvnmgOszMzNRqwCsrJO7ALFiwAKtWrcKrV6+QkJCA5ORkHDp0CD///LM85VM7OPpmmDhxIjZu3IiioiK2xVEPlGD2Y+PGjRg2bBhyc3PZFoWiQEhhLqBtCEZDOQPYiWPSwVwAwPnz59kVRIUhJYWAtn7NBWXI5MmTsXr1aoW2qexI3IGxtLTEjBkzRKawWrZsKRL/ICsrS7bSlUdTdbdRV+TP57Z4l1+CBsOpMsoEXVOFNiduNmbSpEngcrk0p1A9gxTlKXUKAXFw9Eyg3dVfLvmB6gukpAiMgt5JZbZmx9EEhTgoqxISd2BmzZqFsLAwPHv2TPh58OABsrOz8fz5czx9+lSu4cLVyceAY2wJfa910Ghgw7YoakHxjb9Yd/C2srJC//795bJlU9VRZwdvUpgLRle1OjAAoO3ogTZt2rAthsqi7/kbtDuNVGibHGNLGrupAhJ3YDZs2ICJEyfCxsZG+GnXrh3Wr18Pa2tr2NraynU5SZWTkImD4WhAUPAeL168YFsUlUe7/bA650GqLeVnYnx8fBAXF0eTd1aAzZ0m8oZj2hQaKri5gBR9xMqVK/H69Wu2RWGNuuxCYjgchS8bMkaWePLkCfh8vkLbZQtJBj4Sd2CCgoKQlZUlTJ4l7rNly5a6ylw1RL22jxFCUHhyEZYvX862KKqPgMe2BABKE3d6e3vj06dPbItCURDaHbyg3eFrtsWQGiLg4ccff6zXqSRqu8VeIBCg4OQS8F7ekr1Q1cAxtgKXy603AyRJBj4Sd2DGjx+Phg0bVltGIUkd1QSGYaBp44LIyEgUF6vX7FJ9xMh/D5pOP4aTel8rRYAwSil1GWVLgqAwF4RfIrf65QVH3wxNmzZlPTiaKi4vFhQUQPA2BaRYscFVNczt8Ndff8HMzEyh7SozKrOpnHszinU/B1mjadsDOTk5arEbgF1DpDz+UYTHxeHDh+ksjJIg70B2BQdnouSxav5+u3btynoHRhWXFz9+/AhA8fn5GF0j+Pr6wsRE9Xyu5IXKdGB0On/Dmp+DvOCYNgdjYA7Pmf9T+SzVqmiI5AEpyMHXX3+N2NhYtkWhyBkulwsISsBoKXY7raw4kaGF85euqHSeOTbIz88HwE6C4V27duHs2bMKb1dZUZ3gBSoUZ0FSSpeRXAEVnIJWKpQoUzljZAnGwBxfz9mI4sGD2RaHIkc+fPgAAGC0FRONXNZoNG4DzYL3KC4uho6ODtviqAxlHRg2QnuM/24JOGYtUPK4v8LbVkZUplfAcFRGVKnQ6TKKbRFUHkZTeYwvwzDQaGQP/jsaoVrdKevAQEVnYDQsHKBh4UA7L1LSvHlz6LgEgmPYSOFtM/oNQApyFN6usqIyS0iEqO/WMVJSCEGB/DIqqzvK5kTJadgSguwMGI7e9d82a4b570NRC/Ly8gAAjJZqzsAAgODDS6Snp7MtBivU1sG7YcOG0GrlprBM1OXh6JvVmw6MTLdRs44a730vPB2K4lvKkR1WJSlRrpQMGhaO0LCwB+HmsS0KRY506dIFBqN2gGPWgm1Rak1hzGqsX7+ebTFYobYO3s+ePUNJyjkQFuwOo2sCUvRR4e2ygUy3UVPkB6dhK/Df0giL6oKGuS30BswHR7+B+AJ0JkYtYBgGjJYuGI4G26LUGo5hQzx9+pRtMVSK5ORkcK/+WZoPScFwzKyh0aQDndH9F9qBUQI0GtiAfMykyR1rCffOfqXbYk/4xSBFdAYGYHuLvfyIjY1F4ZlfQXhctkWpNYx+A7x8+ZJtMVQKHq80cCYbHVfN5l2g22OKwttVVlSmA8NNilS6l5Ss4Jg0BQjBo0eP2Bal1rD5ktLpMFzpttgXnf8dRVfD2BZDKWBzi708A9m9fPkS/Nf3VHoUzOiZ4dWrV6y1r4qd25KSf33uWOjAED4Pgvy3oKFPS1GZrT06zr7QtLBnWwy5wDFtCnA0kZGRgY4dO7ItTq3w8fGBg4MDnJ2dFd+4Ek7hM8aWENBlQdZZs2aN3LIuc7n/zrwwKmNGK8ExaAjNT5oghLCSMJdVuyEt/34/wsQljOLtjiAnHYUnFyMFgJPCW1c+VGYGhtHQYlsEucFoG8DANwxfffUV26KoJIy28m1j5eg3ACnIrb5Q+XVsup6tchQXFwMMBwxHZcxoJbTs3ZGWlsZK50VVaQRAw7IdwEJoD0bbAAAgsg+pHtsR1f3lqRkMQx+FOsHomYJw80D4UiaarIdGSFUpLi5m5SVGkQ21XV7sB0BvwHyFZ6MGAPy7ZT9f8S0rHJXZRp2eno4pU6Zg27Zt8Pf3F+sVr2yxPmQN93oExo8fz7YYKgnhKt/PmdEzBQCQog/sCqLmSGI75EXfvn2h03WswtqTB/ycDDRv3hwPHjxgWxSZU5Nu1HYbdTHAmuN2WdBO5bN4skcltlELBAJ4enpi5MiRCAwMhJ+fH0aNqn/RaUnxp3qd2r4q2HxB1QUNKycY+IaBY2Auk/rkmVFZVWHbdrRv3x5arfsorD1JkWqzA6OBFy9eIDc3V27ysIE8dWM7gE9RgTKpS2r+TV9QXQcmEqg3s7isd2BOnTqFJ0+eoFevXgAAd3d33Llzp3KWVDV/Foy2Aau7AZQRtl9QdYHhaILR0K5jJf8tJwk7MHSJSYjEtkNO3LhxA7ynVxXSljTwMhIkLluWkLAsw7K6IE/dKAFYceAFAIbDgYHvTkyopozIUEfN/WNY78AkJCTAzs4OWlqlTroaGhqws7NDTEyMTOqv7dbrumzZrs21jLbBf9vzakFtR+h1GdnLe1ZA8s5t7X6U8tQNUlyAwtOh4L2+L3K81t/Y0aNV32cNxkkddQOQj+2QRu79+/ej6Fq41G1Iq3fyDB9R5hR67Ngxqa6T9vkqegax1roh5oUfWeG3xQOq3PkozbOqbdk6+95Uc29VIc3zk1dZcbDugfbmzRsYGxuLHDMxMREGVyosLI12KPiQCT5H+p1IJSnnwDG2Uth1tb1WwCsCB6WjuidPnuD48eMi583NzeHn5wcA2LBhgzCYUhkpKSlwcHDA2bNncffuXZFzXbp0Qe/evfHixQvs379f5FxcXBwcHBwAADt27Kg0EvPy8kKLFi0QHx+Pa9euCY+3a9cOx48fF14LQLiOXvbM6kp1Rqhr167/6Ubea/D/NcTSIE/dIAI++G8egNzaB56hBSYCmAZgM4BrALIrlB8CoBWARAAVFxJbAcgFcAHAjvIn/jU801H6Q94P4IW//3/nd+9GPwA7evUCj8fDmTNnROpt0qQJRo4cCb6zM9YDwL/6VcaTJ0/g4OCAEydOICUlReScq6srunXrhrS0NBw5ckTkXOvWrXHmzBm56gZQve0oayckJATm5v8t43Xo0AHu7u548+ZNJeOpra0t/B3t3LkT79+L5ifz9PSEnZ0drl27hvj4eFy/fh0oKQQ/W7pcQtLqnbTlSXGBxDIRQmBkZIRTp04hKSkJ27ZtQ0FBgUiZ4cOHo1mzZrh48SJu3LgBAMjIyBB5vjWxefPmKssri260adMGHgDeA9hZ7roYACcBfPvv35sBAETsdyzNs6pt2eKkKFgBGFDufCAAfQBHANwEUM4KoDeALgBSAJyoUO9lAA4AwDBYB0BQ/qSfH/z8/GBubo6NGzeWPr/y293/1YWKVPespS1bo24Qlpk2bRrp1auXyDEXFxcyffp0QgghERERBAD9qNAnIiJCJroRGBhIPv/8c5FjPXr0IMHBwVQ3VPQjK90gpHrbQXVD9T5UN+hHWt1gfQbGysoKly5dEjn24cMHNG3aFADg4eGBiIgI2NjYQE9PdbO+1gcKCwuRkZEBDw8PmdSnpaUlnH0pQyAQQCAoHSdQ3VAdZK0bQPW2g+qG6kB1g1IVNekGQwghCpZJhMuXL+PLL79Ebm4uGIZBSUkJTE1Ncf78eXTv3p1N0Sgss3TpUuzbtw+3bt0SHmvXrh38/Pwwd+5c9gSjKAXUdlCqgupG/YB1J14XFxc0adIEFy9eBFDqk2FjY4Nu3bqxLBmFbfr06YP09HSU9bFLSkqQkZGBvn37siwZRRmgtoNSFVQ36gesLyFxOBxER0cjNDQUycnJSEhIwKFDh2hoa4qIEerduzc1QhQRqO2QDkIIMjMz0aRJE7ZFkTtUN0RR22cvM68pCkUOPHr0iPj5+ZENGzaQ0aNHk0ePHrEtEkXJSUtLI5MnTyZbt24lfn5+JCMjg22RZE50dDSxt7cnRkZGxMvLi2RnZ4stt3v3bhFnyAsXLihYUuVCHXSDPvv/UOoOjDoomyRIqpCU/6C6QREHn88nTk5O5Ny5c4QQQk6fPl1pJ5uqk5qaSgIDA8ndu3fJgQMHSIMGDcikSZPElp04cSJJTEwkiYmJJDk5WcGSKhfqoBv02YuitB0YdVA2SZBGISmlUN2gVMWJEyeIrq4uKS4uJoQQwuPxiL6+Prl27RrLksmOnTt3Ei6XK/x70aJFpG3btpXKxcfHk/79+5PTp0+TkpISRYqolKiDbtBnLwrrTrxVwXaYcEVx6dIlrF+/Hu3atYOXlxdmzJiB+Hj5Rd5UB6huUKpC3pG9lQF/f39oa/+XpqJx48Zo0aJFpXK3bt1CVlYWPDw80KpVKyQlJSlSTKVDHXSDPntRlLYDow7KJgmSKiTlP6huUKqipsje6khSUhImT55c6fjUqVNx+/ZtPHjwAJaWlhgyZIhMo92qGuqoG/X92SttB0YdlU0SqlJIyn9Q3aBURU3BD9WNzMxM8Hg8DBs2rMoyDg4OOHLkCIqKihAbG6sw2ZQNddMN+uyVuAOjbsomCZIoJIXqBqVqrKyskJeXJ3KsfGRvdYLP52PNmjVYv359jWUtLCzg4uKCDx8+KEAy5USddIM++1KUtgOjTsomCdIoZH2H6galKupT8MP//e9/+O6772BoaAgAKC4urrY8n8+XKgGjuqFOukGffSlK24FRJ2WTBGkVsj5DdYPqRlXUlwisa9asgb29Pd6/f4+HDx/ixIkTOHnyJJYsWYLk5GTweDysXLkS6enpAEqz+uro6KBz584sS84e6qIb9Nn/B+uReKuiPkVhLa+Q79+/R1paGng8Hjw9PdkWTSmhukF1oyrqQwTWvXv34rvvvhN24AFAX18fr1+/xpIlS9C+fXvY29vj6NGj+O233zBlyhQYGxtjz549LErNPuqgG/TZi8J6MsfqSElJQWhoKLp3746EhAT89NNPsLe3Z1ssmbJ3716MGjVKrEIaGRmxKJlyQ3WD6gaFQqnfKHUHhkKhUCgUCkUcSusDQ6FQKBQKhVIVtANDoVAoFApF5aAdGAqFQqFQKCoH7cBQKBQKhUJROWgHhkKhUJQYQgj+97//QV9fH2/fvhUeHzt2LOLi4liUjMI29V03aAdGgdR3ZaNUDdUNSlUwDAMPDw9YW1ujUaNGAIDs7GycP38eXbt2ZVk6CpvUd92gHRgFUt+VjVI1VDco1RETEwN3d3fh36Ghofjpp5+gp6fHolQUZaA+6wbtwCiY+qxslOqhukGpitjYWGGqjGPHjuHTp08ICAhgWSqKMlCfdYN2YBRMfVY2SvVQ3aCIgxCCuLg4uLm5ITw8HPfu3cPWrVvZFouiBNR33aCReBUIIQSWlpa4e/cujh8/jjdv3uCHH35QqVwcFPlAdYNSFSkpKRg0aBB++OEHuLu7o3Xr1myLRFES6rtuKG0yR3Xk8ePHMDQ0xMGDB+ulslGqhuoGpSrs7e2RmprKthgUJaS+6wadgaFQKBQKhaJyUB8YCoVCoVAoKgftwFAoFAqFQlE5aAeGQqFQKBSKykE7MBQKhUKhUFQO2oGhUCgUCoWictAODIVCoVAoFJWDdmAoFAqFQqGoHP8H3Ga3mH0tTasAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 660x78.5714 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "fig, axs = plt.subplots(1,4, figsize=(6.6, 0.7857142857142857))\n",
    "\n",
    "plt.subplots_adjust(left=None, bottom=None, right=None, top=None, wspace=.27)\n",
    "ax_f = axs.flatten()\n",
    "\n",
    "x_scale = np.linspace(0,3.5, 1000)\n",
    "N = 768\n",
    "layer = 4\n",
    "\n",
    "##########################################\n",
    "############### Plot 1 ###################\n",
    "##########################################\n",
    "ax = ax_f[0]\n",
    "\n",
    "randomM = np.random.normal(0, 1/np.sqrt(N), size=(N,N))\n",
    "_ , sval , _ = np.linalg.svd(randomM)\n",
    "ax.hist(sval, bins=20, density=True, label=r\"$N \\times N$\")\n",
    "\n",
    "\n",
    "y_square = MP(x_scale, n=N, m=N, sigma=1/np.sqrt(N))\n",
    "ax.plot(x_scale, y_square, \"--k\")\n",
    "\n",
    "\n",
    "ax.set_ylabel(r\"p($\\nu$)\", labelpad=-1) \n",
    "ax.set_title(f\"Random Control\")\n",
    "\n",
    "\n",
    "##########################################\n",
    "############### Plot 2 ###################\n",
    "##########################################\n",
    "bins = np.linspace(0,3.5, 40)\n",
    "ax = ax_f[1]\n",
    "\n",
    "path = f\"../PythiaSVD/pythia-410m-deduped_step143000/gpt_neox.layers.{layer}\"\n",
    "sval = torch.load(f\"{path}.attention.query_key_value.weight_K_S\", weights_only=False)\n",
    "U = torch.load(f\"{path}.attention.query_key_value.weight_K_U\", weights_only=False)\n",
    "V = torch.load(f\"{path}.attention.query_key_value.weight_K_Vh\", weights_only=False)\n",
    "N = U.size()[0]\n",
    "M = V.size()[0]\n",
    "std = np.std( (U @ np.diag(sval) @ V ).numpy().astype(np.float64))\n",
    "print(std)\n",
    "std = estimate_sigma_med( (U @ np.diag(sval) @ V ).numpy().astype(np.float64) )\n",
    "print(std)\n",
    "_,_, patches = ax.hist(sval, bins=bins, density=True)\n",
    "ax.set_title(f\"Pythia Key {layer+1}\")\n",
    "\n",
    "y_square = MP(x_scale, n=N, m=M, sigma=std)\n",
    "ax.plot(x_scale, y_square, \"--k\", label=\"MP-Theory\")\n",
    "\n",
    "mp_max = np.max( x_scale[y_square >0 ] )\n",
    "\n",
    "# color outliers red\n",
    "for i in range(len(patches)):\n",
    "    patch = patches[i]\n",
    "    if( patch.xy[0] > mp_max ):\n",
    "        patch.set_facecolor('red') \n",
    "\n",
    "ax.plot([], color=\"red\",  label=\"Outlier\" )\n",
    "\n",
    "##########################################\n",
    "############### Plot 3 ###################\n",
    "##########################################\n",
    "ax = ax_f[2]\n",
    "M = 4*N\n",
    "\n",
    "randomM = np.random.normal(0, 1/np.sqrt(N), size=(N,M))\n",
    "_ , sval , _ = np.linalg.svd(randomM)\n",
    "ax.hist(sval, bins=20, density=True, label=r\"$N \\times 4N$\")\n",
    "\n",
    "y_uneven = MP(x_scale, n=N, m=M, sigma=1/np.sqrt(N))\n",
    "ax.plot(x_scale, y_uneven, \"--k\")\n",
    "\n",
    "for i in range(2):\n",
    "    ax_f[i].set_xlabel(r\"$\\nu$\", labelpad = 0)\n",
    "\n",
    "\n",
    "x_scale = np.linspace(0,3.5, 1000)\n",
    "ax.set_title(f\"Random Control\")\n",
    "\n",
    "\n",
    "\n",
    "##########################################\n",
    "############### Plot 4 ###################\n",
    "##########################################\n",
    "bins = np.linspace(0,4.5, 40)\n",
    "ax = ax_f[3]\n",
    "\n",
    "path = f\"../PythiaSVD/pythia-410m-deduped_step143000/gpt_neox.layers.{layer}\"\n",
    "sval = torch.load(f\"{path}.mlp.dense_h_to_4h.weight_S\", weights_only=False)\n",
    "U = torch.load(f\"{path}.mlp.dense_h_to_4h.weight_U\", weights_only=False)\n",
    "V = torch.load(f\"{path}.mlp.dense_h_to_4h.weight_Vh\", weights_only=False)\n",
    "\n",
    "#std = np.std( (U @ np.diag(sval) @ V ).numpy().astype(np.float64))\n",
    "std = estimate_sigma_med( (U @ np.diag(sval) @ V ).numpy().astype(np.float64) )\n",
    "\n",
    "N = U.size()[0]\n",
    "M = V.size()[0]\n",
    "_,_, patches = ax.hist(sval, bins=bins, density=True)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "ax.set_title(f\"Pythia Up-Proj. {layer+1}\")\n",
    "\n",
    "y_uneven = MP(x_scale, n=N, m=M, sigma=std)\n",
    "ax.plot(x_scale, y_uneven, \"--k\", label=\"MP-Theory\")\n",
    "\n",
    "mp_min = np.min( x_scale[y_uneven >0 ] )\n",
    "mp_max = np.max( x_scale[y_uneven >0 ] )\n",
    "\n",
    "\n",
    "# color outliers red\n",
    "for i in range(len(patches)):\n",
    "    patch = patches[i]\n",
    "    if( patch.xy[0] > mp_max or patch.xy[0]+patch.get_width() < mp_min):\n",
    "        patch.set_facecolor('red') \n",
    "\n",
    "ax.plot([], color=\"red\",  label=\"Outlier\" )\n",
    "\n",
    "\n",
    "\n",
    "##########################################\n",
    "########### General Settings #############\n",
    "##########################################\n",
    "\n",
    "for i in range(4):\n",
    "    ax_f[i].set_xlabel(r\"$\\nu$\", labelpad = -1)\n",
    "    ax_f[i].tick_params(axis='y', pad=1.6)\n",
    "\n",
    "for ax in [ax_f[2], ax_f[3]]:\n",
    "    ax.set_xticks([0, 2.5])  \n",
    "    ax.set_xticklabels(labels=[\"0\", \"2.5\"]) \n",
    "\n",
    "for ax in [ax_f[0], ax_f[2], ax_f[3]]:\n",
    "    ax.set_yticks([0, 0.5])  \n",
    "    ax.set_yticklabels(labels=[\"0\", \"0.5\"]) \n",
    "\n",
    "handlelength=0.7\n",
    "ax_f[0].legend(\n",
    "    loc=\"upper right\",\n",
    "    bbox_to_anchor=(0.95, 0.9),  # x and y position\n",
    "    handlelength=handlelength,\n",
    "    handletextpad =0.4,\n",
    "    fontsize = fontsize-4,\n",
    "    labelspacing=0.2 )\n",
    "\n",
    "ax_f[1].legend(\n",
    "    loc=\"upper right\",\n",
    "    bbox_to_anchor=(1.02, 0.95),  # x and y position\n",
    "    handlelength=handlelength,\n",
    "    handletextpad =0.4,\n",
    "    fontsize = fontsize-3,\n",
    "    labelspacing=0.2 )\n",
    "\n",
    "ax_f[2].legend(\n",
    "    loc=\"upper right\",\n",
    "    bbox_to_anchor=(1.02, 1.0),  # x and y position\n",
    "    handlelength=0.7,\n",
    "    handletextpad =0.4,\n",
    "    fontsize = fontsize-4,\n",
    "    labelspacing=0.2 )\n",
    "\n",
    "ax_f[3].legend(\n",
    "    loc=\"upper right\",\n",
    "    bbox_to_anchor=(1.07, 0.98),  # x and y position\n",
    "    handlelength=handlelength,\n",
    "    handletextpad =0.4,\n",
    "    fontsize = fontsize-3,\n",
    "    labelspacing=0.2 )\n",
    "\n",
    "ax_f[0].set_xlim(left=0)\n",
    "ax_f[1].set_xlim(left=0)\n",
    "ax_f[2].set_xlim(0,4.3)\n",
    "ax_f[3].set_xlim(0,4.9)\n",
    "\n",
    "\n",
    "labelP_x = -0.05\n",
    "labelP_y = 1.05\n",
    "axs[0].text(labelP_x,labelP_y, \"(a)\" ,  transform=axs[0].transAxes, horizontalalignment='right')\n",
    "axs[1].text(labelP_x,labelP_y, \"(b)\" , transform=axs[1].transAxes, horizontalalignment='right')\n",
    "axs[2].text(labelP_x,labelP_y, \"(c)\" ,  transform=axs[2].transAxes, horizontalalignment='right')\n",
    "axs[3].text(labelP_x,labelP_y, \"(d)\" , transform=axs[3].transAxes, horizontalalignment='right')\n",
    "\n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plot1.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plot1.pdf\", bbox_inches='tight')\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Functions to prepare Overlap Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "def analyzeLayer(layer, mode=\"weightStd\" ):\n",
    "    weight = layer[1].astype(np.float64)\n",
    "    featureM = layer[0].astype(np.float64)\n",
    "\n",
    "    # compute eigenvectors and singular vectors\n",
    "    evalues, evectors = np.linalg.eigh(featureM)\n",
    "    idx = np.argsort(evalues)[::-1]\n",
    "    evectors = evectors[:,idx]\n",
    "    U, sVal , V = np.linalg.svd( weight , full_matrices=False)\n",
    "\n",
    "    # how many outside the MP curve?\n",
    "    n = weight.shape[0]\n",
    "    m = weight.shape[1]\n",
    "    largerVal = np.max([n,m])\n",
    "    smallerVal = np.min([n,m])\n",
    "    if mode == \"weightStd\":\n",
    "        # sigmaT =   np.sqrt(largerVal) *np.std(weight)\n",
    "        sigmaT = np.sqrt(largerVal) *estimate_sigma_med(weight )\n",
    "    else:\n",
    "        sigmaT =   np.sqrt(largerVal) * 1/np.sqrt(np.max(np.array([n,m]))) \n",
    "        \n",
    "    max =  sigmaT*(1+ np.sqrt(smallerVal/largerVal))\n",
    "    min =  sigmaT*(1- np.sqrt(smallerVal/largerVal))\n",
    "\n",
    "    outSideMP = len(sVal[sVal > max])\n",
    "    leftOutliers = len(sVal[sVal < min])\n",
    "\n",
    "    overlapM = V @  evectors\n",
    "\n",
    "    return (sVal , np.max(  overlapM , axis= 1) , outSideMP, leftOutliers)\n",
    "\n",
    "\n",
    "def plotOverlapSmall( spectralAx , overlapAx , filePath, matrName, upperBin, sigma3Interval , title, weight= None):\n",
    "        \n",
    "    with open(f\"../Data/{filePath}\", 'rb') as file:\n",
    "        FM_data = pickle.load( file)\n",
    "\n",
    "    if( weight is None):\n",
    "        weight = FM_data[matrName][\"weight\"].astype(np.float64)\n",
    "        \n",
    "    sVal , overlapP , outSideMP, leftOutside = analyzeLayer( ( FM_data[matrName][\"FM\"] ,weight ), mode=\"\" ) #\"mpStd\"\n",
    "\n",
    "    spectralAx.set_title(title)\n",
    "    spectralAx.set_xticklabels([])  \n",
    "\n",
    "\n",
    "    bins = np.linspace(0,upperBin,35)\n",
    "    _,_,patches = spectralAx.hist(sVal, bins=bins, density=True)\n",
    "\n",
    "    # theory curve\n",
    "    n = weight.shape[0]\n",
    "    m = weight.shape[1]\n",
    "    #std = np.std(weight)\n",
    "    std = estimate_sigma_med(weight)\n",
    "    x_theo = np.linspace(0,upperBin, 500)\n",
    "    y_theo = MP(x_theo , n, m, std )\n",
    "\n",
    "    # color outliers red\n",
    "    mp_min = np.min( x_theo[y_theo >0 ] )\n",
    "    mp_max = np.max( x_theo[y_theo >0 ] )\n",
    "\n",
    "    for i in range(len(patches)):\n",
    "        patch = patches[i]\n",
    "        if( patch.xy[0] > mp_max or patch.xy[0]+patch.get_width() < mp_min):\n",
    "            patch.set_facecolor('red') \n",
    "\n",
    "\n",
    "\n",
    "    spectralAx.plot(x_theo , y_theo  , \"--k\", label=\"Marchenko Pastur\", linewidth=1)\n",
    "\n",
    "    # Overlap\n",
    "    spectralAx.set_xlim(bins[0], bins[-1])\n",
    "    overlapAx.set_xlim(bins[0], bins[-1])\n",
    "\n",
    "    # color outliers\n",
    "    if(n != m):\n",
    "        inside_mask = (sVal >= mp_min) & (sVal <= mp_max)\n",
    "    else:\n",
    "        inside_mask =  (sVal <= mp_max)\n",
    "    outside_mask = ~inside_mask\n",
    "    overlapAx.scatter(sVal[inside_mask], overlapP[inside_mask], s=scatterSize)\n",
    "    overlapAx.scatter(sVal[outside_mask], overlapP[outside_mask], s=scatterSize, color='red', zorder=-10)\n",
    "\n",
    "    #overlapAx.scatter(sVal , overlapP, s=scatterSize)\n",
    "    overlapAx.set_xlabel(r\"$\\nu$\", labelpad=-4)\n",
    "\n",
    "    lowB = sigma3Interval[0]\n",
    "    upB = sigma3Interval[1]\n",
    "    overlapAx.axhspan(lowB, upB, xmin=0, xmax=1, facecolor=\"white\", alpha=0.2)\n",
    "\n",
    "\n",
    "    overlapAx.hlines(y= lowB , xmin=bins[0], xmax=bins[-1], colors=\"grey\" , linestyles=\"-.\", label=r\"$3\\sigma$ Interval\")\n",
    "    overlapAx.hlines(y= upB , xmin=bins[0], xmax=bins[-1], colors=\"grey\" , linestyles=\"-.\")\n",
    "    # overlapAx.legend( handlelength=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "upper bound: 0.04226106684654951\n",
      "lower bound: 0.027972771786153316\n"
     ]
    }
   ],
   "source": [
    "def prob_one_exceeds_x(N, x, sigma):\n",
    "    \"\"\"\n",
    "    Computes the probability that at least one out of N samples\n",
    "    from a Gaussian distribution N(0, sigma^2) exceeds x.\n",
    "    \"\"\"\n",
    "    # Compute the CDF of x using the error function\n",
    "    p = 0.5 * (1 + sp.erf(x / (sigma * (2 ** 0.5))))\n",
    "    \n",
    "    # Compute the probability of at least one exceeding x\n",
    "    return 1 - p**N\n",
    "\n",
    "def prob_all_below_x(N, x , sigma):\n",
    "    return 1-prob_one_exceeds_x(N, x, sigma=sigma)\n",
    "\n",
    "\n",
    "N = 14336\n",
    "sigma3Interval = 0.003\n",
    "\n",
    "\n",
    "sigma = 1/np.sqrt(N)\n",
    "lowB , upperB = 0, 1\n",
    "\n",
    "for i in range(30):\n",
    "    val = (lowB + upperB)/2\n",
    "    if( prob_one_exceeds_x(N=N, x=val, sigma=sigma) > sigma3Interval ):\n",
    "        lowB = val \n",
    "    else:\n",
    "        upperB = val\n",
    "\n",
    "print(f\"upper bound: {val}\")\n",
    "\n",
    "lowB , upperB = 0, 1\n",
    "\n",
    "for i in range(30):\n",
    "    val = (lowB + upperB)/2\n",
    "    if( prob_all_below_x(N=N, x=val, sigma=sigma) > sigma3Interval ):\n",
    "        upperB = val\n",
    "    else:\n",
    "        lowB = val \n",
    "        \n",
    "\n",
    "print(f\"lower bound: {val}\")\n",
    "# 1-0.997"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Figure where the Overlap with the activation covariance matrix is plotted for Square matrices\n",
    "We see that outliers can have a significant overlap but dont have to. Observe that particularly for the attention-output matrix there is little overlap in all cases. elaborated in the appendix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjEAAACrCAYAAACXDc34AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABj+ElEQVR4nO2dd1gUxxvHv9eAoyNFwQZYsKERlYhYAKNGf0rUGGvsBktsKcZEY4saa2KPibGHhMRYoom9oKJBxRJ7RcCCUqUId1yb3x/LnXdc4Q6uwnyeZ5/jdmdn3z3emX33nXfeYRFCCCgUCoVCoVBsDLalBaBQKBQKhUKpCNSIoVAoFAqFYpNQI4ZCoVAoFIpNQo0YikkpKSlBTk6OpcWgWICioiLcuXPH0mIYlZcvX5Zb5vnz52aQhGIIhBAkJiZaWowqASEE6enplhZDATVizMTp06cREREBFouFmJgYTJw4EZGRkViyZAlkMplJr33s2DG0aNECHA4Ha9aswevXr/HgwQN06tQJfn5+WLduHYqKiox2vXHjxoHFYoHFYsHLywsODg5Gq5tiWg4fPoy6devCw8MD48ePx7Bhw/C///0Ply9fNqie58+fo2vXrli7dq3G43/88Qeio6MrLGdWVhZmz54NFouFqKgo/PvvvwCAjRs3gsViYdiwYbhw4UKF6y9LYWEh5syZgwYNGqgde/LkCbhcrkLnt2zZYrTrUsrnr7/+Qp06deDi4oKffvoJYrFY5XhBQQGmTZuGDh06WEhCVV69eoVp06bhww8/xPTp0xEdHY158+ZBKBRaTKaCggIMGzYM7u7uCAwMxB9//KFyPDY2VqHfbDYbjx49spCkGiAUs7Fp0yai/JPn5eWRunXrkmXLllWovqNHj5KnT5/qVXb27Nmkdu3aiu85OTkkIiKCpKamVuja2sjOziYTJ04kSUlJJCkpiaSkpBi1forpGTZsGOnSpYvi+48//kjs7OzInTt3yj138+bNir/nzZtHxo8fr7Hcw4cPye7duyslp1gsJgDIzz//rNi3cuVKsmDBgkrVq4m0tDTy+++/E01d5uzZs0l8fDxJSkoily9fJiUlJUa/PkU3w4YNI+Hh4VqPJycna/zfmZu8vDzStGlT8tVXXyn2icViMnjwYBIVFUXEYrFF5Jo5cyb5+++/yfXr18mwYcMIj8cjjx8/VhwfO3asok+/efOmRWTUBvXEmBEej6fy3c3NDaGhoUhISDC4rufPn2P06NGQSCR6ledyueByuQCAvLw8jB07Flu3bkX9+vUNvrYuNm3aBC6XCw6Hg7Zt28Lf39+o9VNMj1xP5AwaNAgikQhHjx7Ved727dsRGxur1zUaNmyI999/v8IyAm/klH/u2LED+fn5mDt3bqXq1US9evVQs2ZNtf3FxcU4dOgQMjMz0bhxY7Rp0wZ2dnZGvz5FN8r9mybYbOt41M2dOxeZmZmYP3++Yh+Xy8Xq1auRkJCAjRs3ml0msViMZs2aoXfv3mjZsiU2b94MNput8L4mJiYiLS0Nr169wltvvYUWLVqYXUZdWMd/tpry7NkznD9/Hi1btlTsu337NmbMmIHRo0eja9euyMzMxN27dzFx4kQsXrwYAwYMQEhICC5evIj09HSsX78e8fHxel/z1atX+PDDD7Fs2TIEBASoHV+5ciW++uordOjQAT///DMAYN68eWCxWIiLi1PI3apVK40uxdTUVPz9998ICQlBZGQkcnNzDf1ZKFZGcXExAMDJyUkxVCgfvrl//z6Cg4ORlpaGQ4cOITU1FYsWLVLEQUkkEkycOBEBAQHo1asXpFIpAOD69etYvny54hp79+7F119/jXXr1mHo0KFqQwLlsX37dty6dQvffPON2jFNbSo5ORmBgYHo3LkzMjIyAADffPMNpkyZYtB1//vvP9jb22PkyJHw8/PDzp07DTqfYhkSEhLw2Wef4aeffkL//v3x6tUrFBYWYtasWejWrRs2btyIrl27omHDhnjw4AFmzpypeNDLh/811aELQgh+++03hIeHqxm6NWvWREhICHbu3InMzEx069YNo0aNAgCcOHECfD4fp0+fBsC8wH7xxReYNGkSwsLC8PDhQzx58gRffPEFPv30U0ydOhV16tTBgQMHwOPxMHXqVJSUlKC4uBi9e/fGnj17VK7N4/EwYsQIxXcHBwe4ubmhXr16ABgdz8zMRI8ePdCwYUNcvXq1Mj+98bG0K6g6sW3bNgKAjBw5krz//vvExcWFfP7550QgEBBCCJFKpaRfv35EIpEQQgh55513yEcffUSkUimJjo4mHTt2JOnp6SQuLo4QQggAvYdr5s2bR3x8fEhISAgZOHCgxjK///47+eWXXwghhJw7d45wOBySlpZGxGIxqVu3Ltm+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",
      "text/plain": [
       "<Figure size 660x150 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "fig, axs = plt.subplots(ncols=3, nrows=2, figsize=figsizeM )\n",
    "fig.subplots_adjust(wspace=0.175 )\n",
    "\n",
    "#############\n",
    "# plot 1   #\n",
    "############\n",
    "\n",
    "layIndex = 4\n",
    "\n",
    "#Plot 1\n",
    "plotOverlapSmall( spectralAx=axs[0][0]  , overlapAx=axs[1][0] , filePath='WikiText_Bert', matrName=f'bert.encoder.layer.{layIndex}.attention.self.key',\n",
    "             upperBin=3.5, sigma3Interval=( 0.0877, 0.1612) , title=f\"Bert, Key {layIndex+1}\")\n",
    "\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[0][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "\n",
    "layIndex = 14\n",
    "with open(f\"../Data/WikiText_Pythia_step143000\", 'rb') as file:\n",
    "        FM_data = pickle.load( file)\n",
    "k=1\n",
    "matr_name = f\"gpt_neox.layers.{layIndex}.attention.query_key_value\"\n",
    "weight = FM_data[matr_name][\"weight\"][k*1024:(k+1)*1024,:].astype(np.float64)\n",
    "\n",
    "plotOverlapSmall( spectralAx=axs[0][1]  , overlapAx=axs[1][1] , filePath='WikiText_Pythia_step143000' , matrName=matr_name, \n",
    "            upperBin=2.6, sigma3Interval=( 0.07915 ,0.14159), title=f\"Pythia, Key {layIndex+1}\", weight=weight)\n",
    "\n",
    "layIndex = 24\n",
    "plotOverlapSmall( spectralAx=axs[0][2]  , overlapAx=axs[1][2] , filePath='Llama3_1_8B_WikiText' , matrName=f\"model.layers.{layIndex}.self_attn.q_proj\", # use something from layer 20\n",
    "            upperBin=4.5, sigma3Interval=(0.04664 ,0.07524), title=f\"Llama, Query {layIndex+1}\")\n",
    "\n",
    "\n",
    "pad = 2\n",
    "# first axis:\n",
    "ax = axs[1][0]\n",
    "ax.legend(loc=\"upper left\", bbox_to_anchor=(0.0, 1.1), handlelength=1,handletextpad =0.4,labelspacing=0.2)\n",
    "ax.set_ylim(0,0.499)\n",
    "ax.set_yticks([0,0.3]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.3\"]) \n",
    "ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "\n",
    "# second axis:\n",
    "ax = axs[1][1]\n",
    "ax.set_ylim(0,0.31)\n",
    "ax.set_yticks([0,0.2]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.2\"]) \n",
    "ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "# thrid axis:\n",
    "ax = axs[1][2]\n",
    "ax.set_ylim(0,0.21)\n",
    "ax.set_yticks([0,0.1]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.1\"]) \n",
    "ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "# second axis upper\n",
    "ax = axs[0][1]\n",
    "ax.set_yticks([0,0.8]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.8\"]) \n",
    "\n",
    "# thrid axis upper\n",
    "ax = axs[0][2]\n",
    "ax.set_yticks([0,0.8]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.8\"]) \n",
    "\n",
    "\n",
    "# Remove unwanted Axis\n",
    "for i in range(3):\n",
    "    pad = 2.5\n",
    "    ax = axs[0][i]\n",
    "    ax.set_xticklabels([]) \n",
    "    ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plot2.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plot2.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Figure where the Overlap with the activation covariance matrix is plotted for non-Square matrices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_10632\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x150 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "fig, axs = plt.subplots(ncols=3, nrows=2, figsize=figsizeM )\n",
    "fig.subplots_adjust(wspace=0.175 )\n",
    "\n",
    "#############\n",
    "# plot 1   #\n",
    "############\n",
    "\n",
    "layIndex = 4\n",
    "\n",
    "#Plot 1\n",
    "plotOverlapSmall( spectralAx=axs[0][0]  , overlapAx=axs[1][0] , filePath='WikiText_Bert', matrName=f'bert.encoder.layer.{layIndex}.intermediate.dense',\n",
    "             upperBin=5.2, sigma3Interval=( 0.0877, 0.1612) , title=f\"Bert, Up-Proj. {layIndex+1}\")\n",
    "\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[0][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "\n",
    "layIndex = 14\n",
    "\n",
    "plotOverlapSmall( spectralAx=axs[0][1]  , overlapAx=axs[1][1] , filePath='WikiText_Pythia_step143000' , matrName=f\"gpt_neox.layers.{layIndex}.mlp.dense_h_to_4h\", \n",
    "            upperBin=3.5,sigma3Interval=( 0.07915 ,0.14159), title=f\"Pythia, Up-Proj. {layIndex+1}\")\n",
    "\n",
    "layIndex = 24\n",
    "\n",
    "plotOverlapSmall( spectralAx=axs[0][2]  , overlapAx=axs[1][2] , filePath='Llama3_1_8B_WikiText' , matrName=f\"model.layers.{layIndex}.mlp.up_proj\", # use something from layer 20\n",
    "            upperBin=3.5,  sigma3Interval=(0.04664 ,0.07524), title=f\"Llama, Up-Proj. {layIndex+1}\")\n",
    "\n",
    "\n",
    "# for i in range(3):\n",
    "#     axs[1][i].set_ylim(0,0.53)\n",
    "#     axs[1][i].legend(loc=\"upper center\", bbox_to_anchor=(0.5, 1.1), handlelength=1)\n",
    "\n",
    "\n",
    "pad = 2\n",
    "# first axis:\n",
    "ax = axs[1][0]\n",
    "ax.set_ylim(0,0.53)\n",
    "ax.set_yticks([0,0.3]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.3\"]) \n",
    "ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "\n",
    "# second axis:\n",
    "ax = axs[1][1]\n",
    "\n",
    "ax.set_ylim(0,0.49)\n",
    "ax.set_yticks([0,0.3]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.3\"]) \n",
    "ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "# thrid axis:\n",
    "ax = axs[1][2]\n",
    "ax.legend(loc=\"upper center\", bbox_to_anchor=(0.4, 1.1), handlelength=1)\n",
    "ax.set_ylim(0,0.38)\n",
    "ax.set_yticks([0,0.3]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.3\"]) \n",
    "ax.tick_params(axis='y', pad=pad) \n",
    "\n",
    "\n",
    "# second axis upper\n",
    "ax = axs[0][1]\n",
    "ax.set_yticks([0,0.5]) \n",
    "ax.set_yticklabels([\"0.0\",\"0.5\"]) \n",
    "\n",
    "\n",
    "\n",
    "# Remove unwanted Axis\n",
    "for i in range(3):\n",
    "    ax = axs[0][i]  \n",
    "    ax.set_xticklabels([])  \n",
    "\n",
    "\n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plot3.pdf\", bbox_inches='tight', dpi=300)\n",
    "plt.savefig(\"../Figures/Neurips_plot3.png\", bbox_inches='tight', dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Systematic View\n",
    "show for all three models and matrix types"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x300 with 35 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plotOverlap( spectralAx , overlapAx , FM_data, weight, upperBin, sigma3Interval, title, yLimit, withLegend=False, labelpad=-2):\n",
    "        \n",
    "    sVal , overlapP , outSideMP, leftOutside = analyzeLayer( ( FM_data ,weight ), mode=\"\" ) #\"mpStd\"\n",
    "\n",
    "    spectralAx.set_title(title)\n",
    "    spectralAx.set_xticklabels([])  \n",
    "\n",
    "    bins = np.linspace(0,upperBin,35)\n",
    "    _,_,patches = spectralAx.hist(sVal, bins=bins, density=True)\n",
    "\n",
    "    # theory curve\n",
    "    n = weight.shape[0]\n",
    "    m = weight.shape[1]\n",
    "    # std = np.std(weight)\n",
    "    std = estimate_sigma_med(weight)\n",
    "    x_theo = np.linspace(0,upperBin, 500)\n",
    "    y_theo = MP(x_theo , n, m, std )\n",
    "\n",
    "    # color outliers red\n",
    "    mp_min = np.min( x_theo[y_theo >0 ] )\n",
    "    mp_max = np.max( x_theo[y_theo >0 ] )\n",
    "\n",
    "    for i in range(len(patches)):\n",
    "        patch = patches[i]\n",
    "        if( patch.xy[0] > mp_max or patch.xy[0]+patch.get_width() < mp_min):\n",
    "            patch.set_facecolor('red') \n",
    "\n",
    "    spectralAx.plot(x_theo , y_theo  , \"--k\", label=\"Marchenko Pastur\", linewidth=1)\n",
    "\n",
    "    # Overlap\n",
    "    spectralAx.set_xlim(bins[0], bins[-1])\n",
    "    overlapAx.set_xlim(bins[0], bins[-1])\n",
    "    overlapAx.set_ylim(None , yLimit )\n",
    "\n",
    "    # color outliers\n",
    "    if(n != m):\n",
    "        inside_mask = (sVal >= mp_min) & (sVal <= mp_max)\n",
    "    else:\n",
    "        inside_mask =  (sVal <= mp_max)\n",
    "    outside_mask = ~inside_mask\n",
    "    overlapAx.scatter(sVal[inside_mask], overlapP[inside_mask], s=scatterSize/1.5)\n",
    "    overlapAx.scatter(sVal[outside_mask], overlapP[outside_mask], s=scatterSize/1.5, color='red', zorder=-10)\n",
    "\n",
    "\n",
    "    overlapAx.set_xlabel(r\"$\\nu$\", labelpad=labelpad)\n",
    "\n",
    "    lowB = sigma3Interval[0]\n",
    "    upB = sigma3Interval[1]\n",
    "    overlapAx.axhspan(lowB, upB, xmin=0, xmax=1, facecolor=\"white\", alpha=0.2)\n",
    "\n",
    "\n",
    "    overlapAx.hlines(y= lowB , xmin=bins[0], xmax=bins[-1], colors=\"grey\" , linestyles=\"-.\", label=r\"$3\\sigma$ Interval\")\n",
    "    overlapAx.hlines(y= upB , xmin=bins[0], xmax=bins[-1], colors=\"grey\" , linestyles=\"-.\")\n",
    "\n",
    "    if(withLegend):\n",
    "        overlapAx.legend( loc=\"upper left\", handlelength=0.6, fontsize= fontsize-2,\n",
    "                handletextpad =0.2, bbox_to_anchor=(-0.1, 1.07), )\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "layIndex = 9\n",
    "\n",
    "llamaAllLayers = [ f\"model.layers.{layIndex}.self_attn.q_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.k_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.v_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.o_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.gate_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.up_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.down_proj\"]\n",
    "\n",
    "pythiaAllLayers = [ f\"gpt_neox.layers.{layIndex}.attention.query_key_value\",\n",
    "f\"gpt_neox.layers.{layIndex}.attention.dense\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_h_to_4h\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_4h_to_h\"]\n",
    "\n",
    "\n",
    "\n",
    "height_ratios = [ 22.5, 22.5,  7.5, 22.5, 22.5]\n",
    "\n",
    "fig, axs = plt.subplots(\n",
    "    nrows=5,\n",
    "    ncols=7,\n",
    "    figsize=(6.6, 3),\n",
    "    gridspec_kw={'height_ratios': height_ratios}\n",
    ")\n",
    "\n",
    "fig.subplots_adjust(wspace=0.1, hspace=0.1 )\n",
    "\n",
    "\n",
    "\n",
    "for axisInd ,modelLayers in zip( [0,3] ,[pythiaAllLayers ,llamaAllLayers ]): #\n",
    "    withLegend = [True] + [False]*6\n",
    "\n",
    "\n",
    "    if(axisInd == 0):\n",
    "        with open(f\"../Data/WikiText_Pythia_step143000\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds = [( 0.07915 ,0.14159) ]*6 + [(0.04664 ,0.07524)]\n",
    "        upperBinBounds = [2.5]*4 + [3.5]*3\n",
    "        yLimit = 0.14869*2.5\n",
    "        labelPad = [-6]*7\n",
    "            \n",
    "    if(axisInd == 3):\n",
    "        with open(f\"../Data/Llama3_1_8B_WikiText\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds =  [(0.04664 ,0.07524)]*6 + [(0.027972, 0.04226106)]\n",
    "        upperBinBounds = [4.4]*2 + [1.7]+[2.5] + [4.8] +[3.7] + [4.3]\n",
    "        yLimit = 0.078605*2.5\n",
    "        labelPad = [-2]*7\n",
    "\n",
    "\n",
    "    j = 0\n",
    "    for modelLayer in modelLayers:\n",
    "\n",
    "        if modelLayer == f\"gpt_neox.layers.{layIndex}.attention.query_key_value\":\n",
    "            for k in range(3):\n",
    "                weight = feauterM[modelLayer][\"weight\"][k*1024:(k+1)*1024,:].astype(np.float64)\n",
    "                features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "\n",
    "                plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "                j += 1\n",
    "        else:\n",
    "            weight = feauterM[modelLayer][\"weight\"].astype(np.float64)\n",
    "            features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "            plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "\n",
    "            j += 1\n",
    "        # skip the gate proj layer for pythia and Bert\n",
    "        if( modelLayer == f\"gpt_neox.layers.{layIndex}.attention.dense\" ):\n",
    "            j += 1\n",
    "\n",
    "\n",
    "\n",
    "titles = [\"Query\", \"Key\", \"Value\", \"Att.-Out\", \"Gate-Proj.\", \"Up-Proj.\", \"Down-Proj.\" ]\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[0][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "axs[4][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[3][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "\n",
    "\n",
    "\n",
    "for axInd , label in zip( [0,3], [f\"Pythia Block {layIndex+1}    \", f\"Llama Block {layIndex+1}    \" ]):\n",
    "    axs[axInd][-1].yaxis.set_label_position(\"right\")\n",
    "    axs[axInd][-1].set_ylabel(label,  fontsize= fontsize)\n",
    "\n",
    "\n",
    "# fix missplaced x-ticks\n",
    "for j in range(4):\n",
    "    axs[1][j].set_xticks([0,2],[\"0\",\"2\"])\n",
    "axs[4][3].set_xticks([0,2],[\"0\",\"2\"])\n",
    "\n",
    "\n",
    "\n",
    "# make the middle axis invisible\n",
    "for ax in axs[2]:\n",
    "    ax.axis(\"off\")\n",
    "\n",
    "# remove the gated Proj for Pythia \n",
    "for i in range(3):\n",
    "    axs[i,4].axis(\"off\")\n",
    "\n",
    "for j in range(1,7):\n",
    "    for k in range(5):\n",
    "        axs[k][j].set_yticks([])\n",
    "\n",
    "\n",
    "for j in range(7):\n",
    "    if(j != 4):\n",
    "        axs[0][j].set_title(titles[j])\n",
    "    else:\n",
    "        axs[3][j].set_title(titles[j])\n",
    "        \n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plot4.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plot4.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evidence in Perplexity Upon removal\n",
    "plot for Pythia and Llama"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 321,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "pythiaInfo = { \"Query\":{\"title\":\"Query\", \"suffix\":\"Q\", \"Sval\": [], \"dim\":(1024,1024), \"stds\": [] },\n",
    "              \"Key\":{\"title\":\"Key\", \"suffix\":\"K\", \"Sval\": [] , \"dim\":(1024,1024), \"stds\": []},\n",
    "              \"Value\":{\"title\":\"Value\", \"suffix\":\"V\", \"Sval\": [] , \"dim\":(1024,1024), \"stds\": []},\n",
    "              \"AttOut\":{\"title\":\"Att.-Out\", \"suffix\":\"attention.dense.weight\", \"Sval\": [], \"dim\":(1024,1024) , \"stds\": []},\n",
    "              \"UpProj\":{\"title\":\"Up-Proj.\", \"suffix\":\"mlp.dense_4h_to_h.weight\", \"Sval\": [], \"dim\":(1024,4096) , \"stds\": []},\n",
    "              \"DownProj\":{\"title\":\"Down-Proj.\", \"suffix\":\"mlp.dense_h_to_4h.weight\", \"Sval\": [] , \"dim\":(4096,1024), \"stds\": []},\n",
    "              }\n",
    "\n",
    "LlamaInfo = { \"Query\":{\"title\":\"Query\", \"suffix\":\"self_attn.q_proj\", \"Sval\": [], \"dim\":(4096, 4096), \"stds\": [] },\n",
    "              \"Key\":{\"title\":\"Key\", \"suffix\":\"self_attn.k_proj\", \"Sval\": [] , \"dim\":(1024,4096), \"stds\": []},\n",
    "              \"Value\":{\"title\":\"Value\", \"suffix\":\"self_attn.v_proj\", \"Sval\": [] , \"dim\":(1024,4096), \"stds\": []},\n",
    "              \"AttOut\":{\"title\":\"Att.-Out\", \"suffix\":\"self_attn.o_proj\", \"Sval\": [], \"dim\":(4096,4096) , \"stds\": []}, #\n",
    "              \"GateProj\":{\"title\":\"Gate-Proj.\", \"suffix\":\"mlp.gate_proj\", \"Sval\": [], \"dim\":(14336, 4096) , \"stds\": []},\n",
    "              \"UpProj\":{\"title\":\"Up-Proj.\", \"suffix\":\"mlp.up_proj\", \"Sval\": [], \"dim\":(14336, 4096) , \"stds\": []},\n",
    "              \"DownProj\":{\"title\":\"Down-Proj.\", \"suffix\":\"mlp.down_proj\", \"Sval\": [] , \"dim\":(4096, 14336), \"stds\": []},\n",
    "              }\n",
    "\n",
    "with open(f\"../Data/WikiText_Pythia_step143000\", 'rb') as file:\n",
    "    FM_Wiki_Pythia = pickle.load( file)\n",
    "\n",
    "with open(f\"../Data/Llama3_1_8B_WikiText\", 'rb') as file:\n",
    "    FM_Wiki_Llama = pickle.load( file)\n",
    "\n",
    "\n",
    "# generate the Pythia Singular value spectra\n",
    "folderP= \"../PythiaSVD/pythia-410m-deduped_step143000\"\n",
    "for i in range(24):\n",
    "    attenionString = f\"gpt_neox.layers.{i}.attention.query_key_value\"\n",
    "    pythiaInfo[\"Query\"][\"Sval\"].append( torch.load(f\"{folderP}/{attenionString}.weight_Q_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "    weight = FM_Wiki_Pythia[attenionString][\"weight\"][:1024,:].astype(np.float64)\n",
    "    pythiaInfo[\"Query\"][\"stds\"].append(estimate_sigma_med(weight ))\n",
    "\n",
    "    pythiaInfo[\"Key\"][\"Sval\"].append( torch.load(f\"{folderP}/{attenionString}.weight_K_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "    weight = FM_Wiki_Pythia[attenionString][\"weight\"][1024:2048,:].astype(np.float64)\n",
    "    pythiaInfo[\"Key\"][\"stds\"].append(estimate_sigma_med(weight ))\n",
    "\n",
    "    pythiaInfo[\"Value\"][\"Sval\"].append( torch.load(f\"{folderP}/{attenionString}.weight_V_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "    weight = FM_Wiki_Pythia[attenionString][\"weight\"][2048:,:].astype(np.float64) \n",
    "    pythiaInfo[\"Value\"][\"stds\"].append(estimate_sigma_med(weight))\n",
    "\n",
    "    attOutString = f\"gpt_neox.layers.{i}.attention.dense\"\n",
    "    pythiaInfo[\"AttOut\"][\"Sval\"].append( torch.load(f\"{folderP}/{attOutString}.weight_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "    weight = FM_Wiki_Pythia[attOutString][\"weight\"].astype(np.float64)\n",
    "    pythiaInfo[\"AttOut\"][\"stds\"].append(estimate_sigma_med(weight))\n",
    "\n",
    "    upProjString = f\"gpt_neox.layers.{i}.mlp.dense_h_to_4h\"\n",
    "    pythiaInfo[\"UpProj\"][\"Sval\"].append( torch.load(f\"{folderP}/{upProjString}.weight_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "    weight = FM_Wiki_Pythia[upProjString][\"weight\"].astype(np.float64)\n",
    "    pythiaInfo[\"UpProj\"][\"stds\"].append(estimate_sigma_med(weight))\n",
    "\n",
    "    downProjString = f\"gpt_neox.layers.{i}.mlp.dense_4h_to_h\"\n",
    "    pythiaInfo[\"DownProj\"][\"Sval\"].append( torch.load(f\"{folderP}/{downProjString}.weight_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "    weight = FM_Wiki_Pythia[downProjString][\"weight\"].astype(np.float64)\n",
    "    pythiaInfo[\"DownProj\"][\"stds\"].append(estimate_sigma_med(weight))\n",
    "\n",
    "\n",
    "    \n",
    "for i in [0,4,9,14,19,24,29]:\n",
    "    folderP= f\"../LlamaSVD/model.layers.{i}.\"\n",
    "\n",
    "    for key in LlamaInfo.keys():\n",
    "        loadS = LlamaInfo[key][\"suffix\"]\n",
    "\n",
    "        LlamaInfo[key][\"Sval\"].append( torch.load(f\"{folderP}{loadS}.weight_S\", weights_only=False).numpy().astype(np.float64) )\n",
    "        weight = FM_Wiki_Llama[f\"model.layers.{i}.{loadS}\"][\"weight\"][:1024,:].astype(np.float64)\n",
    "        LlamaInfo[key][\"stds\"].append(estimate_sigma_med(weight ))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 285,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x160 with 14 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(nrows=2, ncols=7, figsize=(6.6, 2*1.2/1.5) )\n",
    "fig.subplots_adjust(wspace=0.35, hspace=0.2 )\n",
    "\n",
    "#####################################\n",
    "########### Pythia ##################\n",
    "#####################################\n",
    "\n",
    "basePerplexity = 14.6417427\n",
    "\n",
    "plotIndex = 0\n",
    "for i,key in enumerate(pythiaInfo.keys()):\n",
    "    data = pythiaInfo[key]\n",
    "    perplexity = np.load(f\"../Data/Perplexity/perplexityPythia_{143000}_{\"WikiText\"}_{data[\"suffix\"]}.npy\")\n",
    "    perplexity = np.flip(perplexity)\n",
    "\n",
    "    ax = axs[0][plotIndex]\n",
    "\n",
    "    ax.set_title(data[\"title\"] )\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.set_xticks([1, 3,5, 7,9])  # Tick positions\n",
    "    ax.set_xticklabels(labels=[])  # Labels for the ticks\n",
    "    if( plotIndex == 0):\n",
    "        ax.set_ylabel(r\"   $\\Delta$Perplexity\")\n",
    "\n",
    "\n",
    "    if( \"UpProj\" in key or \"DownProj\" in key  ):\n",
    "        barColors = ['red']+ [colors[0]] * 9 \n",
    "    else:\n",
    "        barColors = [colors[0]] * 10 \n",
    "\n",
    "    ax.bar(np.linspace(1,10,10), perplexity-basePerplexity, color = barColors)\n",
    "\n",
    "    \n",
    "    # Inset plot \n",
    "    sval = np.ndarray.flatten( np.array(data[\"Sval\"]) )\n",
    "    in_ax = ax.inset_axes([0.0, 0.5, 0.5, 0.5]) # lower left corner (x,y,height, width)\n",
    "        \n",
    "    bins = np.linspace(0,4,35)\n",
    "    in_ax.hist(sval, bins=bins, density=True)\n",
    "    in_ax.set_xticks([])  \n",
    "    in_ax.set_yticks([])  \n",
    "    in_ax.set_xticklabels(labels=[])  # Labels for the ticks\n",
    "\n",
    "\n",
    "    n , m = data[\"dim\"]\n",
    "    \n",
    "    if( n != m ):\n",
    "        std = np.mean(data[\"stds\"])\n",
    "    else:\n",
    "        1/np.sqrt(np.max(np.array([n,m])))\n",
    "\n",
    "\n",
    "    # theory curve\n",
    "    x_theo = np.linspace(0,3.6, 500)\n",
    "    y_theo = MP(x_theo , n, m, std )\n",
    "    mpMax = x_theo[y_theo > 0][-1]\n",
    "    mpMin = x_theo[y_theo > 0][0]\n",
    "    in_ax.plot(x_theo , y_theo  , \"--k\", label=\"Marchenko Pastur\", linewidth=1)\n",
    "\n",
    "    plotIndex += 1\n",
    "    if(plotIndex == 4):\n",
    "        plotIndex += 1\n",
    "    \n",
    "\n",
    "axs[0,4].axis(\"off\")\n",
    "   \n",
    "\n",
    "#####################################\n",
    "########### Llama ##################\n",
    "#####################################\n",
    "\n",
    "basePerplexity = 5.42733\n",
    "\n",
    "for i,key in enumerate(LlamaInfo.keys()):\n",
    "    data = LlamaInfo[key]\n",
    "    perplexity = np.load(f\"../Data/Perplexity/perplexityLlamaWikiText_{data[\"suffix\"]}.weight.npy\")\n",
    "    perplexity = np.flip(perplexity)\n",
    "\n",
    "    ax = axs[1][i]\n",
    "\n",
    "    if(data[\"title\"] == \"Gate-Proj.\"):\n",
    "        ax.set_title(data[\"title\"] )\n",
    "\n",
    "\n",
    "    ax.set_xlabel(\"decentile removed\", fontsize= fontsize-3, labelpad=-2)\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.set_xticks([1, 3,5, 7,9])  # Tick positions\n",
    "    ax.set_xticklabels(labels=[\"1\", \"3\",\"5\", \"7\",\"9\"])  # Labels for the ticks\n",
    "    if( i == 0):\n",
    "        ax.set_ylabel(r\"$\\Delta$Perplexity   \", labelpad=-1)\n",
    "\n",
    "\n",
    "    n , m = data[\"dim\"]\n",
    "    if( n != m ):\n",
    "        std = np.mean(data[\"stds\"])\n",
    "    else:\n",
    "        1/np.sqrt(np.max(np.array([n,m])))\n",
    "\n",
    "    if( m != n  ):\n",
    "        barColors = ['red']+ [colors[0]] * 9 \n",
    "    else:\n",
    "        barColors = [colors[0]] * 10 \n",
    "\n",
    "    ax.bar(np.linspace(1,10,10), perplexity-basePerplexity, color = barColors)\n",
    "\n",
    "    \n",
    "    # Inset plot \n",
    "    sval = np.ndarray.flatten( np.array(data[\"Sval\"]) )\n",
    "    in_ax = ax.inset_axes([0.0, 0.5, 0.5, 0.5]) # lower left corner (x,y,height, width)\n",
    "        \n",
    "    bins = np.linspace(0,4.5,35)\n",
    "    in_ax.hist(sval, bins=bins, density=True)\n",
    "    in_ax.set_xticks([])  \n",
    "    in_ax.set_yticks([])  \n",
    "    in_ax.set_xticklabels(labels=[])  # Labels for the ticks\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    # theory curve\n",
    "    x_theo = np.linspace(0,3.6, 500)\n",
    "    y_theo = MP(x_theo , n, m, std )\n",
    "    mpMax = x_theo[y_theo > 0][-1]\n",
    "    mpMin = x_theo[y_theo > 0][0]\n",
    "    in_ax.plot(x_theo , y_theo  , \"--k\", label=\"Marchenko Pastur\", linewidth=1)\n",
    "\n",
    "\n",
    "# fix missplaced y-ticks\n",
    "for j in range(4):\n",
    "    axs[0][j].set_yticks([1,100],[r\"$10^0$\",r\"$10^2$\"])\n",
    "axs[1][0].set_yticks([0.1,100],[r\"$10^{-1}$\",r\"$10^2$\"])\n",
    "\n",
    "for i in range(7):\n",
    "    for j in range(2):\n",
    "        axs[j][i].set_ylim(top=3e3)\n",
    "        axs[j][i].tick_params(axis='y', which='major', labelsize=8, pad=0.5)\n",
    "        \n",
    "\n",
    "\n",
    "\n",
    "labels= [\"Pythia\" , \"Llama\"]\n",
    "for i in range(2):\n",
    "    axs[i][-1].yaxis.set_label_position(\"right\")\n",
    "    axs[i][-1].set_ylabel(labels[i])\n",
    "\n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plot5.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plot5.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evidence in relevance for finetuning Bert"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "########### Data aquisition ################\n",
    "path = \"../Data/FinetuningResults\"\n",
    "\n",
    "# BoolQ\n",
    "# results from legacy code:\n",
    "boolqRF = np.load(f\"{path}/boolqRF.npy\")\n",
    "boolqFullM = np.load(f\"{path}/boolqFullM.npy\")\n",
    "boolqFR = np.load(f\"{path}/boolqFR.npy\")\n",
    "\n",
    "\n",
    "# RTE\n",
    "\n",
    "numberRes = 6\n",
    "dataArray = []\n",
    "\n",
    "for i in range(numberRes):\n",
    "    data = np.load(f\"{path}/Bert_rte_decentile_removeFirst_{i}.npy\")\n",
    "    dataArray.append(np.flip(data))\n",
    "\n",
    "rteRF = np.array(dataArray)\n",
    "\n",
    "# first finetune, then reduce\n",
    "dataArray = []\n",
    "fullModel = []\n",
    "\n",
    "\n",
    "for i in range(numberRes):\n",
    "    data = np.load(f\"{path}/Bert_rte_decentile_removal_{i}.npy\")\n",
    "    # only use runs that did train\n",
    "    if(data[0]>0.6):\n",
    "        dataArray.append(np.flip(data[1:]))\n",
    "        fullModel.append(data[0])\n",
    "rteFR = np.array(dataArray)\n",
    "rteFullM = np.array(fullModel)\n",
    "\n",
    "# sst2\n",
    "dataArray = []\n",
    "\n",
    "for i in range(numberRes):\n",
    "    data = np.load(f\"{path}/Bert_sst2_decentile_removeFirst_{i}.npy\")\n",
    "    dataArray.append(np.flip(data))\n",
    "\n",
    "sstRF = np.array(dataArray)\n",
    "\n",
    "# first finetune, then reduce\n",
    "dataArray = []\n",
    "fullModel = []\n",
    "\n",
    "for i in range(numberRes):\n",
    "    data = np.load(f\"{path}/Bert_sst2_decentile_removal_{i}.npy\")\n",
    "    if(data[0]>0.6):\n",
    "        dataArray.append(np.flip(data[1:]))\n",
    "        fullModel.append(data[0])\n",
    "sstFR = np.array(dataArray)\n",
    "sstFullM = np.array(fullModel)\n",
    "\n",
    "titles = [\"BoolQ\", \"RTE\", \"SST2\"]\n",
    "fullModels = [ boolqFullM, rteFullM, sstFullM]\n",
    "dataRFList = [boolqRF, rteRF, sstRF]\n",
    "dataFRList = [boolqFR, rteFR, sstFR]\n",
    "\n",
    "markers = [\"o\", \"v\", \"x\"]\n",
    "colorsList = [ colors[0], colors[1], colors[2]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x200 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1,2, figsize=figsize)\n",
    "plt.subplots_adjust(left=None, bottom=None, right=None, top=None, wspace=.1)\n",
    "\n",
    "ax_flat = axs.flatten()\n",
    "\n",
    "\n",
    "for title ,fullModel, dataRF, dataFR, marker , color in zip(titles, fullModels, dataRFList, dataFRList, markers, colorsList):\n",
    "\n",
    "    meanVal = np.mean(fullModel)\n",
    "    rescale = 1 \n",
    "    std = np.std(fullModel)\n",
    "\n",
    "    # first plot\n",
    "    axs = ax_flat[0]\n",
    "    axs.plot(np.linspace(1,10, 10), np.mean(dataRF, axis=0)*rescale, marker=marker, ls=\"none\" ,  label=title, **nice_points(color))\n",
    "\n",
    "    # second plot\n",
    "    axs = ax_flat[1]\n",
    "    axs.set_yticklabels([])\n",
    "    axs.plot(np.linspace(1,10, 10), np.mean(dataFR, axis=0)*rescale,  marker=marker, ls=\"none\",  label='_nolegend_', **nice_points(color)) \n",
    "\n",
    "\n",
    "    for i in range(2):\n",
    "\n",
    "        numStd= 3\n",
    "        lowB = (meanVal-std*numStd)\n",
    "        upB = (meanVal+std*numStd)\n",
    "\n",
    "        ax_flat[i].hlines(y= lowB , xmin=0.7, xmax=10.3, colors=\"grey\" , linestyles=\"-.\")\n",
    "        ax_flat[i].hlines(y= upB , xmin=0.7, xmax=10.3, colors=\"grey\" , linestyles=\"-.\")\n",
    "\n",
    "        ax_flat[i].set_xticks([1, 3,5, 7,9])  # Tick positions\n",
    "        ax_flat[i].set_xticklabels(labels=[\"1\",\"3\", \"5\", \"7\", \"9\"])  # Labels for the ticks\n",
    "            \n",
    "ax_flat[1].hlines(y= lowB , xmin=1, xmax=10, colors=\"grey\" , linestyles=\"-.\", label=r\"$3\\sigma$ Interval\")\n",
    "\n",
    "\n",
    "ylimits = (0.42,0.96)\n",
    "for i in range(2):\n",
    "    ax_flat[i].set_ylim(ylimits)\n",
    "    ax_flat[i].set_xlabel(\"decentile removed\", fontsize= fontsize, labelpad = 0)\n",
    "\n",
    "ax_flat[0].set_ylabel(\"validation accuracy\", fontsize= fontsize)\n",
    "ax_flat[0].set_title(\"reduce, finetune\", fontsize= fontsize)\n",
    "ax_flat[1].set_title(\"finetune, reduce\", fontsize= fontsize)\n",
    "\n",
    "\n",
    "ax_flat[0].legend(\n",
    "    loc=\"lower center\",\n",
    "    bbox_to_anchor=(0.5, -0.01),  # x and y position\n",
    "    handlelength=handlelength,\n",
    "    handletextpad =0.7,\n",
    "    fontsize = fontsize,\n",
    "    ncol=3,\n",
    "    columnspacing=0.7,  \n",
    "    labelspacing=0.3 )\n",
    "\n",
    "ax_flat[1].legend(\n",
    "    loc=\"lower center\",\n",
    "    bbox_to_anchor=(0.5, -0.01),  # x and y position\n",
    "    handlelength=handlelength,\n",
    "    handletextpad =0.7,\n",
    "    fontsize = fontsize,\n",
    "    columnspacing=0.7,  \n",
    "    labelspacing=0.3 )\n",
    "\n",
    "    \n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plot6.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plot6.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Appendix Plots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## All weight matrices overlap layer 4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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zz/n4MGDOgfuc+fOUb58eapVq5Ykb2BgoMkWWMTFxSXpJzZs2MDSpUtZv349AwYM4MGDBxw/fhzQOJpHR0fz4YcfApqRne7du7NlyxY+/PBDOnTowLlz56hTp46uvMTlpxUPKb26HDx4MBs3buTNmzcAHDx4EF9fXzw8PJLkPXToEAsWLEi1fqNiCccoW2D+/PmiTp06YunSpWLNmjWicePG4uuvvxZxcXFCCCG2bNkicufOLerWrSt+//130bRpU7F3714hhMZhsECBAsLT01NMmDBBCCHEn3/+KRwcHES3bt1EUFCQXl3x8fF6znO2zJUrV0SnTp0EIAYOHCju3r0r3rx5IyZOnCgA4ezsLH7++edkdZSQzz77TNy5c8cCV2B6goODdU7XWq5cuSIKFy4sfHx8xOrVq0XdunVFkyZNxKVLl0T16tVFuXLldAsM5s2bJ3LkyCFatmwpli5dKj766CNx9uxZoVarxdixY4WHh4coWLCgWLRokSUuL1U2bdoknJ2dk8h27NgxUbBgQeHo6CjWrVsn+vbtK0qXLi22b98uhBCiefPmonr16uL48eMiJCREFCpUSNy9ezfVuvz9/UWbNm3EoEGDxOeffy46dOggjhw5opcmJV0mrlPGejl79qxo2rSpaNCggfjoo49E586dRUBAgO48IIYOHSomTZokunfvLq5du5ZsOWFhYWLEiBECEJ07dxYXLlzQO3/48GGRJ08e0axZM3H58mXd8T///FN07NhR/PTTT2LIkCF68b8aNmwoVq1aJYQQYvPmzaJ69erGvHQhhMZpumLFikKhUIiBAweKYcOGie7du4vhw4fryXL8+HHRvn17nZyBgYF65Vy/fl0sWLBA933s2LEiNjZW933t2rUCENOmTRNPnjwRH374ociXL5+4ePFiEplu374tunfvrtN9Yuf5lJ6HS5YsEb6+vmLatGniiy++0FuQUbRoUd3Cp1mzZomOHTtmUGPpRxJCHm9OiZcvX1K1alWCg4P5+++/ad26tUnqOXToEHfu3KF3794mKd/WUKvV9O/fn99++83SosjIyNg4kiQRHBycop+MKWnYsCFfffVVEncNmfRTtGhRduzYQYUKFcxet+zMnQo5cuRg//79dOzYke7du7NmzRrdUKUxWLVqFaCZ392yZYvRyrVVLl++zN9//83jx4/ljkVGRsZo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",
      "text/plain": [
       "<Figure size 660x300 with 35 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "layIndex = 4\n",
    "\n",
    "llamaAllLayers = [ f\"model.layers.{layIndex}.self_attn.q_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.k_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.v_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.o_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.gate_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.up_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.down_proj\"]\n",
    "\n",
    "pythiaAllLayers = [ f\"gpt_neox.layers.{layIndex}.attention.query_key_value\",\n",
    "f\"gpt_neox.layers.{layIndex}.attention.dense\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_h_to_4h\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_4h_to_h\"]\n",
    "\n",
    "\n",
    "height_ratios = [ 22.5, 22.5,  7.5, 22.5, 22.5]\n",
    "\n",
    "fig, axs = plt.subplots(\n",
    "    nrows=5,\n",
    "    ncols=7,\n",
    "    figsize=(6.6, 3),\n",
    "    gridspec_kw={'height_ratios': height_ratios}\n",
    ")\n",
    "\n",
    "fig.subplots_adjust(wspace=0.1, hspace=0.1 )\n",
    "\n",
    "\n",
    "\n",
    "for axisInd ,modelLayers in zip( [0,3] ,[pythiaAllLayers ,llamaAllLayers ]): #\n",
    "    withLegend =  [False]*6 + [True] \n",
    "\n",
    "\n",
    "    if(axisInd == 0):\n",
    "        with open(f\"../Data/WikiText_Pythia_step143000\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds = [( 0.07915 ,0.14159) ]*6 + [(0.04664 ,0.07524)]\n",
    "        upperBinBounds = [2.5]*4 + [3.5]*3\n",
    "        yLimit = 0.14869*2.5\n",
    "        labelPad = [-6]*7\n",
    "            \n",
    "    if(axisInd == 3):\n",
    "        with open(f\"../Data/Llama3_1_8B_WikiText\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds =  [(0.04664 ,0.07524)]*6 + [(0.027972, 0.04226106)]\n",
    "        upperBinBounds = [4.4]*2 + [1.7]+[2.5] + [4.8] +[3.7] + [4.3]\n",
    "        yLimit = 0.078605*2.5\n",
    "        labelPad = [-2]*7\n",
    "\n",
    "\n",
    "    j = 0\n",
    "    for modelLayer in modelLayers:\n",
    "\n",
    "        if modelLayer == f\"gpt_neox.layers.{layIndex}.attention.query_key_value\":\n",
    "            for k in range(3):\n",
    "                weight = feauterM[modelLayer][\"weight\"][k*1024:(k+1)*1024,:].astype(np.float64)\n",
    "                features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "\n",
    "                plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "                j += 1\n",
    "        else:\n",
    "            weight = feauterM[modelLayer][\"weight\"].astype(np.float64)\n",
    "            features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "            plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "\n",
    "            j += 1\n",
    "        # skip the gate proj layer for pythia and Bert\n",
    "        if( modelLayer == f\"gpt_neox.layers.{layIndex}.attention.dense\" ):\n",
    "            j += 1\n",
    "\n",
    "\n",
    "\n",
    "titles = [\"Query\", \"Key\", \"Value\", \"Att.-Out\", \"Gate-Proj.\", \"Up-Proj.\", \"Down-Proj.\" ]\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[0][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "axs[4][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[3][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "\n",
    "\n",
    "\n",
    "for axInd , label in zip( [0,3], [f\"Pythia Block {layIndex+1}    \", f\"Llama Block {layIndex+1}    \" ]):\n",
    "    axs[axInd][-1].yaxis.set_label_position(\"right\")\n",
    "    axs[axInd][-1].set_ylabel(label,  fontsize= fontsize)\n",
    "\n",
    "\n",
    "# fix missplaced x-ticks\n",
    "for j in range(4):\n",
    "    axs[1][j].set_xticks([0,2],[\"0\",\"2\"])\n",
    "axs[4][3].set_xticks([0,2],[\"0\",\"2\"])\n",
    "\n",
    "\n",
    "\n",
    "# make the middle axis invisible\n",
    "for ax in axs[2]:\n",
    "    ax.axis(\"off\")\n",
    "\n",
    "# remove the gated Proj for Pythia \n",
    "for i in range(3):\n",
    "    axs[i,4].axis(\"off\")\n",
    "\n",
    "for j in range(1,7):\n",
    "    for k in range(5):\n",
    "        axs[k][j].set_yticks([])\n",
    "\n",
    "\n",
    "for j in range(7):\n",
    "    if(j != 4):\n",
    "        axs[0][j].set_title(titles[j])\n",
    "    else:\n",
    "        axs[3][j].set_title(titles[j])\n",
    "        \n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plotApp1.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plotApp1.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## layer 14"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x300 with 35 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "layIndex = 14\n",
    "\n",
    "llamaAllLayers = [ f\"model.layers.{layIndex}.self_attn.q_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.k_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.v_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.o_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.gate_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.up_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.down_proj\"]\n",
    "\n",
    "pythiaAllLayers = [ f\"gpt_neox.layers.{layIndex}.attention.query_key_value\",\n",
    "f\"gpt_neox.layers.{layIndex}.attention.dense\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_h_to_4h\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_4h_to_h\"]\n",
    "\n",
    "\n",
    "height_ratios = [ 22.5, 22.5,  7.5, 22.5, 22.5]\n",
    "\n",
    "fig, axs = plt.subplots(\n",
    "    nrows=5,\n",
    "    ncols=7,\n",
    "    figsize=(6.6, 3),\n",
    "    gridspec_kw={'height_ratios': height_ratios}\n",
    ")\n",
    "\n",
    "fig.subplots_adjust(wspace=0.1, hspace=0.1 )\n",
    "\n",
    "\n",
    "\n",
    "for axisInd ,modelLayers in zip( [0,3] ,[pythiaAllLayers ,llamaAllLayers ]): #\n",
    "    withLegend =  [False]*6 + [True] \n",
    "\n",
    "\n",
    "    if(axisInd == 0):\n",
    "        with open(f\"../Data/WikiText_Pythia_step143000\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds = [( 0.07915 ,0.14159) ]*6 + [(0.04664 ,0.07524)]\n",
    "        upperBinBounds = [2.5]*4 + [3.5]*3\n",
    "        yLimit = 0.14869*2.5\n",
    "        labelPad = [-6]*7\n",
    "            \n",
    "    if(axisInd == 3):\n",
    "        with open(f\"../Data/Llama3_1_8B_WikiText\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds =  [(0.04664 ,0.07524)]*6 + [(0.027972, 0.04226106)]\n",
    "        upperBinBounds = [4.4]*2 + [1.7]+[2.5] + [4.8] +[3.7] + [4.3]\n",
    "        yLimit = 0.078605*2.5\n",
    "        labelPad = [-2]*7\n",
    "\n",
    "\n",
    "    j = 0\n",
    "    for modelLayer in modelLayers:\n",
    "\n",
    "        if modelLayer == f\"gpt_neox.layers.{layIndex}.attention.query_key_value\":\n",
    "            for k in range(3):\n",
    "                weight = feauterM[modelLayer][\"weight\"][k*1024:(k+1)*1024,:].astype(np.float64)\n",
    "                features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "\n",
    "                plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "                j += 1\n",
    "        else:\n",
    "            weight = feauterM[modelLayer][\"weight\"].astype(np.float64)\n",
    "            features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "            plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "\n",
    "            j += 1\n",
    "        # skip the gate proj layer for pythia and Bert\n",
    "        if( modelLayer == f\"gpt_neox.layers.{layIndex}.attention.dense\" ):\n",
    "            j += 1\n",
    "\n",
    "\n",
    "\n",
    "titles = [\"Query\", \"Key\", \"Value\", \"Att.-Out\", \"Gate-Proj.\", \"Up-Proj.\", \"Down-Proj.\" ]\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[0][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "axs[4][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[3][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "\n",
    "\n",
    "\n",
    "for axInd , label in zip( [0,3], [f\"Pythia Block {layIndex+1}    \", f\"Llama Block {layIndex+1}    \" ]):\n",
    "    axs[axInd][-1].yaxis.set_label_position(\"right\")\n",
    "    axs[axInd][-1].set_ylabel(label,  fontsize= fontsize)\n",
    "\n",
    "\n",
    "# fix missplaced x-ticks\n",
    "for j in range(4):\n",
    "    axs[1][j].set_xticks([0,2],[\"0\",\"2\"])\n",
    "axs[4][3].set_xticks([0,2],[\"0\",\"2\"])\n",
    "\n",
    "\n",
    "\n",
    "# make the middle axis invisible\n",
    "for ax in axs[2]:\n",
    "    ax.axis(\"off\")\n",
    "\n",
    "# remove the gated Proj for Pythia \n",
    "for i in range(3):\n",
    "    axs[i,4].axis(\"off\")\n",
    "\n",
    "for j in range(1,7):\n",
    "    for k in range(5):\n",
    "        axs[k][j].set_yticks([])\n",
    "\n",
    "\n",
    "for j in range(7):\n",
    "    if(j != 4):\n",
    "        axs[0][j].set_title(titles[j])\n",
    "    else:\n",
    "        axs[3][j].set_title(titles[j])\n",
    "        \n",
    "\n",
    "        \n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plotApp2.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plotApp2.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Time development of the Overlap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 297,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x150 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "layIndex = 9\n",
    "\n",
    "\n",
    "def plotOverlapTimeD( ax , weight , Fm, title,color, lineS , indicateLower=False, label=\"\", ):\n",
    "\n",
    "    \n",
    "    sVal , overlapP , outSideMP, leftOutside = analyzeLayer( ( Fm ,weight) )\n",
    "        \n",
    "    ax.plot(np.flip(overlapP), label=label, color=color, linestyle=lineS)\n",
    "    \n",
    "    ax.set_title(title)\n",
    "    ax.set_ylim(0,0.52)\n",
    "\n",
    "\n",
    "pythiaAllLayers = [ f\"gpt_neox.layers.{layIndex}.attention.query_key_value\",\n",
    "f\"gpt_neox.layers.{layIndex}.attention.dense\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_h_to_4h\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_4h_to_h\"]\n",
    "\n",
    "file_path = 'WikiText_Pythia_step143000' \n",
    "with open(f\"../Data/{file_path}\", 'rb') as file:\n",
    "    FM_data_3 = pickle.load( file)\n",
    "\n",
    "\n",
    "file_path = 'WikiText_Pythia_step20000' \n",
    "with open(f\"../Data/{file_path}\", 'rb') as file:\n",
    "    FM_data_2 = pickle.load( file)\n",
    "\n",
    "file_path = 'WikiText_Pythia_step1000' \n",
    "with open(f\"../Data/{file_path}\", 'rb') as file:\n",
    "    FM_data_1 = pickle.load( file)\n",
    "\n",
    "file_path = 'WikiText_Pythia_step0' \n",
    "with open(f\"../Data/{file_path}\", 'rb') as file:\n",
    "    FM_data_0= pickle.load( file)\n",
    "\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(nrows=2, ncols=6, figsize=(6.6, 1.5) )\n",
    "fig.subplots_adjust(wspace=0.08, hspace=0. )\n",
    "\n",
    "models = [ FM_data_0, FM_data_1, FM_data_2, FM_data_3]\n",
    "titles = [\"T=0\", \"T=1\", \"T=20\", \"T=143\"]\n",
    "modelAxis = [0,0,1,1]\n",
    "\n",
    "colorSet = [ colors[3], colors[1] ,  colors[2],colors[0]]\n",
    "linestyle = [\"-\", \"dotted\", \"-\", \"dotted\"]\n",
    "\n",
    "for color,  secAx , title,model , lineS in zip( colorSet ,modelAxis, titles, models, linestyle):\n",
    "    j = 0\n",
    "\n",
    "    for modelLayer in pythiaAllLayers:\n",
    "\n",
    "        #title = modelLayer.rsplit('.', 1)[-1]\n",
    "        featureM = model[modelLayer][\"FM\"]\n",
    "\n",
    "        if modelLayer == f\"gpt_neox.layers.{layIndex}.attention.query_key_value\":\n",
    "            for k in range(3):\n",
    "                weight = model[modelLayer][\"weight\"][k*1024:(k+1)*1024,:]\n",
    "                \n",
    "                ax = axs[secAx][j]\n",
    "                plotOverlapTimeD(ax=ax, weight=weight, Fm=featureM, title=\"\", label=title, color=color, lineS=lineS)\n",
    "\n",
    "                j += 1\n",
    "\n",
    "        else:\n",
    "\n",
    "            weight = model[modelLayer][\"weight\"]\n",
    "            ax = axs[secAx][j]\n",
    "            plotLowerB = j > 3\n",
    "            if(i == 0):\n",
    "                plotOverlapTimeD(ax=ax, weight=weight, Fm=featureM, title=\"\", indicateLower=plotLowerB, label=title, color=color, lineS=lineS)\n",
    "\n",
    "            else:\n",
    "                plotOverlapTimeD(ax=ax, weight=weight, Fm=featureM, title=\"\", indicateLower=plotLowerB, label=title, color=color, lineS=lineS)\n",
    "\n",
    "            j += 1\n",
    "\n",
    "    #break\n",
    "titles = [\"Query\", \"Key\", \"Value\", \"Att.-Out\",  \"Up-Proj.\", \"Down-Proj.\" ]\n",
    "\n",
    "for j in range(6):\n",
    "    axs[0][j].set_title(titles[j])\n",
    "    axs[1][j].set_xlabel(\"singular vector index\",fontsize = fontsize-3)\n",
    "    axs[0][j].set_xticks([])\n",
    "    for i in range(2):\n",
    "        axs[i][j].legend(\n",
    "        # loc=\"upper right\",\n",
    "        # bbox_to_anchor=(1.07, 0.98),  # x and y position\n",
    "        handlelength=handlelength,\n",
    "        handletextpad =0.4,\n",
    "        fontsize = fontsize-2,\n",
    "        labelspacing=0.2 )\n",
    "    \n",
    "    axs[1][j].set_xticks([0, 400 , 800])  \n",
    "    axs[1][j].set_xticklabels(labels=[\"0\", \"400\", \"800\"]) \n",
    "\n",
    "\n",
    "for j in range(1,6):\n",
    "    axs[0][j].set_yticks([])\n",
    "    axs[1][j].set_yticks([])\n",
    "\n",
    "\n",
    "for ax in [axs[0][0], axs[1][0]]:\n",
    "    ax.set_yticks([0, 0.4])  \n",
    "    ax.set_yticklabels(labels=[\"0\", \"0.4\"]) \n",
    "\n",
    "    \n",
    "\n",
    "axs[0][0].set_ylabel(\"$O_k $\", labelpad=0)\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=0)\n",
    "        \n",
    "plt.savefig(\"../Figures/Neurips_plotApp3.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plotApp3.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Book Corpus Overlap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_36092\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkoAAAEiCAYAAAAGbP0zAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAADFeElEQVR4nOyddVhU2RvHv3eGoUulxEIMFMHALsRu7MDAXH/Gqlira8faq6trY66LYNfaumKjq2BgBxISigpIx8z5/THMyMDEneFOej/PMw/MvSfe+8655773nPe8hyKEELCwsLCwsLCwsJSAo20BWFhYWFhYWFh0FdZQYmFhYWFhYWGRAWsosbCwsLCwsLDIgDWUWFh0nPT0dERGRmpbDBYWFpYfEtZQksHdu3fRt29f/Pzzz5gwYQK6du2K8+fPa1ssnScyMhL9+vUDRVGYOHEioqKikJKSgvHjx8PExATz589HdHS0tsXUKMeOHYO1tTUsLS3xzz//iI+np6dj/vz5sLOzw5UrV6TmffLkCVq2bIl169ZpSlyN8tdff+HUqVNqKfvUqVPo3r07xo0bh7Fjx6Jnz564d++eWupi0TyXL19GgwYNwOFw8PvvvyMzMxMA8Pr1awwePBiVK1fGiRMnaJf38eNHTJo0CRRFoWPHjhg7diw6dOiA3377DTk5OSrJ6OXlhTt37qiUly5Xr15FvXr1wOFwMGbMGPzvf/9Dp06dMGnSJERFRam1bllERUVh4MCBoCgKffv2xdixY9G2bVts27YNfD5f6fKysrLg6uqqvWcHYSnBmTNniI2NDXn48KH4WFRUFHF0dCS7du3SnmB6wuXLlwkA8ubNG0IIIXw+nwwaNIhcvHhRy5Jpj6VLlxIOh0M+fPggcfzs2bNk7dq1cvMuWLCAjBgxQo3SaY+WLVuSzp07lzh+8eJFEhcXJ/6u7H33559/kvLly5O3b9+Kj929e5fY2tqS8+fP0yqDvdd1n/nz55MKFSqUOB4ZGUlmzJihdHlv3rwhAEhoaCghhJD09HRSvXp1Mnz4cJXk27VrF/n06ZNKeZVh3rx5pHLlyuLvfD6fLFu2jFhaWpKrV6+qvX5piJ4D79+/J4QQkpCQQMqUKUMWLFigUnkbN24kWVlZDEpIH3ZEqRg5OTkYM2YM/P39Ub9+ffHxqlWr4pdffsHkyZPx8eNH7QmoBxgZGYn/EkIwZcoUDB8+HJ06ddKyZNpj/Pjx4PF42LNnj8TxkydPYvjw4XLzcjiGeZu+ePEC9vb2uHTpEt69eyc+Hh8fj1GjRqGgoAAA8PTpUwQEBNAuNy4uDjNmzMCcOXNQrVo18fGmTZtixIgRGD16tMIRAmXrZNEOXC5X3N8UxdLSEpaWlkqXV7wsS0tLdO/eHadPn1ZJvjFjxsDe3l6lvMpgZGQEiqLE3zkcDubPnw9fX18MGTIE2dnZapdBmkxFKV++PLy9vVXW5ZQpU2BmZsaEaEpjmD1wKbhy5Qo+fvyItm3bljjXrVs3ZGdnY9euXTA1NcW1a9eQmpqKWbNmwcXFRZzuxIkTmDt3Lrp27YoJEyZAIBDg0qVL6N27N4KCguDh4YFp06Zh7NixoChKPDT76tUreHp6GowhRgjBhAkT0K5dO3Tv3l3inCwd8Xg8TJkyBbm5ucjKykKPHj1w7NgxLV0Bc9jb22PAgAEIDAwUDz1nZmYiPT0djo6OAIDFixdj8+bNmDVrFlatWiW1nBMnToCiKERHRyMpKQnDhw+Hj4+P+PyuXbswb948+Pj4YMmSJWq/rtLw119/YceOHXBzc8OOHTvEx+/du4eEhARs3rwZoaGhuHTpEjIyMvDbb78hIiJCYblHjx5Ffn4+2rRpU+Jc9+7dkZiYiMuXL8vVpbJ1sugme/bsQaNGjbBv3z7Uq1cPjo6O2Llzp1JlZGVlwdbWFvfu3cOwYcOwdetWeHt7o0+fPgCEU+srV67E8uXL0bt3b8TExAAQTuVt2rQJ165dY/qyaDN58mQkJSXh0qVLuHHjBhYtWoTff/8dPXr0wJMnTwAAK1euBEVR+Pfff/Hy5UtUq1YNHTt2RHJyMjIyMuDt7Y2bN28iKCgIdevWxfHjx+Ht7Y0KFSrg/v37Sskj0qW05yEAbN++HRs3bsTcuXPh5+eHL1++AACio6OxatUqPH36lFkF0UUr41g6zJo1awgAEhERUeJcVlYWAUAmTZpEqlSpIh6eDQ0NJVWqVCGEEBITE0MmTpxICCEkOzubWFlZkQMHDpCcnBxiZ2dHpk2bRl6/fk2uXr1Kvn79SiwsLMi1a9cIIYQ8f/6crFu3TiPXqU5CQ0MJANKlSxdSrVo18u3bN4nzsnRECCF+fn5k5MiR4rRjxozRnOBq5u7duwQAOXHiBCGEkL/++oscOnSIEELIy5cviZmZGSFEqBMOh0NSUlIIIYQsWrRIYuoNRYaz9+7dS9q0aSMuf9myZYQQQj58+EAAkNu3b6v9ulQhJyeH/O9//yOEELJu3TpSrlw5kpOTIz5f9Brfv39PlOmqxo8fTwCQ1NTUEudevnxJAJA1a9aUqKeoLpWtk0U7LFq0SNz3FuX9+/dk0aJF5NOnTwSAeBp148aNhMvlit0CpOVDkam3Bw8eEEtLS7Jp0yZSUFBA6tevT/r370/i4uLIqVOnyN27d0nbtm3F+Tdv3kw8PT1Jfn4+CQ8PJxUrViR79+5l+rJLIEsPGRkZBABZvHgxqVOnDuHz+YQQoXuJo6MjSUtLI9nZ2cTGxobcuXOHEELI2rVrSZcuXcRlzJkzhxAi7JcAiK9n2rRpZNiwYTJlEj0HRPfXuXPniJGRETl9+rTU5+GhQ4ck+rmZM2eK5bh+/ToxNTUV/y6ahh1RKobobd/KyqrEOdFUgDxntODgYCQlJWHVqlXYsGED2rVrh9TUVJiYmMDCwgKtW7dGjRo10LZtW5QpUwb+/v7YsmULAOGbycCBA9VwVdrBy8sLMTExGDx4sITOZOkIAKZNm4aDBw/iy5cviI2Nhaurq5akZ56mTZuiUaNG2LZtGwChs7Gvry8AoEaNGrh58yYEAoH4b1pamlLl7927V/zm9ffff6Nz585ITExk/DqY4Pjx4+jduzcAwN/fH+np6Thy5AgjZYumIExNTUucEwgEjNTBovtQFCWe9mrfvj0AYNKkSShbtiwuX74sN+8ff/yB4cOHY8mSJdi2bRt+/vlncLlc2NjYoEWLFqhYsSJ8fX2xe/duNG7cWJxv5MiRePr0Ke7duwcvLy+JqV9tIJq2NzIyQp06dcTfu3fvDkII/vnnH5iamqJ///4ICQkBAJiZmeHatWv48uULYmJixH2w6H4Sjbp6enoiPj5eoQzz58+Hn58fAgMDcfr0afTs2VPq83DXrl1o2rSpON+oUaNw4cIFxMfHw9vbWzzyrg1KTu7+4FSvXh0A8OnTJ/H/IuLi4gAAlStXlpk/JiYGHTt2xPjx46WeLzqPDABTp05F3bp1kZCQgMTERFSsWLE04usUP/30E9zc3DBixAhMnz4dGzduBCBfR40bN0aDBg2wZ88eGBkZYdCgQZoWW61MmjQJo0ePxr///gsHBwdx58PhcPD582csW7YMP/30EwDh1KUyxMTEYOrUqejSpQsAYM6cOcwKzyAhISGwtbXFwYMHAQBOTk7Ytm0bhg0bplQ5Dx8+ROvWrcXfb968iVq1agEQ3q/F72FRx16zZs3SiM+iI5iYmEg1fvl8Png8XonjXC4Xrq6uyM7OxowZM8RTvu7u7vjvv//E6aZNmyYxpV2Uon34hw8fYGJiIv5uYWEBOzs7JCQkqHpJjCJa9bZr1y54eHhInKtSpYpYzuHDh2PQoEFYv349Xr58ifbt2+Po0aNIS0sT90fFoShKrPsBAwaIV4V37dpV4qXnt99+k3BNKV6GiA8fPiArK0v8XZQnISEBFSpUUOKqZZOWlgaBQIAyZcoolY8dUSpG586dYWlpKXVJ56NHj0BRFHr27ClxvOgDrVy5ciXmpOX5OLi5uaFDhw6YNWsW3N3dSye8DuLv74/ffvsNf/75p3gkRZGOpk2bhm3btiEqKkrrb2RMM3jwYJQtWxaDBw+WMArCw8MREBCABQsWwNnZmXZ5pWl72uLt27eoV68e9u/fj3379mHfvn3YsmUL7ty5I/aboEuDBg2QkZEh/jRo0AD9+vWDsbGx1HAeV65cgZ2dHTp27FjinLKGKYv2qVKlClJSUkr8dnFxcTJfOjMyMlC7dm2sW7dO3G6KGknK4OLigjdv3kgcy83N1ZmR8AMHDqBixYoYNWqUXDm9vb1hamqK+fPno2PHjhg6dCiCg4Px9etXWkbFkSNHxLpUdWS4uC5zc3MBCBdSlYZLly6hR48esLS0RNmyZWFnZwcLCwt0796dtv8raygVw8rKCitWrMDmzZvx+fNn8fHc3FysX78eEyZMgIeHB8qWLYvHjx+DEILr168jOzsbhBD4+vriyJEj2LJlCz5+/IiDBw+KgwUSQqR2xlOmTMGhQ4fQv39/jV2nOsnLywPwfapy3rx5GDRoECZPnoxz587J1REA9OnTB/n5+ahSpYpW5FcnpqamGDNmDGxsbNCyZUvx8WvXriEvLw98Pl/caaempqKgoKDEG3OZMmXw+PFj5Ofn4/bt2+L4Mb6+vvjzzz9x6NAhsSNpcnKy5i6OJlu2bMGQIUMkjnXr1g1OTk7iaWhzc3N8+fIFHz9+hIWFBQCIv2dkZGDSpEkSb59FqVChAv744w+sXLlSPAoMCFfZ7dy5Ezt37oS5uTkA2bosXieLbtKtWzfweDxs3bpVfCwjIwNbtmyRWEAi+l1FqytlrcAV9Vmiv8Up3of/73//Q2hoqNiBOyIiAh4eHmjYsGGJvJGRkWpbYJGfn1+inwgODkZgYCAOHDiAcePGIT4+Hrdv3wYgdDTPyclBjx49AAhHdoYOHYqjR4+iR48e6NWrFyIiItCiRQtxecXLVxQPSVldTpw4EYcOHUJGRgYAIDQ0FH5+frCzsyuR99q1a9i8ebPc+gHhFOrSpUvRqlUr7N+/H5cuXcKFCxfw119/oWXLlti4cSNWrlypsBzWW1EGmzZtIi1atCCBgYFk//79pG3btuSXX34h+fn5hBBCjh49SsqVK0datmxJDh48SNq3b08uX75MCBE6DDo7OxN7e3uycOFCQgghJ0+eJMbGxmTIkCEkKipKoq6CggIJ5zl95tmzZ6R///4EABk/fjyJjY0lGRkZZNGiRQQAMTMzI7///rtUHRVl9OjRJCYmRgtXoH7ev38vdroW8ezZM1KpUiXi5uZG/vrrL9KyZUvSrl078uTJE9KoUSNSp04d8QKDP//8k9ja2pLOnTuTwMBA0rt3b/LgwQMiEAjIr7/+Suzs7EiFChXI1q1btXF5cjl8+DAxMzMrIdutW7dIhQoViImJCQkKCiJjxowhtWrVIqdPnyaEENKxY0fSqFEjcvv2bRIdHU0qVqxIYmNj5dZ16tQp0q1bNzJhwgTyv//9j/Tq1YvcuHFDIo0sXRavk0V3efDgAWnfvj3x9vYmvXv3JgMHDiTh4eHi8wDIzz//TBYvXkyGDh1KXr58KbWcpKQkMm3aNAKADBw4kDx69Eji/PXr14mDgwPp0KEDefr0qfj4yZMnSd++fcnKlSvJpEmTJOJ/tWnThuzbt48QQsiRI0dIo0aNmLx0QojQabpu3bqEw+GQ8ePHkylTppChQ4eSgIAACVlu375NfH19xXJGRkZKlPPq1SuyefNm8fdff/2V5OXlib///fffBABZtWoVSU5OJj169CBOTk7k8ePHJWR69+4dGTp0qFj3xZ3nZT0Pd+zYQfz8/MiqVavI5MmTJRZkVKlSRbzwad26daRv374KdTNv3jxG0lCEsOPNskhNTYWXlxfev3+Pc+fOoWvXrmqp59q1a4iJicGIESPUUr6+IRAI8NNPP2H37t3aFoWFhUXPoSgK79+/l+kno07atGmDmTNnlnDXYFGeKlWq4MyZM/D09KSdZ9WqVQp9NRcvXozFixfLTcM6c8vB1tYW//77L/r27YuhQ4di//794qFKJti3bx8A4fzu0aNHGStXX3n69CnOnTuHT58+sR0LCwsLY2hyPCA7Oxs3b95Ep06dkJOTAy8vL43VbWh8+fIFL168QKtWrWBsbIwaNWoold/MzAw+Pj7o1KkT3NzcYG1tDR6Ph2/fvuHdu3c4e/YsOnTooLAc1lBSQNWqVREREYHQ0FDcuHEDb968Qd26dcXLTUvD+fPncfPmTfz1119aiziqS7x69QqrVq3CkCFDxEvHWVhYWFQlMDAQgPCldMKECXByclJ7ncnJyZg0aRJ69OiB8ePHM7Zi60ckKioKw4YNg5+fH9atWyc15Ic8pk6dCmdnZ6xbtw4RERFifyljY2N4e3tjzJgx8PPzU1gOO/XGwsLCwsLCYtDk5+fjy5cv4PF4KFeunFJ5WUOJhYWFhYWF5YeEz+eDy+XKTcOGB2BhYWFhYWH5Ifnnn38UpmFHlFhYWFhYWFgMio8fP2Lo0KEKty16+vQpPn36JDcN68zNwsLCwsLCYlA4OjrC0dFRHI1bGgKBAF+/flVYlsGMKH3+/BkXL16Ei4sLu4IMwiWq0dHR6Ny5s0QjYfUkCasnerB6oocsPbHQg21PkrD3HT1k6Sk6OhqEELnboNy8eVNiv0ipKAxJqScEBQURAOyn2CcoKIjVE6snVk9a1hMLPdj2RK89sXqipyemMJipN1HU1aCgINSuXVupvAEBAdiwYYPa82iyrhcvXmDYsGElotGyepKE1RM9WD3RQ5aeWOihTHui8/u8efMGU6dOhYODA+zt7dG5c2epAQbp/tZ00jFZFhP3nbx6UlNTMXPmTJibm+Pz588ICgoChyN7jZe+6Ykx1GJ+aYHw8HACgHAcapHg4GCl8iqbXtU8mqorODiYtG7dmgCQ2POIkO96Muv2m9rlUDWPJusS6YPVk3xYPdFDlp5Y6KGM/hT9Pjdv3iQ8Ho/Y29uTESNGkGbNmpEBAwaoVJYy6Xr27MlYWYruOyb0NGfOHNK2bVsCgPTs2ZNkZGSUSma66TShJ6YwOENJlQ7bEFHHg80QYfVED1ZP9GANpdLBpP4KCgrIzp07SU5OjviY6P/Q0FDy/v37UtchDboGAB2YMJSksXjxYrJu3TqJY2fOnCEWFhZk4MCBKsurDJrQE1OwcZRYWFhYWAwGPp+Ply9fgsvlYuzYsTAxMRGfMzExAZ/Px5QpU9CtWzd8+/aN8frpbImhTRISErBq1aoSq726d++OixcvYtWqVRqRQ1f0JNrWRB6socTCwsLCYjAcO3YM7u7uePPmjdTzXC4XR44cQXx8PEaPHs34hrm6YgDIYvPmzTAxMcGsWbNKnGvZsiWqVq2K9PR0REVFqVUOTespPDxc6vGdO3cqzGuQhpKVfzCs/IO1LQYLCwsLi4b5448/0K5dO7k7zbu5uWHPnj04duwYDh06pEHptItAIMCBAwcwePBg2NjYyEw3aNAgDB48WGGwRn1iy5YtJY79/fffUg3G4hikocTCwsLC8uPx7t073L17F2PHjlWYtl+/fhg4cCCWLl1qUAaBPO7du4fY2FgMGzZMbrpff/0V9+/fx8GDBzUkmfrhcrnYtWsXACAlJQUDBw7EnDlzMGbMGIV5WUPpB4YdeaMHqycWFv3g0KFDsLCwgK+vL63027Ztw927d+UuiTckmjVrhqdPn6J58+Zy07Vu3RrdunXDihUrDMaI3LFjBzw9PTFnzhx4enrCxMQET58+xezZsxXmNZg4SiJyHwSBV7M9eFVbaFsUrRESEoJt27ZpWwyWHwyRMZm+f4iWJWH5UeFwOBg2bBjMzc1ppS9btiwAIDExERRFwcnJSZ3iaR2KolCnTh1aaefMmQNvb2+cPXsWPXv2VLNkzBMbG4tr166VOP7161d4enqidevWOHLkCC5fvowjR47ILcvgDCVeNW9wylQGyc/Wtihaw8/PD25ubmjYsKHMNCTzMwTmZUGZWmtQMhYWFhb1MWfOHFj5B+OAf7DYYFdkwPP5fDRr1gx9+vRRKZipvpCbm4t27dph1apVirfsgHBUaerUqbCystKAdMxDURSmTJmC+vXrg6KoEudDQkIAAK9fv1ZYll4ZStnZ2cjLy5PrhJYbFij+3yh0Pcw6zUP6/iF4+PChTIX9iORc3yD8x8gERpeXw6zTfKTvH4LMzExYWFhoVTZdgp/0HCQ/CxwLewgEgh9miJ6FRd/49OmTxP1Jd7qcy+VixIgRWL9+PRYtWoQyZcqoS0St8vz5c9y5cwdGRsLHPp0RYH02HCtVqoTg4GB069ZNbrrQ0FCFZelFry8QCLBv3z7UrFkTDx8+lJvWpPVkmHVeCJOWE2BUoy0AID4+Hl5eXqhatSpmz56t9mWP+oBx09EwbTMNxvX6geskHIrNz89HxYoV0bNnTxw7dgx8Pl/LUmqfvIhg5FxegayT02BhYYGhQ4eKzzG9rFifIUQAkpvB6oRFa+zevRs1atSQ2Qbl+RpOmjQJBQUF2L59uzpF1CpPnjwBAHh6eiqV7+rVqzh8+LA6RFI7RY2kzMxMiRWO79+/x4sXL9C2bVuF5eiFofT582e0bdsWHz58UJiWY+UIroMbeK6txH5KTk5OCA0NRdeuXbFr1y7UqFEDI0aM+KE7dW45VxhVbgRj9+4wrtsHgNAg/e2335CcnIz+/fujdu3a2L179w9tMJl2mAvzXutg2u4XCOr0x7Eooe9DbGwsatSogSVLliA5OVnLUuoAWV+Refh/yDw8Di1btsSsWbNw6dIlg3EEZdF9Hj9+DE9PT5VmDRwdHTFkyBAEBgYabJt98uQJqlWrBktLS4njiharHDp0CLNnz9b756W/vz9WrFiBzMxMAEDVqlURGhqKkydPKsyrdkPp69evWLduHdq3bw8XFxe4urqiZs2aaNiwIWbNmoUHDx4oLMPBwQFVqlShVR8hJR/qXC4XPj4+2LZtG+Li4rB582bUrFkTFEUhJycHSUlJSl+XvkMK8kocMzExwaRJk3D37l3cv38fnp6e2L9//4893URR4Fg7wahCPRi7dwWvcJRSIBDAx8cHa9asgYuLC6ZNm4bPnz9rWVhtQsHUewqM3XvgvwSCdVt2YdSoUeKHVkJCgpblYzF0Dp+/gbufzFTOP3bsWHh5eSEtLY1BqXSHyMhIeHp6yjSMZB0fMGAAoqOj8ejRIw1IqT7c3d3x+PFjCdeSLl26YMaMGQrzqvUJuHXrVsyYMQNVq1bF4cOHER0djaioKLx+/Rr37t1D3759cerUKUyYMAFfvnxhplIpRm/RBmBubo4JEyZg3rx5Yhnd3d1/qKBjAABS8q2pqJ4aNWqEY8eO4cqVK6AoCjdv3sTUqVORk5OjaUm1i0B6eHsXFxfs2rULsbGxmDlzJvbu3YuZM2dqWDgdgqJgVKUpjD17wbT1zzDvtxkPHjwARVF49+4dqlSpgv79++PZs2falpTFAMnMzAT5lgROmcoK08oyCFq0aIFjx44ZrI/S/PnzaQVXLE6bNm1QpkwZHD9+XA1SaQ5pI41HjhxBVlaWwrxqc+Zet24d2rRpg4kTJ0qv2MgIzZs3R/PmzZGeno4//vgDEydOhJ2dXanqzQ0PRr6J0GI0cmmuMEzAiBEjcO/ePQwePBj//PMPAgMDaS8t1TVCQkLEnvypqamMlMnj8QAI53N37NiB0NBQnDhxAtWqVWOkfN1H/jB+uXLlsGTJEkyaNEk8RRkWFgYXFxeUL19eEwLqBsU6IYqixNdfuXJl7NixA8uXL0f9+vUxffp0LFy4kF00wMIYMTExANcYHNtKpSonOzsb58+fR9euXWFmpvrolC7i7e0t/Gd7tFL5eDweevbsiePHj2PZsmXMC6Yh2rRpg549e6Jjx46gKArXrl3DyZMnsXTpUoV51TaiNGLECDRq1Ej8/datW8jNzZWa1srKCgsXLmRkRZpJo6EwazsDZm1nlDCSpL1JlCtXDocOHcKBAwdw4sQJtG7dmjEjQ9P4+fnh9OnTOH36tOLVCkrq2t/fH/fv30dOTg6aNWuGO3fuqC6oniOtHTk4OKB8+fIghGDChAmoV68ebt68qSUJdQsej4fRo0fjxYsXWLx4Mf7880+V3mxZWGTh7u4OC7/d4Ni50s4j7T6OiYlBv379cOXKFaZF1CqfP3+GSYNBsOhfchuP4kjTy08//YQRI0botb9q+/btsXz5crx69Qpnz56Fubk5jh07Jp5dkofaDKXiI0O7du1CzZo1sWfPHpl5ypUrx0DNqhlbQ4YMwe3bt+Hj4yM3/IDhIFtPsoamPT09ERYWBnd3dwwfPhx5eSX9nAwOJQ1KiqJw+fJleHh4oEOHDjhw4ICaBNM1FOvJ2NgY8+bNw+PHj8VvpikpKeoWjOUHgaIoUFTpHmm1atWCm5sbTpw4wZBUusHLly+R9+gwkJepUv5WrVrhl19+AZfLZVgyzeLq6opWrVqhY8eO6Nu3L7p3704rn8a8dPft24eIiAg8ffoU48eP11S1SlG/fn2sW7cOFEXh0qVLhu1PwVGtwZcrVw6XLl3C1atXYWxsrPcrIRTCNVY6i729PS5cuAA/Pz8MGzYM+/btY14uXcPIlHbSmjVroly5ckhMTISbmxvWrFlj+O2IRa3MmTMHOTc2MVJWnz59cPr0aRQUSPdP1Eeio6MBAJSF6q4t4eHhOHr0KEMSaZ7IyEjUqFED06dPx+HDh7FkyRLUrVsXz58/V5hXo8uZypUrh/Xr16Nnz55Yu3atUnnpLtmkM32naDkkIQSLFi1Chw4dhHPfBgiloqEECFfHValSBenp6ejSpYvC2Fb6DMXlyTwnrx0ZGxtj7969mDt3Lho0aKAu8XQGilfSUFJ0nzk5OWH8+PGYPXs2Fi1apE7xWAycJ0+egPCZGeH29fXFly9fEB4ezkh5ukB8fDxgbCH1PpVF8fv38OHDmDx5st6+1MydOxe7d+9GYmIi7t27h0ePHuHatWu0YmdpzFAquqqte/fucHBwwLt372jlTU5OxqpVqwAAQUFBePnypVpkFEFRFE6ePAkzMzN069bNIKcH6DR2RQ86LpeLr1+/wtfXF4mJiUyKpzMQgepz8hRFYfny5ahXrx5ycnL0fnmtPAg/X+k8FEVh6dKlWL16NZYtW6bXUYBZtEtMTAw4lvaMlNW4cWN0795dr/1xipOcnFzq7ap8fHyQlJSEN2/eMCSVZvHx8SkRpdvR0REVK1ZUmFdjhlLlypVRp04dTJ48GcePH0ePHj1w9epVWnnt7e0xd+5cEEKwa9cu1KpVS2ba3AdByH9fekdjR0dHnD9/HomJiRg+fLheBSELCQlBQECA/ESk9MPK5ubmOHXqFAQCAQYMGGBQQ9ViaLylKjIoAWDhwoVo27YtrX2F9JJ82WEjFOnnl19+wZw5c7BgwQKDNbhZ1IeVfzCev40FZWarcv6i7dPIyAhnzpxBixaGs7F6nTp1YFSpkeKEcmjSpAkA4P79+0yIpHHS09NLHAsLC0NYWJjCvBozlJYvX46jR4+idu3aOHjwIOrUqYM1a9YwXo9Jo2EKQwLQxc3NDUFBQXjx4oVeBaX08/Oj8XbOzJ53zs7OOHz4MMLCwsSjfiwlmTdvHpycnNC3b98fLxYVDVasWIGnT5/+WCEVWBiBCAqAvIxSj5gUNZjy8/Nx+/Ztg1mwMmrUKJh4DS5VGeXKlYOrq6veGkrt27eHp6cn/Pz80KtXL7i7u6NLly6YPXu2wrwaM5QCAgJQu3ZtTJw4EYcPH0ZSUhLOnTunqeqlQmckoFu3bnjx4gWcnZ01JJWmoG8oKdJTy5YtsXTpUgMN1MaMQWljY4MjR47gzZs3tJaj6h2lVBNFUahSpQqys7OxYMECmaFEWFhKQsG041xwnesxVuKTJ0/QqlUrg/FTevfuHUie4sCK0ija/w8fPhyurvRDMOgSrVu3xpkzZ1C3bl1UrFgRo0aNwuvXr9GsWTOFedUScPLly5cwNTWFi4uL3HQ1atQQ/3/hwgV06dJFHeIoRNEuysbGxnj79i02bNiADRs2iHdf1muYef6LMciHP8N4eHhg5cqVmDFjBkaMGIG6detqWyQGobeIApC/W3lUVBRWr14NgUCA5cuXMyYdi+FCcbgwKtzYmyk8PT1hYmKCBw8eoHnz5oyWrWms/IOReWwyjKp5w6T+gFKVtXjxYmaE0hJVqlTBr7/+KnHs8ePHqFdPvpGtlid+rVq1sHHjRjg4OGDw4MFyV6J9+vQJmzdvRp8+fdQhCmN8+fIFW7duRfXq1RX7/+gFyltKih50hBBMmzYNnp6eGDNmTKmk0xmUiMtCxxAICAhAw4YNDcxIAsDQfoB16tTBwoULsXjxYvTv3/+HWDHIUjr4KXEoiA6DsYevUqu65GFsbIx69erp7TRTcUhuOigTq1KXU1BQgFevXqFixYo6H2/w6dOnWL9+vcJ0Dx48wJMnT+SmUdvQyNSpU3H58mX4+vqiUqVKaNy4MRwcHGBmZoaUlBTExsbi5s2bcHBwwIIFC1ChQgV1iUIbeQ+6pk2b4n//+x+WLl2KESNG6P00U2kCs8nSE0VRSElJwa+//orBgwcbxBYVlJHycZTktSMOh4M2bdqAEIK4uDhUrqx4byp9gOLR3/ZHkUE5e/ZshISEYNq0aQgNDWUkYj+L4SL4Go38p6dgXLc3o+U2atQIoaGhjJapDYigAODngzIu/ZYsycnJ8PDwwIkTJ9C7d+/SC6dGXFxcEB4ejt69e8vc2F0gEODp06cKy1LrHFLHjh3RsWNHREZG4t9//8WzZ8+QkZEBOzs71K5dGzt37mQoGrdmWLRoEf7++2+sWrUKq1ev1rY4OsmSJUsQHByM7du309qV+Ufljz/+wMqVKxEdHW0QBiWT8Hg8rF27Ft27d8f9+/fFq21YWKRB8rMADg+UCsFh5dG0aVPcvn0b+fn54j0v9ZLCFanKvMxIw8o/GIQQ2NjY4MWLFzpvKFlaWiIoKAienp5y0/n5+SksSyPONp6engqFZYrcB0Hg1WzP2Mq3ojg5OWH69OnYvHkzFi9erLObJoaEhGDbtm1y06graJiLiwtGjRqF1atXY/z48XpvBJAC1Ve9yBs56devH2bPno0dO3Zg+vTpKtehK5B85R1F5emna9euiIyMhIeHR6llYzFw8rIYGS0R8b1d+sPf35+xcrUFKcgRuhAoET1fFhRFoXbt2njx4gUDkqkfWXYHIQTfvn2DjY2N3HBDIjS26u369evw8vJCpUqVMGrUKHz48EEt9TARHkDeKq8ZM2bg5cuXOmskAXTDA6iPOXPm4OvXr7h27ZrWZGAMNU37VKlSBf7+/li7du0Pv8JL2v1GURQ8PDxACJEIVsvCUhySnw2UcrREGlb+wbAcfgD5+coHU9UlOBZ2sBi6H9zyzDi865OhBABHjx7F1KlTxfvMnjt3DnZ2dihbtixatGhBK/SPxgylU6dO4cCBA9i9ezfs7OzQqVMnvdxLzcbGBg4ODsjKytLrGBtM+H3IMihdXV0RFxdHe8NBQ0eWnmbNmoWkpCQcP35cC1IxjXoMSn9/fwwcOFAtZbMYBpxyVWFUVT0r07LPzsXChQvVUrYmYWLDYBFubm568+zbuXMnRo8ejTt37mDKlCn4/fffMXHiRAwYMADTpk3Dly9f8MsvvygsR2OGUoMGDVC7dm106tQJa9euxfXr17F7925NVc8oKSkpqFy5Mk6dOqVtUXSW8uXLgxCCzEzVdqvWGdToR1yrVi0MGjQI2dnZ6qtEj5BmUHbp0gVXr17F27dvtSQVi67Dc2kOk3r91VI2ZWqt9i2z1AZFARQF/qdXyDq3ACTnGyPFzp49G48fP2akLHUTHByMZ8+e4f79+wgLC8OyZctw5swZbN++Hb///jsiIiJo9S0aCwhkZ2eHY8eOoU+fPuBwOLC3t0ejRqULqa5uinfaIl+KMmXKoFq1ati/fz8GDChdXApDQJaemjVrhpYtW9Jaoqm7MGcpSfPJOXjwIGPlGyJ9+vSBtbU19u/fj6VLl2pbHBYdRPAtCTAyBse8LONlc6zL6/22QyQ7FYIvUQCHmcc9nTAouoKbmxsqVaoEQOiv1LZtWwm/RwsLC1r+0xobUdq1axc2bNiAChUqoFevXpg/fz6ePXsmdiq+fPmypkRhBH9/f1y4cAHJycnaFkVnadSoEY4dO6a3u00DACgu40UWHzmJjY3FgwcPGK9HozDgKCqiqH7Mzc0xePBg/PXXX/rdjliYp3DEJOfODuQ9PKyeKizKqc2fVlOQgsItk1QIdSINQXYaMo9P0YtntomJicT3smVLGtN0+hWNGUotW7bE+fPnERsbi19++QXm5uZ48OABnJ2d0b59e8ycOVNToqhM0Q584MCB4PP5OHv2rJal0l369eun90aAJmL4TJs2DZMmTVJ7PepEHXoS3W8iHyV2w1wWqfDzGTMCikOZl8O3b99gOXiXWsrXCAK+8C9DL32UiSVI1lf0XHhI4RZg2mbHjh1wdXUVf44ePSrxvUqVKrRcgDQ29TZx4kScOnUKXbt2RcuWLdGyZUvMnTsXfD4f//33HxYsWMBIPeoMD1AUe3t7NG7cWCcd0umEB1AnopsnZc9AWFlZ4cqVK2jcuLHW5CkN6hzFEOlpe9++GDZsGBITE/V2U1giUN/KoLZt2yI6OpoNPMkiHUE+KIamlYpjVKE+uH02AAxF/NYKAj7A4TJ2/1AcLmBsCZKTzkh56qRmzZrw9fWVGQcrLy8PJ0+eVFiOxgwlU1NTDBo0qMRxLpeL5s2b488//2SkHpNGw8AtV5WRsmQhesCRahPw/KMx1qq1NuXx8/ODm5sbGjZsqFU5yow+jGwrV4Xh4X90xp0UOllev34dgweXbodvrSFQn0FpM1Lox/VhU3ed3zaBRfMQAZ8x/5viUMbmoIwLQw+IDA09mwLmlveEScsJjJZJmVox5hyuTlasWIEePXrITePt7a2wHI1NvSnC3d1d2yIojWh7C4FAoGVJdBdT78kIDtbt4VltwzGzAWXjjOELd+r8ULa2yH9zDY6Ojj98zCmWklAUBzAyUZxQBQgRIOfmZhQk6O/LHsfaCTwXZsMnUCbWILm6P6KkyEgCgM6dOytMozOGkj5C+AXIPD4V+/bt07YoOgvFM4P1iBDWAFCAUeWmoESdfaGTql6hZnk5ZSohNzcXZXqv0k/9sKgNc981MKnXTy1lUxQHBfGPIEiJU0v5moCf/Ab5b5jds86k8XAY1+3LaJm6DGsolQKKawSKZ4r/rTogNATYDrwEhJ+PrNOzkf/+znf96JGeNOUXY1K/P0waDSteud7oSd1wylQBODzwP7/TtigsPxiUiaXk6Ime3ZcFCU+Q9/gYo2Vyy7qAY+0k/KJn+lAF1lAqJZwyVSBILfa28QM0HLpQXB5IQTYEKbHaFkXnIbmZIIUbWEqgD+1Jxu7cTEFxjcCxKQ/Bt4QiB/VALyxqJ+vcAuRH3VZb+ZSJlV5MM8mk0JmbSQoSniDvyQlGy9QGAoGA1oIsjTlzawpNrXoTwbFyBD/xqfSTxTtxDTkBanvVW3E4NhUgSIsveUJL+tFFSF4mMg+Pg0nrydoWRSUoNcSbKg7HujzINyn7Mumpky0LMwhSYgAVNmWmC8UzB/KlRM/Xl3YnKGDcUBJ8fof811dgXLfP94M6rg8+n48LFy7g69ev4tXMaWlp2LRpk8KgogZnKGli1VtRKCsnkJw04caMtDOpt0Hpyqo3EZSFnTAyLItseOYAzxQk87PsNDpsWGoiGKRJszGAkRlwYLj0BDreUbMwjwAoHDGRvvybCXg12wEUB4i5p7Y61IqAz3z4BCNjkAIZCyt09D709/dHVFQU0tLS4OjoCACIiorC0KFDFeY1OENJ0xhVbACu71qASyPgmaxpAh1tWEzBMS+Lgtj7ihMauB7kQVEUOOZ2IJlflMkk/KsT+lL/yk/K2IJmQl3SCwvjFOlHxdG7uOob0TSq0pS2PAC03+6KycOxcQYIn9k6OEbfA1kqkkPb+iikefPmOHDgAB4/fgxCCOrXr48vX77g999/V5hX532U3r9/j/HjxyMwMBD+/v6IiYnRtkgSUMbm4Ng4C4NwKZ25mI+FgfpcGLm2glnbGfQzFHf6NlC9FIcyswHJSdO2GCqi/t+Hn/wGWReWIJVuhh+k3fzIiD361DiiJEiLR0H8I9rpQ0JC1CaLKvBqtodJk5GMlklxjIRTeqVA03r6+PEjHjx4AA8PDxw6dAgfPnxAeno6rVXrOm0oCQQC+Pr6YuDAgRg3bhyGDx+ucwH5SF4Wcu7sAP9rNHOFGlgHz7G0B9e+RukLMnDDiTK1gUCVIG46oRf110sK8iBIfo2vymbUCf2wqAMzAKZtpoHrUFNtdeRHhyH3Lv0tTEKGDNGp9kbyskDymPXh4thWhFGNdvSm3GXoQdOGUoMGDeDr64vIyEiMHTsWzZs3R7Vq1VC9enWFeXXaULp48SLevn2L1q1bAwDatWuHJ0+e4P59GtM4SpD//k4p8hAUvLsBkv6RVj6lmkZhA9OVNxRV9SRI/4Tc8ANQYlKJnp6KPQD1XU8mzcbArMNcpfJJvWIFhoG+6okq3EYiQ4W6JK6YpuGkK3pikU4IAGMARpUbgWNecrNTEXTambw0FM9c7IOqUouQ0d401b6y/12FnOsbFaZTRk9cBzeYNh0lM3yKKv2SLJjSU9++fZGQkID69eujWrVqePPmDe7fv48rV64ozKvTPkphYWFwdXUV79PC5XLh6uqK0NDQEnuHZWcLG7IgLaFEOYrIf/0vONbK7bElykMK52lz7u+HO4DpALwAnAZQfD/rJgCiANgBmCqlzL0AeACWA3hR5HjckCFIGDIEbQGEAii+hV9tAPMgnK8fVXisWeFfkV5Q7Lsm9QR+AfKfn0MTAKL4uUsAVAOwH8ClYnk6AYiAsHEuKnbOEsD2wv9nAii6BipuyBBkDxmC+gBOACgeOaQ5gEkAki9cwLRp0wBA7PCuC3riWJcH/+NLFI9R7wZgAYACACOLnYsDUBaAPYAtAMKKne8PoDdF4SGAdUXyLBsyBE5t2wrn5xs2xHiUNECWHD6MatWqYX/DhhC9BsjTE1/Jt2dl9UQyhI7uvQAEQ9iWVgB4XizdaADtANwAEFh4LA7AMgC1AMxHMV0WkfsPCHW5CcBRS0ssW7YMeCG8GwcsXIhevXohIiIC69evl6jT2dkZa9aswYvCtMX1xEIPkd769esHs+ho4cHatdG7d2/0X7kSTwGsKkwbB+BXANnXN4BXox0oEyupZdJpZ/LSkLxMID8H7gBMIbwfDwH4p1g6HwBjIeyTit/DPAj7dwCYR1GIwff7EACmQPh8OAdh2xbhWvhX1n3Xr18/mJmZiY937doVQwG8grC9A4DgcxS45T3A//Je6vWJUEZPJD8H/KRnKIi5J3Gt/hD238uL1C+iOoDFhf8PAxD3zz9wL3LvrQVQHsD2n37CrVu3xMfj4uLw9OlT9OvXD5GRkVi9erVEufb29hg3bhwA5e47U1NTeHl54cyZM4ojeBMdZty4caRZs2YSx1q2bEmmTJlSIm1QUBABwH6KfYKCglg9sXpi9aRlPbHQg21P9NoTqyd6eurVqxc5fvw4IYSQNWvWkKpVq0p8KleuTExMTBS2S50eUeLxeCV2/RUIBFL3VuvcuTOCgoLg4uIiYWH/qGRnZyM6OrrEPjasniRh9UQPVk/0kKUnFnqw7UkS9r6jhyw9DRkyBPXq1QMg1Nnnz5/RrVs38Xk+n4/jx48rLJ8iREfW7klh+fLlOHLkCB49eiQ+VqdOHQwfPhxz5szRnmAsLCwsLCwsesXnz59hZ2cncSw+Ph4VKlSQm0+nR5R8fHywZs0aEEJAURTy8/MRHR2Ntm3blkj7+fNnXLx4kbWwCylqYRdtGKyeJGH1RA9WT/SQpScWerDtSRL2vqMHnfuOEIJnz57hw4cP4PP54mPnzp3DoUOH5FfAyMSymuDz+aRWrVrk+vXrhBBCrly5Qtzd3YlAICiRlp2zpTdny+qJ1ROrJ83riYUebHui155YPdHTU1G6detGypcvT7y9vYmPjw/x8fEh3t7exN7eXmG71OkRJQ6Hg1OnTuG3335DZGQkwsLCcOLECalLEl1cXAAAQUFBqF27tlL1BAQEYMOGDWrPo8m6Xrx4gWHDhon1IuKH1dO6dUBICECIcJXTkCHA9OmsnmjC6okesvTEQg9l2hPd34dOOl0ti4n7TlevTRN6Kp4mOjoaxsaSu2jcvXtXoQw6PaKkDOHh4QQACQ8PVzpvcHCwRvKomq9nz55K55Gljx9WT40bEyI0k4SfJk0IIaye6MLqiR6l0QeLcvqj+5vSScdkWXTbDZ2ymLjvfmQ9FWXChAnk48ePJY4/ffpUYfk6PaKkCgEBAZgwYQL8/Pxo51EmbWnylCafMoSEhGDbtm2Ml6vXemrVCggPBwQCgMMRflcTeq0nDcLqiaU00P1N6aRjsiy6aKpN/hB6yi25Qe+LFy+wadMm8ff8/Hx06tQJdevWFR8TCAT477//8Pr1a7nFG5yhtGHDBnh5eWlbDEZRttH5+fnBzc1NHEzxR0GunlasEE653bolNJKWL9ecYDoGazTQg9UTiyqw7YYejOpp8+YSh6pUqYKHDx+iS5cu4mMVK1aUSCMQCBAbG6uweIMzlAwR9sajh1w9mZoK/ZRY2PZEE1ZPLKrAtht6MKqnIiGERJibm+PYsWNwdnYGAHz9+hVly0pudZOcnIzx48crLF6n93pjYWFhYWFhYZFL/fpSD4uMJADYvn17ifP29vaYMmWKwuLZESUWFhYWFhYW/eXnn4HgYKmn9uzZgwMHDiA6OrrEBrhfvnxBWlqawuJZQ4mFhYWFhYVFfzExkXlq9OjR4HA4OH/+vMT2JQBgYWEBb29vhcWzhhILy49KTg4wd+53B/cVK4S+XCwsLAZNUFAQTE1NERoaim7duqF79+7aFkkhjx8/xoULFzB27FiUK1dOqbwjR45E+/btUalSJZXqNjgfpYCAAISEhGhbDK0SEhKCgIAAbYvBouvMnQts3Ajcvy/8O2+etiViYWFRM1FRUVi9ejX69++PTp06YeHChbTy3blzB5UqVYK/v7/clWIfP35kSlQJ3NzcsGbNGqSnp6uUv3v37tiwYQMSEhKUzmtwI0qGGB5AWX7U8AAsSnLrljCuFCD8e+uWduVhYWFRO66urrh27RoAIDIyEj169AAg3D/ul19+wevXr8Hn8+Hk5IS1a9eievXqAIAWLVqgWrVqaNeuHSpXriy17JcvX2L+/Pk4evQo43KbmprCyspK5fxHjx6FQCDA3r17kZiYiDp16qB///6wt7dXmFfvRpRUsQZZWFik0KqVMPgmIPxbUAA0aQJMny6clmNhYdEb0tPTkZiYWOIjbQTGysoKBw8exLt37/Drr7+ioKAAP/30E1auXIlz587BxsYGJ06cEBtJ0jh16hSaNWuGnTt3olWrVvjrr79w6dIlPH/+HP/8849Ypo0bN2Ln1q3oXb06QqpVQ6cqVbBq2TIMGDAAJ0+ehKWlJT5//oyMjAwMHjwYKSkpiImJwaxZsxAcHIyJEycyop+aNWuiVq1amDdvHubNm4fbt2+jQoUK6N69O/7++2/kSglaKUKtI0rv37/H6tWr4eXlhVu3bmHZsmWoUqVKiXSnT5/GrFmzkJiYiI4dO2Lnzp3ieAeEELi5ueHNmzcAgLZt2+Lq1avqFJuF5cegaBDOggLg4UPhBi/h4cLjbNwpFhbNUtxvcMAA2lnDw8Nx/fr1EsfbtGkDHx8fiWPGxsYYPHgwCCEYNGgQBg4ciC5dusDR0RGEEGRkZCisr27duoiLi8OYMWNQqVIlbNiwAXPmzIGDgwN69uwJAFizZg2sra3heOkSqr57h2QADwGc//oV1KFD4HA4aNGiBV68eAF3d3f06dMHZcqUwfv37+Hj44N27dph1qxZ2Lp1K209yOLu3bvIz8/Hli1bcOrUKXTo0AFnzpxBhw4dcPPmTfTv3x/Tpk1Du3btSuRVm6EkEAjg6+uLjRs3ol27dqhatSoGDx6MsLAwiXRRUVE4e/Ysjh8/jlevXuGnn37C7NmzsXPnTgDA+fPnMWXKFDRr1gwAULVqVXWJzMJiWChy1i4ahLNJE6GRBLDTcCws2kLkNygQCF9YPn2inbVhw4Zwc3MrcdzS0rLEMUIIKIpCw4YNMWTIEFSoUAGjR48GIJyOa9CggcL6KIoCj8cDh8OBqakpcqSMQoeHh2PlypWod+QIBgOIBrAeAPfOHfFo9pQpU7B9+3Z06tQJgwYNAgB4eHjg7t27CA8Ph5ERM2ZKixYtYGlpieHDh+Px48eoWbOm+FybNm0QHR0Nf39/fPjwoURetU29Xbx4EW/fvkXr1q0BAO3atcOTJ09w//59iXS3bt3Cpk2bUKdOHfTt2xeTJ0/GnTt3xOc3b94MLpcLBwcHNGrUSGlvdxaWHxZlnLWLT8OpcS88FhYWGRT3G5QScVoWVlZWKF++fIlPcb+ewMBA9O/fHwCQlJSE8uXLw93dXTyKtHXrVvz6668qic/hcCAQyQ+hP9T27duBVq2QQ1H4R3SiSP/SvXt3PH78GJmZmTAtfJFbuXIl8vLy0KpVK+Tn50uUqSpjxoxBbGwstmzZImEkFaWVjH5PbSNKYWFhcHV1BY/HAwBwuVy4uroiNDQUjRs3Fqfz9/eXyOfo6Ch2FEtPT0dubi7mz5+Pn3/+GRMnTsSff/4JiqJk1hsQEABbW1sAQqfmHymcfEhIiHjFX2pqqnaFYdE+yjhrs3vhsbBon+Kbd9evDzx7xmgVPXv2hJGREUJCQnDlyhWcP38eHh4eCA4ORnBwMH799VeJiNYi7t27h7dv3yI0NBQdOnTAgwcP8PXrV7x79w7//fcfEhIS4Obmhvj4eAQGBmL06NGYO3cuBg4ciEbZ2WhWty6ap6fjS1wcHg4YANGYFUVRGD9+PDp37iyuq0KFCli3bh2MjIzg7u6OTZs2oW3btvj8+TPCwsLg4uJC+3pfvXqFixcvolmzZmJ7RBojRozAiBEjpJ8kamLcuHGkWbNmEsdatmxJpkyZIjff2LFjyYkTJySO5eXlkT///JNwuVyyYcMGqfnCw8MJABIeHl4quQ0FWfpg9SSJQetp2jRCOBxCAOHf6dNVLsqg9cQgrD5Kxw+vv+xs4X3apAkh06eT8Dt32PuOBrL08eDBA2JiYkIoiiIURRFXV1eSkJCgdPlqm3rj8XglrDeBQCB3CC0xMREFBQXo3bt3ibImT56MOXPmIFhGmHIWAycnR7gai86qLGXSGjIrVgABAUI9BASwo0QsLLqOyG/w+nWhz+DYsdqWSK9ZtGgR/vzzT6SkpODDhw/w9vbGchX6QaUNJdHQ1OvXr3H37l2Z6cqXL49v375JHEtLS0OFChWkpufz+diwYQM2bdoks8xevXrR2pfFoPlRjIDi1/nLL9L9baTpgw2kKETU6d67J/zLRt1mYdEOyvbboj7s+XPNyGeg2NraYty4cbCxsYGzszMCAwNLBMvk8/kKy1HaR8nf3x/Z2dk4e/Ys0tLSxKvRiuPj44M1a9aIvevz8/MRHR2Ntm3bSk3/xx9/YPr06WIP/by8PBgbG0uk4fP5Ur369YrSbhtRfFWEoS7jLn6d9vbS/W2Kp+PzgUOH2ECKLCwsuoOy/XZR/0IWlSnuyM7j8Ur4XwUHB2P48OFyy6FlKJ06dQrnz59Hly5dULt2bWzYsAHNmzeXu1S/efPmcHZ2xs2bN+Ht7Y0bN27AxcUFTZo0wZIlS9C3b194enoCEEbTrlmzJlJSUpCSkoKoqCgUFBSgTJkyiImJwdChQ0FRFAIDAzFr1iw6Iusu0m6Y5cuFx2/cEA63UhTg7S1pRIkMrMBASSMgOFiY39BGC4o7IlOU0LlR5OQoWp1QPN3hwyWX1LIruFhYWLSJtIUV8l6aizp1s6jMoUOH8OrVK4ljr1+/FsdKKigowJMnT5gxlMqWLYu5c+fi1q1bWLduHV68eIHc3FwYGxtLDSAJCJcJnjp1Cr/99hsiIyMRFhaGEydOgKIonD59Gp6envD09MThw4cxffp0EFEMFwDm5uZISkrCP//8I967rVmzZvD395e5fE9vkHbDFDWeRDx8KPnWIS0NACQlCaeWDG1Uqfjqj4EDASOjkquyinco3759jwcEAE5OP45vDrvJLQuLbtKsmdAVoOh3eaNMolWoW7cq517B9gESWFpaokKFChKxmIraLAUFBYiLi1NYjlxD6dOnT4iNjYWHhwfKlCmDIUOGYMiQIQCAFy9e4M6dO2jRooXM/DVr1sT+/fsBAJMmTRIfDw8PF/8/cOBADBw4UGr+ovXRJSAgABMmTNDdsADFDYBWrYCbN0saQMWnjOQNxRabWgoJCcG2bdsYFlzDSFuuLu2GX7FC6PgYESH8npX1/ZzIwPpROo4fZVqWhUXXKGqgNG8ufFm7e/d7n0NRwo9oxgAo+dK8Y4fwvKiPWrdO+CKszAImtg+QIDAwEF26dJGb5vLlywrLkWooZWVlYeTIkeKN7Xg8Hvr27Yt169aJ5/dq166N2rVrKyu32tH5TXGlGQBz50ofZi3q/1XUwBLdcIDU4IAGsSlu0ajRshB1TsWGVuHkBFSuLNRLfr5hdxxFO+jYWOm+WexbJouhoWttuqiB8uDB9/5Z1OeEhX0/RojQRWDAAMl+PzNTWEbRPurnn5UzlNiNriVQZCQBQMeOHRWmkWoorVixAj179sS+ffuQl5eHsLAw7NmzB40aNcKlS5fg4eGhvMQs329ukS/S9evC7wsXCm+OAweAjx+/pw8JAW7fFvoridLcuvXdgBK9sSxfLix79myhIzMAFNvbxyCRNh3J4QBDhgg7mpwcwMXFsDuOojooHog1IgJwdAScnYHHj9l93FgMB10bOSlqoBSd+hf5kRY9BghHim7dEhpCu3cLjSRR+qJ9lImJcnJIm7FgKTVSDSUnJyexc5O5uTm6du2Krl274vr16xgzZgyuXr0KCwsLjQqq9+TkAC1bfp8iElHUF+nmTUlDKTlZ+Hn4UGhUcbmy356mTwc2bfp+Q4oMJkOm+HSkhQXwv/9990maO9fwHbuLd9Dm5t+nHwsKhNdfVAfFO2JFUwbsyBOLLqJrIyfNm0uOJImgKKFRJI2HD4HWrQE3t+/PBYoqXR+ljQj7uja6pwakGkrW1tZSE7dp0wbbtm3D5s2bMXv2bLUKZjCIGlFwsKQRJKLoTd68uaTDX9E0ohtJ1tvTrVslb1J9RN6De+FCYOnS7zdk48bfOyeKAsaMkdRLcZ3oqGN3Th4fS44+wp1XyWjhZo9F/evD1JhLL3PxN0grK0k/reJwOEIDqkkTYd6CAmDLFtlTBlp8Sy+VXlgMGxVGTmS1J0baWUGBZF/j4QFERcm/FwFg1y4gO/v7dy+v0vVRdFwWmEbXRvfUgFRD6cuXLzIzeHl54cqVK2oTqLTk5vMx6+8HOH4vFgQE/ZpWxrJBXip1sIzcQLJWq4mgKOD9e8DSUjgaoAiBQDh1V5xWraS/0agZRh9mxUfdihqNDx4AoaHAkydCHdy/L4ytVHTevzjFO9MhQ0r1pqOuB/eSo4+w9eIrCAjwKPorAAorhxTzsys6tfrtm7C9VKggbD916wKJiUIdyAqeZm4OWFsL8xY1uovGpyo+ZaDEW7rEfUcInMqYgUtRaFXbQSU95eTx0WHZJTyOSQEAPHwvQy/a4gd4i9ZpFi4Erl9Hzpt3WNJqNO6YtUOL4HC5bW3BoYfYfvk1ACDi/VfceP4R/y7sLPf+y8njY8nBcNy59ggtPr3CohqA6aIFki9sK1YAhf68Yl6+FBpPReFwhFNpRQ2j4oYUl6t/7UjXRvfUgFRDicvlyl3RJmvESRfosPQSOOW+x3fafvkN7r75jMvzO5W4gVIz89B95RU8/5AGIy6FYa2rYuWQRuJ0tB5ggPxOU1HgMEKE02vA93nq4hgZSd50ogda8dGXCROA48eF53x8gIMHZdcL6Q/+nHw+eqz6F28Sv6FGeWucmdMethbGMsugrSOpAhTzq3J0FBpC0iDku5EkQqQ3EYcPC50mRb8BA8PQvquvwtj+Pfo1FW7UHHjljdLXqsjAuvMqGYLCn1RAgLCDF4GALsJrTkkBjI2BGjUkdZOdXfL65VG9OvD0qaT+isenUrBIQB7bLr3EiTffryk5PRcA8CgmBbl5fJgYc3HnVTKaVLcDQPDf2y9iXQAooZ8lRx+JjSQAIAAOh0XjzqtPso3U4j6A0uKR0YGOEfQDvEXrLDk5QNu2wKNHWNJwKLaW84IgNg0RsWnYffUtLE2MpBrqx+9JRmR+EpuKJUcfl7j/irazAr5AeM/DEo/KNABuXsBKHx/hvUjI9xe44veiNCOpfn3hdJss9NWn6Afwi5JqKI0dOxZdu3bF8uXLpcYtiomJUbtgqmLx5iTMSEsYOdcVH0tISESdiX8BANILeDA3N4NLWR7S09PxOkW4i4sVNxenbz3DjYdv4GBlClBATHIG7HjfHyz7rr4GQDC1fRXwjChYWNliScgDPLl8HfUS0zAuPgkmIuNk1iwgPR3IyICRvT3sC2+kJCcnWKanwzIzE9mmpkgtU0b+9WRmwtrUFHmpqfhSrhzskpPBe/ECqTNmIFsUYJEQ4RvNkCFARAQuXLiAkJAQueX6Lj0FE7tH4u+H4xNwNPSxuMMgBTw8jklBr5XnYYY83PtQgAIBQRleHuwtuNg5vgWO3o3B6ftxsON9H8W4/N9zXH8WjxfxGShrnI/ejSti+Yg2MC7Ixcf584FLl4QGISHCFWmECG8uAEaJibAvLEclPSUlIe/rV3yJj4cdRYG3bh1SFyxAtugNLiWlRL5kRcZGbjqonDQcvx4JCoBdke0LI19HIzHZFf033kFUwleUMS6AdTl78DgcNK1iisjoz4j7koWCAj745Luer/z3Eh3rlsc8v1awMDNGS1dzRH9Iwtd8Y3AJHy0y3yJRFPfDwUEkKFC+vFBPBQXKt6eCAsDRUainb9+QZ2yML3Z2sOvfHzwjI6Q+eIBs0SrJyEhhpz5pknCkioaeHjyPgYNFyR3HAeDCvRf4ks1BloCLFzHJsDLKx6c8Uzx8/xVUXiYgKMDRsGjhQyo+AaduPAUggIOxUGmf80wgAIXczHREZX1DxPuvKCgQYHrHipIVrVsnNLoLjT2jggLYb9gABAcjadgwWP76KyzLlUN2djZSU1NlX8y6dbDYswfWaWnIe/IEX7hc2K1YAR6Ph9TUVGF7evJEaNiLePIESExU3J5YaJGcnIzEwrYnJjcX+PNP4MQJ2Hz6BHMA951rws4kD5/yhIasKckGlSvAxyThVleHExNx6e5z5OQLgHw+HIy/tycbo3ycvfsCGQJTUCCwNxYa98jOwYf4VByOTxDe84XviXxC4aZDLeD8Acn77uVLpDo5yb0ei8xMWMfHI4/H+96PFxQg1cYG2c7OwpEkkdHdvj3QoAHw88/60Z4KR/fw6pXQ32rBAm1LxDhSDSVzc3Ps2LEDnTt3hpubG0aOHAl3d3dQFIVDhw59f/DoIH3aesHZuQwA6UGkngtckEAs4Eh9Qtuy0bhi0wQA0IjzDLaU5IhOs/KSeW/y6+PWy09Ie30bRuDjoaAWuOCjbY1soEZl/OU95nviwEDh30GDYP/tGyZeuwYA2Nu1K3xevULzqChElS+Po40by72eZkZG6GxsjI+XLmFPq1aYEBoKh/R03EhNxcPKlYFx4yQzFNYrL2o6AHR3TIKzs+yt/oR6soMT9QnunGhkVpbU0z9HomACYKCU/uEmvz48KtvCk/MG+fFf0PG3XHAJH21tbIRLYmVQKj29e4fOz57hY5ky2NO6NSbExcEBwI0bN/BQzltcQkKC3HLl6ykO0zang8NxgHclPtw5MbjCFz48+R/C0YKXCcjqP+PeYugfWUjNNYIH5w36VRHgSW5VuGQkwaR6ZQR6/0+mTIzoycUFe+rWxYQxY+BQsSJunD79XU+il6O//hLnU6Sn1tZxcHaWvWeSqD05U5/gzonDFb6wPWVH/wdbKhPDKsrMipv8+siFMTw5b8T33duErwgMPCeZ0MpK4n6Q0JOpKXx27kTzOXMQFRUlDn0iFSsrNPP1/d6eLC0xISUFDg4O39tT69bCT1ECAxXqiYUex48fl76XqI0NMHIkej56BK/YWHSqxEe2w/f2JK0fL4609lS5rAnacsPl5ssgZnhp5wZ89FL9vvPwEPZPon68Xj08lBG0GX/9pR/taelS4NGj77607dsLV2ubmkrOGhAiXIHL5ao20qtFZAacrFWrFu7du4dZs2Zh5MiR4o3jevbsiWBl4jpomKeCaojju8o8nwPh60EyKYN7/O8r954LXMGF/HDxeYXqeiuoJD7GBwf3+HUAAC7pH7Hg8bES+YyK+I2Mun0blrnCNxfXz58x7vp16ZXZ2ADNmsHixg0gORmOAMZdv44yhdNz3q9eoXFKCpCW9n2aoWtXYOhQAMCTJ08QKDLWpKBxPVEc3Cuog8qZyVj06IjUfCrpqRCLwrSO374J9eTsDOTmwtvbG43ldGLa1FMGnwIBwWu+0ErI5fLwxroC6sTGYvD7OzLzlVpPtWvDcds2jMvIQBk7OwDQaT1Ja0+ClDSMuy//WkvoqXJlYOhQuMbHY1zVqkC1asI3+OxsIC9PmJCiAEtLWHz+DABwTE/HOAsLlCkcqRPrKS8POHLk+1v0gAGAsbFCPbHQo2/fvqhbt67kwQULhA7SAGwKX9Zzso1xr8ANKIyMwUQ/LgsBOMgxErbjUvVPYWHf+/G3b7/348WpVg1P+vfX3fYkmqLesUNySj8i4vtuEXPnSq7GFq3ALb7zhI4jNzK3k5MT/v77b2zZsgVv3ryBnZ2dzC1LdIUsmIEDxaEL8sFDPr7Po2TBjHYd2ShqBVNIhwVAgHSBOcpLa/BFcPr2Tfy/WX4+zGSl//ZNGECwEGNAomzb3FzYNm8u9F969Eg4VTJxojjuRolh62JoRU+UBV6amSrUEaCEnophzOcLy//2Ddi6FbbTpsHW1lZmel3Tk4Di4KRTMwx/dhN2+RkK89LSU3EfNy4XxlZWKF9kw0hbW1v90RMBbHMyabUjEU7fvgl9tACYATB78kS2P1yRaTnjGjVQfvJkgCeUWUJPM2eWyKpITyz0sLe3R/nyxYb03d1L+PhcruAlNpIABvpxBXAhNL5L1T/Z2wOdOwOPHsG2fn3YFhQIXSiKx4Nzd0eivb3swrSNvIVKIoduWaux9czpm9Zeb9bW1vod5VkTUEC0tRNyOUYwERQoTq8IWavXjIyAWrVKGEb6ghGRPT3DKIQIDUg9RMDhYlSbn/HPlVXKZ+7VS7jiRhStnKKEjtyvX393tqxfn1F5NQ4FfLAoq5m6uFy9u8cMlkmThKtdX7/WmggcJvovLy9g2rTv33Nzhf16RMT32QEvL2H//uyZ6vWoe2WmvIVKoun7Vq2kh7zRM6dvWoYSC30C3Tpi8ovz6qugRg0J3xG9ggBOmV/VV37xVVv6ahBQQKqxpWp5T58G+vcXOoM+fSrUwdixwngtRUce9Zw8ruyVmIwhijnVqZPwe8eOwJQprOGkLUxMhAaEFg0lPlXKcCB2diXvPxMTScOJKVRcmUk7DIqskDQNGwqnSadPF65AtbeXXBXo6Ch0ESm6ClnHw20YnKEUdTEQ5Rt1g72Hj+Yrp4DIsmqcmqxVC6Cx2a3ObopLAR8s1TCUXK6ccEWYaGsdkYFgAAaB0hAi9J0ZNkzSoFZHR2zImJoKt795+fL7sYMHhW/+rC61R2SkVqsXcEppKHXpojlD+8YNyfhG0uLvoaRhJA6JoCgMyooVJQMpGxkBLVoIV8KJAtlyOELjSbSzhLQNznU83IbBGUquncfBsnx17VROAM+vDIROoCjhyNGXL8L/O3RQ6k1WlzfF5Ze2o5FG164G9/DiCEo5xK+n0446g6tryb3zAFav2qZ+/dJNR6mbMmWEPm6iKbQaNYCvhaPoHTqo/+Wt+CbZRZHhzrHg0EPsuPwaBMLArnZWJhJxpfZcfQOAYHYvT6w+FSk0qKpYY9HWAJgWD05dUCB03i6KQADExwOVKkmPAdiqFXDtGi2jTlsYnKFkjmxYQfby0BwYIx888JAPU+SJHfjMka14lRLMQMCBGXIAiJwBCazwPbqqb+I9JNrYSOQz4vNhnyF0zE2ytoZlbi4sc3ORzeMhVVo07s6dAX9/AICFhQWsra2Rl5eHL4mJsLOzk4znIgNF8Te0pSeKkBL6ESGhp4oVYWljA0s+H9kcDlLT04U3l6kpYGsrXCVCUUDTpkDfvrD49u27nr580W89kSxY8bPo6UlWe/L0FMdAKopEe9JjPVEQyNSPCKXvOxEUBYv69WFNUch79QpfLCxgl54OnkCA1Lp1kS3HYVsv4t7oAVLjKAFAv35AdjZszp6FeW6u2vpxaQjAQQFf+KJXoj1ZWAhHIGfOBM6eLbEaUl39eAmkOFinGpmjR6df8ca2ImosOI+jM3yw8dxz3HmVjIau5bD73zcQmVAE34PFisjK42PzhVfYfOGV+FhE1BfsrDEeo6hrWBZxEKaCfPlyJSUJPw8eCHcP4HIlR5AKV9+K4fOFU3c6sgelwRlKHpx3cObKbngXPzkgMt0GnlZpaOPwCb+/qwEAGFIhDs6mOXLL3h7tggw+Dz0dE2HMEeBYYgUYg48p1aLEafZ5l3RQs//0CRO3bgUA7P31V/hcu4bmERGIcnfH0a5dS1aUkyOOh9SsWTN07twZHz9+xJ49ezBhwgTJeC4yUBR/Q+N6oviY4hoFcIHANm2k5rP/9AkTjxwBXr/G3m3b4OPjg+bNmyPq2TPZcW9ycoB9+wxPT0Zy9JScjIl79wKEYG9AAHwePEDzrCxEmZjgqChPZub3WF5FMAg9JTijflq0TP2IKHHf3byJ5i9fIqpdOxxt1Ehu3ma1aqFz+/b4GB+PPdbWmHDoEBw6dsQNV1c8lLNcWy/i3ugBMuMoFdLzjz/gNWYMbOMiUa9qAXP3nRw+5xqDd+UVEBEh2Y/Xr/+9Hz98WPi3YkXhPbhvHwD13XclDMpigVA/5/HQousKmHH4sOIV4HFMCmpMOYEyvDzwKAE+xCeIA2qWuN4igTkpiiA131gyMKcJcLxeG6SXtcaiyOPifAoD4v7zjzBh0YCtAFC+/PeAuO/e4UtSkjAw54MHSLW2Rra5uTAeE5crNKKK6UGdUIQYwk6qQEREBBo2bIgKvRbCxE62n1B6AQ/ZAq6w4RRGCAaAMrw8mFICyJvwKNpwylpwYWVTFhzCh3XMC9RLeo1xLy9JrngzMQEoCkbGxrA3Nwe4XCS1bg1LgQCWYWHIbtUKqZMny51SU3UE4MmTJ+jSpQvCw8Ph5fV9fpkJPfEo+W9sHFNr2Nua4+Onz8jjC4rcYDnoH3cfAa8vAhYWwsBkAHD1KgDAqEMH2K9cCZiaIikpCZaWlrC0tFQcSVlP9fQ5zwRWpkbgFOSAFOmIHI1zMOD9ne+LAgYOFC5PL3TGNpo6FfYVhbGXfhQ9EVCwNsoDRQSo+CkJZy+vQK69jTDemL29cJoaEPqrFf5vVKYM7N+8ASgKSX5+sJw3j15kbjXoiYUeovZ04cKFknGUimBjYwNzDgeJcxdg5GcnhMEJBBTt9iTXAJBB15RX+P3kHzAV5AsNgIwMWNaogexz55Cq4DGqrvtu3LhxcHaWHhEfAF4UVEE8HOHMEQYOLm1gTi74CgNzFg30urJIYM5nSgTmjBMFDi4MzHlaXmBOCA3KwMBAtd13Bjei1L5hDdz6JBxW79ukMpYNaqDUhpw5eXwsPPQQx+7FIj0nH5YmRihfxgxcDgcDazlgUf96UsrrWZg5Rxhoq+jeYsWGCIsGajYr/NDB2NhYIq5IaePedGxcE1F55cDnEySkZoGiKPRqKHz4nnrwAcjJhykhsDQ1gaOtGUhaNjJyCpCSJ3z94FDAxM61sHKIV6Ez4GOEvU5G85r2EjoqeW4krd/DqciWAGZmZjAzo6cpdehp5aS+GLD+Gl4nfkPN8tb4Z7b8/e8AyetuUq0cCID7776U0I+09M2rlcFC6xcwzagk2/mxEF3R0+mFvUp0UKJruvPqk7CdpWQhI7cA3wgP9tY89PCqiPCoL3j7MR01y1sjaHJrDNt0k6ae59K6ThES950W9cRCD6lxlKRQfv1aXCx2LDUzD91WXsHTuFQQApgYURjuXQ2LBtTH6lNPxX3R7F4eWH3qKe68+gQBIaBAoaXMPh6F/XsBcOsWnIrcl9rsx/s+fIi6hS8D6NpVOGV18btGhrYMACj1BFgWQ4Ddt7eKvzIaODgzE6AoeL9+jcbR0SUCK4tQd6BXgzOUpnZ3x1+lsChNjblYM7wR1gyXPzQvPbOpTnnqy2Ny19oyLe/1I5tIPS7NIAKEOpO1Oay8c/rA5K614WRrhptLpUyRykHZ6y6Rfrj030CfUOW3V1bPLCzFsbUwxp3fukk9V7w9KtU+dbF/F41kESL0izKMCSLhSrmqVYWGX506Ql+mt2+/+31pGIMzlAICAjBhwgT4+flpWxStoa7wAPpu9LCwsLAYEse9vHC3+NRbpe8jQDmfPiAy3ZZ5H8piFPUXVNontwjNwsLQ+d07fPT3xx4Li+++XKdP42FOjoTfV1HU7RtocIbShg0bfnjfAF0OD8DCwsLCwgx9s7NR99YtYdiESZOEB1u0EJ8/33QqYGmDt5mW+Bj33Rf2/CdHhb5cWXyheXDjix0oSjhSlU842B9XqUgqgq5xEZgXeUJ8xKjIdkmj9u6FZXo6AMA1KgrjduyQrMTERBiZvBALV1cgOhqOHA7GfflSco9FGejt1Nv79++xevVqeHl54datW1i2bJnUfeLkpaNbBgsLCwsLy4+GfUAAyhcfGAgNFU5X8fm4cGYp2nZdjLc2zsjmm4j3xUvJpx/ZPq3g+96MBFThQgwCis/HiLfXsPZB0PfwABwOUK+eMHq6qSmcZs8WrgS0tISZszPMKEroZ0RRgLe3MIL3smUl/HqNAZ3yDVSLoSQQCODr64uNGzeiXbt2qFq1KgYPHoywsDDa6eiW8SMQEhLyQ08l0oXVEz1YPdGD1ROLKmi93bi5iTfBtgUgO/gAE/gD2CP79MaNwo8UQkJC4Gdrq3t+X1LgqKPQixcv4u3bt2jdujUAoF27dnjy5AnuF9scT146umX8CISEhGhbBL2A1RM9WD3Rg9UTiyqw7YYe+qQntRhKYWFhcHV1BY8nHLLjcrlwdXVFaGgo7XR0y2ACVX4wVX9kfWocxWH1RA9WT/Rg9cRSGuj+pnTSMVkWXTTVJlk9lR61TL19/PgR1tbWEsdsbGwQHx9PO11OTg6tMkSIgna9ePFCaXm3bdsGNzc3tedRNV9qaioiIiKUyiPSQ/FgZqyeJGH1RA9WT/SQpScWeijTnuj+pnTSMVkW3XZDpywm7rsfWU+MQdTApEmTSOvWrSWONW/enPz888+009EtQ0RQUBCBcKsa9lPkExQUxOqJ1ROrJy3riYUebHui155YPdHTE1OoZUSpfPnyuHXrlsSxtLQ0VKhQgXY6Pp9PqwwRnTt3RlBQEFxcXGhH3TVksrOzER0djc6dO0scZ/UkCasnerB6oocsPbHQg21PkrD3HT3Ufd+pZa+327dvo1u3bkhNTQVFUcjPz4etrS2uXr2Kpk2b0kpXUFBAqwwWFhYWFhYWFnWhFmfu5s2bw9nZGTdv3gQA3LhxAy4uLmjSpAmWLFmCyMhIhenknWNhYWFhYWFh0QRqmXrjcDg4deoUfvvtN0RGRiIsLAwnTpwARVE4ffo0PD094enpKTcdRVEyz7GwsLCwsLCwaAS1eD5pmKioKPK///2P7NixgwwfPpxER0drWyRGOHXqFKlZsyaxsrIiffv2JV++fClVeaye6MHqiR6snlhYWH4E9N5Q4vP5xMPDg/z777+EEEIuXbpEmjVrpmWpSs+7d+/IuHHjyNOnT8mxY8dI2bJlydixY1Uuj9UTPVg90YPVE/NERkaSAQMGkHbt2pHBgweTunXrEgCkXr16aqnvwIEDxMrKilSsWJGMGzeODBgwgAwcOJC8fv1apfLWrFlDJk2aRCstXSPb0Izx+Ph4pdKzetIN9N5QOnfuHDE1NSV5eXmEEEIKCgqIubk5+e+//7QsWen466+/SG5urvj7okWLiLu7u8rlsXqiB6snerB6YpZr164Rc3NzEhgYKHF81apVCg2lxMREcvbsWZXqbdmyJRkxYoT4+5w5c0jZsmVJcnKy0mXdv3+fXLlyRWE6uka2LhvjdEcdBQIBqVGjhnj5etu2bWnXwepJd1CLM7cm0WQEb03i7+8PY+PvGxc6OjqicuXKKpfH6okerJ7oweqJOXJzczF8+HAMHDgQP/30k8S52bNno0WR3eCLk5+fD39/f3z69Emluo2MJN1UBw0ahK9fv5YIzUKHRo0aoX379grTMbHFlTaJiorC2bNncfz4cezbtw/Xrl3D7NmzpaY9f/48pkyZgvv37+P+/fs4cuQI7XpYPekOanHm1iR0o4DrOxEREfjf//6ncn5WT/Rg9UQPVk/M8e+//yIuLg79+/eXen7FihUAhBGKU1NTIRAIkJSUhE2bNuHJkyd48+YN/vnnHwDAyJEjcfPmTZw5cwZRUVEghODvv/+mHWsnKysLAFBQUIBly5bh5cuXqF+/PlavXo2HDx+CEIKtW7eiQoUKCA0NxeDBgzFw4EDk5+fj4sWLePXqFWbMmCG3DnlGduPGjZVOp2lu3bqFTZs2wdjYGHXq1MGTJ09kPtg3b96Mnj17wsHBQWmDm9WT7qD3hhKPxxM3EBECgQACgUBLEjFPYmIiCgoK0Lt3b5XLYPVED1ZP9GD1xBzPnz8HAFSrVk3i+Nu3b5GUlAQAoCgKP//8MxISEuDo6AgnJyeMGzcODRs2RJUqVdCzZ0+MHDkSGRkZ2Lp1q3h/rJo1a+KPP/7A3LlzFcqRnp6OpUuXomnTpujTpw/i4uLw77//Yv78+ahQoQLKli2LFi1a4OTJk6hatSoGDRoEV1dXVK5cGZUqVcLp06fx+vVrhYYSE1tcaRN/f3+J77JGHdPT05Gbm4v58+fj559/xsSJE/Hnn3/SXrnN6kl3Vrjr/dRb+fLl8e3bN4lj8iJ46xt8Ph8bNmzApk2bSlUOqyd6sHqiB6sn5igoKAAA5OXlSRx3dnbGoUOH0Lp1a1hZWSEsLAyOjo64ffs2+Hw+vn79WqKsM2fO4OPHj1i1ahVWrVqFhg0bIicnR279d+/exU8//QQ/Pz94enriwoUL4HK5KFOmDBwdHVG7dm0MGTIEjx8/RlJSEqpWrQoAcHBwQLdu3bB7925UqFBB7hRhUega2fpijMsadbSyssK///6LpKQkbNiwAdu2bcOff/5Ju1xWT7qD3htKPj4+eP/+PUhhgPH8/HxER0ejbdu2WpaMGf744w9Mnz4dlpaWAEp2pnRh9UQPVk/0YPXEHDVq1AAAvHnzRuK4ubk5vLy8AAB169YFh8PBr7/+CkdHR1hYWIh1X5SYmBg0adIEc+bMwZw5cxASEoKlS5fi4cOHsLS0FH8ePnwoztOsWTPs3LkTZ86cwdq1a2Frays+V/St/sOHD+KpOREuLi5ISEhQ6nrpGtn6YIzTGXXk8XiYPHky5syZg+DgYNpls3pils+fP+Px48d4+PCh0j59em8oGXIE7w0bNqBmzZpISUnBy5cvce7cOVy4cEGlslg90YPVEz1YPTFHly5dYGdnh507d5Y4JzJUPnz4AF9fXyxYsADVq1eXWVa5cuVw7do1iWMRERFo0KABMjIyxJ8GDRooLaeLiwsyMjLE04GA0BHd1dVVqXLoGtm6bowrO+rYq1cvpKWl0S6f1RMzBAYGwsPDA46OjvDy8kLDhg1Rvnx51KlTB+vWraM38qal1XaM8urVKzJ8+HCyefNmMnToUPLq1SuN1i8QCMj69euJmZkZ+fTpk/i4v78/uX79ukplHjp0iFAUJbEzsrm5Ofn27ZvKcrJ6ogerJ3qwemKOixcvEnNzc/LHH39IHN+4cSMBQI4ePUosLS1JWloaef/+PbGwsCAnT54k+fn5pFu3buT3338nnz9/JtHR0cTY2JjMnz+fxMfHk4sXL5I1a9bIrLdly5Zk6NChUs/t2bOH1K1bV/xdIBCQxo0bk99++0383cvLizx79owQQsjevXtJmzZtxOemTp0qNR4On88ntWrVEv9GV65cIe7u7kQgEJDFixeTJ0+eKEynC6xdu5YkJSWJvxcNKyGNsLAw4uvrS7t8Vk+lZ86cOWTo0KEkJCSEhIeHk7dv35LXr1+T+/fvkwMHDpDhw4eT6dOnKyzHIAwlXeDZs2ekVq1a4u+fP38mFStWJFlZWVqUSvdg9UQPVk/0MCQ9vXz5kowYMYK0a9eOjBo1iowcOZL4+vqSs2fPko8fP5LatWuTKlWqkDVr1pAhQ4YQLy8vEhcXR/bu3UscHR3JqlWrCCFCY69q1arE1taWjB8/XhzrqjiHDx8m1tbWpFKlSuTw4cMS5xISEkjv3r2JhYUFOXbsmPh4fHw86du3L1m8eDGZOXOmxLm9e/cSHx8fQgghWVlZxMXFhdy9e1dq3bKMbC8vL4kytW2My+KPP/4gp06dIi9evCAvXrwgZ8+eJadOnZIwYG7cuEH+/vtvscEyatQocvPmTaXqYfVUOlauXKkwzYoVKxSmYQ0lhti8eTOZOHGi+HtAQECJ4HEsrJ7owuqJHqyedIc9e/aQvn37alsMlaE7Qilv1LGoAXPgwAFSrlw50q1bN7J06VISGhqq6UtSC/qkp/nz5ytMM2PGDIVp9D48gK5w7do1DBo0CIBw5UlmZmaJ4HEsrJ7owuqJHqyetM+///6LJk2aID09Hc2aNdO2OCpDURQ6d+6MwMBA2NvbAwC+fPmCq1evYvv27eJ0AwcOxMCBA6WWER4eLv5/yJAhGDJkiHqF1gL6pCcPDw/UrFkTPj4+cHNzg7W1NXg8Hr59+4Z3797h4sWLMoNgFoUiRMrSCRalIITAyckJT58+xdmzZ/Hx40f88ssvOhUHQhdg9UQPVk/0YPWkG4waNQpxcXFo1qwZfv31V1hYWGhbJJXZsmULnj9/ji1btgAApk2bBnd3d9b4LoY+6SksLAwbN25EWFgYPn78CB6Ph/Lly8PHxwcjR46kFdaCHVFigDdv3sDS0hLHjx9Hu3btxMt9WSRh9UQPVk/0YPWkG+zdu1fbIjAGO0JJD33SU/PmzdG8efNSlcGOKLGwsLCw/PCwI5T0MDQ9ZWZmKhwFZUeUWFhYWFh+eNgRSnoYmp5OnjyJoUOHyk3DjiixsLCwsLCwGBQfP35E69atxVsEySIhIUHhNj/siBILCwsLCwuLQeHo6IhOnTrBxcVFvDqvOHw+X7yBtDwMZkTp8+fPuHjxIlxcXGBmZqZtcbROdnY2oqOj0blzZ9jZ2YmPs3qShNUTPVg90YPVEz1YPdGD1RM9ZOkpOTkZWVlZqFKlisy8Dx8+VLylj2phnHSPoKAgicBW7Ef4CQoKYvXE6onVE6snnfywemL1pE49MYXBTL25uLgAAIKCglC7dm2paQICArBhwwaZZcg7r628qpb94sULDBs2TKwXEUzpqU+fPrhz5w78/f0ldqlm9SR5ftWqVdixYweePHmCMmXKoHv37vDx8QFFUWq9XqbPl0ZPqtbPVB5N1qWqnpRpuzNnzkR6ejqaNGmChw8fYvPmzUrLr+1zpW1PdH6b7OxsDB8+HA4ODsjLy0PNmjXRp0+fEs7HdMrSVhp190/Lly/H0qVL0adPnxLBQrXRH6t6XpaeGEMt5pcWCA8PJwAIx6EWCQ4OlppG1nE650uTt2fPnirnVUWu4OBg0rp1awKAhIeHS5wT6an4cTr1xcfHkzNnzpDg4GBy+PBh4uTkRKytrcmVK1cYuRZN64kQ2foojZ6Knufz+cTb25v4+fmRZs2aEQCkb9++JDs7u1TXQ4h69VX8vCI9mXX7TW5ZqtTPVB5N1qVqe1LUdgsKCsTf58+fT3r37k3Mzc2JtbW1zC0fVL3XVO0HlTlXmvtOUV0i7ty5Q0xMTEjPnj2Jn58fqVChAnFzcyux9x2dsuikUXQ/qlKXOvqnhIQEMnLkSPL333+T2NhY0qBBAwKAjBs3juTn59OWtTT9E5N9EyH0242qGJyhpEqHrW7o3EBMU9qOSBrdu3cnLi4u4k47LS2NdOrUiVhaWpKHDx+WWmZD0RMhhOTl5ZHY2FhCCJHYxfvYsWNk7NixEg8+VdGkvtRhKBki6mpP/v7+JCAgQOJYfHw86dChA6lUqRLJyMhQqjxt3GtFUZeeCCGEz+eL///27Zv4/7y8PBIfH08IERoLKSkpKtchDXXolGk9CQQC4uPjQ5ydncX7tAkEArJz507C5XLJsGHDJPqr0qAL/RNTcNQzTsVSFD8/P22LUGpu376Ns2fPYu3ateByuQAAa2trHD9+HNWrV8f06dNLXYch6EnEX3/9hbp16yItLU0iEFvfvn2xc+dOcLlcxMXFlaoOQ9IXi2xu3LiB/fv3o169ehLHnZ2dce7cOYSFhSm9bYght52FCxfC398fhBBYWVmJj/N4PDg7O4MQgoEDB6Jr167Izs5mrF590Ok///yDa9euYc+ePeKVYBRFYezYsThw4AAOHTqEBw8eMFKXPugDANLT0xWm0StDKTs7G2lpadoWQ2n0pcHIY8uWLahVqxb69u0rcdzCwgJHjx7F4cOHS12HIegJEC45XblyJTp06AAbGxupad68eYOaNWvin3/+UbkeQ9EXi3yWLVuGevXqYcSIESXO8Xg8VKhQAR8/fsT48eNpdfqA4badpKQk/P7776hSpYr4BcXKPxhW/sHiNBRF4Y8//sDjx48xevRoEIYWfuuDTteuXQtvb2906tSpxLlBgwbh7du3aNy4MSN16Zo+rl+/LvX4pk2bFObVC0NJIBBg3759qFmzJh4+fKhtcX44srOzcfr0aQwbNgwcTskmU61aNdjZ2SE5ORnJyclakFC3uH79OqKiouSOslWvXh1t27bFpEmTaD/cWH483r9/jytXrmDmzJlyt4hIT09HUFAQZs6cqUHpdI9t27bByMgI06dPL2EgFf3eqFEj/PXXXzh48CD27NmjLXE1SmJiIm7fvo1x48bJbEuVK1dGXl4edu/eDYFAoGEJ1cu6deskvhNCsGzZMixatEhhXr0wlD5//oy2bdviw4cP2hblhyQ/Px/z58/H4MGDZabh8/lo1qwZrUZn6Bw8eBBVq1YtsYqkKBRFYevWrUhOTi5xA7OwiIiIiEDZsmXRu3dvuemqV6+OVatWYefOnQgPD9eMcDqGQCDA7t27MXz4cJQpU0Zh+gEDBmDMmDGYMWOGXs5UKEv58uURFRWFPn36yE0XHh6OsWPHIjg4WG46faNhw4ZYu3YtAODdu3do2bIljh07hjVr1ijMqxeGkoODg9yAUSzqxdraGnPmzEG1atVkpuFyuRg1ahT27duHz58/a1A63SM9PR3+/v4KN4l0cXHBzz//jPXr1+PLly8ako5Fn+jXrx8SEhJgaWmpMO348ePh7u6OqVOnMjadpE+8efMGycnJ+CvKTmIkqThFR5b++OMPnDt3TuYUuaHh4uICc3NzuWmaN28OX19fLF26VOH2H/rEokWL0KdPH/z0009o1KgR2rdvj/v376Nnz54K8xpMHCUW9bF9+3a0bt0aderUkZtu/PjxWL58ObZv34758+drSDrdg05IfBGzZ89GYmIio06lLIZBfn4+CCEwMTEBAPHDPX3/EKnpjYyM8Pvvv6Nnz554/vy5wvvV0HBzc0NycjKcJ56mncfKygotWrQAn89HYmIiKlasqEYJtUdeXh4aN26M1atXo0uXLgBQwpgs2q4WLVqEhg0bIiQkBMOHD9eorEzx+vVrHDx4sMTxzMxMNGrUCHw+H4sWLcLt27dl+i+J0IsRJWXIfRAEo0oNYVSpoVIPLEMgJCQEvr6+8PX1RUBAACNlZmRkYNKkSQgLC1OY1s7ODkOGDDHI+W26JCcnIy8vj3Z6Ozs7BAUFGWwHzaI6ly9fRpkyZWDRf7PcEZKidO7cGTExMT+ckQQIfU6sra1BSfGjVMTPP/+M7t27G2y/FR4ejidPnqBcuXIlfLek4eXlha5du2LDhg16OzpZpkwZ7Nq1C1FRUXj//r34Y2JigooVKyIxMRGJiYm0RvMNbkTJpNEwcMtVBaB7Xvfqxs/PT3zNERERaNiwYanLfP78OQQCgeK9cAoZNWoUkpOTkZqairJly5a6fn1j2rRpiI2NxY0bN5TKFxQUBBsbG1rDwLqKohEPFuW4efMmbGxs8M1M0t9Gnp4pioKzszNycnKQkpKC8uXLa0RWbZORkQEXFxfs37+fdp6ievTz88P27dtx5swZ+Pr6qktMrREREQEej4f69esDeCM1TfF2tXDhQiQmJmpIQuaxt7fH4cOH5fqKAqDl02dwI0r5z88i9/7fyH9/G1+/ftW2OHrP06dPQVEU7e0pWrVqhdOnT/+QRhIAPH78GB4eHkrnO3ToEJYsWaIGiVj0lbX7z+ETx0mhr5s0unTp8kOtgLt79y6+fPmCAdufqpTf29sb3t7eWLZsmd6OoMgjMjIStWrVAo/Ho52nWbNm6NOnj0rtT1coaiQlJSVh9erV4PP5AICoqCjcuHGD1oCCwRlKpCAXBfEPkXtrK5ycnNC3b1/ExsZqWyy95dmzZ3B1dVXoAFiU7OxsnD17Fvn5+WqUTPfIy8vDy5cv4enpqXTekSNHIjw8HC9fvlSDZJpBkJEM/tdo5OTkaFsUg0CQGgdOmUoyz8ubQunRoweOHTv2wywS+O+//wBjc1A2ziqXMW/ePDx48AA3b95kUDLdIDIyEi/SrWhP4Yp4/vw5Bg8ejKysLDVJpjlGjBiBO3fuiJ9Lrq6u+PDhA3bs2KEwr9oNpa9fv2LdunVo3749XFxc4Orqipo1a6Jhw4aYNWsW7SigdOeOeR69YNF7Pcz7b8G6deuQmJgoXtFgSB78msLFxQXDhg1TKs+zZ8/Qo0cP3LlzR01S6SYvX75EQUGBSoZS9+7dYWNjgwMHDqhBMvVDctNREBeO7LPzYGFhgaZNm2LhwoV4+lS1N/wfndTUVJCsFHBsK6uUf8SIERAIBPj7778Zlkw3iYyMBMe2EihK+UeayODs2LEjunTpYpChAjZv3gyeB71p/aIGuLGxMQ4dOoQzZ86oUzyN4OPjg1OnTsHU1FR8rHHjxrRG8tVqKG3duhUzZsxA1apVcfjwYURHRyMqKgqvX7/GvXv30LdvX5w6dQoTJkyQ++aTnJyMVatWARD6csh/6xYOm3LMbDF58mSEhYXBxsYGCQkJqFGjBs6fP8/kJRo8kydPxuLFi5XK4+XlhfLly5cq6rQ+8vbtWwBAl80vxJ0N3Tc4U1NT9O/fH8HBwfo59M/PB6+6D8y6LMbWrVtRtWpVbNmyBVu2bAEgXMElGvJmUYytrS0sBgbCqKJi30Bp7cze3h6+vr56a3gry9OnT8GxlT36RgeKonD+/Hm99hOURYMGDcAto7zRXb16dTRu3NggFkalp6eX6FtFAUoVoTZDad26dWjSpAn27t2Lvn37oly5chLnjYyM0Lx5cyxbtgxr1qzBli1bZMbfsbe3x9y5c0EIwa5du1CrVi05NUufTzU1NYWHhwe6d+/OBvijCSEEz58/V3rpOofDQffu3X84Q6lv377IzMwEZazcvlsiJk2ahEWLFuntyhuKZwqufQ3MvG2Fs8a+SEpKwooVKwAAO3bsgIeHh0G8mWoKysQCFM9UcUIZDBw4EAAMYtpEEefPn4exBzNO2C9evMCtW7cYKUsXiIqKwqxZsyDIVm2kbNCgQTh//jwyMzMZlkyzDBgwAC1atMD06dMxY8YMeHl5YePGjbQGAtRmKI0YMQKNGjUSf7916xZyc3OlprWyssLChQuZcRorUkTRN62yZcvi1KlT+OWXXzBz5kxxB84im5SUFNSpU0elh1uXLl3w+vXrHy6aujK+XMVp0KAB/P39xZsO6xVS7l0ejyeOkNy8eXNUrFgRPXv2xMCBA/Hx40dNS6hX7Ny5Ezm3t5eqjAEDBuD+/fulapP6QsWKFcGxKKc4IQ0WLlyIqVOnMlKWLvD48WP8/vvvKufv0aMHcnNzERoayqBUmqdBgwY4ceIEypcvj8zMTHTv3h3h4eEYPXq0wrxqM5Ts7Owkvu/atQs1a9aUu69O8VEnVch9EIz899J9YzgcDlatWoVFixZhxYoViI6OLnV9ukhISAgjcZRETvCVKys/ZOvt7Y1WrVr9MM6kADB27FipbyfKTMHdvXsXK1euZFgy7dOwYUNcunQJwcHBuHbtGurXr4+YmBhti6Wz3Lt3D4K0eKXySNv8lRCC169fMy2eTvHgwQMMGzYMJK90Ix4i/Q0ePBgREREGo7eYmBiYmpqCMrVWKp9IHzVr1sT+/fvRpEkTNUmoOfLy8lBQUAAej4eyZcuiUiV607UaW/W2b98+RERE4OnTpxg/frza6jFpNAy8qi3kplm8eDHevHkDFxcXtcmhTfz8/LBhw4ZSl1MaQ8ne3h43b95EvXr1Si2HvrDnyDmsOPxfqcqIjIzE/PnzkZKSwpBUGsLITGESiqLg5+eHJ0+e4KeffqLdSf2IREdHg2NpX+pyDhw4gFq1ahn0tkKPHj0S7kvGNWGkvG7dusHS0lJqVGd9JCYmBpUrV1Z5xoaiKAwfPhwODg4MS6ZZrl27Bnd3d5w8eRKfPn3C9evX0bx5c1rTrBoND1CuXDmsX78ePXv2FG9OxzR0G0P58uWRnp6OqVOnIikpSS2y6Dvx8fHgcrlwdHRUKT+fz0dkZCTDUukmhBCQzM+gLOxkpqEzstSuXTsIBAK9WzEozZdG1vU6OTlh6dKl4HA4uHz5cqmmBQwRK/9gXP3vqdy2RJe2bduCEIJ///2XAcl0k4l/ngXMbEFxmYmfbGZmhh49euD0afpboegyCQkJpY78n5CQgJ9//hlxcXEMSaV51q9fj7t37+LevXs4dOgQTp48icjISBw7dkxhXo0ZSkWnYLp37w4HBwe8e/eO8XqUWTGUk5ODgwcP4qefftLPlUZqJjMzEw4ODuCosCUAIAyiWLdu3R9i+i01NRXg54NjrnjXcnm4urrC2dlZ6cje2obwVYuZ9d9//2HWrFlYv349wxLpNyQ7FZSZam2pqIFaoUIF1KlTB5cuXWJSPJ1C0QuKKgwePBhNmzbV24UVRTkVa4XbmS6lKsPExARbtmxRuCeaLtO+ffsSwYBNTExoDQRozFCqXLky6tSpg8mTJ+P48ePo0aMHrl69yng90kaUZL3Z2tvbY+fOnThz5swPs4yWFhQFUBRmzpyJ+Hjl/CSKIop4+vDhQ6Yk00ms/INRceRuAKDlByBvZImiKLRu3VrvDCXkq7ap77x58zBnzhzMmDGDvQcLIYTApOkoGDkrH49LGh07dsTly5cZKUsXEWR+AYdhQ6lXr17YsmWLyi+JugSvRjvwarYvVRnlypWDu7u7Xgfj/PTpk8QK0IKCAoSEhODu3bsK82psr7fly5ejc+fOCA0NxcGDBzFx4kRYWVnhp59+0pQIUvH19UW/fv0wZ84c9OnTBxYWqi3tNkRKu3dXjRo1YGFhgYcPH6JDhw5MiqZzUGa2MG0TUOpYLgDg7++vh46ksqe8FbWjFStWICkpCaNHj4abm5vEatkfEYqiwHNtzVh53t7eOHnyJFJTU2Fra8tYuboCr7oPKBNLxsoTtdfXq9vi5cuXaNu2LWNlawN+8htQlg7gmNmolF+kjyGtWum1oeTn54cGDRqgbNmyyMrKQkxMDGxtbXHx4kWFeTVmKIlWYdWuXRsTJ04EALx5I31zPk2zdu1a8fB0nz59tC2OzpATtguUiQUA1QwlDoeDevXqGfyIEgBQxuYwqtyYkbK6deuGbt26MVKWPkBRFLZv346CgoIfYim7IgRZX8H/EAEjlxagjEuvj969ext0v8ZzbaWWcjdu3Ii///4bHz580Nv9zgghyL60DCaNhoPj1rFUZTVv3hyBgYFIT0+HlZUVQxJqDg8PD4SHh+Off/7Bhw8f4OLigp49e0pE6paFWsYVX758SWvpfY0aNcT/X7hwgZG6cx8EyQwPIIuqVavi/fv3BtOZqBweoHDKTYQgJRYkN0Op5e3Fadiwof6t4FIBfvJb5L1QLuq7PL1evXoVERERTIimGUr5HDExMcHff/8Nd3f3Hz6CtyAlFrn39oKoOJ0pQtS+RA95WXHs9Bk+n4/86DAIspjfAL1ly5ZISEjQ6zAy3759AwR8wKT0hk2bNm2wcuVKvb4/LS0t4efnh1mzZmHAgAEwNTXF7du3FeZTy4hSrVq1sHHjRjg4OGDw4MFyrfFPnz5h8+bNjBkpJo2GgVuuqtRz8qYAHB0dwefz8ebNGwWRv3UfPz8/uLm50doVGYDUYIEAQPIyJIa0VZmK27Bhg0HM8yuCnxiJ/FeXYFy7KyPlzZw5Ew0aNMDu3bsZKU/tcBQHyaTTfr58+YL27dtj5cqV6NqVGV3qGyQnHQA9fze6BAQE4P79+7QeCvrEly9fkHtzM0zbTAOncllGy27RQhhm5vbt26haVfozRdcRhYWgGDCUqlatijlz5pS6HE0RERGBmTNnKkz38uVLJCQkyE2jtqm3qVOn4vLly/D19UWlSpXQuHFjODg4wMzMDCkpKYiNjcXNmzfh4OCABQsWoEKFCuoShTYLFizAnj17EBcXBx6Pp21xtA7JzQBlXHLuXxmD6UcwkgChrqCin4Q0fTZo0ECvpiwpHjNTZmXLloWDgwPGjx+Ply9fwsxMcXwmQ4PkZgBGpqC4zPVBlSpVws6dOyEQCAzqnhQbAqbMTwWJHJhv3bql9MbgukJqaioAMDKFCwgD4qakpOjFS0ydOnVAURSGDRsms80LBAJa4QHU6qPUsWNHdOzYEZGRkfj333/x7NkzZGRkwM7ODrVr18bOnTsZicbNFH5+fli5ciXOnDljMNNwpYKfBxgZyzxNx2BKS0uDp6cnNm3ahF69ejEuolYRjcQNPwCSnw2Kx9xDvV69eggKCgKfz9fPLU3kIK/dUBSFrVu3onbt2ti8eTNmzZqlafG0T0F2qfZ4K46VfzAKEpKRk5WF9+/fo1q1aoyVrW2Sk5MBMDv6JsLKPxi5lCu66PECn4KCAlAm1oz1TYGBgYiMjNQLQ8nExAS7du1SOBrYvr3iFYEaceb29PSEpyczS12ZQFZH7enpiaZNm2Lnzp2soQTAtPVkcGxLF6jM2toaaWlpePnypeEZSkUpyAFFIzq1PIq2Szc3N+Tl5SE2NlYvhv1JPnMbr1avXh1jx47FypUr8dNPPxnkSi15UOblwC3PbH8puo+fPn1qUIaSKEabtJFvJjDx8sO6daotZtEFmjZtCouB2xgpy8o/GHlPs2H67jUIIXrh4C6r70xOTkZCQgLc3d1p7TyhsTHY69evw8vLC5UqVcKoUaN0drPU0aNH4+LFi/j06ZO2RdE6RpUagmOlWlRuERRFoWbNmnj16hVDUukmnHKu4Javw1h5tWvXRqtWrfR+x25VWbBgAezs7PD8+XNti6JxeNXbwLQls9s8UWZlUKZMGYOLlG9hYQFOWReAx8z2JdLIyMhAdnbpHOsNBY61E759+yYeydMHfv/9d/Tq1QsLFy5EXl4edu3ahYoVK8LLyws1a9akFYpFY4bSqVOncODAAezevRt2dnbo1KkTnj17pqnqadOnTx/Uq1evVIEWDYFsAHlPT0PwTfH2LopWxVWtWlW8b5yhYlynB4w9fBkrr3Llyrh582aJSLK6i/Jvl/LajbOzM169eiV2qP2RIHlZIPw8RsukKArh4eGYPXs2o+Vqm86dO8O8+3JQXNkuAqWB5GbC2tpab7czCQkJQeaJaSCEmQjjlJUTAOhNnLdVq1Zh06ZNMDY2xq5du7BgwQKsW7cOS5YswcaNG1G5cmVa0/sai6PUoEED1K5dG7Vr10anTp3wyy+/YOXKlVrdukDaFJy9vb1+LctWE2kA8h4eAse2IjjWTqUqq2LFinjy5AkzgukogswvoHhmjDhNitrl190DkJmZafBTT7KmwimKQnR0NL5+/QovLy9tiKYVcm5tBSgKZm1nMFpu3UVhAFQPIKuLqHvrKcrEAo6Ojnj69CkGDRqk1rrUQXJysnA7HIqZMRGOlSNat2YuGKq6uXTpEiIjI2FtbY0PHz7Aw8MDkZGR4g25x48fj44dFceX0tiIkp2dHY4dOybeO8fe3l4tEXhViaNUHEIInj17prdxR1SOo1SEHNE/SrypyRohmDJlCo4fP14qeXSd7EvLkPfsH0bL7N27N0aMGMFomfrG6NGj8csvv2hbDM1SkAPKiDlnbnGxHyKQfe0PxsvVJmvXrkXmkYlqraN69ep4//69WutQB1b+wZi19zajbYkyMsaNGzfQqpV6gnwyTa1atWBtLXT0r1ixIjp27Cg2kgDAyMgItWvXVliOxgylXbt2YcOGDahQoQJ69eqF+fPn49mzZ+I3Aqb2IjJpNAy8qqUbrn/8+DE8PDxw7949RmTSNH5+ftiwYUOpyhAZSkwsUXZxcYG7u3upy9FlSH424w+3ChUq6M8UMAPXLs3Q9vPzQ2hoKJKSFE8BGwokPwdgcNWbuNy8LPDjHiAjI4PxsrVFdna2zDhwTHE3gULIpf/UWoe6IPnZjPtvWQ7dD8tBgYyWqS6Kb2pcPKI4IQRfvyoOVqoxQ6lly5Y4f/48YmNj8csvv8Dc3BwPHjyAs7Mz2rdvTyswlLoo3kF7enrCxsZGr3dKLi3fR5SUN5RE+hR94uPjMX78eL18K6NNQR5gxGyH9Nd/XxHx7G2JiOm6iLpWwPTr1w9cLhdHjhxRS/m6CCnIBcVwWwIAjqU9ABjMfWjlH4zlR8KVGvVWBY6lPUiG/jgvS6CGtpRzY6NwelgPCAwMBJfLFX/27dsn8d3IyIhW36IxH6WJEyfi1KlT6Nq1K1q2bImWLVti7ty54PP5+O+//7BgwQJNiaIQLpeL1q1b6/UGgKXFEgC3cmNGIrpmZ2djx44dGDRokF4sdVcJQQEoDrO3E2VWFiTnG/IAqPdRUHqIIJ+xsor6LJUtWxY+Pj44f/48Jk+ezFgdOo2gAGC4LQEAZS6MXN1k2gEYOdc1DF8lfp7aHLlF8Ny7g+ehn6FNeG4dYVTKGZbiUOZlIUjWD2fuNm3aYOjQoTIDSOfl5eHvv/9WWI7GDCVTU1OpznBcLhfNmzfHn3/+qSlRZFK0g/by8sL27du1LJH2qA7ArE0AI2XVn3cVANBt8SkY7U00jA66CIQQgAhobeOhDJRFWQAEiQCqAN9HldTswKoSAuZlEt2P6wcM+DEWWBT+vuaDAgGK+SCjVOHu8SQ7jfGytQXh58sNissETAb/1DQcG2fmyzQvg4Is/di/c/HixWjTpo3cNHXqKA7rojOx7HXNh6Vu3bowNTUVbir4A5IF4S7mRMDAslKeOQAKJK/QN0I0lVT8o8dYDN0Po2ryb0hl4Tq6w2LQTpQIh2YA+lKG6TctEJSpPyttSgtlbKGWhzPFNYZJk5Hg2rkyXra2MK7XH6at1TvSKMhORdbFZbh//75a61EH+dF3kf/2GqNlUma2QG46CgoKGC1XHSgykgDQCkGiM4aSLmHlH4wRJ3MQExMj9pj/0bgEIOvYZCCv9AEPKQ4HMLYAyTXM4IkURYHicIXXyWS5XCNQxuayIxTpksGkZjkEWSmIiopSax26Qs6NTSiIUc9CEp5bR3BsCvfV1KX2oyIcMxtwrBzUWgfF5UHw6SW8ZwbJjReni/Bj76OglKvAi0MZC7d0SePx9L790IU1lGRAUZTCQIqGTGmcuaVhXLsLOOUU+CfpacdN8rORdWEJCpKYjSJN+PnIvrIKlxQl1FO9KUPOzU1wazfkh7gfCxIeQ5DxWU1lR6IgSfcC/apK3vOzyHul8A4pHTxzgMOFIEf/piyJGvzduBXqw2LwbpRltFTdxuAMJSbiKInIurgUuREH9e5BxGwcJYYMpbp9YFSeZpRpPdM3+PlC58Y85vY7AwBwjMBPeo63dNNrU29q3pGeW9YF/K8xwi/61j6URcBn3N9NRP6Lc8h/xUwoFl2AH/8Ygk/qdSymKAqUiTVITrpa62GMoveHGtoSxeWB4pmqEItf9xAIBLRWt2vMmVtTmDQaBq6ikQu6UByQzCJvdrrsTFsEPz8/uLm5oWHDhiqXkQMAFBcUQzcZPyUOAMAtU0lByiLoqr6LPaSJgC/8h+kOiaIAYzN8y1Uy7o0W9EapwflYonxrJ5BXVyR95nS1fZQWAZ+x+64ERqZAfrF9y/RYj4Sfx0isN0VQplZAjh76qxI+wGU2PADJ+Yacm1twH0BjRktWL2lpaQgKCsLXr1/F8RvT0tJw8OBBhfHqDM5QYhKOeVkIpMXP0OOORQI5b+U5AGOjSQCQFxECcHkw85mmfGZd17eg0KlRDQ83iqeCoSTOrDm9qXsrCY6FHUD4INlSVtvoevtQAgIIH25qMpQonikE0nSorxTkqT2OEgAY1xsAyrTQX1WP2hvXyQMwYt6Q5Cc9RYLoi57oY/To0TA2NkZCQgJcXYULGp49e0Zr/0PWUJIDZWYL8lnOxIeeNBBVmAJg/oBtzBVoZAwUlHJLmOKGna7oXTyipIbYNzwz6Md7LDObbsqCsrArXBAgZ/rDAO5HAsC40XBw7GqopXzKyBTIz5FxUv/0p6kRJaNK+rnXoHGd7swXWmiYMuxooHY6d+6McePG4d27d4iPj4e3tzeys7MxbZril3ed91F6//49xo8fj8DAQPj7+yMmJkZjdVOmVvTmpRUscw8JCVGDdOqFA+G+PkxBcY1BCuTviK60lnTEV4UytYZJi3FqiVli7NkbsrbipK0vjehJveVzbCvBclAguGVdaIiiv2EnOBAufFBqilqZ8m2cwbGtJN+PU4/0xqvZHlznumqvh//xBfKj70oeLKYnXeznBemfIGA6bpaRDENJx/Xx+vVrHD16FM7Ozjh37hxu3bqFe/fu0YrMrdOGkkAggK+vLwYOHIhx48Zh+PDhGDx4sMbqN6raCmadVYgYXqyj1rUGQ4dtAHJuMziixDUG+AwbSiK0/GCkjM3Bq9YGHDNbxss2qtIUsiII6VarUq/eS7VFiq7H7SoiTx6A/Pe3Icj8opaqeG4dYdp6Egqiw5SSS6coIpdx7a4w0oChVBDzH/IjT8qVR+v9vJTfK+fGRuQ9PspwNRyAawyZwV50RR/F6N27N9avX4/3799j+vTpCAgIQLt27dC2bVuFeXXaULp48SLevn2L1q2Fj4p27drhyZMnKgf+UrQarvh5jnkZcMsIw/0p+snlnv/nH7kdtaIGJe+8OhpjCICXAARfo6Wel6dHWecoU2tQxualWpFI+zeQousQNXT4ovoE2WnIf/1viWkhZdubtPP8T69xupTyyTxfinbHBMq2hazzi5CtovEu9UoUGFCa7OhFNX0DkHtrKwRfvu/Hpsr9JuscIUT5kV2a95Em+ylRaQWJT+UalXTaGJ00gqyvIIpWtRbv56VARw9M6Sr//Z3ChQHSXQJK0z+ZNB6BbJlnC5Gjj9L2ParoqFWrVrhz5w7c3d3h4OCABw8e4PPnzwgMVLzBr077KIWFhcHV1VW8TwuXy4WrqytCQ0PRuLGkv312tvBnE6QllChHRP7rf8GxLk/7PMn5hrzIU6gIIA3Ab4XHVwKoCGAngBuFx2ILz/cEMBDA88J0onN1AJQDsKHw2BQAKYWNJxbAb0OGYC6A2gAOAThTRK5YALeGDMEYAHEA5haJYh4bG4vVq1djz549QMOGmA8gxt0dTZs2ldCLCNH3/v37w6zI8Z8AeAO4CmAJhA2DEAJ+kQ5blp7onDOq3Bio3BjZ1zegeMD4HgAGAfgAlDhXFsDGwv8n4ftvIOJXAO4ADgPYUux8GwBjC8sdB+C3IjcrF8A+AC8Kv8vVk9l3TY0YMQIdANwCMK+wvqwLC4GMz4CxBThWjgp1ocx5ysQKgwCIYimL5AaAeyipr4kAmgO4CGAFJPVRn6IwA0B6YbpYS0v89tv3FNu2bYOlpSV+//13PH78GLGxseLz7dq1k9CLiKL3HV9JY1TR9RdHkJUCfIkWX7PofjkI4GyxtD7A9/sF3+9PQLhv3u7C/+cVnivKZIpCEwjvg9+GSG630xBAQHg4UlNTMbl9e8mM7u6YMWMGAAXtqcimtP0B9AKwqlA+UaxjQeZn8b2nyv0m61xBXDjyI08ARqZiPXYHMBjCl6PlkNSVDYDNhf9PAxAByftoDoRt8EhhuqL6ajVuHP73v/8hMTER48aNk2hrNWrUkNCLCKn33fPn6AWhrp4CWF0oY+bpX0DS4sGr0xNGVZoqrR9l0vBTYoCsr8g8/QuuArCFsC8PL5JGpLduAP4DsKnY/VAZQCYAt8K+PK/YbhQrVqxApUqV8Ouvv4p1Jdobk27/1BXAEACvAOTe3Q0ICsCxraR0P67oPKdsFewFsL/YcS8I20kagFAU658oCoEAzADMQMl7a8Tq1ejQoQNu3bqFefPmSbSX6tWrY9GiRSCEwN/fX6JvAoDx48cDKKmn4ty9exfR0dHIy/v+snDp0iUEBQXJzQeiw4wbN440a9ZM4ljLli3JlClTSqQNCgoiEPpCsp8in6CgIFZPrJ5YPbF60skPqydWT+rUU1F69OhBKlasSLy9vYmPjw/x8fEhbdq0IY6OjjLziNDpESUej1di11+BQACBlP3HOnfujKCgILi4uEhY2D8q2dnZiI6ORufOnSWOs3qShNUTPVg90YPVEz1YPdGD1RM9ZOmpKFFRUXj//j2MjCTNngcPHigsnyJEd9eCLl++HEeOHMGjR4/Ex+rUqYPhw4djzpw52hOMhYWFhYWFRW+YM2cOlixZAhMTyQCcT58+hYeH/F0jdNpQun37Nrp164bU1FRQFIX8/HzY2tri6tWrYh8cEZ8/f8bFixdZC7uQoha2nZ2d+DirJ0lYPdGD1RM9WD3Rg9UTPVg90UOWnory5s0bjB8/HlWqVBEfI4Tg3r17eP5cwT6dCifntAifzye1atUi169fJ4QQcuXKFeLu7k4EAkGJtOycLb05W1ZPrJ5YPbF60pUPqydWT+rUU1Fq1KhBBg0aRBYuXEgWL14s/nTp0kVmHhE67aPE4XBw6tQp/Pbbb4iMjERYWBhOnDghNaaKi4sLACAoKAi1a9eWWl5AQAA2bNggsz5557WVV9WyX7x4gWHDhon1IsJg9ZSbi4ABA7DBxgaoXx/4+WegyBCrOO/w4UCRt4cXrq4YFhWlcT3p2/nStCdV62cqjybroqUnV1dg82bg0SNxWw2YPVul+0Jfz7148gTDRo1SuT3R/W3opFN7mnXrgJAQgBAEANgwdCgwfTqtcrTVj6v7PNNly9JTUSpXroyDBw+WOB4XFyczjxiFppSeEB4eTgCQ8PBwmWmCg4PlliHvfGny9uzZU+W8qsolSx8Gq6dp00gwRRECEMLhEDJ9uvS806YJzxemCx88WCt6YuK8OttV8fOlaU+q1s9UHlXzKdKvNGjpqVgbJNOnq3xPqXpO3rVpQpbStie6vyeddEylkanTxo2FvzVAggFCmjShXZe2+nEmzqvaxlQ5T0cf27ZtI8+fPy9xXDRjJY8fylDSFqp0uKVFHQ82dVMqPRXpjIi8zig7W2hENWlCyPTpJHzQIL3TkwhNtit9bE+lRW2GEt22qka00ScVxRDbk0ydSjGM6aLPetKF/qkoHTt2JGXLliVVq1YVf1xcXIilpaXC8nV66k0VAgICMGHCBPj5+WlbFDGaliUkJATbtjG4/YiGKJWeWrUCwsMBgQDgcITfpWFqKhwKF1GneMhG/UGX2rghojb90m2raoRtO8wjU6crVggjU9+6Jfytly/XrGBaQtfaWOPGjTF16lRYWlqKjwkEApw6dUphXoMzlDZs2AAvL93a6VnTDcbPzw9ubm5o2LChRustLaXSk6qdUf36Ej5L+oSudUSGhtr0qwMPTrbtMI9cnRYdQ/xB0LU29uuvv0oYSYDQUMrKUrA1DQzQUGL5QSk+UkSXn38GgoOZl4eFRRaqtlUW/SAnB5g797shXFAAbNkiHEEMDxcayezvr3H4fD62bNmCr1+/ghQarGlpaTh48CDi4+Pl5mUNJZYfm2LBx1hYWBRQ3BBYsUJo/CmT3pCZOxfYuPG7YWRvL/wfEP4NDhaOIsrTGQvjjB49GsbGxkhISICrq3D3zGfPnmH27NkK87KGEsuPR9GOu3BzThYWjaOswaErFDcEFI2QSEs/dKjm5NU0t25JGkYUJfyIpt2SkoB589hRJQ3TuXNnjBs3Du/evUN8fDy8vb2RnZ2NadOmKcxrcIaSLjpzaxp9deZWK0UfSnw+8PChsOOisc8PC4taUNbg0BWKGwK3bslOm5MjHEEpmv7GDaGxYGiI+pjY2O/HOBxg4EDg0CHg48fvx+XpTAMEBQXB1NQUoaGh6NatG7p3765Veejw+PFjXLhwAWPHjkW5cuWUzv/69WscPXoU3bt3x86dO8HhcFBQUIAjR45g+/btcvNyVBVaV9mwYcMPbSQBQic6VYLyGTSih9L9+0BExPe3ux/IuZJFxyhucAQHCx+2uk6rVkIDAFC8am/uXODTJ8ljAoEwAKOhIepjPn4UGr1OTkBAALB6NTBkCH2dqZmoqCisXr0a/fv3R6dOnbBw4UJa+e7cuYNKlSrB398fsUWNwWJ8LGoQMoibmxvWrFmD9PR0lfL37t0b69evx/v37zF9+nQEBASgXbt28PHxUZjX4EaUWFgAlJzWuHHj+0OJhUXb5OQIRzaLoi9TMsqs2rt1S/JlxMlJchpKGXR9qrKo4Su6vuvXgZYthd/r1xcaSd7ewIIFwujcWrgWV1dXXLt2DQAQGRmJHv9v78zDoyrSvn13d7qzr5CQALIpBBBQFpEgCMSRRQd0GETAUXFAFFHH0VdURvRFUQb91CiRJc7HogjiAH7gMLiyBoIiAUGILIEoSwghkJCEJL2d74+TTjq9d6e3hLqvqy/oc+qcU/1LVZ2nqp566o9/BOT942bOnMmxY8cwGAwkJyfz9ttvc8MNNwAwcOBArr/+etLT02nXrp3Ne//666+8/PLLrF271uv5DgsLIzo62uPrBw0axO7du+u+//TTT1y6dIm4uDin1wpDqblSUxPoHPgHe42n5bRGr16BzmlgCPaXy7XKrFnyFiaWBHhKxiXcWbVnGTNq0iTZaDAf1XWGqQyvWlU/fRVMU5Wm/P32W8Pj5883nGJUKuURpjfekI2n3Fz5+E8/eeW3lJeXU1FRYXU8KirKysCIjo7ms88+Iz8/n0WLFqHX63n00UdZvHgx4eHhjB8/ni+++MLh8zZs2MC8efOYMmUKK1as4NFHH6WsrIwjR47w5ZdfMnr0aMrLy1m6dCkRERFs2rSJ+++/n2XLlpGens6+fft44IEH+Mtf/kJBQQFhYWFMnTqVRYsWceXKFTIzM+nduzfZ2dksXLiwUdrYIyEhgeXLlzN58mSH6YSh1FzJzAx0DvyDPT8Py2mNwkLPe7JNGXN99u6Ve7i7dgljKdCYl08TCgUMGBCY/PgKy9Gn2bPh1VchPh4uXXLtHuZl2IQz3yh/Yit/tjDledaseiMJ5DZp1SrYubNRnZl9+/axfft2q+NDhgyxml7SaDRMmDABSZK4//77GT9+PCNHjqRVq1ZIkmTT4LKkV69enD59milTpnDdddeRkZHBiy++SFJSEqNHjwbgrbfeIiYmhlatWtGxY0eKi4vZv38/mzdvRqFQoFQqGThwIHl5eXTv3p0//elPxMfHc+rUKYYOHUp6ejrPP/+8R4bSnj17GDhwoM29YU1IkoRCobj2DCXhzF3rzL1xY6Cz4R9sOZZWV4NO1zCdvWBvzd14snwh5+Y2jemd5o75SIsJSZKniKurA2fIensE0nL06dln5U6cO9PgtozKAPv5NMBW/mxhyvPOndbnTKNPjRgp69u3L6mpqVbHLYMsQr2B0LdvXyZNmkSbNm3461//CsjTcb1793b6PIVCgVqtRqlUEhYWRrUN/7p9+/Yxb948brrpJiZMmEBBQQHvvvsuKpWqLs3TTz/N4sWLGT58OPfffz8APXr0YM+ePezbt4+QEM/MlAEDBvDUU0/xzDPPoFTadsc2GAx89NFHTu8lnLmbIRMnTiRjzJhAZ8M/WDqW6vXQvr31tEbr1g3T9e0L/fvLUwHNGVsvkyVL5BdWU3Acbq688kq9z4o5Bw7IhmygMF/08P773s+Lq0aFOeZ13NxJOli2AjHPny2SkqBfPznPs2db+6ZFRNT/vxEjZdHR0aSkpFh9LKfdsrKyGDduHADnz58nJSWF7t27140iLVy4kJdeesmjPCiVSoxmf99OnTrVrSirrq7myy+/tLrm7rvv5ueff6ayspKwWqN83rx5aLVaBg0ahE6na3BPd5g7dy4dO3akffv2Vp+QkBDat2/P7Nmznf8uj54uCH6efDLQOfA+1dXyC75///oX/Ztvyg1Q//7yi2f/futVNgAhIfXpnnlGbox++EG+T3PmzTfBckufykrfvAQFrvPaa7JRZOsFEMgpJXeW/ptjq27awplRYQvzOv73v8OpU/KIS7BMH7/5ptzetmrV0OgxUVEha7l9O9xxh9xGmejbFx5+uGF6H0+/jh49mrvvvpvVq1ezYsUKNm/ezPTp0zl9+jSrVq3ipZdeonXr1lbX/fDDD5w4cYKtW7dy5syZOmfo/Px8fvzxR86dO0dqaipnz54lKysLvV7PrFmzOHToEP369eN//ud/SEhIoKSkhP1mGigUCh5//HFGjBhRd6xNmzYsWbKEzMxMunfvzoIFCzh48CAXL14kJyfH5d/qyPm7srKSCRMmcN999zm9T7ObehPU0hwjTlv6IxkMoFI1XNlmbxrt9tuvzemmsDDZJ+kf/5BHkior5ePB5ONxLWJvZEWhCOyUkqsb9lZXwwsvyPGBQDYSDh6U/793r7yYJDTUegrP5LP09ddw+LBreWoKW75kZzeMk2TO1asNfZLMUalAra53AXDgT+MtUlJS6qbZzGdfHnzwQYfX3XrrrZw5c6bu+7hx4+pGpmbOnMnMmTMByM/Pr0vTunVrsi3amQdsBBt90qJjP3XqVKZOnWp1zhXfKVfp0qULq1atorMLQYeFodRUuRZXM1n2dv/1L7kRArlxtjeXHR4u+ywF0vcj0EgSREXVG0rB5ONxLWJpkPTuLb80A727vKtL/2fNggUL6jsmlkbC8uVyfbNcZGEyeh54QB5NcRVTe2fqDCkUcufHX+2eo/bW0jkb5OnB8vL6+mYPk8+SeVy3PXu8n3+BTdRqNUOGDHGazquG0sMPP8yKFSs4duwYly5dYkAAVnBcM87cDqL6rl69mkU+Wk4ZMGzFnbHc9Vmvr/9/UpKsSVERVFXJDqSffy77JF0LRqU55mVFoZB7/5MmBY+Px7WILYMkGMqkvdEbyxEke4sjzNN7MoVnD1sry/bt898qTnvtbXU1fPqpdXqjEVJT63cAsEVEhOyz9Nprro3iCdzGYDA0cBy3RWRkpNP7eNVQeuihh6iqqmLTpk2UlZV51VCqqqpCq9USGxvrMF1GRgZ9LH0yfEmgRnYc+BJMnDiR1P/8Bzf6a8GPZdyZkJCGhpElHTrIDZSpp2v6f0ZG8MRf8TWlpbJPhLkvjCRBu3bXxu8PZoJlOsnehrWWxyxHkJxhOa3Y2HeBvalKf63itNfe2oo8DvIx03GlEjQaud2pqqpPc/UqvP66ewE8BW6xdOlSHn30UYdpqsz/JnZotKG0YcMGNm/ezMiRI+nWrRsZGRmkpaXRsWNHh9edOnWK+fPn06dPH7Kzs3n99ddp3769VTqj0cjHH3/M7Nmz+eSTT1wKN+5XArVfk+XQ/S23yEPZR4/KPRlnQ75NDcvI2o6MJJD1Me3lZt64S9K145tzxx3WUwKixyowx1b7JUnWxywjbIM8aqtUwsWLzuvjjh2yM7a5MeYK9oI5muOP+mzZ3ur18kq2I0ecX2s0yr9DoZBHkcxHwrOzg8doboY899xzfPLJJ3ZDDEiSxN69e1m2bJnD+zTaUEpISGDWrFlkZ2fzzjvvkJeXR01NDRqNxqbhA7LxM2bMGN5//33S09Pp2LEjEyZMsOnNfvHiRYYNG9bAiSyo8HSVSGMx9UJMBsTSpfW9ldzc5ufM7WpPNiQEevSQh+RvvVVuhCx7DNeKoZCXZ30smJZVCwLva2ir/ZKkhseWLJE7X5ZcuAAtWzo3kqB+NNgUhdqGQ69NnAVz9Jfzu/moj17veErNHpIEMTH105Ki0+JzYmNj60IB2EKn0zVwPreHx4bShQsX+P333+nRowfx8fFMmjSJSbUxafLy8ti9ezcDBw60ee3XX3/NiRMnGDx4MADp6ence++97N27l1tuuaVB2qSkJE+z6B8sexoDBvh+Dx/zxtVotF1pm9sWJq6uBomPr2+U9+2zPt+3b/M2FMzLhlbb8Fx4uM96rqPnf8+kPxp4/f4+hGkc+wQIqPf5sVyQ4O/I6bZGSs6ebZimslKuU7amuy9edO95phFdVw0lR3GXlEo5JIgLcXAaTViY3G7MmgVZWZ4HqR0/XtZRTLP5hczMTO655x6HaTZv3uz0Pm4bSlevXmXy5Ml1m96p1WrGjh3LO++8Uxd7oVu3bnTr1s3uPXJycujUqRNqtRoAlUpFp06d2Lp1q5Wh5C7PPPNM3SZ3EydO9L1Tt+X8sk7n+6k4O72s1bUfgFLvPtG/2OplDxxo2/CxpLjY/rnk5Pqh7uZIdXXDPaQsqaqSYyoNHep1A/5yhZbF3x5n+bZ8Jg+93isGU7XWwJy1B9h9tJiBqYm8Ou5mx/cM9OiMO9jz+cnNheeegw8/9H0eqqvlDlVYmGxUx8XZLztGo2ebStuKfO/OKIqtCObmedq/X/bz8fXUVXU1pKXZ3p/PVUJCYM4cWWeBX3BmJAGMGjXKaRq3DaU333yT0aNHs3z5crRaLTk5OSxdupR+/frxzTff0KNHD6f3KCoqIiYmpsGx2NhYzlr2ZDzA787clvPL/fv7firO0l+nlom1H4BcaBrO3LZebi+8UP8S2btXXlWSktL4Z40f770XZyBeyo6e6cxIMrF/P/z8s8986ap1RhZ/e5wQlYp5kzyvh9VaA394/Rt+/u0yAPtPXQIU9fe0pUWg/AXdoaZGHnF2NCqRleX7gIq2you7o0OuYPkb+/aVR4BmzHDtenMXA4MBfv214VS6j30Oq7UG5ny2j90bdzJQdSOvKg8TZtQ5v9AWer1/jDqB13HbUEpOTq4LTBUREcGoUaMYNWoU27dvZ8qUKWzZssXpcju1Wl03mmTCaDR6HKbcnAWb81jU46bADf+7GrDNhLMXrq3zzWlvMlubtp450/A3mq8g8RSFQm5oLadFvZFvf72UHS1Rdqe36wdfup1H7ATfc4JpFGnN7gKKr9RPH0tAzjGz0UJbWrjiLxjoUafMTPjsM8ejM3q93Fl4/33f5ePZZ50b1d6mb9/6TWFXr3ae3oQpFIG96XcfhKGp1hqYvWY/K7blU6XTQ0QKud2SqVGG8O7eFZ7f+FpZSNLMcNtQshwJMjFkyBAWLVpEZmYmL7zwgsN7pKSkWEXrLCsro02bNu5mx4rPdxew49kNjB/Y3vlQvRkuD/M769WbD2X36FE/f24eh0SS5L3HVCr5/yYfI1vRpvV6eRje9ELYvl3uVQUhbk2V2Fq6Dr5rvCUJ1q2TDS7zl6urvhKWBMKJ3/KZq1bV+024MyXgByfSn3+/zN+X/8C8Sf2c1kFTudn1azGnSyq5WG7bv06n01P99+cI27VTXgVlrsWnn8ojhqZOikIhp3n2WZg5E+6+W643phVIUO9Y7K6B2xhjy962JZZ8/nkDQ8le3XKlzlmlGd2VsKwsN36wl1CpZJ1sraCzpKYG/va3hj5cFlQr1czuM4H1l3sjPbmOP9/ajtfvl0ccXdHqhXt6Mn/DIZvazVl7gMXfHqt9Uq2BplCwrHM6b+5b5dmoknDebrK4bSiVlJTYPdenTx++++47p/cYOnQob731Vt0OxjqdjoKCAoYNG+ZudqyQgAtXqsn86ihrdhWQ+9Zo4iI1AJRWahn15nccPlOKJIFGBQ8NuZ55k/oxZ+0BFn59FKMEuacu8eFXR+nRLo7/vvSHuusB657s9u31EXX1eli0qL4ROHBAHmp94w3rYW5bIyRGozzsbmrI9+6Vl+CavxC8aUhYBpEbPx7eequu0XfXR8RcwwMFFlMllthauu5LlErr1TzuOJVaYjFyWH3bYOas2ue6P40NzPXuf0NLQOLHEyX1LzfLgJvnz8vLjd0ZYVSp5BeQH5xI/7Uln2Vb84mP1JAcH07h5SouVWiRgBZRGrbPGcnib4/y+e7fuHDF+Qa9B0+X0r3qenL3LyZOb/HyLCqCbdugVy/45Re5LhYVwXvvwQcfWAcrBc+nbRy1Ac72jerZ0+GS8vOaGNLG/JOLYTHw0CoAQkMU3JASw5HTZUjIdctgkFCpFA20M69z5mXJYJQ4+NvlumvZtp15tvTwBvbim5kbCYMGWYftsCQzUx51cpBmTu/xLO46AlDAlRoWf3uc3UeLKSytqhuNzD11iR1Hivj+lRHMXrOfJd8eQ6o9vjr7FCUV2rp0NVoDoRoVO/Mu8Mvvl20+U69UMbvPBN7+6RNX1GhIr17uO543t0U5TRS3DSWVSuVwRZu9ESdz0tLSaN26NTt37uT2229nx44ddOjQgf79+zNnzhzGjh1Lz54969K7MyVX89NK1F3uQN1xIMXlNbSbvhYFYOsOWoPcmK/ceYqo0BCM5uF2gEO/lzLyiRXsObykfuj3zBnbhsvevbYztHixPKfuqlFguZlkRYXcyLihwWpgkSsJZ86UfYFMLFggvzjOnaNaGcIfhr/Cz8YoQPYRyf71AkqFos4QqNYZuHvedxw5U0aISiFPn9ZqaJRg8TdH2X7kPCqFgkHdkuSX/Ysz5e0N7PQSvYJlYx0ZCY89Jjvam0bnGtu7e/NN+eW7Zg2UlzPnpzIWXvwVIwoOFFxi+5EiThSWU6WTX0hd28SgUio4VVRB55QY/vPiHQ0M8GqtgTte+5qDv5cCcsNt4kDBJfhkJfNslSF3p2FnzPCrj4RBgosVWi5WNFyBV1KhpcdzG928m4LisFg6j8vk+NonrY2lQ4fsZMKBUXDLLfZXqZqPHKWlyWVq3TooKbHfBnzwgZOfoLDt4FzLgDHzKAmLaTDNVKOXOHy6rO67UYJFdaMdNDz+zVFWZ5+ktFKLwcYjjBJkXk1i512v859v5llr2FgSEuQFFab28uab5b3MBg2SjYRnn5X9jVJTHY+MHzjgtGzvTkq1mo4z1R/LY4lT11gdL7Eokx9tOeHweQAoFKztMMAzQ8nUcXan/mVmuv8cgddx21CaOnUqo0aN4o033mCQjRfNb44Cg9WiVCrZsGEDc+fO5dChQ+Tk5PDFF1+gUCjYuHEjPXv2rDOUiouL+eijjwBYuXIlycnJdO3a1e69U9LGE9qyPWC7h1quV1NlVBGuNBAdouOCNoxqnZFwKkjSWBsjxSj5n7g+PJn3FdcVnUNlMHA5Ph6jQkGLS5cwKhQUJSc7/L0ha9eSWPv/88nJRJWXE1VZSVVYGKXx8Q6vjdTriamqQqvRUNKiBS2Li1Hr9ZTGxlJla6dqYCiQoNMx0oFzZvG5cxR++aW1k/T586BU8kGHdH42RBKuqtfpQMFl4tVazpw9x+dbfkaJbIAmmEqRSv5c1IZiREGkUsvpwguU6jQc+v0SivWreWr3FxAbK38sddLrSaxdtea2TpWVxFy5Iut022203LULtVZLaXw8VVOmyA20aaPOAwfkBnzGDIqPHnV43+LiYgoLCxserKmRRyrWrye2vJyIq1f5Ia4dLTU1XNCGYZTgTOEFohVGomttoUvFcnmMAgoLK7nlbysZldaNn05dpri4hPBQFadKQYFEosa6F3kwMp7C2r+VxzqlphL5j38QA2i1WkpKSmjZsiVqtZrS0lKHEWqLHa0mBBLUWkI19keFbNU7gHi1FrXCcSfAVJ5iQ3QoFBKlaBg9/EU+3++4O+CSTl9+KRvQIPsOffEFdOhAZJ8+xOh0aLOyKElIoOXChfX1LjHRzhOhWKdz6BRdnJ9PoYP24mpEFEgKj3UyGEFfXUl0iESpTmOjPEmAgsKUFCbc+xLLdi30Xr1r2ZKW48ahDgmh9KefqOrfXzbMTTHd5s6tcz0o1jmeuiru04fCy7ZHdQBiy8roczGfvMT2RKv1jStPNnWyxiApKNGFcjEsxnOdcnIoKSx0vd4dP+7wvgL/4LahFBERwZIlSxgxYgSpqalMnjyZ7t27o1AoWLNmjUvhwEHeuffjjz8GYIbZCoh9FkvAExMTmTVrFrNmzXLpvne3Ok/r1kq7548YO3BOaklrxQW6K0/znaE/AP2Uh4lT2IlmfV0bVgyewt+/+YaY6mq+69ePmpAQ/rJnD7qQELLuusthnhKvXOGJbdsAWDZqFEOPHiXt5ElOpqSw1kk4hAH5+Yw4fJii+HiWDh7M9K1bSSovZ8dNN7HfTkBPgHPnzsnTeHZY/+WX7Jk82e758op4bg5PcE+nWnYabqYGDT2VxwnBwH5jV1QYCFVFk9XzMbvXNVqnkycpuucell69yvS77iLp0CF2pKayX6er1yIqqn4kacUKWScHrF+/nj22NqlMSICpUxl94AApRWUk3tSOISEF7un0WwtUSg13plwmBAOxcbJOw1Q2wiBcR512jdJp/35GjBhBUVERS5cuZfr06SQlJbFjxw72799v9zpnOvmk3tViqzyFXxdOVn/7ZQm8UJ6OHKFo0CDv1rvevdlz9912zw/TGzmniPdqvbNZnkAuUz0ea5xOZ88y4upVisLDWdq2LdOnTCGpbVt2bNwol6cVZo7P0dEwbRrggk4REex5zP7fd/SBA5zrMIxh0RLdVT7WqZYKKZw9xp4gwbIpUzxrx//0J5ZmZble73r3tj9bIfAbHgWc7Nq1Kz/88APPP/88kydPxlA7tD169GhWrVrl1Qy6yy/G6zlt6GT3fDVyF79YiucHQ/3qvCPGTqhsTtDVIkFkzZcA/OHIEYy1Q75qvZ5p27c7zFOI2dD/I7t2EVU779zp4kWn10bWpm115QrTtm8nvnZrktuPHeOWggLrCzQa0Go5WF6OI3fNsUVF9LLTW6lUaZh263SQoBg3dQK0tcXqhPG6umMGlPxguBEkGHL+MA/lW//uRus0bhytZsxgWkkJ8S1bglrN7aWl3OLAeD948CBZDhrssWPH0qtXr4YHp0+HK1cAiK2qYvSwl5DAuzpZIsGd5w4w4dRuz3Rq1w7mzatbkdqqVSumTZtGfG1P+Pbbb3cYw8yZTj6rd9jQSYJqZajv650kuV7vanFa78aMoVdeXv1WQ8OHy9HSa3ngtmd8U+9sIcH/3bXQc506dCBy/nxITKSVVltf77BTnlauhK++AkniYEWFY51M9W72bDh50up8bFUV53okoUbne51qMVLfEXCqk8lnTa2Gn34iUqeDCRNo9fjjTKuocL3e5eY6rHcC/+BxZO7k5GQ++eQTPvzwQ44fP07Lli3tblniT64SjhLnuwHrUKOjPkTBVcKdXqOqnTOPN/OvUQIpZWV2rrAmufYFCxCu0xHu4rUag6HBc+KqqoizZQB07Qq//kqhEx+gxPbtSbHjyPrwoCfRKTSg8EwnE1WYrwRSUE4kKOC/SX15Idexf4rbOnXrBk88gUajIcVsOjEuLq4uAKktrKbVLEhMTGxwP86dg9OnG6TRqtR1WplotE6WKOCXyA6klDWMIuuyTmfPNphm9bZOvqx3Jup0UoCEMrjqXS1O611KCimWI0pm99eh9k29s4Olhm7pZDBA7TSkS+Xp6adl/8EDByhs2dLhSEldveveXY77ZcdH0186WeJQp7/8Bf7+d5vXaYCU6Oi6707rnTfixwkaTaP3eouJiaFv3+AJbXjy6yxS+t1FYo+hgc6K/+nWDRYtYvXIkSw6Zu3s6SonY5LrVsT6AqPSizGuEhLgrrvgiSf8s7/duHG+f4YtJCgKt/brchkXp8QFApcwbR/iDqGh9QZEbi68+67za2bMkB22DxyQnemDNDQKILdFw4fLbZGgWdFoQynY6DRiGlEpNwQ6G/6lZUsYObLOWJi4ZQups2bR11FDdMKFFR7ByLp1ssOtySHbXwYSyE7cgVquq4Aytes9Xis6dPBaVgReRqVyvDIvmIiPl0cm+/Txj0FgblzV1MjxsBw4eQeM3bub30bkgjqanaHUrElIkOMPAWzdKv/7hz/IQ9rmlTQ0VI4P5MhQSk2VV7g1JSZMkF/4doa1fY4/9t9yhKsbA5ujUkHnznJ8r2aEUmoihoUrjBkjG//BSGysbBgplfXGUaAMgtBQefT4008D83x7xMcHh5FkJxBqaaWWP/7ze44XXrEZmkTgnGZnKEVQRTT2Vz1Uo0GHGjU6wtDWzUtHUOXUCdCgUKCSJC5HRMjhASorMQJFNpa6mxNiMJBYUQHA+ZgYompqiKqpoUqtptTOEn8TkTU1xERFoV27lpKKivplpY8/Xr/C8NIlq+ucLecuvuMOCu1Ec46WKqhWhHqsUwXhSCgJrw3RIPsCSEQj+2+ojToKbYUHsNRJqyVKr6cqPp7SYcPkgJh2fGUiIyOJiYnx+rL3BuEBjhyxCmsQW3tvX+hkiUk3u+WpSxdKe/aEU6dkQ/i++2TnfpDjcVVU+EwnX9Y7K52kMO4+vc9mGTKn0fWuuhptSAgl0dG0VCpRl5RQGh5OlcbiJaPRyBsunz5NsdL+yj+wE27iwQdhyxZALke+qne2sFueIiKoWr2aUsvgkRZtjV/qnTl//jMcPEhsbVgPf+kEsjN3JeGoDdqG5Wn4cEqd+PD5SqcGWGwHVf3Bh8wePoN/JfVDXyvJz79d5rrpa+VILioFWlvBtsxoEalGAi5X6pCAUJWCqLAQlCplXST0MKPO8W4VvtwyyHT/r7/23j1t0OwMpR7KfFqr7Be8ry8kcag8lp7RZQxJusD/ye8MwKQ2p2kd5jg6cOXx48RcucJ3991HTWgof1m5El1oKFkvveTwusQLF3hi4UIAlr30EkO3bSMtN5eT3buz1snOxQNychhx440UlZZ6dTn3+o0b2TNkiM1zt3KEry8kcqg8ziOdFhd0oMKgZnSrQjRKI+sKW6NRGHm6U+3qFRVk2Xh24oULPLFsGTzyCMvatmXo0KGkpaVx8vBh1q5dKweqtMOAAQN8suy9QXiA666TP2aM3riRg/nnuTG+2gs6tUGjMNTrZEmtbonFxTzx+efQti3LbruNoQYDaa++ysn8fFmntm2hstKmXr7SyZf1rl6nc2iURsg+xWO5n5Dx4vMOr2tUvTt+nBGZmRSVl8s6/fWvJGVksKO0lP3t2tm+qGNHWaeffrJ7X7vhJmrrQ/WFMxy6EkvPmCu+L0/UlidLnbRa0ubOrS9PDvBLvbOkY0dGh4RwoOCS33QCuKjVsPz3dkw99i3L7ryNoceOkXbddZwcPpy1Tlam+Uqn4uJiCgsK5Lhu//43tGpVd25Oz7GsT7wZvRGruFwxpnhTDtxFL2pDKanUERuiI1Ytx5vSGoyodOWgg/XbD7J+6wH+veUdUrS1zu2ffUbIypW243IdOkTpV1/JnQqFAnr3hiefbDAaF6lSEfPPf8rxptLSaKnXo96zh9LbbqMK5KCyN99cf90778CaNRRrtVb59yYKSWoeO6zm5ubSt29fEjv3I/yG2whp3ctmOvcD38nyLNv6Prf9dsS9gJMaDeh0hOh0JJaUgEbD+VatiAKiWrSgavBgSpXK+j++KThbTY08zXPgAJE33UTM3LlolUqXeyJfffUVq1ev5ttvv2Xfvn306VO/jYhJp6+++opeqakwalSDVTcANYoQFrZP5/M2t3I1IpJotY4L2nC7OsWEqajWG9HpJSQaBnRLiAwhLDKaE+fKSFZWcte5/TypP0Ho4kWyPrW/k5tvJuRvfyOxbVsAzp8/T1RUFFFRUVRVVVFaWmpb41o87bEdPHiQkSNHOtbJFB6gpgYyMmDjxroI6rFlZbx8432s7Jbus8B3cREh/KFXG6YPTyVUrSIkJITE2tVGwaLTdX96BXWC/VWv3gg4+dTQ1jx3aAMtPvtMrnf33SdPLZrXn/JyeYq2tJSQ6GgSt22D5GRrnYqK5Cja334rP+TOOxtMYfulPJlTUwNz57Lz+4NMGfQ3WSefBVKU27Ss7R/SveYiIe3bk1hdDbffzvmnnyaqRYuAlye7OtUSGxvLU//6kS/3/S7rVBMKCoXPA04O79+ZDx5Jo/RScVDUu2nTptG6dWu718vxy5Jq43K5GefNw3hT5nG55pnF5TrsRryp0xZxAze6EL8sKyvLSidv0exGlHTdxlIV2x7MDMwWkfKS29KrOgy1dajKqKJ1i1hKzldgkOCyrn44XQG0iNbQJi6cwReP8erP/ybs3jth9g54+WXily2TN73t3Rvlli2kOFjeaYm5SRVe+7HJ2283+KoBl5dzP/LII9x00018a3oJ2CAxMZGUDh0gJ0f2c/r1V7jhBnnYNi+Pty58ylv5m+WXzvz5vtth3eJ3mkg2Mz7Dw8MJD3dt2a/PwwNkZMgfkI2lf/yDN3flEBJ6E+s07UgKV3BP37aoVEr2HC/m7KWrVFTpiApX0zougoGpiUjA3vwSxndJ5NVxN7m9J5w5waLT/3v5nroGqrRSyx/nfc/hM6UAKBWgrd3bRlKq0YWEotDq5SF9nQaNCrq0jiVEqUSS4Nzlq1TU6IkKDSElPpw2SiW3dU3ilXE3EaYZCu+9J4flsJeZw4etDlnp1KGDS6uufF6ezPnXvxgPjNEamLU6l5U7T6LAgASU6TRoQpRo9UaUSoWsae20iUoBXVrHIJXXoEBBq9g4zpdVkRShICkmlF/Mtj9JjAnl/oEda8vdFKssNGifgqne2eDDxweTtPZnco4VM75LIi/c04P5G37hm5/PcqywvC5dtAbGDbyefSdLOHG+nFA11OgMVBg1GEzlEgWX9WHERYaSEh+OqrbM2aufwVLvxo4dS6+337YZPmHKbU9QrfBi/DLsxJuqjcdlwi9xA6+/Hl57rS4218ErVxzG5Woszc5Q+v7VEV62KO8GzJyHMzOb1/47cXEOpwoEDggLg3feIQx4q/YjgLhIDdlzHU9tCewTplHx7sO38O7DjnvfriBvjisbE2leMMyDiTCNymrT7XmT+tjfiLsZkpiYSIqdVYDmcaF8HW/KXkwzn8Uv695dXmRQG5ur8PvvXbqvpzQ7Q0kgEAgEMraMCUHzobi42O6ihmgqvbuIwoHTu3kevLKIQqWiJCqKluXlqI3GhosoOnaEsWPrF/ZMmEBx9+6waZPDezcGYSgJBAKBQNAEWb9+vYNFOYe9tIjCudO7+eKcRi9e2r2borZtWTp1KtM//JCk4mJ2jBnDfvOZIouFKs6c3huLMJQEAoFAIGiCjB07ll4dO8Ijj8hhQcx4vPdDnGgpjyCdqIyi6HS9H+7mC62cOr1fNcjmwY6SligUsi+XTlLy8em29YmMRj7dlkH76vrpvxCzkBKPLFtGVLnsL9bp5EmmLVli/aBOnaBvXzhyhMgbb4TUVFr98APTtm0jXq2G5GRu79SJWx5+2G68Kmd7UTaWgBhKp06dYv78+fTp04fs7Gxef/11m/vEuZrOnGeeeYbp06czceJEX2U/6Fm9ejWLmlmAQYFAIBA0JDExkZQuXWDXLqtza7QGXlmzn3U//g4SJMe1oLVCUbdgorxGT1RYCH++tT3/GNuLN9cfZN0Pv1NerSMqLIRpQ9rz+v297fu0lZZCejqcOS5v/jt5srxc32zhj8uLlyzQ0HCxRlztxx7OnN4bi98NJaPRyJgxY3j//fdJT0+nY8eOTJgwgZycHI/SWZKRkeGT5YGNYfXq1X413CZOnEhqampQ7cHnCv7Wqakj9PItzVnf5vzbAkWwaRqmUfHWg/1468F+LqV3Jy0gLwTKzbV7Otj0aAyOw8j6gK+//poTJ04wePBgANLT0zl48CB7LXaSdjVdU2D16tWBzkKTQOjkHkIv39Kc9W3Ovy1QCE0b0pz08LuhlJOTQ6dOnVCr5aWKKpWKTp06sdW0d5mb6dzB2R/O0fnGXOsMX+bLE4ROrtHY3+pLrYLh+c7w5P6e5inYG21Py64vynww5aWx93MlnbfSuEIwPSuQ7UOwt02W+H3qraioiJiYmAbHYmNjOXv2rEfpTJiim+bl5dl99qJFi0hNTfXofGOuLS0tJdfBEKUv8mXSwTLqq9CpIYHSyRvnfamX5fnG6OTp8711jafXOdPXFp7q5Gmd8vSco9/mj7w0tjy5+vd0JZ230rhSXtx9VnNtn7z9bHs6eQ3Jz8yYMUMaPHhwg2NpaWnSk08+6VE6EytXrpSQY/OLj9ln5cqVQiehk9BJ6BSUH6GT0MmXOnkLv48opaSkkJ2d3eBYWVkZbdq08SidiREjRrBy5Uo6dOjgcjj55kxVVRUFBQWMGDGiwXGhU0OETq4hdHINoZNrCJ1cQ+jkGvZ08hZ+3xR3165d3HXXXZSWlqJQKNDpdMTFxbFlyxZuvfVWt9MJBAKBQCAQ+Aq/O3OnpaXRunVrdu7cCcCOHTvo0KED/fv3Z86cORw6dMhpOoFAIBAIBAJ/4PepN6VSyYYNG5g7dy6HDh0iJyeHL774AoVCwcaNG+nZsyc9e/Z0mE4gEAgEAoHAH/h96k0gEDQPPImc3xTYuHEjzz//PIWFhdx555189NFHJCQkBDpbAoEgQPh96q2xnDp1iscff5ysrCweeughfvvtt0alCzS+2sxP6OQ5TUWTqqoqysrKAvJsU+T88ePHM23aNB588EEmTJgQkLx4k5MnT7Jp0ybWr1/P8uXL2bZtGy+88ILL1zeHeuePutYcdHIHTzVtjjr5sy33Gj5ZS+cjDAaD1KNHD+n777+XJEmSvvnmG2nAgAEep/MmGzZskLp06SJFR0dLY8eOlUpKSmymMxqNUufOneuWMw4bNszreRE6eU4gNHEXg8EgLVu2TGrbtq20devWgOThv//9rxQWFiZptVpJkiRJr9dLERER0o8//hiQ/HiLFStWSDU1NXXfX331Val79+4uXRts9S5Y61qw6eQO/tQ02HUK1vLlC5qUoeRq4+zvRjw/P1+aNm2a9Msvv0jr1q2TEhISpKlTp9pMu2nTJmnBggXS3r17pb1790oXL170en6ETp7TFAyAoqIiqaCgQAICZijNnj3byoDo0aOHNH/+/IDkx1csXLhQGjlypEtpg6neBXNdCyad3MHfmgazTsFcvnxBk5p6C+T2J47Izs5mwYIF3HjjjYwdO5annnqK3bt320ybmZmJSqUiKSmJfv360aJFC6/nR+jkOf7WxBOSkpIC7gvkbuT8pkpubi6PPfaYS2mDqd4Fc10LJp3cwd+aBrNOwVy+fEGTMpR8tf1JY3nooYfQaDR131u1akW7du2s0pWXl1NTU8PLL79Mx44deeqpp5B84EsvdPKca8UAaCxqtbquYTZhNBoxGo0BypH3KSwsRK/Xc++997qUPpjqXTDXtWDSyR38rWkw6xTM5csXNClDydXGOdCNuL1eaHR0NN9//z3nz58nIyODRYsW8cEHH3j9+UInzwm0Jk2FlJQUrly50uCYo8j5TQ2DwUBGRgYLFixw+ZpgrnfBVNeCWSd38LWmTUmnYCpfvqBJGUquNs6BbMRd6YWq1WqeeuopXnzxRVatWuX1PAidPKe5GwDeYujQoZw6daqud6jT6SgoKGDYsGEBzpl3eO+993j22WeJiooCQKvVOr0mWOtdsNW1YNXJHfyhaVPRKdjKl08IpIOUu2RnZ0sxMTGS0WiUJEmStFqtFBERIe3Zs8ejdN5Gr9dLM2fOlMrLy11K/+OPP0qpqalez4fQyXMCpYknEEBnboPBIHXt2lXavn27JEmS9N1330ndu3ev060p895770kbNmyQ8vLypLy8PGnTpk3Shg0bnF4XjPUuGOtaMOrkDv7StCnoFIzlyxc0KUPJUeP8v//7v9LBgwedpvMlb7/9tnT+/Pm67+bLjG2Rk5MjjRkzxuv5EDp5TlMyAAJpKEmSJB09elR68MEHpczMTOmBBx6Qjh49GrC8eIs1a9ZICoWiwY7kERER0pUrV5xeG4z1LhjrWjDq5A7+0rQp6BSM5csX+H0Lk8YQzNufZGRk0KVLFy5fvszly5c5efIker2e/fv3M3bsWHr27MnOnTv57bffeOCBB1AoFGRlZfH88897PS9CJ89pKlvnBIOfRpcuXfj4448BmDFjRoBz4x3Gjx/P+PHjPbo22OpdsNa1YNPJHfypabDrFKzlyycE2lJrDjjqhfbp00dat26dJEmS9Omnn0otWrSQ7rrrLum1114L6GhAIBA6eYcLFy5Ib7zxhgRIU6ZMkfLy8gKdJUGQIeqa9xGa1nOtaSH2ehMIBAKBQCCwQ5Na9SYQCAQCgUDgT4ShJBAIBAKBQGAHYSgJBIImiSRJvPfee0RERFBcXFx3/OGHH2bHjh0BzJlAIGhOCEPJC4gG2zWETq4hdHINhULBiBEjaN++PYmJiQCUlJSwZcsWbrnllgDnLngQ5ck1hE6ucS3qJAwlLyAabNcQOrmG0Ml1tm7dSnp6et33uXPn8sorrxAeHh7AXAUXojy5htDJNa5FnYSh5CVEg+0aQifXEDq5xrZt2+q2TfnPf/5DZWUljz76aIBzFXyI8uQaQifXuNZ0EoaSlxANtmsInVxD6OQcSZLYsWMHQ4YMYfny5Rw+fJglS5YEOltBiShPriF0co1rTScRR8kLSJJEcnIyv/zyC5s2baKoqIiZM2cGXTTnQCN0cg2hk2scO3aMUaNGMXPmTNLT0+ncuXOgsxSUiPLkGkIn17gWdWpSW5gEK8ePHycqKor169eLBtsBQifXEDq5RpcuXcjPzw90NoIeUZ5cQ+jkGteiTmJESSAQCAQCgcAOwkdJIBAIBAKBwA7CUBIIBAKBQCCwgzCUBAKBQCAQCOwgDCWBQCAQCAQCOwhDSSAQCAQCgcAOwlASCAQCgUAgsIMwlAQCgUAgEAjs8P8ByDh0lsbelVgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 660x300 with 35 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "layIndex = 9\n",
    "\n",
    "llamaAllLayers = [ f\"model.layers.{layIndex}.self_attn.q_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.k_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.v_proj\",\n",
    "f\"model.layers.{layIndex}.self_attn.o_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.gate_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.up_proj\",\n",
    "f\"model.layers.{layIndex}.mlp.down_proj\"]\n",
    "\n",
    "pythiaAllLayers = [ f\"gpt_neox.layers.{layIndex}.attention.query_key_value\",\n",
    "f\"gpt_neox.layers.{layIndex}.attention.dense\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_h_to_4h\",\n",
    "f\"gpt_neox.layers.{layIndex}.mlp.dense_4h_to_h\"]\n",
    "\n",
    "\n",
    "height_ratios = [ 22.5, 22.5,  7.5, 22.5, 22.5]\n",
    "\n",
    "fig, axs = plt.subplots(\n",
    "    nrows=5,\n",
    "    ncols=7,\n",
    "    figsize=(6.6, 3),\n",
    "    gridspec_kw={'height_ratios': height_ratios}\n",
    ")\n",
    "\n",
    "fig.subplots_adjust(wspace=0.1, hspace=0.1 )\n",
    "\n",
    "\n",
    "\n",
    "for axisInd ,modelLayers in zip( [0,3] ,[pythiaAllLayers ,llamaAllLayers ]): #\n",
    "    withLegend =  [False]*6 + [True] \n",
    "\n",
    "\n",
    "    if(axisInd == 0):\n",
    "        with open(f\"../Data/Bookcorpus_Pythia_step143000\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds = [( 0.07915 ,0.14159) ]*6 + [(0.04664 ,0.07524)]\n",
    "        upperBinBounds = [2.5]*4 + [3.5]*3\n",
    "        yLimit = 0.14869*2.5\n",
    "        labelPad = [-6]*7\n",
    "            \n",
    "    if(axisInd == 3):\n",
    "        with open(f\"../Data/Llama3_1_8B_bookcorpus\", 'rb') as file:\n",
    "            feauterM = pickle.load( file)\n",
    "        # Define Plot specifics\n",
    "        sigmaBounds =  [(0.04664 ,0.07524)]*6 + [(0.027972, 0.04226106)]\n",
    "        upperBinBounds = [4.4]*2 + [1.7]+[2.5] + [4.8] +[3.7] + [4.3]\n",
    "        yLimit = 0.078605*2.5\n",
    "        labelPad = [-2]*7\n",
    "\n",
    "\n",
    "    j = 0\n",
    "    for modelLayer in modelLayers:\n",
    "\n",
    "        if modelLayer == f\"gpt_neox.layers.{layIndex}.attention.query_key_value\":\n",
    "            for k in range(3):\n",
    "                weight = feauterM[modelLayer][\"weight\"][k*1024:(k+1)*1024,:].astype(np.float64)\n",
    "                features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "\n",
    "                plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "                j += 1\n",
    "        else:\n",
    "            weight = feauterM[modelLayer][\"weight\"].astype(np.float64)\n",
    "            features = feauterM[modelLayer][\"FM\"].astype(np.float64)\n",
    "            plotOverlap( spectralAx=axs[axisInd][j]  , overlapAx=axs[axisInd+1][j] , FM_data=features, weight=weight ,\n",
    "                    upperBin=upperBinBounds[j], sigma3Interval=sigmaBounds[j], title=f\"\", yLimit=yLimit, withLegend=withLegend[j], labelpad=labelPad[j])\n",
    "\n",
    "            j += 1\n",
    "        # skip the gate proj layer for pythia and Bert\n",
    "        if( modelLayer == f\"gpt_neox.layers.{layIndex}.attention.dense\" ):\n",
    "            j += 1\n",
    "\n",
    "\n",
    "titles = [\"Query\", \"Key\", \"Value\", \"Att.-Out\", \"Gate-Proj.\", \"Up-Proj.\", \"Down-Proj.\" ]\n",
    "\n",
    "axs[1][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[0][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "axs[4][0].set_ylabel(\"$O_k $\", labelpad=-0)\n",
    "axs[3][0].set_ylabel(r\"$p(\\nu ) $\", labelpad=-0)\n",
    "\n",
    "\n",
    "for axInd , label in zip( [0,3], [f\"Pythia Block {layIndex+1}    \", f\"Llama Block {layIndex+1}    \" ]):\n",
    "    axs[axInd][-1].yaxis.set_label_position(\"right\")\n",
    "    axs[axInd][-1].set_ylabel(label,  fontsize= fontsize)\n",
    "\n",
    "# fix missplaced x-ticks\n",
    "for j in range(4):\n",
    "    axs[1][j].set_xticks([0,2],[\"0\",\"2\"])\n",
    "axs[4][3].set_xticks([0,2],[\"0\",\"2\"])\n",
    "\n",
    "\n",
    "# make the middle axis invisible\n",
    "for ax in axs[2]:\n",
    "    ax.axis(\"off\")\n",
    "\n",
    "# remove the gated Proj for Pythia \n",
    "for i in range(3):\n",
    "    axs[i,4].axis(\"off\")\n",
    "\n",
    "for j in range(1,7):\n",
    "    for k in range(5):\n",
    "        axs[k][j].set_yticks([])\n",
    "\n",
    "\n",
    "for j in range(7):\n",
    "    if(j != 4):\n",
    "        axs[0][j].set_title(titles[j])\n",
    "    else:\n",
    "        axs[3][j].set_title(titles[j])\n",
    "        \n",
    "\n",
    "        \n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plotApp5.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plotApp5.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Book Corpus perplexity increase"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 284,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x160 with 14 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(nrows=2, ncols=7, figsize=(6.6, 2*1.2/1.5) )\n",
    "fig.subplots_adjust(wspace=0.35, hspace=0.2 )\n",
    "\n",
    "#####################################\n",
    "########### Pythia ##################\n",
    "#####################################\n",
    "\n",
    "basePerplexity = 12.029\n",
    "\n",
    "plotIndex = 0\n",
    "for i,key in enumerate(pythiaInfo.keys()):\n",
    "    data = pythiaInfo[key]\n",
    "    perplexity = np.load(f\"../Data/Perplexity/perplexityPythia_{143000}_{\"book_corpus\"}_{data[\"suffix\"]}.npy\")\n",
    "    perplexity = np.flip(perplexity)\n",
    "\n",
    "    ax = axs[0][plotIndex]\n",
    "\n",
    "    ax.set_title(data[\"title\"] )\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.set_xticks([1, 3,5, 7,9])  # Tick positions\n",
    "    ax.set_xticklabels(labels=[])  # Labels for the ticks\n",
    "    if( plotIndex == 0):\n",
    "        ax.set_ylabel(r\"   $\\Delta$Perplexity\")\n",
    "\n",
    "\n",
    "    if( \"UpProj\" in key or \"DownProj\" in key  ):\n",
    "        barColors = ['red']+ [colors[0]] * 9 \n",
    "    else:\n",
    "        barColors = [colors[0]] * 10 \n",
    "\n",
    "    ax.bar(np.linspace(1,10,10), perplexity-basePerplexity, color = barColors)\n",
    "\n",
    "    \n",
    "    # Inset plot \n",
    "    sval = np.ndarray.flatten( np.array(data[\"Sval\"]) )\n",
    "    in_ax = ax.inset_axes([0.0, 0.5, 0.5, 0.5]) # lower left corner (x,y,height, width)\n",
    "        \n",
    "    bins = np.linspace(0,4,35)\n",
    "    in_ax.hist(sval, bins=bins, density=True)\n",
    "    in_ax.set_xticks([])  \n",
    "    in_ax.set_yticks([])  \n",
    "    in_ax.set_xticklabels(labels=[])  # Labels for the ticks\n",
    "\n",
    "\n",
    "    n , m = data[\"dim\"]\n",
    "    \n",
    "    if( n != m ):\n",
    "        std = np.mean(data[\"stds\"])\n",
    "    else:\n",
    "        1/np.sqrt(np.max(np.array([n,m])))\n",
    "\n",
    "\n",
    "    # theory curve\n",
    "    x_theo = np.linspace(0,3.6, 500)\n",
    "    y_theo = MP(x_theo , n, m, std )\n",
    "    mpMax = x_theo[y_theo > 0][-1]\n",
    "    mpMin = x_theo[y_theo > 0][0]\n",
    "    in_ax.plot(x_theo , y_theo  , \"--k\", label=\"Marchenko Pastur\", linewidth=1)\n",
    "\n",
    "    plotIndex += 1\n",
    "    if(plotIndex == 4):\n",
    "        plotIndex += 1\n",
    "    \n",
    "\n",
    "axs[0,4].axis(\"off\")\n",
    "   \n",
    "\n",
    "#####################################\n",
    "########### Llama ##################\n",
    "#####################################\n",
    "\n",
    "basePerplexity = 6.00444602\n",
    "\n",
    "for i,key in enumerate(LlamaInfo.keys()):\n",
    "    data = LlamaInfo[key]\n",
    "    perplexity = np.load(f\"../Data/Perplexity/perplexityLlamaBookCorpus_{data[\"suffix\"]}.weight.npy\")\n",
    "    perplexity = np.flip(perplexity)\n",
    "\n",
    "    ax = axs[1][i]\n",
    "\n",
    "    if(data[\"title\"] == \"Gate-Proj.\"):\n",
    "        ax.set_title(data[\"title\"] )\n",
    "\n",
    "\n",
    "    ax.set_xlabel(\"decentile removed\", fontsize= fontsize-3, labelpad=-2)\n",
    "    ax.set_yscale(\"log\")\n",
    "    ax.set_xticks([1, 3,5, 7,9])  # Tick positions\n",
    "    ax.set_xticklabels(labels=[\"1\", \"3\",\"5\", \"7\",\"9\"])  # Labels for the ticks\n",
    "    if( i == 0):\n",
    "        ax.set_ylabel(r\"$\\Delta$Perplexity   \", labelpad=-1)\n",
    "\n",
    "\n",
    "    n , m = data[\"dim\"]\n",
    "    if( n != m ):\n",
    "        std = np.mean(data[\"stds\"])\n",
    "    else:\n",
    "        1/np.sqrt(np.max(np.array([n,m])))\n",
    "\n",
    "    if( m != n  ):\n",
    "        barColors = ['red']+ [colors[0]] * 9 \n",
    "    else:\n",
    "        barColors = [colors[0]] * 10 \n",
    "\n",
    "    ax.bar(np.linspace(1,10,10), perplexity-basePerplexity, color = barColors)\n",
    "\n",
    "    \n",
    "    # Inset plot \n",
    "    sval = np.ndarray.flatten( np.array(data[\"Sval\"]) )\n",
    "    in_ax = ax.inset_axes([0.0, 0.5, 0.5, 0.5]) # lower left corner (x,y,height, width)\n",
    "        \n",
    "    bins = np.linspace(0,4.5,35)\n",
    "    in_ax.hist(sval, bins=bins, density=True)\n",
    "    in_ax.set_xticks([])  \n",
    "    in_ax.set_yticks([])  \n",
    "    in_ax.set_xticklabels(labels=[])  # Labels for the ticks\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    # theory curve\n",
    "    x_theo = np.linspace(0,3.6, 500)\n",
    "    y_theo = MP(x_theo , n, m, std )\n",
    "    mpMax = x_theo[y_theo > 0][-1]\n",
    "    mpMin = x_theo[y_theo > 0][0]\n",
    "    in_ax.plot(x_theo , y_theo  , \"--k\", label=\"Marchenko Pastur\", linewidth=1)\n",
    "\n",
    "\n",
    "# fix missplaced y-ticks\n",
    "for j in range(4):\n",
    "    axs[0][j].set_yticks([1,100],[r\"$10^0$\",r\"$10^2$\"])\n",
    "axs[1][0].set_yticks([0.1,100],[r\"$10^{-1}$\",r\"$10^2$\"])\n",
    "\n",
    "for i in range(7):\n",
    "    for j in range(2):\n",
    "        axs[j][i].set_ylim(top=3e3)\n",
    "        axs[j][i].tick_params(axis='y', which='major', labelsize=8, pad=0.5)\n",
    "        \n",
    "\n",
    "\n",
    "\n",
    "labels= [\"Pythia\" , \"Llama\"]\n",
    "for i in range(2):\n",
    "    axs[i][-1].yaxis.set_label_position(\"right\")\n",
    "    axs[i][-1].set_ylabel(labels[i])\n",
    "\n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plotApp4.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plotApp4.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Lazyness of the Attention-Output Matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 329,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\339377359.py:10: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  pythiaSvalQuery.append( torch.load(f\"../PythiaSVD/pythia-410m-deduped_step143000/gpt_neox.layers.{i}.attention.query_key_value.weight_Q_S\").numpy() )\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\339377359.py:11: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  pythiaSvalAttOut.append( torch.load(f\"../PythiaSVD/pythia-410m-deduped_step143000/gpt_neox.layers.{i}.attention.dense.weight_S\").numpy() )\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in sqrt\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n",
      "C:\\Users\\PC\\AppData\\Local\\Temp\\ipykernel_153812\\1796025759.py:13: RuntimeWarning: invalid value encountered in divide\n",
      "  x_err = (largerVal/smallerVal)* np.sqrt((max**2-np.power(x,2) )*(np.power(x,2)-min**2))/(np.pi*sigmaT**2*x)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 660x150 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with open('include/AverageSpectraPlot.pickle', 'rb') as handle:\n",
    "    allData = pickle.load(handle)\n",
    "\n",
    "keys = [\"Bert Attention\", \"Bert Query\", \"Llama Att-out\" ,\"Llama Query\"]\n",
    "\n",
    "# generate the Pythia data\n",
    "pythiaSvalQuery = []\n",
    "pythiaSvalAttOut = []\n",
    "for i in range(24):\n",
    "    pythiaSvalQuery.append( torch.load(f\"../PythiaSVD/pythia-410m-deduped_step143000/gpt_neox.layers.{i}.attention.query_key_value.weight_Q_S\").numpy() )\n",
    "    pythiaSvalAttOut.append( torch.load(f\"../PythiaSVD/pythia-410m-deduped_step143000/gpt_neox.layers.{i}.attention.dense.weight_S\").numpy() )\n",
    "\n",
    "pythiaSvalQuery = np.ndarray.flatten(np.array(pythiaSvalQuery))\n",
    "pythiaSvalAttOut = np.ndarray.flatten(np.array(pythiaSvalAttOut))\n",
    "\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1,3, figsize=figsizeM)\n",
    "plt.subplots_adjust(left=None, bottom=None, right=None, top=None, hspace=.25)\n",
    "\n",
    "\n",
    "x =  allData[\"Llama Query\"][\"sVal\"]\n",
    "\n",
    "\n",
    "plotData = [ ( allData[\"Bert Query\"][\"sVal\"], allData[\"Bert Attention\"][\"sVal\"]  ) ,  ( pythiaSvalQuery, pythiaSvalAttOut )   ,\n",
    "            ( allData[\"Llama Query\"][\"sVal\"], allData[\"Llama Att-out\"][\"sVal\"] ) \n",
    "            ] \n",
    "\n",
    "labels = [ \"Query\", \"Att.-Out\"]\n",
    "names = [\"Bert\", \"Pythia\", \"Llama\"]\n",
    "\n",
    "\n",
    "\n",
    "bins = np.linspace(0,6, 55)\n",
    "for i in range(3):\n",
    "    ax = axs[i]\n",
    "\n",
    "\n",
    "    for j in range(2):\n",
    "        data = plotData[i][j]\n",
    "        ax.hist(data, density=True, bins=bins, label=labels[j], color=colors[j],alpha=0.8) \n",
    "\n",
    "         # Only valid for square matrix!    \n",
    "        n = len(data)\n",
    "        m = len(data)\n",
    "\n",
    "        std = 1/np.sqrt(np.max(np.array([n,m])))\n",
    "        # theory curve\n",
    "        x_theo = np.linspace(0,2.6, 500)\n",
    "        y_theo = MP(x_theo , n, m, std )\n",
    "\n",
    "        maxTheoVal = x_theo [max((i for i, x in enumerate(y_theo) if x > 0), default=-1)]\n",
    "\n",
    "        axs[i].plot(x_theo,y_theo,  linewidth=1, color=\"black\", ls=\"--\",zorder=100)\n",
    "\n",
    "        \n",
    "        ax.set_xlabel(r\"$\\nu$\", fontsize = fontsize , labelpad=0) \n",
    "        ax.set_xlim(-0.2,4.5)\n",
    "        #ax.set_ylim(0,ylim)\n",
    "        ax.set_title(names[i], fontsize=fontsize)  \n",
    "    \n",
    "    ax.legend()\n",
    "axs[0].set_ylabel(r\"$p(\\nu)$\",fontsize = fontsize, labelpad=1)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.savefig(\"../Figures/Neurips_plotApp6.png\", bbox_inches='tight')\n",
    "plt.savefig(\"../Figures/Neurips_plotApp6.pdf\", bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
