{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cbb36c4a-28f7-4ebc-a024-b8c2042184c4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "torch.set_default_dtype(torch.float64)\n",
    "torch.cuda.is_available()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e7701f0b-f2e1-4938-9f14-31af68c84875",
   "metadata": {},
   "outputs": [],
   "source": [
    "class DeepLinearNetwork(nn.Module):\n",
    "    def __init__(self, layer_sizes, init_scale=1.0):\n",
    "        \"\"\"\n",
    "        Initialize the deep linear network with scaled-down weight initialization.\n",
    "\n",
    "        Parameters:\n",
    "        layer_sizes (list of int): A list containing the sizes of each layer in the network.\n",
    "                                   For example, [input_size, hidden1_size, hidden2_size, ..., output_size].\n",
    "        init_scale (float): A scaling factor for the initial weights of each layer. Default is 1.0 (no scaling).\n",
    "        \"\"\"\n",
    "        super(DeepLinearNetwork, self).__init__()\n",
    "\n",
    "        # Create a list to hold the layers\n",
    "        self.layers = nn.ModuleList()\n",
    "\n",
    "        # Iterate through the layer sizes and create the linear layers\n",
    "        for i in range(len(layer_sizes) - 1):\n",
    "            layer = nn.Linear(layer_sizes[i], layer_sizes[i + 1], bias=False)\n",
    "            \n",
    "            # Scale down the weights of the layer by the specified factor\n",
    "            with torch.no_grad():\n",
    "                layer.weight *= init_scale\n",
    "                if layer.bias is not None:\n",
    "                    layer.bias *= init_scale\n",
    "            \n",
    "            self.layers.append(layer)\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        Forward pass through the network.\n",
    "\n",
    "        Parameters:\n",
    "        x (torch.Tensor): Input tensor to the network.\n",
    "\n",
    "        Returns:\n",
    "        torch.Tensor: Output tensor after passing through the network.\n",
    "        \"\"\"\n",
    "        layer_inputs = [x]  # To store the input to each layer\n",
    "        for layer in self.layers:\n",
    "            x = layer(x)\n",
    "            layer_inputs.append(x)  # Append the input to the next layer\n",
    "        return x, layer_inputs\n",
    "\n",
    "class MuPDeepLinearNetwork(nn.Module):\n",
    "    def __init__(self, layer_sizes, init_scale=1.0):\n",
    "        \"\"\"\n",
    "        Initialize the deep linear network using μP parameterization.\n",
    "\n",
    "        Parameters:\n",
    "        layer_sizes (list of int): A list containing the sizes of each layer in the network.\n",
    "                                   For example, [input_size, hidden1_size, hidden2_size, ..., output_size].\n",
    "        init_scale (float): A scaling factor for the initialization of weights. Default is 1.0.\n",
    "        \"\"\"\n",
    "        super(MuPDeepLinearNetwork, self).__init__()\n",
    "\n",
    "        # Create a list to hold the layers\n",
    "        self.layers = nn.ModuleList()\n",
    "\n",
    "        # Iterate through the layer sizes and create the linear layers using μP parameterization\n",
    "        for i in range(len(layer_sizes) - 1):\n",
    "            layer = nn.Linear(layer_sizes[i], layer_sizes[i + 1], bias=False)\n",
    "            \n",
    "            # μP initialization: Scale the weights by a factor related to the fan-in\n",
    "            fan_in = layer_sizes[i]\n",
    "            with torch.no_grad():\n",
    "                layer.weight.data.normal_(0, init_scale / math.sqrt(fan_in))  # μP scaling of weights\n",
    "                if layer.bias is not None:\n",
    "                    layer.bias.data.zero_()  # μP recommends no scaling for biases\n",
    "            \n",
    "            self.layers.append(layer)\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        Forward pass through the network.\n",
    "\n",
    "        Parameters:\n",
    "        x (torch.Tensor): Input tensor to the network.\n",
    "\n",
    "        Returns:\n",
    "        torch.Tensor, list of torch.Tensor: Output tensor and a list of layer inputs.\n",
    "        \"\"\"\n",
    "        layer_inputs = [x]  # To store the input to each layer\n",
    "        for layer in self.layers:\n",
    "            x = layer(x)\n",
    "            layer_inputs.append(x)  # Append the input to the next layer\n",
    "        return x, layer_inputs\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ae90c815-30b5-42bd-8a54-cbe15a8fc730",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def compute_jacobians(model, x):\n",
    "    \"\"\"\n",
    "    Compute the Jacobian of the network's output with respect to the input to each layer.\n",
    "\n",
    "    Parameters:\n",
    "    model (DeepLinearNetwork): The deep linear network.\n",
    "    x (torch.Tensor): Input tensor to the network.\n",
    "\n",
    "    Returns:\n",
    "    list of torch.Tensor: A list containing the Jacobians of the output with respect to the input of each layer.\n",
    "    \"\"\"\n",
    "    # Enable gradient tracking on the input\n",
    "    optimizer.zero_grad()\n",
    "    x.requires_grad_(True)\n",
    "\n",
    "    # Perform the forward pass and get the layer inputs\n",
    "    output, layer_inputs = model(x)\n",
    "\n",
    "    jacobians = []\n",
    "\n",
    "    # Compute the Jacobian for each layer's input\n",
    "    for i, layer_input in enumerate(layer_inputs):\n",
    "        # Compute the Jacobian of the output with respect to the current layer's input\n",
    "        jacobian = []\n",
    "        for j in range(output.shape[1]):\n",
    "            grad_outputs = torch.zeros_like(output)\n",
    "            grad_outputs[:, j] = 1.0  # Set the gradient of the desired output component to 1\n",
    "            jac = torch.autograd.grad(\n",
    "                outputs=output,\n",
    "                inputs=layer_input,\n",
    "                grad_outputs=grad_outputs,\n",
    "                retain_graph=True,\n",
    "                create_graph=True,\n",
    "                allow_unused=True,\n",
    "            )[0]\n",
    "            jacobian.append(jac)\n",
    "        \n",
    "        jacobian = torch.stack(jacobian, dim=1)\n",
    "        jacobians.append(jacobian.detach().cpu())\n",
    "\n",
    "    return jacobians\n",
    "\n",
    "def compute_jacobians_wrt_loss(model, x, y, loss_fn):\n",
    "    \"\"\"\n",
    "    Compute the Jacobian of the network's output with respect to the input to each layer.\n",
    "\n",
    "    Parameters:\n",
    "    model (DeepLinearNetwork): The deep linear network.\n",
    "    x (torch.Tensor): Input tensor to the network.\n",
    "\n",
    "    Returns:\n",
    "    list of torch.Tensor: A list containing the Jacobians of the output with respect to the input of each layer.\n",
    "    \"\"\"\n",
    "    # Enable gradient tracking on the input\n",
    "    optimizer.zero_grad()\n",
    "    x.requires_grad_(True)\n",
    "\n",
    "    # Perform the forward pass and get the layer inputs\n",
    "    output, layer_inputs = model(x)\n",
    "    loss = loss_fn(output, y)\n",
    "    loss.backward()\n",
    "    return x.grad.detach().cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fdd4c302-3636-481c-8456-1f356acb1012",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_all_layer_svs(model):\n",
    "    eigs = []\n",
    "    with torch.no_grad():\n",
    "        for layer in model.layers:\n",
    "            _, S, _ = torch.linalg.svd(layer.weight.data.detach().cpu(), full_matrices=True)\n",
    "            S, _ = torch.sort(S, descending=True)\n",
    "            eigs.append(S)\n",
    "    return eigs\n",
    "\n",
    "def plot_all_layer_svs(eigs, title='', save_fp=None):\n",
    "    plt.close()\n",
    "    plt.clf()\n",
    "    plt.figure(figsize=(5,4))\n",
    "    \n",
    "    for layer_idx in range(len(eigs)):\n",
    "        plt.plot(range(len(eigs[layer_idx])), eigs[layer_idx], label=f'Layer {layer_idx}')\n",
    "    \n",
    "    plt.ylabel(r'Singular Value')\n",
    "    plt.xlabel(r'Singular Value Index')\n",
    "    plt.legend()\n",
    "    plt.xscale('log')\n",
    "    \n",
    "    if title != '':\n",
    "        plt.title(title)\n",
    "        \n",
    "    if save_fp is not None:\n",
    "        plt.savefig(save_fp, bbox_inches='tight')\n",
    "        \n",
    "    # plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "25903a8b-9c72-4e05-b768-f11e4099d5ca",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "input_size = 10\n",
    "output_size = 5\n",
    "num_samples = 5000\n",
    "\n",
    "num_epochs = 5000\n",
    "hidden_width = 512\n",
    "n_h_layers = 6\n",
    "learning_rate = 5e-3\n",
    "weight_decay = 1e-2\n",
    "init_scale = 1.0\n",
    "batch_size = 128\n",
    "\n",
    "log_freq = num_epochs / 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "58de375e-0c3c-4105-99d9-b63ace076345",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "X = torch.randn(num_samples, input_size)\n",
    "beta = torch.randn(input_size, output_size)\n",
    "y = X @ beta\n",
    "\n",
    "dataset = torch.utils.data.TensorDataset(X, y)\n",
    "dataloader = torch.utils.data.DataLoader(dataset, \n",
    "                                         batch_size=batch_size, \n",
    "                                         shuffle=True, \n",
    "                                         drop_last=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a3953727-a5a1-4d2e-9378-1c676b5af9fa",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "layer_sizes = [input_size]\n",
    "for _ in range(n_h_layers):\n",
    "    layer_sizes.append(hidden_width)\n",
    "layer_sizes.append(output_size)\n",
    "\n",
    "model = DeepLinearNetwork(layer_sizes, init_scale=init_scale)\n",
    "model = model.to('cuda')\n",
    "\n",
    "criterion = nn.MSELoss()\n",
    "optimizer = optim.SGD(model.parameters(), lr=learning_rate, weight_decay=weight_decay)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "65252833-208b-40ba-aaf9-58c6ef39c3a7",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAb0AAAGMCAYAAABOCHxMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABsu0lEQVR4nO3deVxUVf/A8c+dYZ8BBAQEFcU1F8wtTU2NTDTNNPNXpuaGPS49pY+l6dOiaUVpmpmZmYVraplZmmU8Cm5ZqUnmmguIifuC7DAz5/cHMjmCyj4o3/frNS/nnnvuvd87c+U759x77tWUUgohhBCiAtDZOwAhhBCirEjSE0IIUWFI0hNCCFFhSNITQghRYUjSE0IIUWFI0hNCCFFhSNITQghRYUjSE0IIUWFI0hNCCFFhSNK7wa+//srjjz9OUFAQzs7O+Pv706ZNG1588UWbeg8++CAPPvigfYLMx+TJk9E0rdS38/jjj+Pq6sqVK1duWqd///44Ojpy9uzZAq9X0zQmT55c/ADtbOXKlTRq1AhXV1c0TSM2NjZPnV27dqFpGu+++26eeT179kTTND755JM88zp16oSPjw+FuYlScY6LhQsXomkau3btum3duXPnsnDhwiJtp7jefvtt1qxZU+D6mqbx73//u0jbGjx4MDVr1izQ9mNiYtA0jZiYmEJvJ79lS/v/+BdffMGsWbPynXe3/P8EQAmrdevWKZ1Opx566CG1fPlyFRMTo5YvX65efPFFVbVqVZu6+/fvV/v377dTpHlNmjRJlcXXuXbtWgWojz76KN/5V65cUa6urqpXr16FWi+gJk2aVAIR2s+5c+eUo6Oj6tGjh4qJiVE7duxQqampeeqZzWbl6empunTpkqfcy8tLGQwG9dRTT9nMy8zMVK6urqp3796FiunkyZNqx44dhd8ZpVRkZKQC1M6dO29bt1GjRqpjx45F2k5xGQwGNWjQoALXB9Rzzz1XpG0dPXpU/f777wXaflJSktqxY4dKSkoq9Haio6MVoKKjo61lxfkuC6J79+6qRo0a+c7bsWOHOnnyZKltuyw52DPhljfTpk0jODiYDRs24ODwz0fTt29fpk2bZlO3YcOGZR1emUpLS8PNzS1P+SOPPEJgYCCff/45o0aNyjN/+fLlpKenEx4eXhZhlit//fUX2dnZDBgwgI4dO960nk6no0OHDkRHR2MymazH2h9//MHly5d56aWXWLJkic0yv/76K+np6YSGhhYqpmrVqlGtWrXC74zIV+3atQtc18PDg/vvv7/Etm3P77Ik98PepHvzOhcvXqRy5co2CS+XTmf7Ud3YvRkfH4+mabz33nvMnDmT4OBgjEYjbdq04Zdffsmzvk8//ZR69erh7OxMw4YN+eKLL/J0ndyseyR3W7frTlq5ciVhYWEEBATg6upKgwYNmDBhAqmpqTb1Bg8ejNFo5M8//yQsLAx3d3c6deqU7zr1ej2DBg1i9+7d/Pnnn3nmR0ZGEhAQwCOPPML58+cZNWoUDRs2xGg04ufnx0MPPcTWrVtvGTfcvCsnt8stPj4+z762adMGg8GA0WikS5cu7Nmzx6bO8ePH6du3L4GBgdau606dOuXbBXmj7777jjZt2uDm5oa7uzudO3dmx44d1vmDBw/mgQceAOCpp55C07Rbdn+HhoaSkpJi03UYExNDYGAgw4YN4+zZsxw4cMBmXu5yhdnn/D7HzMxMXnzxRapUqYKbmxsdOnRg9+7d1KxZk8GDB+eJNTk5mZEjR1K5cmV8fHzo3bs3iYmJ1vk1a9Zk//79bN68GU3T0DTNehxbLBbefPNN6tevj6urK5UqVaJJkyZ88MEHN/1sADIyMnjxxRdp2rQpnp6eeHt706ZNG7799lubepqmkZqayqJFi6zbLuxph9z/Z8uXL+eVV14hMDAQDw8PHn74YQ4fPmxT98b/o7fafn7/f3ft2kXfvn2pWbMmrq6u1KxZk6effpoTJ07cNs4bv8vc/wv5va7/DD766CM6dOiAn58fBoOBkJAQpk2bRnZ2trXOgw8+yPfff8+JEyds1nP9ft7Yvblv3z569uyJl5cXLi4uNG3alEWLFhX5sy0rkvSu06ZNG3799VdeeOEFfv31V5uDoqA++ugjoqKimDVrFsuWLSM1NZVu3bqRlJRkrTN//nz+9a9/0aRJE1avXs2rr77KG2+8UaS+/1s5cuQI3bp147PPPuPHH39kzJgxfPnll/To0SNP3aysLB577DEeeughvv32W954442brnfo0KFomsbnn39uU37gwAF+++03Bg0ahF6v59KlSwBMmjSJ77//nsjISGrVqsWDDz5Yovv69ttv8/TTT9OwYUO+/PJLlixZQnJyMu3bt7dJHN26dWP37t1MmzaNqKgoPv74Y5o1a3bL85OQc66jZ8+eeHh4sHz5cj777DMuX77Mgw8+yLZt2wB47bXX+Oijj6zx7Nixg7lz5950nbnJKzo62loWHR1Nx44dqV+/PlWqVLH5jKKjo/H19bX2MBR0n/MzZMgQZs2axZAhQ/j222954oknePzxx2/6OQwbNgxHR0e++OILpk2bRkxMDAMGDLDO/+abb6hVqxbNmjVjx44d7Nixg2+++QbI6T2ZPHkyTz/9NN9//z0rV64kPDz8tp95ZmYmly5d4qWXXmLNmjUsX76cBx54gN69e7N48WJrvR07duDq6kq3bt2s277V534r//3vfzlx4gQLFixg/vz5HDlyhB49emA2m2+6TGG3Hx8fT/369Zk1axYbNmzg3Xff5fTp09x3331cuHChUPF2797dus3c18yZMwFo1KiRtd6xY8fo168fS5YsYd26dYSHhzN9+nSGDx9urTN37lzatWtHlSpVbNZ3M4cPH6Zt27bs37+f2bNns3r1aho2bMjgwYPz9IpB0T7bUmPv/tXy5MKFC+qBBx5QgAKUo6Ojatu2rYqIiFDJyck2dTt27GhzDiMuLk4BKiQkRJlMJmv5b7/9pgC1fPlypVTOeZsqVaqo1q1b26zvxIkTytHR0aZPPb9+/eu3FRkZaS273Tk9i8WisrOz1ebNmxWg/vjjD+u8QYMGKUB9/vnnt/uIbPa/cuXKKisry1r24osvKkD99ddf+S5jMplUdna26tSpk3r88cdt5nHDOb2b7U/ueaa4uDillFIJCQnKwcFBPf/88zb1kpOTVZUqVdSTTz6plMr5bgE1a9asAu+jUjnfV2BgoAoJCVFms9lm/X5+fqpt27bWstzv66uvvrrtei0Wi/L29lZhYWHW7VSqVEnNmzdPKaXUk08+qfr06aOU+ud8Xu6+FHSflcr7Oe7fv18B6uWXX7ZZdvny5QqwOTeV+1mPGjXKpu60adMUoE6fPm0tu9k5vUcffVQ1bdr0tp/H7eQeO+Hh4apZs2Y284p7Ti/3e+vWrZtNvS+//FIBNufRBg0alOe81822f7P/vzfuV0pKijIYDOqDDz645bK3+z9+6NAh5ePjo0JDQ1VmZma+dcxms8rOzlaLFy9Wer1eXbp0yTrvVuf0bvz/2bdvX+Xs7KwSEhJs6j3yyCPKzc1NXblyxWY/CvLZlhVp6V3Hx8eHrVu3snPnTt555x169uzJX3/9xcSJEwkJCSnQL7Hu3buj1+ut002aNAGwdl8cPnyYM2fO8OSTT9osFxQURLt27Upwb3K68/r160eVKlXQ6/U4OjpazzUdPHgwT/0nnniiwOsODw/nwoULfPfddwCYTCaWLl1K+/btqVu3rrXevHnzaN68OS4uLjg4OODo6MjGjRvz3X5RbNiwAZPJxMCBAzGZTNaXi4sLHTt2tLaWvL29qV27NtOnT2fmzJns2bMHi8Vy2/UfPnyYxMREnnnmGZsubqPRyBNPPMEvv/xCWlpaoePWNI2OHTuyfft2srOziY2N5cqVK9ZuqdzYlVL88ssvNufzCrrP+dm8eTNAnuOvT58++XbrAzz22GM20zce07fSqlUr/vjjD0aNGsWGDRu4evXqbZfJ9dVXX9GuXTuMRqP12Pnss89K7Ni5UXH2s6BSUlJ4+eWXqVOnDg4ODjg4OGA0GklNTS3Wfp05c4auXbsSEBDAN998g5OTk3Xenj17eOyxx/Dx8bH+HRg4cCBms5m//vqrSNvbtGkTnTp1onr16jblgwcPJi0tLU8rsSw+24KSpJePli1b8vLLL/PVV1+RmJjIf/7zH+Lj4/Nttt/Ix8fHZtrZ2RmA9PR0IOe8IYC/v3+eZfMrK6qUlBTat2/Pr7/+yptvvklMTAw7d+5k9erVNvHkcnNzw8PDo8Dr79OnD56enkRGRgKwfv16zp49a3MBy8yZMxk5ciStW7fm66+/5pdffmHnzp107do1z/aLKndYxH333Yejo6PNa+XKldYfKpqmsXHjRrp06cK0adNo3rw5vr6+vPDCCyQnJ990/bnfV0BAQJ55gYGBWCwWLl++XKTYQ0NDSU1NZefOnURHR+Pv70/9+vWBnKR34cIF9u/fb+0CzU16Bd3nW+3Pjceag4NDnmM31+2O6VuZOHEi7733Hr/88guPPPIIPj4+dOrU6bbDIFavXs2TTz5J1apVWbp0KTt27GDnzp0MHTqUjIyM2263KIqznwXVr18/5syZw7Bhw9iwYQO//fYbO3fuxNfXt8jbSU5Oplu3bmRnZ/PDDz/g6elpnZeQkED79u05deoUH3zwgfVHfW5XfFG3efHixZv+n8idf72y+GwLSq7evA1HR0cmTZrE+++/z759+4q9vtwvP78xbGfOnLGZdnFxAXLOb1yvIC3OTZs2kZiYSExMjM2VhDc7l1LY8T+urq48/fTTfPrpp5w+fZrPP/8cd3d3/u///s9aZ+nSpTz44IN8/PHHNsveKsnkun7fc/+DQN59r1y5MgCrVq2iRo0at1xnjRo1+Oyzz4CcKy2//PJLJk+eTFZWFvPmzct3mdzv6/Tp03nmJSYmotPp8PLyuu3+5Cc3icXExLBjxw6b76lhw4ZUrlyZ6OhoYmJiCAgIsCbEwuzzzfbn7NmzVK1a1VpuMpny/KEqCQ4ODowdO5axY8dy5coV/ve///Hf//6XLl26cPLkyXyvEIacYyc4OJiVK1faHJs3/l+4kyQlJbFu3TomTZrEhAkTrOW55y+LIjs7myeeeIJjx46xdevWPFd3rlmzhtTUVFavXm1zrBTk4q1b8fHxuen/CfjnGC2PpKV3nfy+RPinKzD3V0xx5F6k8OWXX9qUJyQk8PPPP9uU5V4ltnfvXpvy3C7FW8n9Q3F9wgDyHfRcVOHh4ZjNZqZPn8769evp27evzR8xTdPybH/v3r23PEGe62b7vnbtWpvpLl264ODgwLFjx2jZsmW+r/zUq1ePV199lZCQEH7//febxlG/fn2qVq3KF198YTMoPDU1la+//tp6RWdRNGrUCF9fXzZt2sTWrVttrrjTNI0OHTrw448/8ssvv9hctVnUfQbo0KEDkHPl5/VWrVqFyWQq0n5AznF2u1/tlSpVok+fPjz33HNcunQpzxW419M0DScnJ5uEd+bMmTxXbxZ026WpoNvXNA2lVJ7/EwsWLCjyBR3h4eHExMSwevVqa5fhjdvMjTGXUopPP/00T93CfI6dOnWy/rC+3uLFi3FzcyvXQxykpXedLl26UK1aNXr06ME999yDxWIhNjaWGTNmYDQaGT16dLG3odPpeOONNxg+fDh9+vRh6NChXLlyhTfeeIOAgACb80ZVqlTh4YcfJiIiAi8vL2rUqMHGjRutXZS30rZtW7y8vBgxYgSTJk3C0dGRZcuW8ccffxR7H3K1bNmSJk2aMGvWLJRSecbmPfroo0ydOpVJkybRsWNHDh8+zJQpUwgODr7tH9hu3brh7e1NeHg4U6ZMwcHBgYULF3Ly5EmbejVr1mTKlCm88sorHD9+nK5du+Ll5cXZs2f57bffMBgMvPHGG+zdu5d///vf/N///R9169bFycmJTZs2sXfvXptf3TfS6XRMmzaN/v378+ijjzJ8+HAyMzOZPn06V65c4Z133iny55d7afmqVatQSuUZ29exY0fGjBmDUsom6RV0n/PTqFEjnn76aWbMmIFer+ehhx5i//79zJgxA09PzzxDcwoqJCSEFStWsHLlSmrVqoWLiwshISH06NGDxo0b07JlS3x9fTlx4gSzZs2iRo0aNud+b/Too4+yevVqRo0aRZ8+fTh58iRTp04lICCAI0eO5Nl2TEwMa9euJSAgAHd3d2uruCwUdPseHh506NCB6dOnU7lyZWrWrMnmzZv57LPPqFSpUqG3O336dJYsWcLzzz+PwWCwGRrl4eFBw4YN6dy5M05OTjz99NOMHz+ejIwMPv7443y75ENCQli9ejUff/wxLVq0QKfT3fQH1KRJk1i3bh2hoaG8/vrreHt7s2zZMr7//numTZtm08Va7pT5pTPl2MqVK1W/fv1U3bp1ldFoVI6OjiooKEg988wz6sCBAzZ1b3b15vTp0/Osl3zuNjJ//nxVp04d5eTkpOrVq6c+//xz1bNnzzxXpp0+fVr16dNHeXt7K09PTzVgwAC1a9euAl29+fPPP6s2bdooNzc35evrq4YNG6Z+//33PMsOGjRIGQyGwn1Y13zwwQcKUA0bNswzLzMzU7300kuqatWqysXFRTVv3lytWbMm3yvg8vuMfvvtN9W2bVtlMBhU1apV1aRJk9SCBQtsrt7MtWbNGhUaGqo8PDyUs7OzqlGjhurTp4/63//+p5RS6uzZs2rw4MHqnnvuUQaDQRmNRtWkSRP1/vvv21xtezNr1qxRrVu3Vi4uLspgMKhOnTqp7du329QpzNWbuebOnasA5evrm2debGys9UriI0eO5BvTrfZZqfyPi4yMDDV27Fjl5+enXFxc1P3336927NihPD091X/+8x9rvZvdkSW/Kwvj4+NVWFiYcnd3V4D1+50xY4Zq27atqly5snJyclJBQUEqPDxcxcfH3/azeeedd1TNmjWVs7OzatCggfr000/z3Z/Y2FjVrl075ebmpoDb3hmGm1y9eeP3lt9V0vkduzfbfn6f099//62eeOIJ5eXlpdzd3VXXrl3Vvn37VI0aNWyuAC3I1Zu5V13n97r+M1i7dq269957lYuLi6pataoaN26c+uGHH/Ks/9KlS6pPnz6qUqVKStM0m23l9//zzz//VD169FCenp7KyclJ3XvvvTafVWE/27KiKVWIG/mJUnPlyhXq1atHr169mD9/vr3DERXMzz//TLt27Vi2bBn9+vWzdzhClBpJenZw5swZ3nrrLUJDQ/Hx8eHEiRO8//77HDp0iF27dtkMLBWipEVFRbFjxw5atGiBq6srf/zxB++88w6enp7s3bvXehGREHcjOadnB87OzsTHxzNq1CguXbpkPfE7b948SXii1Hl4ePDTTz8xa9YskpOTqVy5Mo888ggRERGS8MRdT1p6QgghKgwZsiCEEKLCkKQnhBCiwpCkJ4QQosK4oy9ksVgsJCYm4u7uXujbaAkhhLh7KKVITk4mMDDwljdZuKOTXmJiYp67fAshhKi4Tp48ecsnzN/RSc/d3R3I2cnCPCFACCHE3eXq1atUr17dmhdu5o5Oerldmh4eHpL0hBBC3PZUl1zIIoQQosKQpCeEEKLCkKQnhBCiwrijz+kJIURpslgsZGVl2TsMATg6OqLX64u9Hkl6QgiRj6ysLOLi4rBYLPYORVxTqVIlqlSpUqxx2ZL0hBDiBkopTp8+jV6vp3r16kV+orwoGUop0tLSOHfuHAABAQFFXpckPSGEuIHJZCItLY3AwEDc3NzsHY4AXF1dATh37hx+fn5F7uqUny9CCHEDs9kMgJOTk50jEdfL/QGSnZ1d5HVI0hNCiJuQe/qWLyXxfUjSE0IIUWFI0hNCCFFhSNITQoi7xODBg+nVq5e9wyiwzZs306JFC1xcXKhVqxbz5s0r9W1K0hNCCFFqbja4Py4ujm7dutG+fXv27NnDf//7X1544QW+/vrrUo1Hkp4QQlQQM2fOJCQkBIPBQPXq1Rk1ahQpKSkApKam4uHhwapVq2yWWbt2LQaDgeTkZABOnTrFU089hZeXFz4+PvTs2ZP4+Hhr/dzWZkREBIGBgdSrVy/fWObNm0dQUBCzZs2iQYMGDBs2jKFDh/Lee++Vzs5fI0lPCCFuQylFWpbJLi+lVInth06nY/bs2ezbt49FixaxadMmxo8fD4DBYKBv375ERkbaLBMZGUmfPn1wd3cnLS2N0NBQjEYjW7ZsYdu2bRiNRrp27WrTotu4cSMHDx4kKiqKdevW5RvLjh07CAsLsynr0qULu3btKtaQhNuRwelCCHEb6dlmGr6+wS7bPjClC25OJfOnesyYMdb3wcHBTJ06lZEjRzJ37lwAhg0bRtu2bUlMTCQwMJALFy6wbt06oqKiAFixYgU6nY4FCxZYhw9ERkZSqVIlYmJirEnMYDCwYMGCW45zPHPmDP7+/jZl/v7+mEwmLly4UKy7rtzKXZH0DiQmYUwu3q8hfw8XKhudZFyOEOKuFR0dzdtvv82BAwe4evUqJpOJjIwMUlNTMRgMtGrVikaNGrF48WImTJjAkiVLCAoKokOHDgDs3r2bo0eP5nk6eUZGBseOHbNOh4SEFGhg/41/b3NbtaX5d/iuSHpPfvILOufi3yqokpsjdf2M1PFzp66fkbr+Rur6uePv4SzJUIgKzNVRz4EpXey27ZJw4sQJunXrxogRI5g6dSre3t5s27aN8PBwm+7EYcOGMWfOHCZMmEBkZCRDhgyx/v2zWCy0aNGCZcuW5Vm/r6+v9b3BYLhtPFWqVOHMmTM2ZefOncPBwQEfH5+i7uZt3RVJz8/dGQcXlyIvb1aKCymZXEnLZmf8ZXbGX7aZ7+7sQB1/Y04i9HO3vg/0dEWnk2QoxN1O07QS62K0l127dmEymZgxY4b1BtpffvllnnoDBgxg/PjxzJ49m/379zNo0CDrvObNm7Ny5Ur8/Pzw8PAoVjxt2rRh7dq1NmU//fQTLVu2xNHRsVjrvpU7+1u8ZtNLDxb7C8jINnPsfApHz6Vw5GwKR84lc+RcCicuppGcaWJPwhX2JFyxWcbNSU8dPyN1riXD3NZhNS839JIMhRB2kJSURGxsrE2Zt7c3tWvXxmQy8eGHH9KjRw+2b9+e77g4Ly8vevfuzbhx4wgLC6NatWrWef3792f69On07NmTKVOmUK1aNRISEli9ejXjxo2zqXs7I0aMYM6cOYwdO5Znn32WHTt28Nlnn7F8+fIi73tB3BVJryS4OOppFOhJo0BPm/JMk5n4C2k5SfBsCkfPp3D0bArHL6SQlmVm799J7P07yWYZZwcdtXxzW4Y5ibCOnzs1fNxw1MsFs0KI0hMTE0OzZs1sygYNGsTChQuZOXMm7777LhMnTqRDhw5EREQwcODAPOsIDw/niy++YOjQoTblbm5ubNmyhZdffpnevXuTnJxM1apV6dSpU6EbHsHBwaxfv57//Oc/fPTRRwQGBjJ79myeeOKJwu90IWiqJK+HLWNXr17F09OTpKSkYrf0CivbbCHhUlpOIrzWKjxyNoVj51PINOX/0ElHvUZwZUNOF+l15wxrVnbD2aFk+u2FEMWXkZFBXFwcwcHBuBTj1MmdatmyZYwePZrExMRy9aSJW30vBc0H0tIrIke9jtq+Rmr7GoEq1nKzRfH35bRrXaQ53aRHz+V0m6ZlmfnrbAp/nU2xWZdep1HDx816zjCnZZizbpcSOokthBC3k5aWRlxcHBEREQwfPrxcJbySIkmvhOUkMAM1fAw83PCfMSgWiyIxKZ0j53K6R49eS4hHzqaQnGni+PlUjp9PZcP+s9ZlNA2CvN24t1olOjXw48F6fni6ld4JXiFExTZt2jTeeustOnTowMSJE+0dTqmQ7k07U0pxLjnT5uKZo2dT+OtcMlfSbO9KoNdptKzhxcMN/OnUwI9avkY7RS3E3a2id2+WV9K9eRfQNA1/Dxf8PVx4oG5la7lSioupWfx1JpmtRy+w8eBZ/jqbwq9xl/g17hJvrT9IrcoGOjXwo1MDf1rW8MJBLpIRQohbkqRXTmmaRmWjM5XrONO2TmVe7noPCRfT2HjoLBsPnuPXuIscv5DK8a1xfLo1Dk9XRx6s70unBv50rOeLp6t0gwohxI0k6d1BgnzcGNIumCHtgrmakc3Wv3JagNGHz3E5LZtvYxP5NjYRB51Gq2BvOjXw5+EGftTwuf3dEYQQoiKQpHeH8nBxpHuTALo3CcBsUfyecJn/HcxpBR49l8LPxy7y87GLTF13gDp+Rjo18OPhBv40D/KSgfNCiApLkt5dQK/TuK+mN/fV9GbiIw2Iv5BqTYA74y9Zh0x8svk4Xm6OhNbPOQ/YoV5l3F2kG1QIUXFI0rsL1axsYFj7WgxrX4uk9Gw2/3WejQfPEnP4PJfTslm95xSr95zCUa/x0D1+DGtfi5Y1vOSm2kKIu54kvbucp6sjj90byGP3BmIyW9h14jIbr7UCj1/IGRe4Yf9Z7q3mSXj7WjzSuIrcKk0IcdeSv24ViINex/21fHile0M2vfQgG8Z04OlWQTg76Pjj7yReWL6HjtOimb/lGEnppffkYiFE6Rg8eDC9evWydxgFcvr0afr160f9+vXR6XQ2D7gtTZL0KrD6VdyJ6B3CzxMeYmznelQ2OpGYlMHb6w/RNmIjb6zdT8LFNHuHKYS4g2VlZeVbnpmZia+vL6+88gr33ntvmcUjSU/gY3TmhU512fbyQ0zr04T6/u6kZpmJ3B7Pg+9FM3LpbnafuMQdfPMeIQQwc+ZMQkJCMBgMVK9enVGjRpGSknMv4NTUVDw8PFi1apXNMmvXrsVgMJCcnAzAqVOneOqpp/Dy8sLHx4eePXsSHx9vrZ/b2oyIiCAwMJB69erlG0vNmjX54IMPGDhwIJ6envnWKQ2S9ISVi6OeJ1tW58cx7VkS3oqO9XyxKPhh3xme+HgHj8/9mXV7EzGZ83+KhBB3LaUgK9U+rxL8sanT6Zg9ezb79u1j0aJFbNq0ifHjxwM5Tzvv27cvkZGRNstERkbSp08f3N3dSUtLIzQ0FKPRyJYtW9i2bRtGo5GuXbvatOg2btzIwYMHiYqKYt26dSUWf0mQC1lEHpqm0b6uL+3r+vLX2WQ+3xbH6j2niD15hX9/sYeqlVwZ0q4mT95XHQ8Z8iAqguw0eDvQPtv+byI4lcwNJq4/bxYcHMzUqVMZOXIkc+fOBWDYsGG0bduWxMREAgMDuXDhAuvWrSMqKgqAFStWoNPpWLBggfVq78jISCpVqkRMTAxhYWFATgJdsGBBuXxKg7T0xC3V83fnnSea8POEhxjzcF18DE6cupLOm98fpG3EJiZ/t5+/zibbO0whRAFER0fTuXNnqlatiru7OwMHDuTixYukpqYC0KpVKxo1asTixYsBWLJkCUFBQXTo0AGA3bt3c/ToUdzd3TEajRiNRry9vcnIyODYsWPW7YSEhJTLhAfS0hMFVNnozJiH6zGiY22+jT3Fgq1xHDmXwsKf41n4czwtanjR977qdG8SgJuTHFbiLuPoltPiste2S8CJEyfo1q0bI0aMYOrUqXh7e7Nt2zbCw8PJzv7nau1hw4YxZ84cJkyYQGRkJEOGDLG26iwWCy1atGDZsmV51u/r62t9bzCU31sfyl8nUSgujnqeui+IJ1tWZ8uRCyz75QQbD51j94nL7D5xmSlrD9CzWSB97wuicdWyOzktRKnStBLrYrSXXbt2YTKZmDFjBjpdTiffl19+mafegAEDGD9+PLNnz2b//v0MGjTIOq958+asXLkSPz+/O/ZxbpL0RJFomkbHer50rOfLuasZfLX7b1buPEnCpTSW/pLA0l8SCKnqSd9W1Xns3kC53ZkQZSQpKYnY2FibMm9vb2rXro3JZOLDDz+kR48ebN++nXnz5uVZ3svLi969ezNu3DjCwsKoVq2adV7//v2ZPn06PXv2ZMqUKVSrVo2EhARWr17NuHHjbOoWRG6cKSkpnD9/ntjYWJycnGjYsGGh97ug5JyeKDY/DxeeC61DzEsPsmxYax5tEoCTXsefp5J45Zt9tHprI+NX/cHvCZdl2IMQpSwmJoZmzZrZvF5//XWaNm3KzJkzeffdd2ncuDHLli0jIiIi33WEh4eTlZXF0KFDbcrd3NzYsmULQUFB9O7dmwYNGjB06FDS09OL1PLLjW/37t188cUXNGvWjG7duhVpvwtKnpwuSsWl1CxW//43y39L4Nj5VGt5fX93hrSrSe/m1XBykN9conyq6E9OX7ZsGaNHjyYxMbFcXZBSEk9Ol786olR4G5wY1r4W/xvbka9GtKF386o4O+g4fDaZCav/pOP0aBb9HE9GttneoQohrklLS2P//v1EREQwfPjwcpXwSkq5SXoRERFomlZm918TZUPTch57NPPJpvz2ysO82r0Bfu7OnE7KYNJ3+3ng3Zx7faZmmuwdqhAV3rRp02jatCn+/v5MnDjR3uGUinLRvblz506efPJJPDw8CA0NZdasWQVaTro370wZ2WZW7f6bj2OOcepKOgCV3BwJbxfMwLY18XSVi16EfVX07s3y6q7o3kxJSaF///58+umneHl52TscUQZcHPUMuL8GMeMeZHqfJgRXNnAlLZsZUX/xwDubmL7hEBdTMu0dphDiLmT3pPfcc8/RvXt3Hn74YXuHIsqYo17H/7Wszv/GdmT2082o7+9OcqaJj6KP8cC70by34bDc51MIUaLsOk5vxYoV/P777+zcubNA9TMzM8nM/KcFcPXq1dIKTZQhvU7jsXsDeTQkgKiDZ5mz6Sh/nkpiTvRRYk9eYU6/ZlRyu/tOqAshyp7dWnonT55k9OjRLF26tMB95hEREXh6elpf1atXL+UoRVnS6TS6NKrCd/9ux+ynm+HqqGfb0Qv0+mg7R8/J/T2FEMVntwtZ1qxZw+OPP45er7eWmc1mNE1Dp9ORmZlpMw/yb+lVr15dLmS5Sx1IvMqzi3dx6ko67s4OzH66GaH3+Nk7LFEByIUs5dMdfSFLp06d+PPPP4mNjbW+WrZsSf/+/YmNjc2T8ACcnZ3x8PCweYm7V8NAD779dzta1fQmOdPE0EU7mb/lmNzVRQhRZHY7p+fu7k7jxo1tygwGAz4+PnnKRcVV2ejM0mGtef3bfazYeZK31x/i0Jlk3n48BBfHvD+MhBDiVux+9aYQt+PkoCOidwiTezREr9NY/fspnv70F85dzbB3aEKUK4MHD6ZXr172DqNAVq9eTefOnfH19cXDw4M2bdqwYcOGUt9uuUp6MTExBR6YLioWTdMY3C6YRUNa4enqyJ6EKzw2Zzu/Hr9o79CEELeQlZWVb/mWLVvo3Lkz69evZ/fu3YSGhtKjRw/27NlTqvGUq6QnxO08ULcya55rRx0/I2euZvDU/F94dvEujsjT24W4rZkzZxISEoLBYKB69eqMGjWKlJQUAFJTU/Hw8GDVqlU2y6xduxaDwUBycs7/sVOnTvHUU0/h5eWFj48PPXv2JD4+3lo/t7UZERFBYGAg9erVyzeWWbNmMX78eO677z7q1q3L22+/Td26dVm7dm3p7Pw1kvTEHSe4soHVo9rydKsg9DqNqANn6TJrCy+v2svppHR7hyfuQkop0rLT7PIqyQu3dDods2fPZt++fSxatIhNmzYxfvx4IOeair59+xIZGWmzTGRkJH369MHd3Z20tDRCQ0MxGo1s2bKFbdu2YTQa6dq1q02LbuPGjRw8eJCoqCjWrVtXoNgsFgvJycl4e3uX2P7mRx4iK+5IHi6ORPQOIfyBYKZvOMSG/WdZueska2JPMaRdMCM71sbTTe7hKUpGuimd1l+0tsu2f+33K26ObiWyrutv6B8cHMzUqVMZOXIkc+fOBWDYsGG0bduWxMREAgMDuXDhAuvWrSMqKgrIuaGITqdjwYIFaJoG5CTFSpUqERMTQ1hYGJCTQBcsWFCopzTMmDGD1NRUnnzyyRLZ15uRlp64o9XxM/LJMy35emRbWtX0JtNkYd7mY3SYHs1n2+JkeIMQ14mOjqZz585UrVoVd3d3Bg4cyMWLF0lNzXnmZatWrWjUqBGLFy8GYMmSJQQFBdGhQwcAdu/ezdGjR3F3d8doNGI0GvH29iYjI4Njx45ZtxMSElKohLd8+XImT57MypUr8fMr3bG40tITd4UWNbxYOfx+Nh06x7s/HuKvsylMXXcAJwcdz9xfw97hiTucq4Mrv/b71W7bLgknTpygW7dujBgxgqlTp+Lt7c22bdsIDw8nOzvbWm/YsGHMmTOHCRMmEBkZyZAhQ6ytOovFQosWLVi2bFme9fv6+lrfGwyGAse1cuVKwsPD+eqrr8rkHsyS9MRdQ9M0OjXw58H6fnyw8QizNx5h2g+HCGvoj7+H3FVDFJ2maSXWxWgvu3btwmQyMWPGDHS6nE6+L7/8Mk+9AQMGMH78eGbPns3+/fsZNGiQdV7z5s2trbGSuDnI8uXLGTp0KMuXL6d79+7FXl9BSPemuOvodRqjO9Xl3mqeJGeamPzdfnuHJESZSUpKsrnTVWxsLAkJCdSuXRuTycSHH37I8ePHWbJkCfPmzcuzvJeXF71792bcuHGEhYVRrVo167z+/ftTuXJlevbsydatW4mLi2Pz5s2MHj2av//+u1BxLl++nIEDBzJjxgzuv/9+zpw5w5kzZ0hKSir2Z3ArkvTEXUmv04jo3QS9TuOHfWf4af8Ze4ckRJmIiYmhWbNmNq/XX3+dpk2bMnPmTN59910aN27MsmXLiIiIyHcd4eHhZGVlMXToUJtyNzc3tmzZQlBQEL1796ZBgwYMHTqU9PT0Qrf8PvnkE0wmE8899xwBAQHW1+jRo4u87wVRLp6cXlTy5HRxO+/8cIh5m48R4OlC1NiOGJ2lR1/cXkW/4fSyZcsYPXo0iYmJhbogpbTd0TecFqIsjO5UlyBvN04nZfDehsP2DkeIci0tLY39+/cTERHB8OHDy1XCKymS9MRdzdVJz1uP59zAfNGOeGJPXrFvQEKUY9OmTaNp06b4+/szceJEe4dTKiTpibte+7q+9G5WFaVgwtd7yTZb7B2SEOXS5MmTyc7OZuPGjRiNRnuHUyok6YkK4ZXuDfByc+TQmWQWbI2zdzhCCDuRpCcqBB+jM692bwjArP/9xYmLqXaOSAhhD5L0RIXRu3lV2tXxIdNk4ZVv9sktyoSogCTpiQpD0zTe6hWCs4OOo+dSOCMPoRWiwpFBS6JCqVnZwIJBLWlavRLuLvIUBiEqGkl6osJpX9f39pWEEHcl6d4UQghRYUjSE0KIu8TgwYPp1auXvcMokG3bttGuXTt8fHxwdXXlnnvu4f333y/17Ur3phBCiFKTlZWV7+3MDAYD//73v2nSpAkGg4Ft27YxfPhwDAYD//rXv0otHmnpCSFEBTFz5kxCQkIwGAxUr16dUaNGkZKSAkBqaioeHh6sWrXKZpm1a9diMBhITk4G4NSpUzz11FN4eXnh4+NDz549iY+Pt9bPbW1GREQQGBhIvXr18o2lWbNmPP300zRq1IiaNWsyYMAAunTpwtatW0tn56+RpCeEELehlMKSlmaXV0mOJ9XpdMyePZt9+/axaNEiNm3axPjx44Gcllffvn2JjIy0WSYyMpI+ffrg7u5OWloaoaGhGI1GtmzZwrZt2zAajXTt2pWsrCzrMhs3buTgwYNERUWxbt26AsW2Z88efv75Zzp27Fhi+5sf6d4UQojbUOnpHG7ewi7brv/7bjS3knlq+5gxY6zvg4ODmTp1KiNHjmTu3LkADBs2jLZt25KYmEhgYCAXLlxg3bp1REVFAbBixQp0Oh0LFixA0zQgJylWqlSJmJgYwsLCgJwEumDBggI9paFatWqcP38ek8nE5MmTGTZsWIns681IS08IISqI6OhoOnfuTNWqVXF3d2fgwIFcvHiR1NSc2/K1atWKRo0asXjxYgCWLFlCUFAQHTp0AGD37t0cPXoUd3d3jEYjRqMRb29vMjIyOHbsmHU7ISEhBX4s0datW9m1axfz5s1j1qxZLF++vIT32pa09IQQ4jY0V1fq/77bbtsuCSdOnKBbt26MGDGCqVOn4u3tzbZt2wgPDyc7O9tab9iwYcyZM4cJEyYQGRnJkCFDrK06i8VCixYtWLZsWZ71+/r+M/7VYDAUOK7g4GAgJ1GePXuWyZMn8/TTTxd1N29Lkp4QQtyGpmkl1sVoL7t27cJkMjFjxgx0upxOvi+//DJPvQEDBjB+/Hhmz57N/v37GTRokHVe8+bNWblyJX5+frd8OnlRKaXIzMws8fVeT5KeEELcRZKSkoiNjbUp8/b2pnbt2phMJj788EN69OjB9u3bmTdvXp7lvby86N27N+PGjSMsLIxq1apZ5/Xv35/p06fTs2dPpkyZQrVq1UhISGD16tWMGzfOpu7tfPTRRwQFBXHPPfcAOeP23nvvPZ5//vmi7XgBSdITQoi7SExMDM2aNbMpGzRoEAsXLmTmzJm8++67TJw4kQ4dOhAREcHAgQPzrCM8PJwvvviCoUOH2pS7ubmxZcsWXn75ZXr37k1ycjJVq1alU6dOhW75WSwWJk6cSFxcHA4ODtSuXZt33nmH4cOHF36nC0FTd/DzVa5evYqnpydJSUml0tQWQlRMGRkZxMXFERwcjIuLi73DKXPLli1j9OjRJCYmFviClLJwq++loPlAWnpCCCEASEtLIy4ujoiICIYPH16uEl5JkSELQgghAJg2bRpNmzbF39+fiRMn2jucUiFJTwghBACTJ08mOzubjRs3YjQa7R1OqZCkJ4QQosKQpCeEEKLCkKQnhBCiwpCkJ4QQosKQpCeEEKLCkKQnhBCiwpCkJ4QQosKQpCeEEHeJwYMH06tXL3uHUWjbt2/HwcGBpk2blvq2JOkJIYQoNVlZWbecn5SUxMCBA+nUqVOZxCNJTwghKoiZM2cSEhKCwWCgevXqjBo1ipSUFABSU1Px8PBg1apVNsusXbsWg8FAcnIyAKdOneKpp57Cy8sLHx8fevbsSXx8vLV+bmszIiKCwMBA6tWrd8uYhg8fTr9+/WjTpk3J7uxNSNITQojbUEqRnWm2y6skH4Sj0+mYPXs2+/btY9GiRWzatInx48cDOU8779u3L5GRkTbLREZG0qdPH9zd3UlLSyM0NBSj0ciWLVvYtm0bRqORrl272rToNm7cyMGDB4mKimLdunU3jScyMpJjx44xadKkEtvH25GnLAghxG2YsizMH73ZLtv+1wcdcXTWl8i6xowZY30fHBzM1KlTGTlyJHPnzgVg2LBhtG3blsTERAIDA7lw4QLr1q0jKioKgBUrVqDT6ViwYAGapgE5iatSpUrExMQQFhYG5CTQBQsW3PIpDUeOHGHChAls3boVB4eyS0XS0hNCiAoiOjqazp07U7VqVdzd3Rk4cCAXL14kNTUVgFatWtGoUSMWL14MwJIlSwgKCqJDhw4A7N69m6NHj+Lu7o7RaMRoNOLt7U1GRgbHjh2zbickJOSWCc9sNtOvXz/eeOON23Z/ljRp6QkhxG04OOn41wcd7bbtknDixAm6devGiBEjmDp1Kt7e3mzbto3w8HCys7Ot9YYNG8acOXOYMGECkZGRDBkyxNqqs1gstGjRgmXLluVZv6+vr/W9wWC4ZSzJycns2rWLPXv28O9//9u6bqUUDg4O/PTTTzz00EMlsdt5FCvpZWRkVMinCgshKhZN00qsi9Fedu3ahclkYsaMGeh0OYn0yy+/zFNvwIABjB8/ntmzZ7N//34GDRpknde8eXNWrlyJn5/fLZ9OfjseHh78+eefNmVz585l06ZNrFq1iuDg4CKv+3YK/RPCYrEwdepUqlatitFo5Pjx4wC89tprfPbZZyUeoBBCiIJLSkoiNjbW5pWQkEDt2rUxmUx8+OGHHD9+nCVLljBv3rw8y3t5edG7d2/GjRtHWFgY1apVs87r378/lStXpmfPnmzdupW4uDg2b97M6NGj+fvvvwsco06no3HjxjYvPz8/XFxcaNy48W1bisVR6KT35ptvsnDhQqZNm2bTZxsSEsKCBQtKNDghhBCFExMTQ7NmzWxer7/+Ok2bNmXmzJm8++67NG7cmGXLlhEREZHvOsLDw8nKymLo0KE25W5ubmzZsoWgoCB69+5NgwYNGDp0KOnp6cVq+ZUpVUi1a9dW//vf/5RSShmNRnXs2DGllFIHDx5UlSpVKtS65s6dq0JCQpS7u7tyd3dX999/v1q/fn2Bl09KSlKASkpKKtR2hRDiVtLT09WBAwdUenq6vUOxi6VLlyofHx+VmZlp71Bs3Op7KWg+KHRL79SpU9SpUydPucVisTkZWhDVqlXjnXfeYdeuXezatYuHHnqInj17sn///sKGJYQQopjS0tLYv38/ERERDB8+/JZXYN6pCp30GjVqxNatW/OUf/XVVzRr1qxQ6+rRowfdunWjXr161KtXj7feeguj0cgvv/xS2LCEEEIU07Rp02jatCn+/v5MnDjR3uGUikJfvTlp0iSeeeYZTp06hcViYfXq1Rw+fJjFixffcuT97ZjNZr766itSU1NvejuazMxMMjMzrdNXr14t8vaEEELYmjx5MpMnT7Z3GKWq0C29Hj16sHLlStavX4+mabz++uscPHiQtWvX0rlz50IH8Oeff2I0GnF2dmbEiBF88803NGzYMN+6EREReHp6Wl/Vq1cv9PaEEEJUXJpSJXhjtyLIysoiISGBK1eu8PXXX7NgwQI2b96cb+LLr6VXvXp1kpKS7pwrh4QQ5V5GRgZxcXEEBwfLWORy5Fbfy9WrV/H09LxtPrD7HVmcnJysF8a0bNmSnTt38sEHH/DJJ5/kqevs7Iyzs3NZhyiEEOIuUeikp9PprLekyY/ZbC5WQEopm9acEEIIUVIKnfS++eYbm+ns7Gz27NnDokWLeOONNwq1rv/+97888sgjVK9eneTkZFasWEFMTAw//vhjYcMSQgghbqvQSa9nz555yvr06UOjRo1YuXIl4eHhBV7X2bNneeaZZzh9+jSenp40adKEH3/8sUgXxAghhBC3U2Ln9Fq3bs2zzz5bqGXkXp1CCCHKUok8syI9PZ0PP/zQ5sakQgghytbgwYPp1auXvcMokJiYGDRNy/M6dOhQqW630C09Ly8vmwtZlFIkJyfj5ubG0qVLSzQ4IYQQd7asrKxb3s7s8OHDNkMMrn8uX2kodNJ7//33bZKeTqfD19eX1q1b4+XlVaLBCSFEeaCUwmSnq8odnJ1vecV8YcycOZPIyEiOHz+Ot7c3PXr0YNq0aRiNRlJTUwkICODzzz+nT58+1mXWrl1L3759OXPmDO7u7pw6dYqxY8fy008/odPpeOCBB/jggw+oWbMmkNPavHLlCq1bt+bDDz/EycmJ+Pj4m8bk5+dHpUqVSmT/CqLQSW/w4MGlEIYQQpRfpsxMZg/qc/uKpeCFRatwLKEB8jqdjtmzZ1OzZk3i4uIYNWoU48ePZ+7cuRgMBvr27UtkZKRN0suddnd3Jy0tjdDQUNq3b8+WLVtwcHDgzTffpGvXruzdu9faotu4cSMeHh5ERUVxu/ufNGvWjIyMDBo2bMirr75KaGhoiezrzRQo6e3du7fAK2zSpEmRgxFCCFF6xowZY30fHBzM1KlTGTlyJHPnzgVg2LBhtG3blsTERAIDA7lw4QLr1q0jKioKgBUrVqDT6ViwYIG19RkZGUmlSpWIiYkhLCwMAIPBwIIFC27ZrRkQEMD8+fNp0aIFmZmZLFmyhE6dOhETE0OHDh1K6RMoYNJr2rQpmqbdNmNrmlbswelCCFHeODg788KiVXbbdkmJjo7m7bff5sCBA1y9ehWTyURGRgapqakYDAZatWpFo0aNWLx4MRMmTGDJkiUEBQVZk9Du3bs5evQo7u7uNuvNyMjg2LFj1umQkJDbPpaofv361K9f3zrdpk0bTp48yXvvvWf/pBcXF1dqAQghRHmnaVqJdTHay4kTJ+jWrRsjRoxg6tSpeHt7s23bNsLDw22ehTps2DDmzJnDhAkTiIyMZMiQIdZWncVioUWLFixbtizP+q+/AMVgMBQpxvvvv7/UL4gsUNKrUaNGqQYhhBCidO3atQuTycSMGTPQ6XJGq3355Zd56g0YMIDx48cze/Zs9u/fz6BBg6zzmjdvzsqVK/Hz8yuVm/zv2bOHgICAEl/v9Yo8OP3AgQMkJCSQlZVlU/7YY48VOyghhBBFk5SURGxsrE2Zt7c3tWvXxmQy8eGHH9KjRw+2b9/OvHnz8izv5eVF7969GTduHGFhYTbjr/v378/06dPp2bMnU6ZMoVq1aiQkJLB69WrGjRtXqLHas2bNombNmjRq1IisrCyWLl3K119/zddff13kfS+IQie948eP8/jjj/Pnn3/anOfLbf7KOT0hhLCfmJgYmjVrZlM2aNAgFi5cyMyZM3n33XeZOHEiHTp0ICIigoEDB+ZZR3h4OF988QVDhw61KXdzc2PLli28/PLL9O7dm+TkZKpWrUqnTp0K3fLLysripZde4tSpU7i6utKoUSO+//57unXrVvidLoRCP0+vR48e6PV6Pv30U2rVqsVvv/3GxYsXefHFF3nvvfdo3759acWaR0GfnySEEIVR0Z+nt2zZMkaPHk1iYuJtL0gpS3Z5nt6OHTvYtGkTvr6+6HQ66+DEiIgIXnjhBfbs2VP4PRFCCGF3aWlpxMXFERERwfDhw8tVwisphb73ptlsxmg0AlC5cmUSExOBnItdDh8+XLLRCSGEKDPTpk2jadOm+Pv7M3HiRHuHUyoKnfQaN25sHazeunVrpk2bxvbt25kyZQq1atUq8QCFEEKUjcmTJ5Odnc3GjRutjZu7TaG7N1999VVSU1MBePPNN3n00Udp3749Pj4+rFy5ssQDFEIIIUpKgZNe06ZNGTZsGP3797feWLpWrVocOHCAS5cu5Xn6ghBCCFHeFLh7s3Xr1rz66qsEBgbSr18/Nm7caJ3n7e0tCU8IIUS5V+Ck98knn3DmzBnmz5/PmTNnCAsLo2bNmkyZMoWEhITSjFEIIYQoEYW6kMXFxYVnnnmGTZs2cfToUZ555hk+++wzatWqRZcuXfK9pY0QQghRXhT66s1cuY+liI+PZ8WKFezatYunn366JGMTQgghSlSR770JOY+piIyMZPXq1Tg4OPDss8+WVFxCCCFEiSt0Sy8hIcE6Jq9Tp06cOHGCuXPncvr06XxvXiqEEKJsDB48mF69etk7jALLzMzklVdeoUaNGjg7O1O7dm0+//zzUt1mgVt6X3zxBZGRkURHR+Pv78/AgQMJDw+nTp06pRmfEEKIO1hWVtZNb2f25JNPcvbsWT777DPq1KnDuXPnMJlMpRpPgVt6gwcPxmg0smbNGk6ePElERIQkPCFEhaCUwpJltsurkM8EuKWZM2cSEhKCwWCgevXqjBo1ipSUFABSU1Px8PBg1SrbJ8SvXbsWg8FAcnIyAKdOneKpp57Cy8sLHx8fevbsSXx8vLV+bmszIiKCwMBA6tWrl28sP/74I5s3b2b9+vU8/PDD1KxZk1atWtG2bdsS29/8FLil9/fff+Pn51easQghRLmksi0kvv6zXbYdOKUtmpO+RNal0+mYPXs2NWvWJC4ujlGjRjF+/Hjmzp2LwWCgb9++REZG0qdPH+syudPu7u6kpaURGhpK+/bt2bJlCw4ODrz55pt07dqVvXv3Wlt0GzduxMPDg6ioqJsm7e+++46WLVsybdo0lixZgsFg4LHHHmPq1Km4urqWyP7mp8BJTxKeEELc2caMGWN9n3sF/siRI5k7dy4Aw4YNo23btiQmJhIYGMiFCxdYt24dUVFRAKxYsQKdTseCBQusNySJjIykUqVKxMTEEBYWBoDBYGDBggW3fErD8ePH2bZtGy4uLnzzzTdcuHCBUaNGcenSpVI9r1esqzeFEKIi0Bx1BE4p3W63W227pERHR/P2229z4MABrl69islkIiMjg9TUVAwGA61ataJRo0YsXryYCRMmsGTJEoKCgujQoQMAu3fv5ujRo7i7u9usNyMjg2PHjlmnQ0JCbvtYIovFgqZpLFu2DE9PTyCn+7VPnz589NFHpdbak6QnhBC3oWlaiXUx2suJEyfo1q0bI0aMYOrUqXh7e7Nt2zbCw8PJzs621hs2bBhz5sxhwoQJREZGMmTIEGurzmKx0KJFC5YtW5Zn/b6+vtb3BoPhtvEEBARQtWpVa8IDaNCgAUop/v77b+rWrVuc3b2pQv2EMJvNbN68mcuXL5dKMEIIIUrHrl27MJlMzJgxg/vvv5969epZn4d6vQEDBpCQkMDs2bPZv38/gwYNss5r3rw5R44cwc/Pjzp16ti8rk9eBdGuXTsSExOtF9IA/PXXX+h0OqpVq1b0Hb2NQiU9vV5Ply5duHLlSimFI4QQojiSkpKIjY21eSUkJFC7dm1MJhMffvghx48fZ8mSJfmOrfby8qJ3796MGzeOsLAwmwTUv39/KleuTM+ePdm6dStxcXFs3ryZ0aNH8/fffxcqzn79+uHj48OQIUM4cOAAW7ZsYdy4cQwdOrRUL2QpdGdxSEgIx48fL41YhBBCFFNMTAzNmjWzeb3++us0bdqUmTNn8u6779K4cWOWLVtGREREvusIDw8nKyuLoUOH2pS7ubmxZcsWgoKC6N27Nw0aNGDo0KGkp6fj4eFRqDiNRiNRUVFcuXKFli1b0r9/f3r06MHs2bOLvO8FoalCDgL56aefePnll5k6dSotWrTI03db2B0vjqtXr+Lp6UlSUlKZblcIcXfLyMggLi6O4OBgXFxc7B1OmVu2bBmjR48mMTHxtheklKVbfS8FzQeFvpCla9euADz22GM2z9BTSqFpGmazubCrFEIIUQ6kpaURFxdHREQEw4cPL1cJr6QUOulFR0eXRhxCCCHsbNq0abz11lt06NCBiRMn2jucUlHo7s3yRLo3hRCloaJ3b5ZXdunezJWWlkZCQgJZWVk25U2aNCnqKoUQQohSVeikd/78eYYMGcIPP/yQ73w5pyeEuFvcwR1hd6WS+D4KPWRhzJgxXL58mV9++QVXV1d+/PFHFi1aRN26dfnuu++KHZAQQtibXp9z95Ube7KEfaWlpQHg6OhY5HUUuqW3adMmvv32W+677z50Oh01atSgc+fOeHh4EBERQffu3YscjBBClAcODg64ublx/vx5HB0d0elK7v6XovCUUqSlpXHu3DkqVapk/VFSFIVOeqmpqdYnLnh7e3P+/Hnq1atHSEgIv//+e5EDEUKI8kLTNAICAoiLi+PEiRP2DkdcU6lSJapUqVKsdRQ66dWvX5/Dhw9Ts2ZNmjZtyieffELNmjWZN28eAQEBxQpGCCHKCycnJ+rWrStdnOWEo6NjsVp4uQqd9MaMGcPp06cBmDRpEl26dGHZsmU4OTmxcOHCYgckhBDlhU6nkyELd5lij9NLS0vj0KFDBAUFUbly5ZKKq0BknJ4QQggog3F6udzc3GjevHlxVyOEEEKUugIlvbFjxxZ4hTNnzixyMEIIIURpKlDS27NnT4FWdv0NqIUQQojypkBJT24yLYQQ4m4gIy6FEEJUGIW+kCU0NPSW3ZibNm0qVkBCCCFEaSl00mvatKnNdHZ2NrGxsezbt49BgwaVVFxCCCFEiSt00nv//ffzLZ88eTIpKSmFWldERASrV6/m0KFDuLq60rZtW959913q169f2LCEEEKI2yqxc3oDBgzg888/L9Qymzdv5rnnnuOXX34hKioKk8lEWFgYqampJRWWEEIIYVXswem5duzYUejb9fz4448205GRkfj5+bF79246dOhQUqEJIYQQQBGSXu/evW2mlVKcPn2aXbt28dprrxUrmKSkJCDn6Q35yczMJDMz0zp99erVYm1PCCFExVLopOfp6WkzrdPpqF+/PlOmTCEsLKzIgSilGDt2LA888ACNGzfOt05ERARvvPFGkbchhBCiYiv2DadLynPPPcf333/Ptm3bqFatWr518mvpVa9eXW44LYQQFVyZ3XC6JDz//PN89913bNmy5aYJD8DZ2RlnZ+cyjEwIIcTdpNBJz8vLK9/B6Zqm4eLiQp06dRg8eDBDhgy57bqUUjz//PN88803xMTEEBwcXNhwhBBCiAIrdNJ7/fXXeeutt3jkkUdo1aoVSil27tzJjz/+yHPPPUdcXBwjR47EZDLx7LPP3nJdzz33HF988QXffvst7u7unDlzBsg5b+jq6lq0PRJCCCFuotDn9J544gk6d+7MiBEjbMo/+eQTfvrpJ77++ms+/PBD5s+fz59//nnrjd/kdmaRkZEMHjz4trHIQ2SFEEJAwfNBoZOe0WgkNjaWOnXq2JQfPXqUpk2bkpKSwrFjx2jSpEmpDzKXpCeEEAIKng8KfUcWb29v1q5dm6d87dq11vF1qampuLu7F3bVQgghRKkq9Dm91157jZEjRxIdHU2rVq3QNI3ffvuN9evXM2/ePACioqLo2LFjiQcrhBBCFEeRxult376dOXPmcPjwYZRS3HPPPTz//PO0bdu2NGK8KeneFEIIAaV4Tq88kaQnhBACSnlwusVi4ejRo5w7dw6LxWIzT24ULYQQorwqdNL75Zdf6NevHydOnODGRqKmaZjN5hILTgghhChJhU56I0aMoGXLlnz//fcEBATcdKydEEIIUd4UOukdOXKEVatW5RmnJ4QQQpR3hR6n17p1a44ePVoasQghhBClqtAtveeff54XX3yRM2fOEBISgqOjo838Jk2alFhwQgghREkq9JAFnS5v41DTNJRSZX4hiwxZEEIIAaU4ZCEuLq5YgQkhhBD2UuikV6NGjdKIQwghhCh1BUp63333HY888giOjo589913t6z72GOPlUhgQgghREkr0Dk9nU7HmTNn8PPzy/ecnnVlck5PCCGEHZToOb3rbzV2423HhBBCiDtFocfpCSGEEHeqAie9X3/9lR9++MGmbPHixQQHB+Pn58e//vUvMjMzSzxAIYQQoqQUOOlNnjyZvXv3Wqf//PNPwsPDefjhh5kwYQJr164lIiKiVIIUQgghSkKBk15sbCydOnWyTq9YsYLWrVvz6aefMnbsWGbPns2XX35ZKkEKIYQQJaHASe/y5cv4+/tbpzdv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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "eigs = get_all_layer_svs(model)\n",
    "# plot_all_layer_svs(eigs, title='Singular Values of Weights at Initialization', save_fp='figs/weight_svs_init.pdf')\n",
    "plot_all_layer_svs(eigs, title='Singular Values of Weights at Initialization')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2fa71ddd-6fc2-4c6b-b573-8882afe42a72",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Train Loss: 7.593496577676231\n",
      "Epoch 501, Train Loss: 0.00019045072974263475\n",
      "Epoch 1001, Train Loss: 0.00021567485387496998\n",
      "Epoch 1501, Train Loss: 0.00022194021703195914\n",
      "Epoch 2001, Train Loss: 0.0002255441035319183\n",
      "Epoch 2501, Train Loss: 0.00021896064940663367\n",
      "Epoch 3001, Train Loss: 0.00021624173706813753\n",
      "Epoch 3501, Train Loss: 0.00022249025574359177\n",
      "Epoch 4001, Train Loss: 0.00021643354405518584\n",
      "Epoch 4501, Train Loss: 0.00021153226085558475\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "losses = []\n",
    "\n",
    "for epoch in range(num_epochs):\n",
    "    for batchX, batchY in dataloader:\n",
    "        batchX = batchX.to('cuda')\n",
    "        batchY = batchY.to('cuda')\n",
    "        \n",
    "        y_pred, _ = model(batchX)\n",
    "\n",
    "        loss = criterion(y_pred, batchY)\n",
    "        losses.append(loss.item())\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "    if epoch % log_freq == 0:\n",
    "        with torch.no_grad():\n",
    "            total_loss = 0.0\n",
    "            for batchX, batchY in dataloader:\n",
    "                y_pred, _ = model(batchX.to('cuda'))\n",
    "                loss = criterion(y_pred.cpu(), batchY)\n",
    "                total_loss += loss * batchX.shape[0]\n",
    "\n",
    "            print(f'Epoch {epoch+1}, Train Loss: {total_loss / num_samples}')\n",
    "\n",
    "            eigs = get_all_layer_svs(model)\n",
    "            # plot_all_layer_svs(eigs, title=f'Singular Values of Weights - Epoch {epoch+1}', save_fp=f'figs/weight_svs_ep_{epoch+1}.pdf')\n",
    "            plot_all_layer_svs(eigs, title=f'Singular Values of Weights - Epoch {epoch+1}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "01474656-d4f6-4e0d-8b2f-56fa3117fe3e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "nfm = model.layers[0].weight.T @ model.layers[0].weight\n",
    "nfm = nfm.detach().cpu()\n",
    "\n",
    "jacs = compute_jacobians(model, X.to('cuda'))\n",
    "jacs[0] = jacs[0].reshape(-1, input_size)\n",
    "agop = jacs[0].t() @ jacs[0] / num_samples\n",
    "\n",
    "loss_grads = compute_jacobians_wrt_loss(model, X.to('cuda'), y.to('cuda'), criterion)\n",
    "lgop = - loss_grads.t() @ X / (weight_decay*num_samples)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "04f6473c-8abd-4b6f-aac3-b945db63fbb4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "n_layers = [20, 17, 15, 13, 11, 9, 7, 5, 4, 3, 2, 1]\n",
    "pows = [1./x for x in n_layers]\n",
    "agop_sims = []\n",
    "lgop_sims = []\n",
    "\n",
    "U, S, Vh = torch.linalg.svd(agop)\n",
    "U2, S2, Vh2 = torch.linalg.svd(lgop)\n",
    "\n",
    "for power in pows:\n",
    "    _S = S.clone()\n",
    "    _S2 = S2.clone()\n",
    "    _agop = U @ torch.diag(_S.pow(power)) @ Vh\n",
    "    _lgop = U2 @ torch.diag(_S2.pow(power)) @ Vh2\n",
    "    \n",
    "    sim = F.cosine_similarity(nfm.flatten().unsqueeze(0), _agop.flatten().unsqueeze(0))\n",
    "    agop_sims.append(sim.squeeze())\n",
    "    \n",
    "    sim = F.cosine_similarity(nfm.flatten().unsqueeze(0), _lgop.flatten().unsqueeze(0))\n",
    "    lgop_sims.append(sim.squeeze())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "3cb4e284-1182-4f3f-a417-197452f5b739",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.9744441177761077, 0.9842074385169408, 0.9896642392107975, 0.9940234481859385, 0.9971604961404553, 0.9990999713056136, 0.9999216106714994, 0.9989121749338704, 0.9962963982673795, 0.988920552844428, 0.9656109547240204, 0.8707840085898628]\n",
      "[0.9781266404725388, 0.9850000535146877, 0.9885030135771986, 0.9910411473950982, 0.9926557629798163, 0.993552464057331, 0.9940908554286904, 0.9946895859785059, 0.9951449707229363, 0.995802164630458, 0.9967344475573418, 0.9964436889981592]\n"
     ]
    }
   ],
   "source": [
    "print([float(x) for x in agop_sims])\n",
    "print([float(x) for x in lgop_sims])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ad5877e7-e011-4a07-9599-bfb46441d6bc",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f3e40f8c8b0>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkQAAAHbCAYAAAAqOIVRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAACVsklEQVR4nOzdd1hTZxsG8PtkkLAVUfZ0AIoogii4bcWBWyturaNabV0dStU62modtX5tHbUO0Lo67LJWxW0FRRC34mTIlL0hkPf7A0mN7JiQBJ7fdeXSnLznPc85CXDnPYtjjDEQQgghhDRiPHUXQAghhBCibhSICCGEENLoUSAihBBCSKNHgYgQQgghjR4FIkIIIYQ0ehSICCGEENLoUSAihBBCSKNHgYgQQgghjR4FIkIIIYQ0ehSIiMb6999/MWjQIDRt2hS6urpo3bo1Pvvssxrnmzp1KgwMDGq1DI7jsHLlyhrbBQYGguM4REdH19jW3t4eU6dOrdXylencuXPgOA7nzp2r92U3FitXrgTHcVU+Dh06pBH1KaL8Mx4eHl5j261btyIwMFCh5ahSSEgIVq5ciczMzDrNp66fWaJZBOougJDKHDhwAJMmTcKYMWOwd+9eGBgY4PHjx0hISFDqckJDQ2Ftba3UPknDNWPGDAwYMKDC9JkzZ+Lx48eVvlafqqpP2bZu3QpTU1ONCxEhISFYtWoVpk6diiZNmtR6vt9++w1GRkaqK4xoBQpEROPEx8fjnXfewaxZs7B161bZ9D59+ih9WV27dlV6n6RyEokEHMdBINDeXzvW1tYVAnR0dDTu3LmDCRMm1OmPsCpUVh+pWkFBAXR1deHu7q7uUogGoF1mROPs3LkTeXl5WLx48Wv18+jRIwwaNAgGBgawsbHBBx98gKKiIrk2le0yu3z5Mrp16waxWAxLS0sEBARAIpFU6F8ikeDjjz+Gubk59PT00L17d4SFhVVaS1JSEmbNmgVra2vo6OjAwcEBq1atQklJiaxNdHQ0OI7Dxo0bsWnTJjg4OMDAwADe3t64fPmyQtsgPDwcY8eOhb29PXR1dWFvb49x48YhJiZGbrkCgQBr166tMP+FCxfAcRx+/vln2bSHDx9i/PjxaNGiBUQiEVxcXLBlyxa5+cp33+3btw8ffPABrKysIBKJ8OjRI+Tn5+PDDz+Eg4MDxGIxTExM4OnpiYMHDyq0juq2e/duMMYwY8aMatvduXOnwraMiIgAx3Fo166dXNuhQ4fCw8NDbtrhw4fh7e0NfX19GBgYoH///oiMjJRrU9kus6KiInzwwQeyz2nPnj0RERFR5W6inJwcvPvuuzA1NUWzZs0wcuRIuZFZe3t73LlzB+fPn5ftKrS3t6923TmOw3vvvYc9e/bAyckJurq68PT0xOXLl8EYw4YNG2Sf9759++LRo0dy8wcHB2PYsGGwtraGWCxGq1atMGvWLKSmpsqt+0cffQQAcHBwkNVWvgvZ3t4egwcPxpEjR+Du7g6xWIxVq1bJXnt1W2RmZuKDDz6Ao6MjRCIRWrRogUGDBuH+/fuyNsXFxfj888/h7OwMkUiE5s2b4+2338bz58/l+jpz5gx69+6NZs2aQVdXF7a2thg1ahTy8/Or3W6kfmnvVzXSYF24cAEmJia4f/8+hg0bhtu3b8PExAQjR47E+vXrazW0LZFIMHToUEyfPh0ffPABLly4gM8++wzGxsb49NNPq5zv7t27eOONN2Bvb4/AwEDo6elh69atOHDgQIW2M2fOxN69e/Hhhx+iX79+uH37NkaOHImcnBy5dklJSfDy8gKPx8Onn36Kli1bIjQ0FJ9//jmio6OxZ88eufZbtmyBs7MzNm/eDABYvnw5Bg0ahKdPn8LY2LgWW/A/0dHRcHJywtixY2FiYoLExERs27YNnTt3xt27d2Fqagp7e3sMHToU27dvx8cffww+ny+b/7vvvoOlpSVGjBgh2z4+Pj6wtbXFV199BXNzc5w4cQLz5s1DamoqVqxYIbf8gIAAeHt7Y/v27eDxeGjRogUWLVqEffv24fPPP4e7uzvy8vJw+/ZtpKWl1bg+LwfI6vD5fFkwYIyhtLS0VvPVdfRKKpUiMDAQrVq1Qq9evapt265dO1hYWODUqVN46623AACnTp2Crq4u7t69i4SEBFhaWqKkpATnz5/H7NmzZfOuWbMGy5Ytw9tvv41ly5ahuLgYGzZsQI8ePRAWFoa2bdtWudy3334bhw8fxscff4y+ffvi7t27GDFiBLKzsyttP2PGDPj5+eHAgQOIi4vDRx99hIkTJ+LMmTMAynYvjR49GsbGxrIRXJFIVOO2Onr0KCIjI/Hll1+C4zgsXrwYfn5+mDJlCp48eYLvvvsOWVlZWLRoEUaNGoXr16/L3sPHjx/D29sbM2bMgLGxMaKjo7Fp0yZ0794dt27dglAoxIwZM5Ceno5vv/0WR44cgYWFBQDIbZtr167h3r17WLZsGRwcHKCvr19prTk5OejevTuio6OxePFidOnSBbm5ubhw4QISExPh7OwMqVSKYcOG4eLFi/j444/h4+ODmJgYrFixAr1790Z4eDh0dXURHR0NPz8/9OjRA7t370aTJk0QHx+P48ePo7i4GHp6ejVuO1JPGCEaxsnJiYnFYmZoaMjWrFnDzp49y9avX890dXVZt27dmFQqrXb+KVOmMADsp59+kps+aNAg5uTkJDcNAFuxYoXsub+/P9PV1WVJSUmyaSUlJczZ2ZkBYE+fPmWMMXbv3j0GgC1cuFCuv/379zMAbMqUKbJps2bNYgYGBiwmJkau7caNGxkAdufOHcYYY0+fPmUAWPv27VlJSYmsXVhYGAPADh48WO16nz17lgFgZ8+erbJNSUkJy83NZfr6+ux///tfhXl/++032bT4+HgmEAjYqlWrZNP69+/PrK2tWVZWlly/7733HhOLxSw9PV2uv549e1aowdXVlQ0fPrzadalM+fapzePlbVBeS20e5e9vbf3zzz8MAFu7dm2t2k+cOJE5OjrKnr/55pts5syZrGnTpiwoKIgxxtilS5cYAHby5EnGGGOxsbFMIBCw999/X66vnJwcZm5uzsaMGSObtmLFCvbyr/U7d+4wAGzx4sVy8x48eLDC53TPnj0MAJszZ45c2/Xr1zMALDExUTatXbt2rFevXrVaZ8bKfs7Mzc1Zbm6ubNrvv//OALCOHTvK/Uxv3ryZAWA3b96stC+pVMokEgmLiYlhANgff/whe23Dhg1Vvo92dnaMz+ezqKioSl97eVusXr2aAWDBwcFVrlP5Nvz111/lpl+9epUBYFu3bmWMMfbLL78wAOz69etV9kU0A+0yIxpHKpWisLAQn3zyCQICAtC7d2989NFHWLt2LS5duoTTp0/X2AfHcRgyZIjcNDc3N7ldRZU5e/Ys3njjDZiZmcmm8fl8+Pv7V2gHABMmTJCbPmbMmAqjDEePHkWfPn1k3/7LHwMHDgQAnD9/Xq69n5+f3CiNm5sbANRYe2Vyc3OxePFitGrVCgKBAAKBAAYGBsjLy8O9e/dk7Xr37o0OHTrI7fravn07OI7DO++8AwAoLCzE6dOnMWLECOjp6cmty6BBg1BYWFhh196oUaMq1OTl5YV//vkHS5Yswblz51BQUFCrdbG0tMTVq1dr9Xh5d5OHh0et57O0tKzT9t21axcEAkGtDy5+44038OTJEzx9+hSFhYX4999/MWDAAPTp0wfBwcEAykaNRCIRunfvDgA4ceIESkpKMHnyZLltLhaL0atXr2rPKiz/bI0ZM0Zu+ujRo6scDRs6dKjc89f5/L2sT58+ciMyLi4uAICBAwfK7eYrn/7y8lJSUjB79mzY2NhAIBBAKBTCzs4OAOQ+xzVxc3NDmzZtamz3zz//oE2bNnjzzTerbHP06FE0adIEQ4YMkXtfOnbsCHNzc9n70rFjR+jo6OCdd95BUFAQnjx5Uut6Sf2iXWZE4zRr1gwPHz5E//795aYPHDgQCxYswLVr16r9RQUAenp6EIvFctNEIhEKCwurnS8tLQ3m5uYVpr86rXz3zqvTBQIBmjVrJjctOTkZf/31F4RCYaXLfPk4CAAV5i/fHVHb4PCy8ePH4/Tp01i+fDk6d+4MIyMjcByHQYMGVehv3rx5mDFjBqKiouDo6IgffvgBo0ePlq1jWloaSkpK8O233+Lbb7+t1bqU77Z42TfffANra2scPnwY69atg1gsRv/+/bFhwwa0bt26ynXR0dFBx44da7XeLwdKAwODWs9Xl11mqamp+PPPP+Hn51fpZ6Yy5Z/bU6dOwcHBARKJBH379kVycrLskhKnTp1Ct27doKurC6Ds8wMAnTt3rrRPHq/q77Xln9OXAz5Q+ee0nDI/fy8zMTGRe66jo1Pt9PKfValUCl9fXyQkJGD58uVo37499PX1IZVK0bVr1zrVVdnnsTLPnz+Hra1ttW2Sk5ORmZkpq/dV5T8LLVu2xKlTp7B+/XrMnTsXeXl5cHR0xLx58zB//vxa105UjwIR0Thubm6VHkTMGANQ/R+A19WsWTMkJSVVmP7qtPI/GklJSbCyspJNLykpqXAsjKmpKdzc3PDFF19Uusy6jkrUVlZWFo4ePYoVK1ZgyZIlsulFRUVIT0+v0H78+PFYvHgxtmzZgq5duyIpKQlz586Vvd60aVPw+XxMmjRJbvrLHBwc5J5Xdk0cfX19rFq1CqtWrUJycrJstGjIkCFyB6y+Kjo6ukL/VTl79ix69+4NoGyUpLZnKD59+rTGA4TL7du3D8XFxTUeTP0ya2trtGnTBqdOnYK9vT08PT3RpEkTvPHGG5gzZw6uXLmCy5cvyw72Bco+PwDwyy+/yEZFaqv8c5qcnFzj51RT3b59Gzdu3EBgYCCmTJkim/7qgde1UdtrNDVv3hzPnj2rtk35QefHjx+v9HVDQ0PZ/3v06IEePXqgtLQU4eHh+Pbbb7FgwQKYmZlh7NixtV8BolIUiIjGGTVqFHbs2IF//vlH7nTYY8eOAVDtqfJ9+vTBn3/+ieTkZNm36tLSUhw+fFiuXfkf2/3798vtnvnpp58qHPg7ePBgHDt2DC1btkTTpk1VVvurOI4DY6zCAa87d+6s9CBjsViMd955B9999x1CQkLQsWNHdOvWTfa6np4e+vTpg8jISLi5uVX5zbguzMzMMHXqVNy4cQObN29Gfn5+lQeZlu8yqw0nJyfZ/8t3mdVGXcLprl27YGlpKdv1WVtvvvkmfvrpJ9jY2MDPzw8A0KZNG9ja2uLTTz+FRCKRGwHt378/BAIBHj9+XOkuyOr07NkTQNkZap06dZJN/+WXX2p9gHplRCLRa48Y1VZ5iHn1c/z9999XWhfw+qNZAwcOxKeffoozZ86gb9++lbYZPHgwDh06hNLSUnTp0qVW/fL5fHTp0gXOzs7Yv38/rl27RoFIg1AgIhrH19cXQ4YMwerVq2XD4uHh4Vi1ahUGDx4sO7ZCFZYtW4Y///wTffv2xaeffgo9PT1s2bIFeXl5cu1cXFwwceJEbN68GUKhEG+++SZu376NjRs3VjgLbvXq1QgODoaPjw/mzZsHJycnFBYWIjo6GseOHcP27dtVcu0YIyMj9OzZExs2bJCdTXb+/Hns2rWryuvlzJkzB+vXr0dERAR27txZ4fX//e9/6N69O3r06IF3330X9vb2yMnJwaNHj/DXX3/JzkSqTpcuXTB48GC4ubmhadOmuHfvHvbt2wdvb+9qz7jR0dGBp6dnrde/nKGhoULzVefKlSu4c+cOPvnkE7ndc7XxxhtvYOvWrUhNTZWdSVg+fc+ePWjatKlcyLa3t8fq1auxdOlSPHnyBAMGDEDTpk2RnJyMsLAw2YhbZdq1a4dx48bhq6++Ap/PR9++fXHnzh189dVXMDY2Vni0tX379jh06BAOHz4MR0dHiMVitG/fXqG+auLs7IyWLVtiyZIlYIzBxMQEf/31l+yYq1frAso+p1OmTIFQKISTk5PcaE1tLFiwAIcPH8awYcOwZMkSeHl5oaCgAOfPn8fgwYPRp08fjB07Fvv378egQYMwf/58eHl5QSgU4tmzZzh79iyGDRuGESNGYPv27Thz5gz8/Pxga2uLwsJC7N69GwBq3PVP6pmaD+ompFL5+fls8eLFzMbGhgkEAmZra8sCAgJYYWFhjfNOmTKF6evrV5j+6hk4jFU8y4yxsrN8unbtykQiETM3N2cfffQR27FjR4WzV4qKitgHH3zAWrRowcRiMevatSsLDQ2tcMYKY4w9f/6czZs3jzk4ODChUMhMTEyYh4cHW7p0qezMm/KzqDZs2FCh9srqfFVlZ5k9e/aMjRo1ijVt2pQZGhqyAQMGsNu3b1daY7nevXszExMTlp+fX+nrT58+ZdOmTWNWVlZMKBSy5s2bMx8fH/b5559XqOXnn3+uMP+SJUuYp6cna9q0KROJRMzR0ZEtXLiQpaamVrt+mmTmzJmM4zj2+PHjOs+bkZHBeDwe09fXZ8XFxbLp5Wcojhw5stL5fv/9d9anTx9mZGTERCIRs7OzY6NHj2anTp2StansM15YWMgWLVpU4XNqbGwsd5Zk+VlmV69elZu/ss9VdHQ08/X1ZYaGhgwAs7Ozq3adAbC5c+fKTavq817ZZ+fu3busX79+zNDQkDVt2pS99dZbLDY2ttKfi4CAAGZpacl4PJ5c3XZ2dszPz6/S+ir7ecjIyGDz589ntra2TCgUshYtWjA/Pz92//59WRuJRMI2btzIOnTowMRiMTMwMGDOzs5s1qxZ7OHDh4wxxkJDQ9mIESOYnZ0dE4lErFmzZqxXr17szz//rHabkfrHMfbiwAxCSKOXkpICOzs7vP/++1i/fr26yyEqEhISgm7dumH//v0YP368usshRCNQICKE4NmzZ3jy5Ak2bNiAM2fO4MGDB3IH4RLtFRwcjNDQUHh4eEBXVxc3btzAl19+CWNjY9y8ebPC2ZiENFZ0DBEhBDt37sTq1athb2+P/fv3UxhqQIyMjHDy5Els3rwZOTk5MDU1xcCBA7F27VoKQ4S8hEaICCGEENLo0ZWqCSGEENLoUSAihBBCSKNHgYgQQgghjR4dVF1LUqkUCQkJMDQ0rPXl3wkhhBCiXowx5OTkwNLSstqLkVIgqqWEhATY2NiouwxCCCGEKCAuLq7auwJQIKql8ku/x8XFVbg1w+uQSCQ4efIkfH19q7wbuqYsQ1W1atM20Jbl1kRT61KEJqyLJtRQF9pWrzI0xnXWJqp8f7Kzs2FjY1PjLVwoENVS+W4yIyMjpQciPT09GBkZqTQMKGMZqqpVm7aBtiy3JppalyI0YV00oYa60LZ6laExrrM2qY/3p6bDXeigakIIIYQ0ehSICCGEENLoUSAihBBCSKNHgYgQQgghjR4FIkIIIYQ0ehSICCGEENLoUSAihBBCSKNHgYgQQgghjR4FIkIIIYQ0ehoViC5cuIAhQ4bA0tISHMfh999/r3Ge8+fPw8PDA2KxGI6Ojti+fXuFNr/++ivatm0LkUiEtm3b4rffflNB9YQQQgjRVhoViPLy8tChQwd89913tWr/9OlTDBo0CD169EBkZCQ++eQTzJs3D7/++qusTWhoKPz9/TFp0iTcuHEDkyZNwpgxY3DlyhVVrQYhhBBCtIxG3cts4MCBGDhwYK3bb9++Hba2tti8eTMAwMXFBeHh4di4cSNGjRoFANi8eTP69euHgIAAAEBAQADOnz+PzZs34+DBg0pfB0IIIYRoH40aIaqr0NBQ+Pr6yk3r378/wsPDIZFIqm0TEhJSb3USommKSqQoLgUYY+ouhRBCNIJGjRDVVVJSEszMzOSmmZmZoaSkBKmpqbCwsKiyTVJSUrV9FxUVoaioSPY8OzsbQNkdecvDljKU96XMPlW1DFXVqk3bQN3LLZUy5BaVILeoBDmFlf+bW1SC3FdfKypBbmEpcookyC0qRXGJFIAAi68GQ18kgL4OHwYiQdn/RXzo6whgIBbAQIf/3+tiAfR1XrwuEpS115H/P49X/d2kVUFd762m1VAX2lavMjTGddYmqnx/atunVgciAOA4+V/A5d94X55eWZtXp71q7dq1WLVqVYXpJ0+ehJ6enqLlVik4OFjpfapqGaqqVZu2QV2dPBmMIilQWAIUlpY/OBSUvjzt1edl0wpfTCsoBYqlyg0cUgbkFJYFJ6CoxvY10eExiPmAmA+I+ICIz2T//+9f9srzF9N4Lz8H+HUcv1bXe6tpNdSFttWrDI1xnbWJKt6f/Pz8WrXT6kBkbm5eYaQnJSUFAoEAzZo1q7bNq6NGrwoICMCiRYtkz7Ozs2FjYwNfX18YGRkpaQ3KkmtwcDD69esHoVCotH5VsQxV1apN26A6pVKGZ5kFeJSci4cpuXiYkoeHKTmIfp6DIikHqRL3TokEPBiIBDAUC+T+NRDxYSAWwkDE/+81Udloj6Hov7YiPsOFc+fQpVtPFEk55BaVIK+oFHnlI0zFZf/PKyote634pf+Xty0ukc1X8mLliqUciqVAtuwLmeIBTkfAkxu5MigfmZIbpeJDV8AhPfYBJg7qASsTg9ffuAqoj8+XMmlbvcrQGNdZm6jy/Snfw1MTrQ5E3t7e+Ouvv+SmnTx5Ep6enrIN6u3tjeDgYCxcuFCujY+PT7V9i0QiiESiCtOFQqFKfphU1a8qltHYt4FUyhCXkY+Hybl4kJJT9m9yDh4/z0WhRFrJHP+FAj6PkwswRmJhWViRBRshDF95Xt6+7FH2XEfweof/SSQSiPiApYnBa28PxhiKSqSysJQrC1Jlu+fyXtqFl/ciXOUU/hescmQhq6xNUUnZNiwukaK4RIqM/NoMd/OxMyoELQxFaG9ljPbWxnCzNkZ7qyZobljx51hV6uMzrEzaVq8yNMZ11iaqeH9q259GBaLc3Fw8evRI9vzp06e4fv06TExMYGtri4CAAMTHx2Pv3r0AgNmzZ+O7777DokWLMHPmTISGhmLXrl1yZ4/Nnz8fPXv2xLp16zBs2DD88ccfOHXqFP799996Xz+iXaRShmcZBXiQnIMHKTl49CIAPUqpKviUjWq0bG6ANmYGaGNmCAcTXcTdDcfg/m/AxEAXYiGvxt212objOIiFfIiFfJgavH74kJRK/xupkgWlisGq/PXM/GJce5SI5EIOKTlFOH0/Bafvp8j6szAWo73Vi4Bk3QTtrYxhoq/z2nUSQhoWjQpE4eHh6NOnj+x5+S6rKVOmIDAwEImJiYiNjZW97uDggGPHjmHhwoXYsmULLC0t8c0338hOuQcAHx8fHDp0CMuWLcPy5cvRsmVLHD58GF26dKm/FSMaTSpliM98EXySc/EwOQcPU3LxKCUXBZLSSufR4fPg2FwfbcwM0cbMAK3NDNHGzBA2TXUheOngF4lEgmPRQAtDEYRCfj2tkXYT8nlooqeDJnq1Cy0SiQTHjj1D7zd98Si1ADefZeHWsyzcjM/C4+e5SMwqRGJWIU7eTZbNY9VE90VAMoabVVlIMtajUQNCGjONCkS9e/eu9jTgwMDACtN69eqFa9euVdvv6NGjMXr06Nctj2g5KQPiMvIRnV6IBy92cz1Mrn3wad2iPPgYwNZETy74EPXT0xHAw84EHnYmsmm5RSW4E5+FW+WPZ1l4kpqH+MwCxGcW4J/b/x1faNdMr2x324tdbq5WxjASU0gipLHQqEBEiLKlZBfixJ0kHLuViIhoPoovV76rtDz4tDYzRJsXwae1mQHsKPhoNQORAF0cm6GLYzPZtOxCCW6/CEflQSkmLV/2OHozUdbW0VQf7a2NX+xya4J2lkbQF9GvTUIaIvrJJg3Os4x8HL+dhOO3kxARm4H/Bh05CPkcWjZ/EXhaGMh2d1HwaTyMxEL4tDSFT0tT2bTM/GLcjs/GzfjMst1tz7IQn1mAJ6l5eJKahz+uJwAAOA5o2dwAbi8duN3WwhiChnVYmOaQlgKSgheP/Bf/5lUyLR8ozq84TfZvPvjF+eieng5+2jaAJyh7M8EBHK+KB/fiUclrcvO92qayebhK5qvD8mTzVvV6NTVUuczaLK+G9anz8qrqj1f2XjMpoMaLxVIgIg3C09Q8/HM7EcdvJ+Hmsyy519xtm8DXpQV4SXcxecQA6Irr76wjoh2a6Omge2tTdG/9X0hKzyt+sZsts+y4pPgsJGYV4tGL48uORMYDAHgc0LqFAUwYD5Zxmejs2Fxdq1G/SksqCR//BZBKXyvOq0X7l14vKVRauTwAzQAgT2ldEiUSAhgGQPLGE0CnWU3NVYICEdFKjDE8TMnFsVtlIeh+Uo7sNY4DOtubYKCrOQa4msPCWPfFgbd3aRSI1JqJvg56tWmOXm3+CzgpOYW4HV82gnQ7Pgs3nmXheU4RopJzAfDw1o4wdLJtghk9HOHb1kx9n7dSSTXhowBcYQ5s0y6DF54ISIvk2xVXFmYqmVZaXL/rJNAFhLqAUO/Fv7qAjn7FaUK9lx7/TSvhCXEt8jo6uXeEgMeVjUQw9mJUopIH2H8jFhVef3Uae2Weyh7VLE9uvir6fnWa0pdVzXpWuyzUvA3rQo1n4VIgIlqDMYY7Cdn453Yi/rmdhCfP//uqx+dx8GnZDANczeHb1rxerz1DGo8WhmL0dRajr/N/F3ZNzi5EZHQadgdfQ2Q6H9diMzFn/zVYNdHF293s4d/ZBoblB2czVjbqUeWuneoCyasjKtW8Li2pdj0EANwBILbaZrXEvRQ+Kgsruq+8/mrbl/7VqeI1gS7Ae71wySQSJD4VgrkMAug6RPWrFiFPIinGqeCTeFNHPRdXBSgQEQ0nlTJExmXi+O1EHL+ThLj0AtlrOnweerQ2xQBXc/Rra1br07QJkSOVloWU8qBS1b+SAqCkAJAUyv1rJimEb3Ee2gmewNTZGMlpGUjPzIIgvxC6wcXIPlUMnrAEulwReJIClH2lriccDxBWDCZSgRgpmXloYWkHnujVUZbKQktlozHlYUWs1m/1RAtwHMDxAVRz6RGBBMUCQxohIuRlpVKGq9HpsgOjk7L/O45ALOShj1MLDHA1R1/nFv998ybaT1oKlBS9CCeV/FtaVMn0QvCK8tE66QZ4526U7f4pKawQWqr9t/T17+HGA2ADABmAPcoeeHlAo7IBG75O1SMllQWS8v9XOfJSSR98YaV/YEolElw5dgyDBg0Cj0ZLCAFAgYhoiFIpcPFRKoLvpSL4bhJSc/87PsFAJEBf5xYY6GqOXk7NoadDH1ulY6zsuJNqw0gVr8n+raFNaXH1r9ewm6cqfABtASCxhoa1wRP+N+ohFL84bqXmf0t5Orj3MBoubp3AFxvKQgkTinEtsQi/3EjDv7H5KGBiFEAHbaxbYFqPVhjoak7HtRGiIegvC1Gr+MwCfHf6Af64xkf+lf8usGmsK0S/tmYY6GqObq1MIW6MV3kuP4unpPDFMSKFLz0veGl3zquvVdFWtsunAAJJAfrnZkJw7/3/wkx97sqpCccvCyUCURX/6sieS3lCxCWmwtqhNfgivarDi1DvRdDRrfxfgRjgK/YrUSqR4HH2MTh5DAL/pREXDoCHA+DhA0Ql5WD3v0/x2/V4RD7LwfsHI2FpLMbUbvbw72wLY10aqSFEnSgQEbVIzS3ClrOPsP9yLIpLpQA4NNPXQX9Xcwx0NUdXx2YQatM3Z8bKAkh+2kuPDPByU+CUeBW8M1fLRkiqCSkVQo6CIya1wQEQA5XvygEAflVBRPTSo4rX+ZW9Xps+Xpq/DsGkVCLB9WPHYDlAPoxoGidzQ6wb7YaPBjjhx8sx+PFyDBKyCrHm2H3879RDvOVpg7e72cOumb66SyWkUaJAROpVdqEEP1x4gl3/PkV+cdntMro6NIWHbire9+8FsUhDDowufincFKQD+emvhJ10+X8L0iu9ZgofgDMAJFV4qW5kpxzr/nfWjfDVkQ+9iiMhFdqXPUo4IS6GXkX3Pm9CKDaQDyZ8HTpIVoVMDURY8GYbzO7VEn9eT8Cuf58iKjkHgSHRCAqNhm9bM0zv7ojO9k0b3I2ACdFkFIhIvSiUlCIoJBrbzj9GZr4EAOBmbYyP+zvDy84I//zzD/g8Ff7yL8iAUX4MuKfngaJM+SDzyqgO8tPKRm0UwdcB9Jq9eJhAKm6KmJRs2LZ0Al9kUEOAqSLQqOAsHiaRIFsvBWjWmk5BVhOxkI8xnW3wlqc1Lj1Kw85/n+Bc1HOcuJOME3eS4WZtjOndHTCovYV2jZYSoqUoEBGVkpRK8VN4HL45/RDJ2WVn87RqYYAPfdugfztzcBwHiUSivAXmpwPPo4Dn94CU+2X/Po+CMDcZfQAgqg598YRy4Ub+3xcPXRP5aTr6cuGlVCLBzWPHYN1Ps3fnEPXhOE52lexHKTnY9W80jlx7hpvPsjD/0HWsPXYfU3zsMd7LFsZ69BkiRFUoEBGVkEoZ/rqZgE3BDxCTlg8AsGqii4X92mCEu9XrjwYVZMgFHqTcA57fB3KTq5ylUGAMUVNLcPqmgG5T+WAjCzsvhxsD2nVE6lWrFoZYO7I9PurvhP2XYxAUGoOk7EKsO34f35x+iLc8rfF2Nwc4mNJxRoQoGwUiolSMMZy5n4INJ6Jkt9MwNdDBe31aYVwXW4gEdTxbrCBDPvCkvAhAudUclGNsAzR3Bpo7AS1cgOYukDRxwInTFzFo0CAIaaSGaDgTfR28/0ZrvNPLEX/dSMSuf5/iXmI29obGYN/lGLzhbIbp3R3Q1dGEjjMiREkoEBGlufwkDRtORCEiJgMAYCgWYFZPR7zdzQH6ouo/aoKSPHBxV4D0h/K7vGoMPk5l4aeFy38hSGRYsa0yd8sRUk9EAj5Ge1hjVCcrhD5Ow65/n+L0/RScupeMU/eS0c7SCNO7O2CwmyV0BHScESGvgwIReW2347Ow/kQULjx4DqDsatJTfRwwu5dj1bfTKC0BYkOAqH8giPoHfhlPgVtVLMDIGmjh/CLwvAg/pm0AsZFqVogQDcNxHHxamcKnlSkeP8/FnktP8UvEM9xJyMain27gy3/+O86oqb6GnKlJiJahQEQU9vh5LjadfIC/b5VdIljA4zDWywbv920NMyNxxRkKs4HHp4H7x4CHJ4HCTABl18QBAGZkBe7l0R4KPoRU0LK5AT4f3h4f9HPCgbBYBIVEIyWnCBtOROHbMw8xqpM1pnV3QMvm6rtJJiHaiAIRqbOEzAJsOX8Xv0Q8g5SVHXc8vKMVFrzZuuJF5bLigahjQNQ/wNMLgPSlXVd6zYA2A1DSqj9OPMiH75DRdHwPIbXUVF8Hc/u0wswejvj7Vtn1jG7HZ2P/lVjsvxKLvs4tMKO7A7xbNqPjjAipBQpEpNYy8yU4Es3Dh2H/QlJadpuHN13M8GH/NnA2fzGKwxiQdKssAEX9DSTekO+kWSvAaVDZw8YL4PHBJBKUPD5Wz2tDSMOgI+BhhLs1hne0wpWn6dj171OcupeMM/dTcOZ+CpzNDTG9uwOGdrSs+0kNhDQiFIhIrUTEZOC9A9eQmMUDwNDV0QQf9XeGh11ToKQYeHz2v5GgrLiX5uTKgo/TIMDZDzBtra5VIKRB4zgOXR2boatjMzxNzUPgpaf4KfwZ7ifl4KNfbmLd8ShM8bbDhK52MNShESNCXkWBiFSLMYadF59i3fH7KJEymIoZ1vt7oI+9GNyj08Avx4CHp4CirP9mEugCLfsCTgOBNgMAg+bqWwFCGiEHU32sGuaKRf2ccPBqLAIvRSMpuxBfBT/Ad2cfYXhHC7hI1V0lIZqFAhGpUla+BB/8fAOn7pVd7HCMiy7GFv6Kjle+B/dziPzNR/Wbl4UfZz/AoRego6emqgkh5Yz1hJjdqyWmd3fAsVtl1zO6+SwLh8Pj0USHj+4989HK3FjdZRKiESgQkUpdj8vE3P3XEJ9ZAEt+Nn5oHYq2z34GJ8n/r5GpE+D84nggK0+AR9dBIUQTCfk8DOtohaEdLBEek4Elv97E4+d5mLD7Kg6/4w17uvI1IRSIiDzGGPZcisbaf+6heelzfGVwHCPYafCiy+5DlqVrCwOf6eC3HQI0a6nmagkhdcFxHDrbm+DHaZ4Y8c05JGUXwX9HKA694023AyGNHgUiIpNVIMHiX27i7t0bWM3/E2+JL0JQ8mK3mLUXSrotxLmoYgzq6kc3KiVEi5kaiDC3bSn2xhnjYUoe/L8PxaF3usKRrl1EGjHax0EAADefZeK9/x1A/wfLcVZnEcYJzkKAEsChJzDlL2D6SbBW/ehmp4Q0EEY6wL63PeFkZoiUnCKM3XEZj5/nqrssQtSGAlEjxxjD0RP/IGHHW9hXOA8j+JfA5xjQ2heYdrIsDDn0pCBESAPUzECEAzO7wNn8v1D0KIVCEWmcKBA1YnmPQ3BnQ38MDh2LAbwwAICkzWDgnfPAhJ8B2y5qrpAQomrNDETYP6MsFD3PKcK4Hy7jUUqOussipN5RIGpsGAOeXkDujoHQ3zcQrvlXUMo4PDIfBPZuKITj9wOWHdVdJSGkHpWNFHWVhaKxO67gYTKFItK4UCBqLBgD9+gU2O7+QNAQGCSEoJjx8Rf/Tdx/6yxazT4IzqytuqskhKiJib4ODs7sirYWRkjNLRspekChiDQiFIgaOsbA3f8bvaJWQHB4LLi4KyhiQgSW+GKZ7V70+OAg2rm6q7tKQogGaKqvg/0zuqCdpRFSc4sxbsdlRCVRKCKNAwWihiwvFTjgD8GvU9CkIBoFEOP7Ej/0kvwPxb5fYt00PzTR01F3lYQQDfJyKErLK8b4HygUkcaBAlFD9fQCsK0b8PAESnk62FoyDD6FmxGoPx1bZg3EOz1bgqMzxwghlWiiVxaKXK3KQtG4Hy7jflK2ussiRKUoEDU0pSXAmc+BoKFAbhJSde3hV7Aa60v84dbaEX/P6wEPOxN1V0kI0XBN9HSwf3pXtLcyRnpe2e6zuwkUikjDRYGoIcmMAwL9gAsbADDcNh+OHhmf4j6zhZ9NKXZMdIeJPu0iI4TUjrGeED/O6IIO1sbIyJdgwk4KRaThokDUUNz9E9jeDYi7DIiMcKrdWgyOHoMCiPHJQCf4WjPweLSLjBBSN8a6Quyd3gUdbJogI1+C8Tsv405ClrrLIkTpKBBpO0kBcHQh8NMkoDALsPLEEa+DmBFhBwD4qL8T3vaxU3ORhBBtZqwrxL7pXuho0wSZ+RKM/+EKbsdTKCINCwUibZZyD/ihLxC+u+x5twX42e0HLAou+0X1Xp9WmNunlRoLJIQ0FEZiIfZO94K7bRNkFUgwYSeFItKwUCDSRowBEYHAjj5Ayl1AvwUw6Tf80fwdfPz7PQDAjO4O+MC3jXrrJIQ0KEZiIfZO80KnF6Fo/A+XcesZhSLSMFAg0jYFmcDPU4G/5gMlBUDLvsC7l/BPvgsW/XQDjAETu9piqZ8LnVZPCFE6Q7EQQdO84GHXFNmFJZiw8zJuPstUd1mEvDaNDERbt26Fg4MDxGIxPDw8cPHixWrbb9myBS4uLtDV1YWTkxP27t1boc3mzZvh5OQEXV1d2NjYYOHChSgsLFTVKqhGXBiwvQdw93eAJwD6rQYm/IozzxjmHYpEqZRhtIc1Vg91pTBECFGZ8lDkKQtFV3AjLlPdZRHyWjQuEB0+fBgLFizA0qVLERkZiR49emDgwIGIjY2ttP22bdsQEBCAlStX4s6dO1i1ahXmzp2Lv/76S9Zm//79WLJkCVasWIF79+5h165dOHz4MAICAuprtV6PVApc/ArYPQDIigWa2gPTTgLd5uPfx+mY/eM1SEoZhnSwxLpRbnQ2GSFE5QxEAgRO80Jn+6bIKSzBxJ1XEBmboe6yCFGYxgWiTZs2Yfr06ZgxYwZcXFywefNm2NjYYNu2bZW237dvH2bNmgV/f384Ojpi7NixmD59OtatWydrExoaim7dumH8+PGwt7eHr68vxo0bh/Dw8PpaLcXlJAH7hgOnVwOsFHAdDcy6AFh7IOxpOmbuDUdxiRS+bc2waUwH8CkMEULqiYFIgMC3veBlb4KcohJM3hWGaxSKiJbSqEBUXFyMiIgI+Pr6yk339fVFSEhIpfMUFRVBLBbLTdPV1UVYWBgkEgkAoHv37oiIiEBYWBgA4MmTJzh27Bj8/PxUsBZK9DC47PYbT88DQj1g2BZg1E5AbIzrcZmYFngVBZJS9GrTHN+Od4eQr1FvJyGkEdAXCbDn7c7wcvgvFEXEUCgi2keg7gJelpqaitLSUpiZmclNNzMzQ1JSUqXz9O/fHzt37sTw4cPRqVMnREREYPfu3ZBIJEhNTYWFhQXGjh2L58+fo3v37mCMoaSkBO+++y6WLFlSZS1FRUUoKiqSPc/OLrs6q0QikQUtZSjvS67P0mLwzn4G/pWyUTHWoh1KRuwETFsDJSW4m5iNybvDkVtUgq4OTfHdWDfwmBQSibT2y1BWrUqgqn7rexmatNyaaGpditCEddGEGupC2fXq8IAfJnbEOz9G4srTDEzefQW7J3ugk20TpfSvDNr2HjU2qnx/atsnxxhjSl+6ghISEmBlZYWQkBB4e3vLpn/xxRfYt28f7t+/X2GegoICzJ07F/v27QNjDGZmZpg4cSLWr1+P5ORktGjRAufOncPYsWPx+eefo0uXLnj06BHmz5+PmTNnYvny5ZXWsnLlSqxatarC9AMHDkBPT095K/0K/aJkeERvRdP8pwCAJ6Zv4o7VWEh5ZbfcSMwHvr3DR14JBwdDhnddSiHiq6wcQgiptaJS4If7PDzM5kHEY5jtUgpHI3VXRRq7/Px8jB8/HllZWTAyqvoDqVGBqLi4GHp6evj5558xYsQI2fT58+fj+vXrOH/+fJXzSiQSJCcnw8LCAjt27MDixYuRmZkJHo+HHj16oGvXrtiwYYOs/Y8//oh33nkHubm54PEq7mqqbITIxsYGqamp1W7QupJIJAgODka/fv2gE/U7+P98CK44D0y3KUr9/gfmNEjWNjotD+N3XsXz3GK0tzJC0FQPGIqFdVqGUFhze1X3U1/91vcyNGm5NdHUuhShCeuiCTXUhSrrLSguxaz9kQh9kg59HT52Tu4ET7umSl2GIrTtPWpsVPn+ZGdnw9TUtMZApFG7zHR0dODh4YHg4GC5QBQcHIxhw4ZVO69QKIS1tTUA4NChQxg8eLAs6OTn51cIPXw+H4wxVJUHRSIRRCJRpctR9pvFLy2E+PhC8G4eKptg6wNu1A8QGFvL2sSl52PKngg8zy2Gs7kh9k3vgiZ6dbtRq7JqV8U2UGW/9b0MTVpuTTS1LkVowrpoQg11oYp6hUIhdk/1woy9V3HpURqm771WduC1g4lSl6MobXuPGhtVfSZrQ6MCEQAsWrQIkyZNgqenJ7y9vbFjxw7ExsZi9uzZAICAgADEx8fLrjX04MEDhIWFoUuXLsjIyMCmTZtw+/ZtBAUFyfocMmQINm3aBHd3d9kus+XLl2Po0KHg89W8vynpJnpHfQpeURLA8YCeHwM9PwL4/701SVmFGL/zMhKyCtGyuT5+nFH3MEQIIfVFV4ePXVM6Y0ZQOP59lIqpe8KwZ2pndHFspu7SCKmSxgUif39/pKWlYfXq1UhMTISrqyuOHTsGO7uyG5QmJibKXZOotLQUX331FaKioiAUCtGnTx+EhITA3t5e1mbZsmXgOA7Lli1DfHw8mjdvjiFDhuCLL76o79WTl/4UgsABEJYWgxlagBu1E7DvLtfkeU4Rxu+8jLj0Atg108OBmV1halBx5IoQQjSJWMjHzimemLk3HBcfpmLqnqvY83ZndKVQRDSUxgUiAJgzZw7mzJlT6WuBgYFyz11cXBAZGVltfwKBACtWrMCKFSuUVaJymDhA6jYWKU9uwXTaYQiN5c+uy8grxsSdV/DkeR6smuhi/4wuMDMSV9EZIYRoFrGQjx8me+KdfRG48OA53t5zFbundoZ3SwpFRPPQhWvUTNr/S4Q5LAD05PevZxVIMGn3FUQl56CFoQj7Z3SBdVPVnd1GCCGqIBbysWOSB3q1aY4CSSneDgxDyKNUdZdFSAUUiNSNrwO8ct+x3KISTN0Thtvx2Wimr4MDM7vA3lRfTQUSQsjrEQv5+H6SB3o7NUehRIppQVdxiUIR0TAUiDRMQXEppgdeRWRsJox1hdg3vQtatTBUd1mEEPJaykNRn/JQFHgV/z6kUEQ0BwUiDVJUUop39oXjytN0GIoE2DfdC20t6apmhJCGQSTgY/skD/R1boGiEimmB13FxYfP1V0WIQAoEGkMSakUc/dH4uLDVOjp8LHn7c5ws26i7rIIIUSpRAI+tk3shDddykNROC48oFBE1I8CkQYoZcAHP9/CqXvJEAl42DnZE572mnERM0IIUTaRgI8tEzrhTRczFJdIMWNvOM5TKCJqRoFIzaRShoOPePjnTjKEfA7fT/KATytTdZdFCCEqJRLwsXVCJ/RrWxaKZu4Nx9moFHWXRRoxCkRqxBjDp3/dw9VUHvg8Dt+N74TeTi3UXRYhhNQLHQEPW8Z3Qv92ZaFo1t4InL1PoYioBwUiNYpLL8Dft5LAgWHjKFf0b2eu7pIIIaRe6Qh4+G58JwxoZ47iUilm7YvAmfvJ6i6LNEIUiNTItpke9r3tiQmtpBjsZqHucgghRC2EfB6+He+Oga7/haLT9ygUkfpFgUjNXK2M0Lk5U3cZhBCiVkI+D9+Mc8eg9uaQlDLM/jECp+5SKCL1hwIRIYQQjSDk8/C/se7wc7OApJTh3f0ROHknSd1lkUaCAhEhhBCNIeTz8D//jhj8IhTN2X8NJygUkXpAgYgQQohGEfB52OzfEUM6WKJEyjB3/zUcv02hiKgWBSJCCCEaR8Dn4esxHTCsY1koeu/ANfxzK1HdZZEGjAIRIYQQjSTg8/DVWx0wvDwUHYzEMQpFREUoEBFCCNFYAj4PX43piJHuViiVMrx/MBJ/36RQRJRPoO4CCCGEkOrweRw2vNUB4IAj1+Ix71AkpIxhSAdLdZdGGhAKRIQQQjQen8dhw+gO4MDh12vPsODwdTAAQykUESWhXWaEEEK0Ap/HYf1oN7zlYY1SKcOCQ5H443q8ussiDQQFIkIIIVqDz+OwbpQbxnhaQ8qAhYev4/dICkXk9VEgIoQQolV4PA5fjnTD2M42kDJg0U/X8VvkM3WXRbQcBSJCCCFah8fjsGZEe4zzKg9FN3DkGoUiojgKRIQQQrQSj8fhi+HtMc7LFowBH/x8A79EUCgiiqFARAghRGuVhSJXTOhSFoo++uUGfg6PU3dZRAtRICKEEKLVeDwOnw1zxcSuZaHo419v4qerFIpI3VAgIoQQovXKQ9FkbzswBiw+chOHr8aquyyiRSgQEUIIaRA4jsOqoe0wpTwU/XoLh8IoFJHaoStVE0IIaTA4jsPKoe3AcRwCQ6Kx5MgtSBnwVicLdZdGNBwFIkIIIQ0Kx3FYMaQtOA7Ycykan/x2CyWlJTBWd2FEo9EuM0IIIQ0Ox3H4dHBbTO/uAAD49M97CHvOqbkqoskoEBFCCGmQOI7DMj8XWSj6K4YHSalUzVURTUWBiBBCSIPFcRwWD3BGcwMdZEs4BN9NUXdJRENRICKEENKg6Qh4GNvZGgCw7wqddUYqR4GIEEJIg+fvaQ0exxAek4m7CdnqLodoIApEhBBCGjwzIzE6mDAAwN7QaPUWQzQSBSJCCCGNQk/zsgOqf78ej8z8YjVXQzQNBSJCCCGNgoMh4GJuiEKJFD+HP1N3OUTDUCAihBDSKHAcMKmrDQBg7+VolEqZmisimoQCESGEkEZjcHsLGOsKEZdegHNRdAo++Q8FIkIIIY2Grg4fYzuXjRIFhcaouRqiSSgQEUIIaVQmdrUDxwEXHjzHk+e56i6HaAiNDERbt26Fg4MDxGIxPDw8cPHixWrbb9myBS4uLtDV1YWTkxP27t1boU1mZibmzp0LCwsLiMViuLi44NixY6paBUIIIRrKxkQPbzi3AADspVEi8oLGBaLDhw9jwYIFWLp0KSIjI9GjRw8MHDgQsbGVX11027ZtCAgIwMqVK3Hnzh2sWrUKc+fOxV9//SVrU1xcjH79+iE6Ohq//PILoqKi8MMPP8DKyqq+VosQQogGmextDwD4NeIZcotK1FsM0QgCdRfwqk2bNmH69OmYMWMGAGDz5s04ceIEtm3bhrVr11Zov2/fPsyaNQv+/v4AAEdHR1y+fBnr1q3DkCFDAAC7d+9Geno6QkJCIBQKAQB2dnb1tEaEEEI0TfdWpnBsro8nz/PwW2Q8JnWlvwmNnUYFouLiYkRERGDJkiVy0319fRESElLpPEVFRRCLxXLTdHV1ERYWBolEAqFQiD///BPe3t6YO3cu/vjjDzRv3hzjx4/H4sWLwefzq+y3qKhI9jw7u+xS7xKJBBKJ5HVWU055X8rsU1XLUFWt2rQNtGW5NdHUuhShCeuiCTXUhbbVqwyVrfMELxt89vd9BF16Cv9OFuA4Tl3lNXqq/EzWtk+OMaYxF2JISEiAlZUVLl26BB8fH9n0NWvWICgoCFFRURXm+eSTT7Bnzx4cPXoUnTp1QkREBPz8/JCSkoKEhARYWFjA2dkZ0dHRmDBhAubMmYOHDx9i7ty5mD9/Pj799NNKa1m5ciVWrVpVYfqBAwegp6envJUmhBCiFoUlwKcRfBRJOcxtW4o2xhrz55AoUX5+PsaPH4+srCwYGRlV2U6jRojKvZrSGWNVJvfly5cjKSkJXbt2BWMMZmZmmDp1KtavXy8b/ZFKpWjRogV27NgBPp8PDw8PJCQkYMOGDVUGooCAACxatEj2PDs7GzY2NvD19a12g9aVRCJBcHAw+vXrJ9udp2zKWoaqatWmbaAty62JptalCE1YF02ooS60rV5lqGqdb3L3sD8sDg+YBRYM6qi+Ahs5VX4my/fw1ESjApGpqSn4fD6SkpLkpqekpMDMzKzSeXR1dbF79258//33SE5OhoWFBXbs2AFDQ0OYmpoCACwsLCAUCuV2j7m4uCApKQnFxcXQ0dGp0K9IJIJIJKowXSgUquQXiKr6VcUyaBtoz3Jroql1KUIT1kUTaqgLbatXGV5d57e7O2B/WBxO309BSl4JrJroqrE6oorPZG3706izzHR0dODh4YHg4GC56cHBwXK70CojFAphbW0NPp+PQ4cOYfDgweDxylavW7duePToEaRSqaz9gwcPYGFhUWkYIoQQ0ji0amGIbq2aQcqA/ZfpFPzGTOFAJJFIEBcXh6ioKKSnpyutoEWLFmHnzp3YvXs37t27h4ULFyI2NhazZ88GULYra/LkybL2Dx48wI8//oiHDx8iLCwMY8eOxe3bt7FmzRpZm3fffRdpaWmYP38+Hjx4gL///htr1qzB3LlzlVY3IYQQ7VR+Cv6hq3EolJSqtxiiNnXaZZabm4v9+/fj4MGDCAsLkzsLy9raGr6+vnjnnXfQuXNnhQvy9/dHWloaVq9ejcTERLi6uuLYsWOy0+QTExPlrklUWlqKr776ClFRURAKhejTpw9CQkJgb28va2NjY4OTJ09i4cKFcHNzg5WVFebPn4/FixcrXCchhJCG4Q3nFrBqoov4zAIcvZmI0R7W6i6JqEGtA9HXX3+NL774Avb29hg6dCiWLFkCKysr6OrqIj09Hbdv38bFixfRr18/dO3aFd9++y1at26tUFFz5szBnDlzKn0tMDBQ7rmLiwsiIyNr7NPb2xuXL19WqB5CCCENl4DPw8Sudlh3/D6CQqIxqpMVnYLfCNU6EIWEhODs2bNo3759pa97eXlh2rRp2L59O3bt2oXz588rHIgIIYSQ+uTf2QZfn3qAW/FZuB6XCXfbpuouidSzWgein3/+uVbtRCJRlaM7hBBCiCYy0dfB0A6W+CXiGYJCoikQNUK1Pqg6MzNThWUQQggh6jXlxcHVf99KxPOcouobkwan1oFo2rRpWLx4sdw1grZv366SogghhJD61t7aGJ1sm0BSynAorPIbipOGq9aBaPjw4Th06BAcHBzw5ptvomfPnjhw4IAqayOEEELq1RQfewDA/iuxkJRKq29MGpRaB6LPP/8coaGhyM3NxaZNm2BiYiK7NhAhhBDSEAx0tYCpgQhJ2YU4eSdZ3eWQelTrQGRlZQWJRAI+nw83Nzf89ttv+Oyzz1RZGyGEEFKvdAQ8jPeyAQAEhUartxhSr2p9ltmmTZswYMAA9O7dG+7u7oiLi6v0Xl+EEEKINpvQ1Q5bzz1G2NN03EvMhouF8m7oTTRXrUeI3N3dERERAV9fXyQkJEAsFuOPP/5QZW2EEEJIvTMzEqO/qzkAYG8o3d+ssajTrTv09PQwYsQIjBgxQlX1EEIIIWo3xdsef99MxO+R8VgywBnGesq9AzvRPHW6uevKlSvx559/Ij4+XlX1EEIIIWrX2b4pnM0NUSApxc8Rceouh9SDOo0QrV69WnZ/F1NTU3h4eKBTp07o1KkTPDw8ZDdgJYQQQrQZx3GY6mOPJUduYW9oDKZ1cwCPR/c3a8jqNELUuXNnWFlZYdmyZVi5ciWsrKxw7NgxjBs3Do6OjjA1NYWvr6+qaiWEEELqzbCOVjASCxCbno/zD56ruxyiYnUaIbpy5QoCAwPxySefwN3dHV9//TXatGkDiUSCmzdv4tq1a7W68zwhhBCi6XR1+PDvbIMfLj5FYEg0+ji3UHdJRIXqNEIEAFOnTsWDBw/Qrl07eHp64qOPPkJRURE8PDwwc+ZMbN26VRV1EkIIIfVuUld7cBxw/sFzPE3NU3c5RIXqHIgAwMDAAOvXr0dERATu37+PVq1aYffu3cqujRBCCFEr22Z66OtUNjK0j07Bb9AUCkQAIJFIUFBQgLFjx8LW1hYzZ85Eenq6MmsjhBBC1G7yi/ub/RwRh7yiEvUWQ1SmTscQffHFF7h16xZu3bqFBw8eQF9fH25ubujSpQtmzZoFY2NjVdVJCCGEqEWPVqZwMNXH09Q8/BYZj4ld6YzqhqhOgWj58uWwt7fH1KlTMW7cOLRu3VpVdRFCCCEagcfjMKmrHVYfvYu9odGY0MVWdgka0nDUaZdZ9+7dkZaWhpUrV6Jjx47w9vbGe++9h927d+PGjRsoLS1VVZ2EEEKI2oz2tIaeDh8PknNx+QkdHtIQ1SkQXbhwAVlZWYiKisKuXbvQo0cP3Lt3Dx9++CHc3d1hYGAALy8vVdVKCCGEqIWRWIiRnawAAHtDo9VbDFGJOu0yK9e6dWu0bt0aY8eOlU17+vQpwsPD6TpEhBBCGqTJ3vb48XIsTt5NRkJmASyb6Kq7JKJECp9l9ioHBwe89dZbWLNmjbK6JIQQQjRGGzNDeDs2Q6mUYf8VOgW/oVFaICKEEEIauikvTsE/GBaHQgkdN9uQUCAihBBCaulNlxawNBYjPa8Yx24lqrscokQUiAghhJBaEvB5mPDiOkRBIdHqLYYoFQUiQgghpA7GdraBjoCHG8+ycD0uU93lECWhQEQIIYTUQTMDEYa4WQIA9tIoUYOh9EDE4/HQt29fREREKLtrQgghRCNM8SnbbXb0ZiJSc4vUXA1RBqUHot27d6NXr16YN2+esrsmhBBCNIKbdRN0tGmC4lIpDoXFqrscogRKD0RTp07FihUrcOnSJWV3TQghhGiM8lGiHy/HoqRUquZqyOtS6ErVAFBYWIibN28iJSUFUqn8B2Ho0KGvXRghhBCiyQa1t8AXf99DUnYhgu8mY2B7C3WXRF6DQoHo+PHjmDx5MlJTUyu8xnEc3eSVEEJIgycS8DHOyxbfnnmEwJBoCkRaTqFdZu+99x7eeustJCYmQiqVyj0oDBFCCGksxnexBZ/H4crTdNxPylZ3OeQ1KBSIUlJSsGjRIpiZmSm7HkIIIURrWBjron+7sr+Fe0Pp/mbaTKFANHr0aJw7d07JpRBCCCHaZ4q3PQDgt2vxyCqQqLcYojCFjiH67rvv8NZbb+HixYto3749hEKh3Ot0yj0hhJDGwsvBBM7mhriflIOfw+Mwo4ejuksiClAoEB04cAAnTpyArq4uzp07B47jZK9xHEeBiBBCSKPBcRwme9vjk99uYd/lGEzr5gAej6t5RqJRFNpltmzZMqxevRpZWVmIjo7G06dPZY8nT54ou0ZCCCFEow13t4SRWICYtHycf/hc3eUQBSgUiIqLi+Hv7w8ej26FRgghhOjpCDDG0wYA3d9MWymUaKZMmYLDhw8ruxZCCCFEa03sageOA849eI7o1Dx1l0PqSKFAVFpaivXr16NXr154//33sWjRIrnH69q6dSscHBwgFovh4eGBixcvVtt+y5YtcHFxga6uLpycnLB3794q2x46dAgcx2H48OGvXSchhBBSzt5UH73bNAdjwL7LdAq+tlHooOpbt27B3d0dAHD79m25114+wFoRhw8fxoIFC7B161Z069YN33//PQYOHIi7d+/C1ta2Qvtt27YhICAAP/zwAzp37oywsDDMnDkTTZs2xZAhQ+TaxsTE4MMPP0SPHj1eq0ZCCCGkMpN97HE26jl+Co/DB75toKej8B2ySD2r9Tt18+ZNuLq6gsfj4ezZsyoraNOmTZg+fTpmzJgBANi8eTNOnDiBbdu2Ye3atRXa79u3D7NmzYK/vz8AwNHREZcvX8a6devkAlFpaSkmTJiAVatW4eLFi8jMzFTZOhBCCGmcerVuDvtmeohOy8fvkQkY36XiF3mimWodiNzd3ZGYmIgWLVrA0dERV69eRbNmzZRaTHFxMSIiIrBkyRK56b6+vggJCal0nqKiIojFYrlpurq6CAsLg0QikV0jafXq1WjevDmmT59e4y648n6Liopkz7Ozyy7JLpFIIJEo78Jb5X0ps09VLUNVtWrTNtCW5dZEU+tShCasiybUUBfaVq8y1Oc6j/eywZp/ohB46SlGu5u/9p6TxkCV709t++QYY6w2DZs1a4Zjx46hS5cu4PF4SE5ORvPmzV+ryFclJCTAysoKly5dgo+Pj2z6mjVrEBQUhKioqArzfPLJJ9izZw+OHj2KTp06ISIiAn5+fkhJSUFCQgIsLCxw6dIl+Pv74/r16zA1NcXUqVORmZmJ33//vcpaVq5ciVWrVlWYfuDAAejp6SllfQkhhDQ8+SXAigg+iqUc3m9bglbG6q6occvPz8f48eORlZUFIyOjKtvVeoRo1KhR6NWrFywsLMBxHDw9PcHn8ytt+7rXIno1TTPGqkzYy5cvR1JSErp27QrGGMzMzDB16lSsX78efD4fOTk5mDhxIn744QeYmprWuoaAgAC5A8Szs7NhY2MDX1/fajdoXUkkEgQHB6Nfv34VrvitactQVa3atA20Zbk10dS6FKEJ66IJNdSFttWrDPW9zjdwF4euPsNDzgrzBnVQ+fK0nSrfn/I9PDWpdSDasWMHRo4ciUePHmHevHmYOXMmDA0NFS6wMqampuDz+UhKSpKbnpKSUuWNZHV1dbF79258//33SE5OhoWFBXbs2AFDQ0OYmpri5s2biI6OljueSCqVAgAEAgGioqLQsmXLCv2KRCKIRKIK04VCoUp+mFTVryqWQdtAe5ZbE02tSxGasC6aUENdaFu9ylBf6/x2N0ccuvoMwfdSkJpfAgtjXZUvsyFQxftT2/7qdPj7gAEDAAARERGYP3++0gORjo4OPDw8EBwcjBEjRsimBwcHY9iwYdXOKxQKYW1tDaDs1PrBgweDx+PB2dkZt27dkmu7bNky5OTk4H//+x9sbGyUug6EEEKIk7khujqa4PKTdOy/HIsP+zupuyRSA4XOB9yzZ4+y65BZtGgRJk2aBE9PT3h7e2PHjh2IjY3F7NmzAZTtyoqPj5dda+jBgwcICwtDly5dkJGRgU2bNuH27dsICgoCAIjFYri6usoto0mTJgBQYTohhBCiLFO87XH5SToOhsXi/TdaQSSo/DATohkUvkDC6dOncfr0aaSkpMh2QZXbvXu3wgX5+/sjLS0Nq1evRmJiIlxdXXHs2DHY2dkBABITExEbGytrX1paiq+++gpRUVEQCoXo06cPQkJCYG9vr3ANhBBCyOvq19YMFsZiJGYV4titRIxwt1Z3SaQaCgWiVatWYfXq1fD09JQdZK1Mc+bMwZw5cyp9LTAwUO65i4sLIiMj69T/q30QQgghyibg8zCxqx02nIhCUEgMBSINp1Ag2r59OwIDAzFp0iRl10MIIYQ0GP6dbfC/Uw9xPS4TN+Iy0cGmibpLIlVQ+G73L18niBBCCCEVmRqIMNjNAgAQFBqt3mJItRQKRDNmzMCBAweUXQshhBDS4Ez2sQcAHL2RiLTcouobE7VRaJdZYWEhduzYgVOnTsHNza3COf6bNm1SSnGEEEKItuto0wQdbJrgRlwmDl2Nw9w+rdRdEqmEQoHo5s2b6NixIwDl3+2eEEIIaWimeNthUVwm9l+OwayejhDwFdpBQ1RIoUCkyrvdE0IIIQ3NoPYW+OLve0jIKsSpe8kY4Gqh7pLIKyiiEkIIISomFvIx1qvszghBITFqroZUptaB6OWLIdZGfHx8nYshhBBCGqoJXezA53EIfZKGB8k56i6HvKLWgahz586YOXMmwsLCqmyTlZWFH374Aa6urjhy5IhSCiSEEEIaAssmuvBtW3aj8qCQaPUWQyqo9TFE9+7dw5o1azBgwAAIhUJ4enrC0tISYrEYGRkZuHv3Lu7cuQNPT09s2LABAwcOVGXdhBBCiNaZ7G2Pf24n4ci1eHw8wBnGusq9sztRXK1HiExMTLBx40YkJCRg27ZtaNOmDVJTU/Hw4UMAwIQJExAREYFLly5RGCKEEEIq0dXRBE5mhiiQlOLXiGfqLoe8pM5nmYnFYowcORIjR45URT2EEEJIg8VxHCb72GHpb7ex73IMpvrYg8ejy9VoAoXvdl9YWIibN29Werf7oUOHvnZhhBBCSEM0vKMVvvznPp6m5uHCw+fo7dRC3SURKBiIjh8/jkmTJiEtLa3CaxzHobS09LULI4QQQhoifZEAb3nYYPelp9gbGkOBSEModB2i9957D2PGjEFiYiKkUqncg8IQIYQQUr3J3nYAgLNRKYhJy1NzNQRQMBClpKRg0aJFMDMzU3Y9hBBCSINnb6qP3k7NwRjw42W6UKMmUCgQjR49GufOnVNyKYQQQkjjMcXbHgBw+Goc8otL1FsMUewYou+++w5vvfUWLl68iPbt21e42/28efOUUhwhhBDSUPVq0xx2zfQQk5aPP64nYJyXrbpLatQUCkQHDhzAiRMnoKuri3Pnzsnd4Z7jOApEhBBCSA14PA6Tutrh87/vISgkGmM728j9PSX1S6FdZsuWLcPq1auRlZWF6OhoPH36VPZ48uSJsmskhBBCGqS3PGygK+TjflIOrkZnqLucRk2hQFRcXAx/f3/weArNTgghhBAAxnpCDHe3AkD3N1M3hRLNlClTcPjwYWXXQgghhDQ6U3zKTsE/ficJSVmFaq6m8VLoGKLS0lKsX78eJ06cgJubW4WDqjdt2qSU4gghhJCGztncCF0cTHDlaToOXInBIl8ndZfUKCkUiG7dugV3d3cAwO3bt+VeowPCCCGEkLqZ4mNfFojCYjG3byuIBHx1l9ToKBSIzp49q+w6CCGEkEarX1szmBuJkZRdiH9uJcmOKyL1h46KJoQQQtRMyOdhQpey6xAFhUart5hGqtYjRIsWLcJnn30GfX19LFq0qNq2dAwRIYQQUjfjutji2zOPEBmbiZvPMuFm3UTdJTUqtQ5EkZGRkEgksv9XhY4hIoQQQurO1EAEPzcL/BYZj72hMdj4VhN1l9So1DoQvXzcEB1DRAghhCjfZG87/BYZjz9vJCBgoDOaGYjUXVKjodAxRAUFBcjPz5c9j4mJwebNm3Hy5EmlFUYIIYQ0Nh1tmsDN2hjFJVIcDo9TdzmNikKBaNiwYdi7dy8AIDMzE15eXvjqq68wbNgwbNu2TakFEkIIIY0Fx3GY4m0PANh/ORYlpVL1FtSIKBSIrl27hh49egAAfvnlF5ibmyMmJgZ79+7FN998o9QCCSGEkMbEz80CJvo6iM8swOn7Keoup9FQKBDl5+fD0NAQAHDy5EmMHDkSPB4PXbt2RUxMjFILJIQQQhoTsZCPsZ1tAND9zeqTQoGoVatW+P333xEXF4cTJ07A19cXAJCSkgIjIyOlFkgIIYQ0NhO62oHHASGP0/AwOUfd5TQKCgWiTz/9FB9++CHs7e3RpUsXeHt7AygbLSq/pQchhBBCFGPVRBe+bc0BAHtDac9LfVAoEI0ePRqxsbEIDw/H8ePHZdPfeOMNfP3117Lnz549g1RKB4QRQgghdTXZxw4A8Ou1Z8gulKi5moZP4Vt3mJubw93dHTzef114eXnB2dlZ9rxt27aIjo5+rQIJIYSQxsjbsRlatzBAfnEpfo14pu5yGjyV3suMMabK7gkhhJAGi+M4TPaxBwDsC42BVEp/U1WJbu5KCCGEaKiR7lYwFAnwJDUP/z5KVXc5DRoFIkIIIURD6YsEGO1pDQDYGxqt3mIaOApEhBBCiAab1LXs4OrT91MQm5ZfQ2uiKJUGIo7jFJpv69atcHBwgFgshoeHBy5evFht+y1btsDFxQW6urpwcnKS3Vak3A8//IAePXqgadOmaNq0Kd58802EhYUpVBshhBBSnxybG6Bnm+ZgDPjxCp2Cryoad1D14cOHsWDBAixduhSRkZHo0aMHBg4ciNjY2Erbb9u2DQEBAVi5ciXu3LmDVatWYe7cufjrr79kbc6dO4dx48bh7NmzCA0Nha2tLXx9fREfH6/wuhFCCCH1ZeqLU/APX41DQXGpmqtpmFR6t/u7d+/Czs6uTn1v2rQJ06dPx4wZM+Di4oLNmzfDxsamypvG7tu3D7NmzYK/vz8cHR0xduxYTJ8+HevWrZO12b9/P+bMmYOOHTvC2dkZP/zwA6RSKU6fPl2n2gghhBB16NWmBWxN9JBVIMGfN+jLvCoIFJlp2LBhGDlyJGbPno3MzEx06dIFQqEQqamp2LRpE959910AgI2NTZ36LS4uRkREBJYsWSI33dfXFyEhIZXOU1RUBLFYLDdNV1cXYWFhkEgkEAqFFebJz8+HRCKBiYlJlbUUFRWhqKhI9jw7OxsAIJFIIJEo7wJZ5X0ps09VLUNVtWrTNtCW5dZEU+tShCasiybUUBfaVq8yNIR1Hu9ljS+PP8CeS9EY0cFc4cNSNJEq35/a9skxBfZrmZqa4vz582jXrh127tyJb7/9FpGRkfj111/x6aef4t69e3UuGAASEhJgZWWFS5cuwcfHRzZ9zZo1CAoKQlRUVIV5PvnkE+zZswdHjx5Fp06dEBERAT8/P6SkpCAhIQEWFhYV5pk7dy5OnDiB27dvVwhT5VauXIlVq1ZVmH7gwAHo6ekptH6EEEKIovIkwIprfEikHOa1K0FLunVoreTn52P8+PHIysqq9n6rCo0Qqfpu96+mXsZYlUl4+fLlSEpKQteuXcEYg5mZGaZOnYr169eDz+dXaL9+/XocPHgQ586dqzIMAUBAQAAWLVoke56dnQ0bGxv4+voq9Qa2EokEwcHB6NevX6WjWZq0DFXVqk3bQFuWWxNNrUsRmrAumlBDXWhbvcrQUNb5Bu7gcHg8HnPWeH+Qm7rLURpVvj/le3hqolAgKr/b/YgRI3DixAksXLgQwOvf7d7U1BR8Ph9JSUly01NSUmBmZlbpPLq6uti9eze+//57JCcnw8LCAjt27IChoSFMTU3l2m7cuBFr1qzBqVOn4OZW/QdJJBJBJBJVmC4UClXyw6SqflWxDNoG2rPcmmhqXYrQhHXRhBrqQtvqVQZtX+cpPo44HB6PE3eTkV5QCjOjqr/YayNVvD+17U+j7navo6MDDw8PBAcHy00PDg6W24VWGaFQCGtra/D5fBw6dAiDBw+Wu8/ahg0b8Nlnn+H48ePw9PRUuEZCCCFEXdpaGsHL3gQlUob9Vyo/+5ooRqERotGjR6N79+5ITExEhw4dZNPfeOMNjBgx4rUKWrRoESZNmgRPT094e3tjx44diI2NxezZswGU7cqKj4+XXWvowYMHCAsLQ5cuXZCRkYFNmzbh9u3bCAoKkvW5fv16LF++HAcOHIC9vb1sBMrAwAAGBgavVS8hhBBSnyb72CEsOh0HrsTivT6toCOgaywrg0KBCCi72725ubncNC8vr9cuyN/fH2lpaVi9ejUSExPh6uqKY8eOyU7fT0xMlLsmUWlpKb766itERUVBKBSiT58+CAkJgb29vazN1q1bUVxcjNGjR8sta8WKFVi5cuVr10wIIYTUl/7tzGFmJEJydhH+uZ2IYR2t1F1Sg6BwIMrMzMSuXbtw7949cBwHFxcXTJ8+HcbGxq9d1Jw5czBnzpxKXwsMDJR77uLigsjIyGr7i46Ofu2aCCGEEE0g5PMwoYsdNgU/wN7QGApESqLQOFt4eDhatmyJr7/+Gunp6UhNTcXXX3+Nli1b4tq1a8qukRBCCCEvGetlAyGfQ0RMBm7HZ6m7nAZBoUC0cOFCDB06FNHR0Thy5Ah+++03PH36FIMHD8aCBQuUXCIhhBBCXtbCUIxB7cuusxcUEq3eYhoIhUeIFi9eDIHgvz1uAoEAH3/8McLDw5VWHCGEEEIqN8XHHgDwx40EZOQVq7eYBkChQGRkZFTpzVbj4uJkF2wkhBBCiOq42zRBeytjFJdIcehqnLrL0XoKBSJ/f39Mnz4dhw8fRlxcHJ49e4ZDhw5hxowZGDdunLJrJIQQQsgrOI7DZO+yM7B/vByDUmmd78RFXqLQWWYbN24seyMmT0ZJSQmAsgsjvvvuu/jyyy+VWiAhhBBCKjekgyXWHLuH+MwCnL6XDN925jXPRCql0AiRjo4O/ve//yEjIwPXr19HZGQk0tPT8fXXX1d6uwtCCCGEKJ9YyMdYL1sAwN7Q17+XaGOmUCBau3Ytdu/eDT09PbRv3x5ubm7Q09PD7t27sW7dOmXXSAghhJAqTOhiCx4H/PsoFY9SctRdjtZSKBB9//33cHZ2rjC9Xbt22L59+2sXRQghhJDasW6qhzddym6ATqNEilMoECUlJcHCwqLC9ObNmyMxMfG1iyKEEEJI7ZWfgv9rxDPkFErUW4yWUigQ2djY4NKlSxWmX7p0CZaWlq9dFCGEEEJqz6dlM7RqYYC84lIcuRav7nK0kkKBaMaMGViwYAH27NmDmJgYxMTEYPfu3Vi4cCFmzpyp7BoJIYQQUg2O4zDlxSn4QaHRkNIp+HWm0Gn3H3/8MdLT0zFnzhwUF5ddHVMsFmPx4sUICAhQaoGEEEIIqdmITtZYdzwKT57n4dLjVPRo3VzdJWkVhUaIOI7DunXr8Pz5c1y+fBk3btxAeno6Pv30U2XXRwghhJBaMBAJMNrDGgAQFEIHV9eVQoGonIGBATp37gxXV1e6/hAhhBCiZpNe7DY7fT8Zcen5aq5Gu7xWICKEEEKI5mjZ3AA9WpuCsbLbeZDao0BECCGENCBTvO0BAIeuxqGguFS9xWgRCkSEEEJIA9LHuQWsm+oiq0CCv24kqLscrUGBiBBCCGlA+DwOk18cSxQYEg3G6BT82qBARAghhDQwYzxtIBLwcDcxGxExGeouRytQICKEEEIamCZ6Ohje0QoAEET3N6sVCkSEEEJIAzTZp2y32T+3EpGSXajmajQfBSJCCCGkAWpnaYzO9k1RImU4EBar7nI0HgUiQgghpIGa/OIU/P1XYlFcIlVvMRqOAhEhhBDSQPVvZ44WhiI8zynC8TtJ6i5Ho1EgIoQQQhooHQEP47vYAgD2hkSrtxgNR4GIEEIIacDGd7GFkM8hPCYDt+Oz1F2OxqJARAghhDRgLQzFGOhqAQDYGxqt3mI0GAUiQgghpIGb8uIU/D+uJyAjr1jN1WgmCkSEEEJIA9fJtinaWRqhqESKn8Lj1F2ORqJARAghhDRwHMdhio89AGDf5RiUSun+Zq+iQEQIIYQ0AkM7WKKJnhDPMgpw5n6KusvROBSICCGEkEZALOTDv7MNADq4ujIUiAghhJBGYmIXO/A44OLDVDxKyVV3ORqFAhEhhBDSSNiY6OENFzMAwI+XY9RcjWahQEQIIYQ0IlNe3N/sl4hnyC0qUW8xGoQCESGEENKIdGvVDI7N9ZFbVIIj156puxyNQYGIEEIIaUQ4jpONEgWFRIMxOgUfoEBECCGENDqjPKxhIBLg8fM8hDxOU3c5GoECESGEENLIGIgEGNXJCgAQGBKt3mI0BAUiQgghpBGa9GK32el7yYhLz1dvMRpAIwPR1q1b4eDgALFYDA8PD1y8eLHa9lu2bIGLiwt0dXXh5OSEvXv3Vmjz66+/om3bthCJRGjbti1+++03VZVPCCGEaLxWLQzQvZUppAzYfyVW3eWoncYFosOHD2PBggVYunQpIiMj0aNHDwwcOBCxsZW/Wdu2bUNAQABWrlyJO3fuYNWqVZg7dy7++usvWZvQ0FD4+/tj0qRJuHHjBiZNmoQxY8bgypUr9bVahBBCiMYpv7/Z4auxKJSUqrcYNdO4QLRp0yZMnz4dM2bMgIuLCzZv3gwbGxts27at0vb79u3DrFmz4O/vD0dHR4wdOxbTp0/HunXrZG02b96Mfv36ISAgAM7OzggICMAbb7yBzZs319NaEUIIIZqnr3MLWDXRRUa+BH/eSFB3OWolUHcBLysuLkZERASWLFkiN93X1xchISGVzlNUVASxWCw3TVdXF2FhYZBIJBAKhQgNDcXChQvl2vTv37/aQFRUVISioiLZ8+zsbACARCKBRCKpy2pVq7wvZfapqmWoqlZt2gbastyaaGpditCEddGEGupC2+pVhsa4zrU13ssaG04+ROClpxjuZgaO4+q9BlW+P7Xtk2MadAGChIQEWFlZ4dKlS/Dx8ZFNX7NmDYKCghAVFVVhnk8++QR79uzB0aNH0alTJ0RERMDPzw8pKSlISEiAhYUFdHR0EBgYiPHjx8vmO3DgAN5++2250POylStXYtWqVRWmHzhwAHp6ekpYW0IIIUT98iTAigg+JIzDAtcSOBiquyLlys/Px/jx45GVlQUjI6Mq22nUCFG5V9MpY6zKxLp8+XIkJSWha9euYIzBzMwMU6dOxfr168Hn8xXqEwACAgKwaNEi2fPs7GzY2NjA19e32g1aVxKJBMHBwejXrx+EQqHS+lXFMlRVqzZtA21Zbk00tS5FaMK6aEINdaFt9SpDY1znurgmvYNfrsXjMc8acwe51fvyVfn+lO/hqYlGBSJTU1Pw+XwkJSXJTU9JSYGZmVml8+jq6mL37t34/vvvkZycDAsLC+zYsQOGhoYwNTUFAJibm9epTwAQiUQQiUQVpguFQpX8MKmqX1Usg7aB9iy3JppalyI0YV00oYa60LZ6laExrnNtTO3mgF+uxeP4nWQsH1KKFobimmdSAVW8P7XtT6MOqtbR0YGHhweCg4PlpgcHB8vtQquMUCiEtbU1+Hw+Dh06hMGDB4PHK1s9b2/vCn2ePHmyxj4JIYSQxsDVyhgedk0hKWU4eCVO3eWohUaNEAHAokWLMGnSJHh6esLb2xs7duxAbGwsZs+eDaBsV1Z8fLzsWkMPHjxAWFgYunTpgoyMDGzatAm3b99GUFCQrM/58+ejZ8+eWLduHYYNG4Y//vgDp06dwr///quWdSSEEEI0zWRvO0TEZGD/lRjM6dMSQr5GjZmonMYFIn9/f6SlpWH16tVITEyEq6srjh07Bjs7OwBAYmKi3DWJSktL8dVXXyEqKgpCoRB9+vRBSEgI7O3tZW18fHxw6NAhLFu2DMuXL0fLli1x+PBhdOnSpb5XjxBCCNFIA10t8LnhPaTkFOHEnSQMdrNUd0n1SuMCEQDMmTMHc+bMqfS1wMBAuecuLi6IjIyssc/Ro0dj9OjRyiiPEEIIaXB0BDyM97LF/04/RFBIdKMLRI1rPIwQQgghVRrfxRYCHoer0Rm4k5Cl7nLqFQUiQgghhAAAzIzEGOBqDgDYFxqj5mrqFwUiQgghhMhMfXF/s9+vxyMzv1i9xdQjCkSEEEIIkfGwa4q2FkYolEjxU3jjOQWfAhEhhBBCZDiOwxSfsjO7912OQalUY+7wpVIUiAghhBAiZ2gHKxjrChGXXoBzUSnqLqdeUCAihBBCiBxdHT7GdrYBAAQ1koOrKRARQgghpIKJXe3AccCFB8/x+HmuustROQpEhBBCCKnAxkQPbzi3ANA4TsGnQEQIIYSQSk32tgcA/BrxDLlFJeotRsUoEBFCCCGkUt1bmcKxuT5yikrwW2S8ustRKQpEhBBCCKkUj8dhcteyU/D3hkSDsYZ7Cj4FIkIIIYRUaZSHNfR1+HiYkovQx2nqLkdlKBARQgghpEqGYiFGdrIGAASFRqu3GBWiQEQIIYSQapVfuTr4bjLiMwvUXI1qUCAihBBCSLVatTBEt1bNIGXAj5cb5in4FIgIIYQQUqPyU/APhcWiUFKq3mJUgAIRIYQQQmr0hnMLWDXRRUa+BEdvJqq7HKWjQEQIIYSQGgn4PEx8cQp+UAM8BZ8CESGEEEJqxb+zDXQEPNyKz0JkXKa6y1EqCkSEEEIIqRUTfR0M7WAJoOxCjQ0JBSJCCCGE1NpUH3sAwN+3EvE8p0i9xSgRBSJCCCGE1JqrlTE62TaBpJThUFisustRGgpEhBBCCKmTKS9GiX68EgNJqVS9xSgJBSJCCCGE1MlAVwuYGoiQnF2Ek3eS1V2OUlAgIoQQQkid6Ah4GN/FFkDDub8ZBSJCCCGE1NmELrYQ8DiEPU3HvcRsdZfz2igQEUIIIaTOzIzE6O9qDgDY2wBGiSgQEUIIIUQhU17c3+y3yHhk5UvUW8xrokBECCGEEIV0tm8KFwsjFEqk+DkiTt3lvBYKRIQQQghRCMdxmOJddn+zvaExKJVq7/3NKBARQgghRGHDOlrBSCxAbHo+zj9IUXc5ChOou4CGRCqVori4uE7zSCQSCAQCFBYWorS0VCV1KWsZqqpVG7aBjo4OeDz6/kAIIa/S1eHDv7MNfrj4FEEhMejrbKbukhRCgUhJiouL8fTpU0ildbtiJ2MM5ubmiIuLA8dxKqlNWctQVa3asA14PB4cHBygo6OjguoIIUS7Tepqj53/PsX5B8/xNDUPDqb66i6pzigQKQFjDImJieDz+bCxsanTSIJUKkVubi4MDAxUNgKhrGWoqlZN3wZSqRQJCQlITEyEra2tykIbIYRoK9tmeujr1AKn76dgb2g0Vgxpp+6S6owCkRKUlJQgPz8flpaW0NPTq9O85bvZxGKxSsOAMpahqlq1YRs0b94cCQkJKCkpgVAoVEGFhBCi3Sb72OP0/RT8Ev4MH/o6QV+kXRGDDopQgvJjUmh3SsNV/t6q6hgnQgjRdj1amcLBVB85RSX4LTJe3eXUGQUiJaJdKQ0XvbeEEFI9Ho/DZNkp+NFgTLtOwadARAghhBClGOVhDT0dPh4k5yL0SZq6y6kTCkSN2NSpU8FxHGbPnl3htTlz5oDjOEydOrVeahk5ciSEQiEuX75c6euRkZHw9/eHhYUFRCIR7OzsMHjwYPz1118VvoUEBQXBy8sL+vr6MDQ0RM+ePXH06FG5NufOnQPHcbJH8+bNMXDgQNy4cUNl60gIIQ2dkViIkZ2sAAB7Q2LUXE3dUCBq5GxsbHDo0CEUFBTIphUWFuLgwYOwtbWtlxpiY2Nx9epVzJ07F7t27arw+h9//IGuXbsiNzcXQUFBuHv3Ln7++WcMHz4cy5YtQ1ZWlqzthx9+iFmzZmHMmDG4ceMGwsLC0KNHD4wYMQI7duyo0HdUVBQSExPx999/IyMjAwMGDJDrjxBCSN1MfnF/s5N3kxCfWVB9Yw2ikYFo69atcHBwgFgshoeHBy5evFht+/3796NDhw7Q09ODhYUF3n77baSlyQ/Vbd68GU5OTtDV1YWNjQ0WLlyIwsJCVa6GVujUqRNsbW1x5MgR2bQjR47AxsYG7u7u9VJDYGAgfH19MXv2bBw+fBh5eXmy1/Ly8jB9+nT4+fnh77//hq+vL1q2bAkvLy/MmDEDN27cgLGxMQDg8uXL+Oqrr7BhwwZ8+OGHaNWqFVxcXPDFF19g/vz5WLZsGeLi5O+106JFC5ibm8PLywtfffUVkpKSqhylIoQQUrM2ZobwadkMUgYcuKI9o0QaF4gOHz6MBQsWYOnSpYiMjESPHj0wcOBAxMbGVtr+33//xeTJkzF9+nTcuXMHP//8M65evYoZM2bI2uzfvx9LlizBihUrcO/ePezatQuHDx9GQECAStaBMYb84pJaPwqKS+vUvrqHIgexvf3229izZ4/s+e7duzFt2rQa54uNjYWBgUG1j8p2x726rQIDAzFmzBg4OzujTZs2+Omnn2Svnzx5Emlpafj444+r7KP8gOeDBw/CwMAAs2bNqtBm0aJFkEgkcsHvVbq6ugDKrmpNCCFEceWjRAfD4lAo0Y6zczXuIgGbNm3C9OnTZYFm8+bNOHHiBLZt24a1a9dWaH/58mXY29tj3rx5AAAHBwfMmjUL69evl7UJDQ1Ft27dMH78eACAvb09xo0bh7CwMJWsQ4GkFG0/PaGSvmtyd3V/6OnU7W2dNGkSAgICEB0dDY7jcOnSJRw6dAjnzp2rdj5LS0tcv3692jZGRkbVvn7q1Cnk5+fjjTfeAABMnDgRu3btwttvvw0AePDgAQDAyclJNs/Vq1fRp08f2fNDhw5h8ODBePDgAVq2bFnp5Q8sLS1hZGQk6+9VaWlpWLVqFQwNDeHl5VVtzYQQQqr3pksLWBqLkZBViL9vJmKUh7W6S6qRRgWi4uJiREREYMmSJXLTfX19ERISUuk8Pj4+WLp0KY4dO4aBAwciJSUFv/zyC/z8/GRtunfvjh9//BFhYWHw8vLCkydPcOzYMUyZMqXKWoqKilBUVCR7np2dDaBs9ODVEQSJRALGGKRSqeyhLpUtv3zUqLzGl6czxmBiYoJBgwYhMDAQjDEMGjQIJiYmstfL53m1Hx6PB0dHx1rVVJWdO3dizJgxEAgEYIzB398fH330Ee7duwcnJyfZMl9eL1dXV1y7dg1AWVAqLi6GVCqVa/uq8nXhOE6uL2vrsh/SvLw8tG7dGocPH4apqWmFPsr7l0gk4PP5Na5zufLPiqaNOmlqXYrQhHXRhBrqQtvqVYbGuM7qNq6zNb469QhBIU8x1K36+5up8v2pbZ8aFYhSU1NRWloKMzP5DWdmZoakpKRK5/Hx8cH+/fvh7++PwsJClJSUYOjQofj2229lbcaOHYvnz5+je/fuYIyhpKQE7777boXg9bK1a9di1apVFaafPHmywtWoBQIBzM3NkZubi+LiYjDGELqoa11WXWkkBXnILqz8mjk5OTnybSUSlJSUIDs7G/7+/rLdUhs2bEB2djZKSkogkUhkYfDVfuLi4uDt7V1tPW+99Ra+/vrrSl/LyMjAH3/8AYlEgu3bt8uml5aWYvv27Vi1ahWsrMrOVrh27Ro6d+4sa9OiRQvZ/wsKCpCdnQ17e3tcunQJqampFUaJEhMTkZOTAxsbG2RnZyM/Px8AcOzYMRgaGqJZs2ay0axX1xcoC+sFBQW4cOECSkpKql3nygQHB9d5nvqgqXUpQhPWRRNqqAttq1cZGuM6q4uJBBBwfNyMz8a2w8dgZ1jzPKp4f8p/39dEowJRuVcvglf+zb4yd+/exbx58/Dpp5+if//+SExMxEcffYTZs2fLzlg6d+4cvvjiC2zduhVdunTBo0ePMH/+fFhYWGD58uWV9hsQEIBFixbJnmdnZ8PGxga+vr4VdgMVFhYiLi4OBgYGEIvFAADjWq4rYww5OTkwNDRU6Y1NK1uGUCiEQCCAkZERRo4cKVvfESNGgM/nQyAQQCgUytb31X6cnJxkIzVVMTIyqnK32d69e2FtbY1ff/0VeXl50NfXB8dxOHPmDL788kts2LABw4YNg4mJCbZs2VLl8T+6urowMjLCpEmT8P333+PQoUN477335NqsXLkSQqEQ48aNg5GRkSzUurq6okmTJjVuw8LCQujq6qJnz56y97g2JBIJgoOD0a9fP4265Yem1qUITVgXTaihLrStXmVojOusCcJLb+O3yAQ85tvg3UHtq2ynyvensi+5ldGoQGRqago+n19hNCglJaXCqFG5tWvXolu3bvjoo48AAG5ubtDX10ePHj3w+eefy0LPpEmTZMcltW/fHnl5eXjnnXewdOnSSu9tJRKJIBKJKkwXCoUV3qzS0lJwHAcej6fQjUMByOZXhaqWUX4NnvK67927BwCy9Xv59cr60dHRQZs2bRSua/fu3Rg9ejTat2+P7OxsGBkZye4qv2TJEvzzzz8YNmwYdu7cCX9/fwwZMgTz5s1D69atkZubi+PHj8vq5fF46NatG+bPn4+PP/4YEokEw4cPh0QiwY8//ohvv/0Wa9euha2trdz7VNv3jMfjgeO4St//2lB0PlXT1LoUoQnrogk11IW21asMjXGd1entbg74LTIB/9xOxrLB7dDcsOLf1Zep4v2pbX8adZaZjo4OPDw8KgyZBQcHw8fHp9J58vPzK/xBKz/Go/yYkqralB9XQspUN5qjbBEREbhx4wZGjRpV4TVDQ0P4+vrKRvhGjBiBkJAQ6OnpYfLkyXByckLfvn1x5swZ2QHV5TZv3oytW7fi0KFDaN++PTw8PHD+/HkcOXIE77zzTr2sGyGEkDJu1k3Q0aYJikulOHy18rPFNYVGjRABZadHT5o0CZ6envD29saOHTsQGxsrO307ICAA8fHx2Lt3LwBgyJAhmDlzJrZt2ybbZbZgwQJ4eXnB0tJS1mbTpk1wd3eX7TJbvnw5hg4dWqcDZBuawMDAal///fffVbZsDw+Pag+C/vPPP+Wee3p64ueff65V39OmTatw2QCpVCo3bNq7d28Kw4QQUg+m+thjweHr+PFyLGb3agkBX6PGYmQ0LhD5+/sjLS0Nq1evRmJiIlxdXXHs2DHY2ZXdMC4xMVHumkRTp05FTk4OvvvuO3zwwQdo0qQJ+vbti3Xr1snaLFu2DBzHYdmyZYiPj0fz5s0xZMgQfPHFF/W+foQQQkhjMrC9OT7/WwdJ2YU4eTcZg9pbqLukSmlcIALK7qM1Z86cSl+rbFTj/fffx/vvv19lfwKBACtWrMCKFSuUVSIhhBBCakEk4GOcly2+PfMIQSHRGhuINHPcihBCCCENxvgutuDzOFx5mo77SbU766u+USAihBBCiEpZGOtiQDtzAMDeUM28vxkFIkIIIYSo3GTvsmOBf7sWj6x8zbtiOAUiQgghhKicl4MJnM0NUSApxc8RceoupwIKRIQQQghROY7jMNnbHgCw73IMpFLNuvQJBSJCCCGE1Ivh7pYwEgsQk5aP8w+fq7scORSICCGEEFIv9HQEGONpAwAIColWbzGvoEBECCGEkHozsasdOA44F/Uc0al56i5HhgJRIzZ16lRwHCe7LcrL5syZA47jMHXqVJUtPzo6GhzH4fr161W2KS4uxoYNG9CpUyfo6+vD2NgYHTp0wLJly5CQkCDXNi4uDtOnT4elpSV0dHRgZ2eH+fPnIy0tTa5d7969ZTeuFYlEaNOmDdasWYPS0lJVrCYhhJCX2Jvqo3eb5gDKjiXSFBSIGjkbGxscOnQIBQUFsmmFhYU4ePAgbG1t1VgZUFRUhH79+mHNmjWYOnUqLly4gIiICKxfvx5paWn49ttvZW2fPHkCT09PPHjwAAcPHsSjR4+wfft2nD59Gt7e3khPT5fre+bMmUhMTERUVBTmzZuHZcuWYePGjfW9ioQQ0ihN8bEHAPwUHof84hL1FvOCRt66g9SfTp064cmTJzhy5AgmTJgAADhy5AhsbGzg6Oio1tq+/vpr/PvvvwgPD4e7u7tseqtWrdC/f3+5m7POnTsXOjo6OHnyJHR1dQEAtra2cHd3R8uWLbFs2TJ8+eWXsvZ6enowNy+7SNh7772HP/74A7///jsWL15cT2tHCCGNV8/WzWHfTA/Rafn4LTIeYzpZqrskGiFSCcaA4rzaPyT5dWtf3UOBO7i//fbb2LNnj+z57t27K9wtvjKxsbEwMDCo9lHZ7rjaOnjwIPr16ycXhl7GcRwAID09HSdOnMCcOXNkYaicubk5JkyYgJ9++qnau9vr6upCItG8C4URQkhDxONxmPTiFPy9ITHV/n6uLzRCpAqSfGBN7dIuD0ATZS77kwRAR79Os0yaNAkBAQGyY3ouXbqEQ4cO4dy5c9XOZ2lpWe3xPwBgZGRUp1pe9uDBA/Tu3Vtu2ogRIxAcHAwAcHNzQ0hICB4+fAjGGFxcXCrtx8XFBRkZGUhNTYWxsbHca1KpFCdPnsSJEyewYMEChWslhBBSN6M9rLHxRBSiknMQFp2h7nIoEBHA1NQUfn5+CAoKAmMMfn5+MDU1rXE+gUCAVq1aqbS28lGgclu3bkVeXh6++eYbXLhwoVZ9lH/zeLmvrVu3YufOnSguLgZQFgpXrFihpKoJIYTUxFhXiJGdrLD/Six+vBKHgYp/f1YKCkSqINQrG6mpBalUiuycHBgZGoLHU8IeTKGeQrNNmzYN7733HgBgy5YttZonNjYWbdu2rbbNxIkTsX37doVqat26Ne7fvy83zcLCAgBgYmIim9aqVStwHIe7d+9i+PDhFfq5f/8+mjZtimbNmsmmTZgwAUuXLoVIJIKlpSX4fL5CNRJCCFHcZG977L8Si+B7KejaUb21UCBSBY6r/W4rqRQQlpa1V0YgUtCAAQNkoyX9+/ev1Tyq3mU2btw4LFu2DJGRkVUeRwQAzZo1Q79+/bB161YsXLhQ7jiipKQk7N+/H5MmTZIbITI2Nlb56BYhhJDqOZkboqujCS4/SUdIMg8T1FgLBSICAODz+bh3757s/7WhrF1mUVFRyMvLg76+vmyUrG3btli4cCH+/vtv9O3bFytXrkSPHj3QtGlTPHjwAP/8849cnd999x18fHzQv39/fP7553BwcMCdO3fw0UcfwcrKCp9//vlr10kIIUT5pnjbvwhEHIpKpBAK1VMHBSIi8zqjOa9j/PjxFaY9ffoU9vb2OH36NDZv3ow9e/YgICAAUqkUDg4OGDhwIBYuXChr37p1a4SHh2PlypXw9/dHWloazM3NMXz4cKxYsQJNmzZFdnZ2fa4WIYSQWujX1gzmRiIUFBQiJi0P7axFaqmDAlEjFhgYWO3rv//+u0qXb29vD8ZY2XFU2dkwMjKqcByVSCTC4sWLa3V9IDs7O7nLB7xMKpXK/l/T2XOEEELqj4DPQ9BUT9y5ch5tzAzVVgddh4gQQgghauXYXB98NScSCkSEEEIIafQoEBFCCCGk0aNARAghhJBGjwIRIYQQQho9CkRKpAk3pyOqQe8tIYQ0bBSIlKD8AoHlV3omDU/5e0u3+CCEkIaJrkOkBAKBAHp6enj+/DmEQmGd7kkmlUpRXFyMwsJC5dzLTIXLUFWtmr4NpFIpnj9/Dj09PQgE9CNDCCENEf12VwKO42BhYYGnT58iJiamTvMyxlBQUABdXd0Kd3ZXFmUtQ1W1asM24PF4sLW1VVl9hBBC1IsCkZLo6OigdevWdd5tJpFIcOHCBfTs2RNCFd3ARVnLUFWt2rANdHR0VDZ6RQghRP0oECkRj8eDWCyu0zx8Ph8lJSUQi8UqCwPKWoaqatWmbUAIIaRhoq+8hBBCCGn0KBARQgghpNGjQEQIIYSQRo+OIaql8gvzZWdnK7VfiUSC/Px8ZGdnq/SAYmUsQ1W1atM20Jbl1kRT61KEJqyLJtRQF9pWrzI0xnXWJqp8f8r/btd0gV0KRLWUk5MDALCxsVFzJYQQQgipq5ycHBgbG1f5OsfongS1IpVKkZCQAENDQ6VeiyY7Oxs2NjaIi4uDkZGR0vpVxTJUVas2bQNtWW5NNLUuRWjCumhCDXWhbfUqQ2NcZ22iyveHMYacnBxYWlpWe/kUGiGqJR6PB2tra5X1b2RkpPIfUmUtQ1W1atM20Jbl1kRT61KEJqyLJtRQF9pWrzI0xnXWJqp6f6obGSpHB1UTQgghpNGjQEQIIYSQRo8CkZqJRCKsWLECIpFI45ehqlq1aRtoy3Jroql1KUIT1kUTaqgLbatXGRrjOmsTTXh/6KBqQgghhDR6NEJECCGEkEaPAhEhhBBCGj0KRIQQQghp9CgQEUIIIaTRo0BECCGEkEaPAlEjRicYknIN5bPQUNaDEFL/KBBpqPJf7Kr4BS+VSgEAHMdp9B8QVW4DdSrf/poiLS0NHMdpXF2KUOZ9Bl+Htn1mG8J7X1fa9h4R1aNApKEkEgkA1YSWbt26Yfny5bL+X8fhw4eRk5OjjLLkMMaQlZUFQLXBrbS0VCX9vio7OxupqanIycmp9uaC9W3EiBHo0qULsrOzNaquuvriiy9w5coVdZeB06dPA4BWBMznz5/j0aNHyMzMBI/HaxQBQSKRID8/H0VFRRr/hbAxq6/fy6/S3t+ADdTGjRsxdOhQDBkyBFOnTkVCQoJSv/VOnDgRV65cwYULF5CQkABA8W+Hfn5+WLt2LfT19eWmv+4vmQ0bNmDIkCEYMmQIPvroI5SWlir9m39ISAgAgM/nq/wP16ZNmzB8+HC8+eabcHd3x44dO5CYmKjSZdbGxx9/jL///hsAcOTIEQDq+0X0OhYuXIh169bB2dm5wmv1+Qfviy++QL9+/TBz5kwAZTeE1tTtuXnzZgwfPhy+vr7o3r07IiMjNWZ0TVV27dqFcePGwcfHBzNmzMDt27cb/Dprm99++w3R0dHg8/lgjNV/YGVEY6xevZqZm5uzTz75hC1YsIB5enqyJk2asL1797Li4uLX7n/ZsmXM3NycHT9+nDVv3px98sknr9VX8+bNWWxsrGxaSUmJrE6pVKpQvytXrmQ2Njbss88+YwsWLGBt27ZlFy5ckL2uaL8v27hxI2vSpAlbunQpy8vLU1q/ldm/fz8zNjZmP/74I/v111/ZJ598wng8Hnv77bdZRESESpZZG7t27WIikYhduXKFTZ48mbVu3Vopn7H6tnv3biYWi1lYWBhjjLHc3FyWkZHB4uLi6r2Wb775hnl5eTFHR0fm6enJUlJSZK+VlpbWez1VCQwMZEZGRiwwMJAdOHCA9e3b97V+F2iDoKAg1rRpU7Zu3Tq2aNEi5ufnx6ZOncoKCgpU9rNP6ubnn39mHMexTp06sX///Vc2vT5/digQaYjY2Fjm6OjIfvrpJ9m03Nxc9sEHHzA+n8/Wr1//Wv3v3buX6ejosIsXLzLGGNu0aRNzdHRkoaGhjLG6BYJDhw4xHR0d2Yf25MmT7KOPPmLdu3dn48aNY2fOnFGoxqNHj7LmzZuz8+fPM8YYKy4uZr169WK//fYbCwsLYzdu3FCo35ddvHiR2drasjfeeIN169aNzZw5Uy7UKfOXY1ZWFuvWrRv79ttvZdNSUlKYk5MT4/F4rGfPniwpKUnpy63JuXPnGI/HY4cPH2aMMRYTE8McHBzYsmXLWElJSb3V8bpCQ0MZj8djQUFBjLGy93bKlCnMzs6OtW7dms2dO1e2Xetj+/7666+sZ8+eLDIykrm7uzMrKyuWnJzMTp8+zbZt28YkEonKa6jJjRs3mJWVFTtw4IBs2rJly9j8+fPZjz/+yLZu3fraX2o0zb1795itrS3bv3+/bFpgYCBr0qQJi4qKUmNlpNzjx4+Zp6cnGzt2LHvrrbdYu3bt5N6v+vq9RIFIQ6SkpLCWLVuyc+fOMcbkU/G3337LeDwe27Ztm0J9x8TEsKZNm7Ldu3fLpt26dYvZ2tqyDz/8sE595efnM2dnZ9aiRQvGGGPnz59nFhYWbNKkSWz8+PFs5MiRTCQSscDAwDr3O2nSJLZkyRLZL+KSkhJmbm7OnJ2dmbOzM+PxeGzDhg116vdlJSUlbMWKFWzkyJHs/v37bOPGjax79+5s1KhR7OrVq7J2L/8heJ0/CoWFhczV1ZXt27ePMfbfezpt2jS2e/duZmdnx4YPH65w/4rWNGDAALZs2TJZTYWFhWzWrFnM1dWVpaWlydWqyZYvX844jmNHjhxh4eHhzNLSks2dO5etX7+ebd26lbVo0YL169ev3urJzc1lfn5+LDMzk0VHR7Nx48YxHR0dxnEcO3r0KGNM/SFj9+7dbPz48SwjI0M2rX379qx169ase/furEWLFszd3Z3l5uaqr0glkkqlLCgoiA0aNIglJibKfa7d3NzY8ePHZe3KacNnv6E5e/Ys8/X1ZeHh4ezatWvsnXfeYU5OTuyLL76QtamP94UCkYYoKSlh7dq1Y2PGjJGbVv6DumLFCubl5SUbUaiLx48fs5MnTzLG5H/wg4KCmL6+Pvv777/r1N+dO3dYhw4dmLW1NXNwcGAbN25kBQUFjDHGnj17xubMmcO8vb1ZcnJyrfuUSqXsxo0b7NatW7Jpffv2ZT169GC3b99m0dHR7Ouvv2bNmzd/rV1NGRkZcusbGBjI3nzzTdavXz/2119/yaaXB1NFnT59mpWUlDA/Pz/Wv39/Fh0dzRhjbM+ePYzjOJaamspOnDjB2rZty+Lj419rWXXx999/y420lX8e0tPTmb29PZs2bVq91fI6ykc6ly5dyjiOY0ZGRmzx4sWssLBQ1ubs2bPM1NSU/fHHHyqr49SpU0wqlTKJRMKKi4uZj4+P7IvLrVu3mK6uLuM47rVHeJXhzJkzrKCggN28eVM2bcGCBczNzY09efKE5efns6SkJGZmZib3h0ibBQcHs5MnT7LvvvtONq38D6uXlxf74YcfZNNv3brFMjMz673Gxu7s2bOMMSbbW8EYY1FRUWzp0qWsbdu2bPbs2bIRor///lulhxpQINIg+/btYx07dmSrVq2S/WCW/8H666+/mImJCXv48OFrL6e8z2fPnrHevXuz6dOn17mP9PR0NnLkSNazZ0+WmJgoF7R27tzJTExM6vyH/uVvACkpKey9996TOw7j3LlzzNLSUi401UVV386PHz/Ohg8fzrp378527drF/vjjD8ZxHLt06ZJCywkMDGTt27dnRUVF7MyZM6xXr17M3Nyc9erVi/H5fHbw4EHGGGNhYWFMV1eXXbt2TaHl1NWePXuYh4cHKyoqYoz9Nwxd/u/GjRuZs7OzbPtq6jflwMBA1rZtW1ndBw4cYJ06darwfj1+/JiZm5uz33//XWV1dOjQQbY9GWPsiy++YJ999hljjDFnZ2c2YsQI9vXXXzOBQMBGjx6tkjpqIzAwkLm5ucnVyljZrvSYmBjZ8/T0dObt7c22b99e3yUqXWBgIPP09GT5+fmyaaWlpbLfA3379mVLly5ljDH26NEjJhaL6zyyTV5PYGAgc3V1lTt+sfz3TnJyMtu0aRPr1KkTGzFihOz38suHICgbBSI1Ki4uZnl5ebJvtRkZGWz+/PnMw8ODffjhh+z+/fuytjdv3mRt2rSp83E0NR23sH//fsZxXK2+Rb+6H7ewsFAurZd/kP/44w/WvXv3WgeiV/t99biP8n4vX77MOnfuzG7fvl2rfqtbxsv9M8bYtWvX2LRp01i7du0Yx3Fs1apVdV7Gy/127dqVjR8/njHGWHh4ONuyZQvbuHGj7Pio8ukeHh7szp07Ci+rrnV5e3uzUaNGVXoA9fPnz5mjo6PcKKUmKl+P4cOHy352kpOTZaOU5R4/fszc3d3ZqVOnVFrH6NGjZdvz0qVLbOjQoczd3Z116tSJZWRksJKSEnbo0CG2YsUKldShaK2VSUpKYp6enrLjy7SZVCplXbp0YW+99Val6zxnzhy2YMECxhhjrVq1YpMnT67vEhu9mn4n5efnsx9//JF17dqVcRzHZs2apdJ6KBCpyc6dO9moUaNYhw4d2MSJE9n169cZY2V//JcvX868vb1Z586d2dq1a9nmzZuZi4uL7A9sbRw5ckS2m0YqlVYYHXn5+cSJE1nPnj2r3MVVU18vy8jIYJ06dWJz5sxRao3p6enM3d2dvfPOOzX2q+gyyg/SnT17dp2W8bLy4HXjxg3m5+dXadCUSqUsIyOD+fr6sgEDBii8LEXrGjp0KDty5Ijc9PLQ+eeffzJjY2OVhYjX9ep6/PLLL5W2y8rKYgMGDGD9+/evlzp+/fVXxljZUH+bNm2Yq6sre/Dggay9so5LU0at5e/9q1+WsrKyWP/+/dmbb75Zr/WpQlXr/PKo5+rVq9m4ceOYr68v8/Lykk1X93FejUVNv5PK34fU1FRmZ2fH/Pz8ZPOq6j2iQKQGr54COnjwYDZ16lSWk5Mja3P06FG2aNEiZmFhwd588025P9I1fRjqevriDz/8UOXBvXXp68yZM6xPnz6sW7duNdZal37Pnz/PfH19Wffu3WvsV9Fl5OTksN69eyvtF2NhYSFbsGAB69atW4XQER4ezvr27ctcXV0r/PCrWnld3bt3r3TZ0dHRbNq0aRq7u6xcZetR7ty5c2zIkCHMxcVF5dv35TrKt1loaKhSzohUture+wsXLrBRo0ap5TOpSpWtc/n7tGnTJsZxHGvdunWDWmdtU93nUiKRsIULFzJbW9t6eY8oENWzup4CWlRUJPcLv6Y/VIqevlje78sftrr0lZCQwL788ks2adIk2a6LqmqtS7+JiYns66+/ZjNnzqyx39fZDkVFRWzu3Lmy4w3qEgiKi4sr3QfOGGM+Pj5s0qRJFY7dOHLkCEtMTKy0FmWpa11V7apUt7qsR1FRETt+/DhbtmyZbJetsrZvTXVMmDChwm47danrNjt16hT7/PPPWUJCAmOs/k5zVqa6ft4vX77M+vbty549e8YY08511jaK/K785Zdf6u09okBUj6o7BbRDhw7sxIkTjDH5N72uH4CXT1+MiIio8fTFyoKQon2lp6fLLnRY3R/TuvabmZlZ56BS12W8rK7bfMqUKeyXX36R+2NY/kN/7tw5Nnz4cNkuqFd/2FUZOupSlyb/MajLejBW9lkuP7ZImdtXm7anItus/LOpKUG4ruqyzuVnBpaftaut66xt6vIevXpMEZ1238DUdArojh07ZNNv3bold62Q2qjp9MVZs2bJnb4YHh6ulL6OHj0qdx0fZdVYl34VXUZN26EmY8eOZRzHMRMTE/b999+zrKwsudcLCgrY1KlTWY8ePWTT6uMHW5G6NHF3gSLroSl1qGt7aso2q0+NcZ21jab+rnwZBaJ6oupTQJV5+qIifX3zzTf/b+/+Y6oq/ziAvy9w4RIQKjAZagx3hSAp5hx1o7j4B4O5CtsydLjphpUKjFGoWf2hbbYFlRQmuQkMB3PUqq3RstoUUhGYiraEi0FLaYkrYcUPxfvj8/3DL2fciQl6z+Vczvu13Y17znOe5/Oc8wefPed8zlUlxun0q9Z5uJdjx47Jk08+Kc3NzbJz504xGAzy1ltv3fGuKKfTKRaLRV577bU7VojUoNW4Zkor89BKHHMtVk/R45x9ja9cIyZEXqJ2CagnyxfVKoX0RomlN8s4bTablJeXK88C1dTUiJ+fn+Tl5bm9L2p8fFw+//xzWbt2rbS3t9/3eL4e10xpZR5aiWOuxeopepyzr/GVa8SEyAvULgH1ZPmiWqWQ3iixnI0yzomfOJg4vrW1VebNmyfPPvusnDlzRoaHh6WwsFB27dola9eu9dq7aLQa10xpZR5aiWOuxeopepyzr/GFa8SEyIvULgH1ZPmiWqWQ3iixnI0yTpfLpVzLgYEBSUxMlPj4eMnJyRF/f3/lVunEO5G8RatxzZRW5qGVOKbDl2L1FD3O2ddo+RoxIVKJ2iWgnixfVKsU0hslllor45z8srtly5aJwWCQ1tZWj45xP7Qa10xpZR5aiWM6fClWT9HjnH2NFq8REyKVqF0C6snyRbVKIb1RYqnFMk6XyyXHjh0Tg8GgvPtIC2W9Wo1rprQyD63EMR2+FKun6HHOvkZr14gJkQrULgH1ZPmiWqWQ3iix1GoZp91ul+LiYiksLFR9rJnQalwzpZV5aCWO6fClWD1Fj3P2NVq7RkyIPEzt8kJP9q9WrN4osdR6Gefkn2HR0vt9tBrXTGllHlqJYzp8KVZP0eOcfY2WrhETIg9Tu7zQk/2rFas3Six9pYyTiIh8g0FEBORRo6OjCAkJgYjAYDDg9OnTWL16NZKTk7Fv3z4kJCRg165dCAsLQ29vL5KSkrB79+5Z6V+tWNU+B94ag4iI9IEJkYrk9goc/Pz8cO3aNaxatQpOpxOJiYloamrC8PAwgoODcfnyZcTGxs5q/2rFqvY58NYYREQ0tzEh8gKHw4GAgAAAQHx8PHp7e3Hq1ClYLBbN9a9WrGqfA2+NQUREc5PfbAegBwEBARARHD9+HL29vaivr4fFYoHL5dJc/2rFqvY58NYYREQ0N3GFyEscDgdKS0vhdDpRWVmp6f7VilXtc+CtMYiIaO5hQuRFIyMjCA0NBQDlQWCt9q9WrGqfA2+NQUREcwsTIiIiItI9PkNEREREuseEiIiIiHSPCRERERHpHhMiIiIi0j0mRERERKR7TIiIiIhI95gQERERke4xISIij2htbYW/vz+ys7On3D8wMIDi4mKYzWaYTCYsXLgQzzzzDD777DOMjY25te3v70d+fj5iYmIQGBiI2NhYFBcX4/r1627tNm3aBIPBAIPBAKPRiKVLl6K0tBSjo6OqzZOI5qaA2Q6AiOaGmpoaFBUV4dChQ7hy5QoeeeQRZd9vv/2GtLQ0zJs3D++99x6Sk5PhcDhw6dIl1NTUICYmBi+88ILS1mKxID4+HkeOHEFcXBwuXryI7du347vvvkNbWxsWLFig9J2dnY3a2lrY7XacOHECmzdvxujoKKqqqrx+Djzl1q1bCAwMnO0wiPRFiIge0MjIiISFhYnNZpPc3FzZs2eP2/6srCxZvHixjIyMTHm8y+VS/s7OzpbFixfL2NiYW5urV6/KQw89JFu2bFG2bdy4UXJyctzabd68WaKjo6ccx2q1SkFBgRQUFEh4eLgsWLBA3n77bbfxb968KUVFRRIVFSVBQUGSlpYmHR0dyv5vvvlGwsPDxel0iohIZ2enAJDS0lKlzauvvirr1q1T5vb+++9LXFycmEwmefzxx+WLL76YMq6SkhKJiIiQ9PT0KeMXEWlvbxer1Somk0kSEhKko6NDDh48KM8///xdjyGie+MtMyJ6YI2NjUhISEBCQgI2bNiA2tpayP9/Fej69ev44YcfUFBQgJCQkCmPn/i9ucHBQXz//ffYtm0bgoOD3dpER0cjLy8PjY2NSt9TCQ4Oht1uv+v+uro6BAQEoL29HZ988gn27duHQ4cOKft37NiBL7/8EnV1dTh37hzMZjOysrIwODgIAEhPT8fw8DA6OzsBAC0tLYiMjERLS4vSR3NzM6xWKwDgnXfeQW1tLaqqqnDx4kWUlJRgw4YNbu0nx3Xq1CkcPHhwytjb2tpgtVqRnZ2Nn3/+GUlJSdi9ezfKy8uxZ8+eu86ZiKZhtjMyIvJ9Tz/9tFRUVIiIiN1ul8jISPnxxx9FRKStrU0AyFdffeV2TEREhISEhEhISIjs2LHDre3XX3895TgfffSRAJBr166JyJ0rRO3t7RIRESEvv/zylMdbrVZJTEx0WxHauXOnJCYmisjtlS6j0SgNDQ3K/lu3bklMTIyUlZUp21asWCEffPCBiIisWbNG9u7dK4GBgfLvv//K1atXBYB0d3fLyMiImEwmaW1tdYsjPz9f1q9f7xZXSkrKlDFPZrFYJC8vT/ne2Ngofn5+8uKLL97zWCL6b1whIqIH0tPTg46ODqxbtw4AEBAQgNzcXNTU1Li1m1gFmtDR0YHz58/jsccew/j4+LTGkv+vDE3uq6mpCaGhoTCZTLBYLEhPT0dlZeVd+3jqqafcjrdYLPj111/hdDrR19cHu92OtLQ0Zb/RaERqaiq6u7uVbRkZGWhuboaI4MSJE8jJycHy5ctx8uRJHD9+HAsXLsSjjz6Krq4u3Lx5E5mZmQgNDVU+hw8fRl9fn1tcK1eu/M+5//HHHzh9+jS2bt2qbAsMDISIcHWIyAP4UDURPZDq6mo4HA4sWrRI2SYiMBqNGBoagtlshsFggM1mcztu6dKlAOB2a2yibVdXF9asWXPHWDabDfPnz0dkZKSybdWqVaiqqoLRaERMTAyMRuN9z2WqhGti++RtGRkZqK6uxoULF+Dn54ekpCRYrVa0tLRgaGhIuV3mcrkAAN9++63b+QGAoKAgt+93u504YSIhm5w49fT0IDU1FcnJyTOZJhFNgStERHTfHA4HDh8+jA8//BDnz59XPhcuXEBsbCwaGhoQERGBzMxM7N+//57l8BNtDxw4gBs3brjtGxgYQENDA3Jzc92Sk5CQEJjNZsTGxk4rGWpra7vj+7Jly+Dv7w+z2YzAwECcPHlS2W+323HmzBkkJiYq2yaeI6qoqIDVaoXBYIDVakVzc7Pb80NJSUkICgrClStXYDab3T5Lliy5Z6yT/fPPP/D391e+Dw4Ooqys7I7EiojuDxMiIrpvTU1NGBoaQn5+PpYvX+72eemll1BdXQ0AOHDgABwOB1auXInGxkZ0d3ejp6cH9fX1sNlsbv/o9+/fj/HxcWRlZeGnn35Cf38/jh49iszMTCxatAh79+59oJj7+/vx+uuvo6enB0eOHEFlZSWKi4sB3E6utm7diu3bt+Po0aPo6urCK6+8grGxMeTn5yt9hIeHIyUlBfX19cjIyABwO0k6d+4cLl26pGwLCwtDaWkpSkpKUFdXh76+PnR2duLTTz9FXV3djOJOSUmB0+lEWVkZbDYb1q9fj9jYWHR3d+Py5csPdE6ICHyomoju33PPPSerV6+ect/Zs2cFgJw9e1ZERP78808pLCyUuLg4MRqNEhoaKqmpqVJeXi6jo6Nux/7++++yadMmiY6OFqPRKEuWLJGioiL5+++/3dpNVXb/X6xWq2zbtk22bNkiDz/8sMyfP1/efPNNt4esb9y4IUVFRRIZGTll2f2EN954QwDIL7/8omx74oknJCoqyq0/l8slH3/8sSQkJIjRaJSoqCjJysqSlpYWt7iKi4vvGf+7774rERERYjKZZOPGjfLXX3/JihUrxGw2T/scENHUDCL/Ub9KRDSHZGRkICUlBRUVFbMdChFpDG+ZERERke4xISIiIiLd4y0zIiIi0j2uEBEREZHuMSEiIiIi3WNCRERERLrHhIiIiIh0jwkRERER6R4TIiIiItI9JkRERESke0yIiIiISPeYEBEREZHuMSEiIiIi3WNCRERERLr3P4Np27UhqKmEAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.log(pows), agop_sims, label='M = AGOP')\n",
    "plt.plot(np.log(pows), lgop_sims, label='M = LGOP')\n",
    "plt.xticks(np.log(pows), [f'1/{x}' for x in n_layers], rotation=50)\n",
    "plt.ylabel(r'cos_sim(nfm, $M^{\\alpha})$')\n",
    "plt.xlabel(r'AGOP power $\\alpha$')\n",
    "plt.title(f'{n_h_layers} hidden layers == {n_h_layers+1} weight matrices')\n",
    "plt.grid()\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "badd1f79-e6dd-4041-ba75-ecd6e793ab79",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:.conda-torch_and_jax_conda]",
   "language": "python",
   "name": "conda-env-.conda-torch_and_jax_conda-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
