{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "from implicit_regularization_resnets_nodes.resnet import *\n",
    "depth = 256\n",
    "lr = 4e-2\n",
    "formatted_lr = \"{:.0e}\".format(lr)\n",
    "use_bn = True\n",
    "smooth_init = True\n",
    "adaptive = False\n",
    "planes = 16\n",
    "seed = 0\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Select the non linearity: can be either 'Gelu' or 'ReLU'\n",
    "non_lin = 'gelu'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "net = iTinyResnet(\n",
    "    depth,\n",
    "    in_planes=planes,\n",
    "    use_bn=use_bn,\n",
    "    non_lin=non_lin, \n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "we initialize the inner weights smoothly\n"
     ]
    }
   ],
   "source": [
    "if smooth_init:\n",
    "    print(\"we initialize the inner weights smoothly\")\n",
    "    state_dict = net.state_dict()\n",
    "    modules = ['conv1', 'conv2', 'bn1', 'bn2'] if use_bn else ['conv1', 'conv2']\n",
    "    for i in range(1, depth):\n",
    "        for n in modules:\n",
    "            for m in ['weight', 'bias']:\n",
    "                state_dict['residual_layers.%d.%s.%s'%(i, n, m)] = state_dict['residual_layers.0.%s.%s'%(n, m)]\n",
    "    net.load_state_dict(state_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==> Resuming from checkpoint..\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load checkpoint.\n",
    "print(\"==> Resuming from checkpoint..\")\n",
    "checkpoint_name = \"./checkpoint/ckpt_lr_%s_depth_%s_seed_%s_use_bn_%s_smooth_init_%s_adaptive_%s_non_lin_%s.pth\" % (formatted_lr, depth, seed, use_bn, smooth_init, adaptive, non_lin)\n",
    "\n",
    "checkpoint = torch.load(checkpoint_name, map_location=torch.device('cpu')\n",
    ")\n",
    "\n",
    "net.load_state_dict(checkpoint[\"net\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(81.28, 82.204)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max(checkpoint['log_dict']['test_acc']), max(checkpoint['log_dict']['train_acc'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# not a clean way to gather all the convolution matrices\n",
    "\n",
    "conv1_flatten = []\n",
    "for i in range(depth):\n",
    "    conv1_flatten.append(net.state_dict()['residual_layers.%d.conv1.weight'%i].flatten().numpy())\n",
    "conv1_flatten = np.array(conv1_flatten)\n",
    "\n",
    "conv2_flatten = []\n",
    "for i in range(depth):\n",
    "    conv2_flatten.append(net.state_dict()['residual_layers.%d.conv2.weight'%i].flatten().numpy())\n",
    "conv2_flatten = np.array(conv2_flatten)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Let's display the smoothness of the convolution at random indices across depth"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj8AAAE7CAYAAAAy1eC8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACEFElEQVR4nO3deXxU1fn48c/sk2Qy2VcI+xL2HURxBQFxQ6lb/boitlbqgtJKa23tIrW1Vqv8SvXrUlupfrVqqyASEUQBUUB2iGxJIPs+SSaz398fNzPJkJ1MFpLn/XrlBblz750zJ5PkyXOec45GURQFIYQQQog+QtvdDRBCCCGE6EoS/AghhBCiT5HgRwghhBB9igQ/QgghhOhTJPgRQgghRJ8iwY8QQggh+hQJfoQQQgjRp0jwI4QQQog+Rd/dDegrfD4feXl5REZGotFours5QgghRK+iKApVVVWkpqai1bac25Hgp4vk5eWRlpbW3c0QQggherVTp07Rv3//Fs+R4KeLREZGAuoXxWq1huSebrebDRs2MHfuXAwGQ0ju2ddJn4aW9GfoSZ+GlvRn6HVXn9psNtLS0gK/b1siwU8X8Q91Wa3WkAY/4eHhWK1W+aYNEenT0JL+DD3p09CS/gy97u7TtpSWSMGzEEIIIfoUCX6EEEII0adI8COEEEKIPkVqfoQQQogu5vP5cLlc3d2MTuF2u9Hr9TgcDrxeb8juazAY0Ol0IbmXBD9CCCFEF3K5XJw8eRKfz9fdTekUiqKQnJzMqVOnQr6uXXR0NMnJyR2+rwQ/QgghRBdRFIX8/Hx0Oh1paWmtLsZ3LvL5fFRXV2OxWEL2+hRFwW63U1RUBEBKSkqH7ifBjxBCCNFFPB4Pdrud1NRUwsPDu7s5ncI/pGc2m0Ma3IWFhQFQVFREYmJih4bAel/I2Ud53F42vHKQzB0F3d0UIYQQzfDXwBiNxm5uybnJHzC63e4O3UeCn16i8ISNo98Usmt9dnc3RQghRCtkj8ezE6p+k+Cnl/C41cI5V62nm1sihBBC9GwS/PQSPm9d8OOQ4EcIIYRoiQQ/vYTPqwDgdnhRfEo3t0YIIURv9IMf/IBbb721u5vRYRL89BL+4AfA7QrdolJCCCGE38qVK3nppZdCcq8tW7Zw9dVXk5qaikaj4YMPPgjJfdtCgp9ewuutXyzLVSvBjxBCiNCLjY0lIiIiJPeqqalhwoQJrFq1KiT3aw9Z56eXCMr8OD2AqfsaI4QQotfJyspi8ODBnDx5kkGDBnX4fldccQVXXHFFxxt2Fnpl5mfVqlUMGjQIs9nMjBkz+Prrr1s8/5133iE9PR2z2cy4ceNYt25do3MOHz7MNddcQ1RUFBEREUybNo2cnJzOegnt1jD4kcyPEEKcGxRFwe5xdcuHorSvPnTv3r1ER0c3CnyeeuopLBZL4MNqtdK/f3+sVmvgWE/6fQm9MPPz9ttvs2zZMlavXs2MGTN47rnnmDdvHpmZmSQmJjY6f9u2bdxyyy2sXLmSq666ijVr1rBw4UJ2797N2LFjATh+/DizZs1i8eLFPPnkk1itVg4ePIjZbO7ql9csX8NhL5nxJYQQ54Rar5tx//5jtzz3/kXLCde3fbHFPXv2MH78+EbHf/jDH3LjjTcGPm9qe4vU1NSONziEel3w8+yzz7JkyRLuuusuAFavXs3atWt59dVXeeyxxxqd//zzzzN//nyWL18OwG9+8xsyMjJ48cUXWb16NQA///nPWbBgAX/4wx8C1w0dOrQLXk3beT0Nhr0ckvkRQggRWnv37mXixImNjsfGxhIbGxv43OfzYbPZsFqtPXbvsl4V/LhcLnbt2sWKFSsCx7RaLXPmzGH79u1NXrN9+3aWLVsWdGzevHmBqnOfz8fatWv5yU9+wrx58/j2228ZPHgwK1asYOHChc22xel04nQ6A5/bbDZAXZK7o8ty+/nv43a78bjqsz21Nc6QPUdf07BPRcdJf4ae9GlodXV/ut1uFEXB5/Ph8/kwaXTsve6RLnnuM5k0unbtLL9nzx4WLFjQ6JqVK1eycuXKFq89cOAAAwYMaPEcf5+0do6iKLjd7kZ7e7Xna9irgp+SkhK8Xi9JSUlBx5OSkjhy5EiT1xQUFDR5fkGBukdWUVER1dXV/P73v+e3v/0tTz/9NOvXr+f6669n06ZNXHzxxU3ed+XKlTz55JONjm/YsCHkm9llZGRgO2bEX+S8Z9c+jpXKD8aOyMjI6O4m9CrSn6EnfRpaXdWfer2e5ORkqqurcblcXfKczanC0eZzbTYbWVlZDB8+PPDHvN/3v//9VguXLRZLo+vOVFtb2+o5LpeL2tpatmzZgscTXOJht9tbvLahXhX8dAZ/FHrttdfy8MMPAzBx4kS2bdvG6tWrmw1+VqxYEZRRstlspKWlMXfuXKxWa0ja5na7ycjI4PLLL2evksvuo6cAGD50JJPmtRxhi6Y17FODwdDdzTnnSX+GnvRpaHV1fzocDk6dOoXFYulRdaOt2bt3LzqdjunTp2MyBc8mtlqtDBw4MPC5oihUVVURGRnZ4l5c1dXVHDt2LPB5YWEhJ06cIDY2ttkskcPhICwsjIsuuqhR/7UWODXUq4Kf+Ph4dDodhYWFQccLCwtJTk5u8prk5OQWz4+Pj0ev1zN69Oigc0aNGsWXX37ZbFtMJlOjNwiAwWAI+TeYwWAApf4N5nUr8kOxgzrj69SXSX+GnvRpaHVVf3q9XjQaDVqttsfWwzRl//79pKenExYW1uq5/qSB/3U2Z/fu3Vx66aWBzx95RB3+u+OOO3j99debvEar1aLRaJr8erXn63fu9HwbGI1GpkyZwsaNGwPHfD4fGzduZObMmU1eM3PmzKDzQU1/+s83Go1MmzaNzMzMoHO+++67oEi3u3kbTnWXgmchhBAhtHTpUvbv3x/Se15yySUoitLoo7nAJ5R6VeYHYNmyZdxxxx1MnTqV6dOn89xzz1FTUxOY/XX77bfTr1+/QHHWgw8+yMUXX8yf/vQnrrzySt566y127twZtHz38uXLuemmm7jooou49NJLWb9+PR9++CGbN2/ujpfYpKB1fmSquxBCCNGsXhf83HTTTRQXF/PEE09QUFDAxIkTWb9+faCoOScnJygNd/7557NmzRoef/xxfvaznzF8+HA++OCDwBo/ANdddx2rV69m5cqVPPDAA4wcOZJ///vfzJo1q8tfX3N8HtneQgghhGiLXhf8gJqeW7p0aZOPNZWtueGGG7jhhhtavOfdd9/N3XffHYrmdYrG21sIIYQQoim9quanL5PtLYQQQoi2keCnl5DtLYQQQoi2keCnl2g420u2txBCCCGaJ8FPLyGzvYQQQoi2keCnl2g47OVx+YI+F0IIIUQ9CX56iYaZHwC3U4a+hBBCiKZI8NNLeD3BmR5Z5VkIIUSo/eAHP+DWW2/t7mZ0mAQ/vcSZmR+p+xFCCBFqK1euDNoBoaP3mjZtGpGRkSQmJrJw4cJGW0l1Fgl+eolGw16S+RFCCBFisbGxREREhORen3/+Offffz9fffUVGRkZuN1u5s6dS01NTUju35JeucJzX9Qo81MrmR8hhBChk5WVxeDBgzl58iSDBg3q8P3Wr18f9Pnrr79OYmIiu3bt4qKLLurw/VsimZ9eIjC7S6P+IzU/QgghQmnv3r1ER0c3CnyeeuopLBZL4MNqtdK/f3+sVmvgWE5OTqv3r6ysBNTsUmeTzE8v4V/k0BSmx2n3SM2PEEKcAxRFwePqnqVJ9EYtGo2mzefv2bOH8ePHNzr+wx/+kBtvvDHwuc/no7q6GovFEthIPDU1tcV7+3w+HnroIS644IKgjcU7iwQ/vYQ/82OOMOC0e6TmRwghzgEel4+XHvy8W5773ucvxmDStfn8vXv3MnHixEbHY2Njg7I1Pp8Pm82G1WoNBD+tuf/++zlw4ABffvllm9vTETLs1Uv4PGrmx2wxADLbSwghRGjt2bOHCRMmNDre0WGvpUuX8tFHH7Fp0yb69+/fmS8hQDI/vYS/4NkUrn5JZZFDIYTo+fRGLfc+f3G3PXdb2Ww2srKymsz8nO2wl6Io/PjHP+b9999n8+bNDB48uP0v4ixJ8NNL+Ie9jGb1S+pxy/YWQgjR02k0mnYNPXWXvXv3otPpGDNmTKPHznbY6/7772fNmjX85z//ITIykoKCAgCioqIICwsL/YtoQIa9egl/5sdYl/nxuCTzI4QQIjT27t1Leno6JpMpZPf861//SmVlJZdccgkpKSmBj7fffjtkz9Ecyfz0EoHZXv7MTzfNHhBCCNH7LF26lKVLl4b0noqitH5SJ5HMTy+gKAqKry7zE6amTyXzI4QQQjRNgp9eoOHqzsYwqfkRQgghWiLBTy/QZPAjmR8hhBCiSRL89AKBrS1oMNtLan6EEEKIJknw0wtI5kcIIYRoOwl+egF/8KPVagKLVknNjxBC9FzdOdPpXBaqfpPgpxcIBD96DXqDzPYSQoieSqdTf0a7XK5ubsm5yW63A2AwGDp0n14Z/KxatYpBgwZhNpuZMWMGX3/9dYvnv/POO6Snp2M2mxk3bhzr1q1r9twf/vCHaDQannvuuRC3+ux562p+tDqtZH6EEKIH0+v1hIeHU1xcjN1ux+Fw9MoPl8sV0vvV1tZSWlpKUVER0dHRgSDyrL8OIfp69hhvv/02y5YtY/Xq1cyYMYPnnnuOefPmkZmZSWJiYqPzt23bxi233MLKlSu56qqrWLNmDQsXLmT37t2MHTs26Nz333+fr776qsk9SrpTIPOj02Aw+jM/PhRFQaPRdGfThBBCNKDRaEhJSeHkyZNkZ2d3d3M6haIo1NbWEhYWFvLfQdHR0SQnJ3f4Pr0u+Hn22WdZsmQJd911FwCrV69m7dq1vPrqqzz22GONzn/++eeZP38+y5cvB+A3v/kNGRkZvPjii6xevTpwXm5uLj/+8Y/55JNPuPLKK7vmxbRRw+BHZ1AzP4pPwedV0Okl+BFCiJ7EaDQyfPjwXjv05Xa72bJlCxdddFGHh6caMhgMHc74+PWq4MflcrFr1y5WrFgROKbVapkzZw7bt29v8prt27ezbNmyoGPz5s3jgw8+CHzu8/m47bbbWL58eZObunU3n0cNfnQ6bSDzA+rQl07fK0c2hRDinKbVajGbzd3djE6h0+nweDyYzeaQBj+h1KuCn5KSErxeL0lJSUHHk5KSOHLkSJPXFBQUNHm+f3dZgKeffhq9Xs8DDzzQ5rY4nU6cTmfgc5vNBqgRsdvtbvN9WuK/j8ul/qvRgVfxgAZQwFHjRKuXGQXt4e/TUH2N+jrpz9CTPg0t6c/Q664+bc/z9argpzPs2rWL559/nt27d7dr7HLlypU8+eSTjY5v2LCB8PDwUDaRr3d8A4Rjt9fw8ccfo9FaULwaPs3YiD5cgp+zkZGR0d1N6FWkP0NP+jS0pD9Dr6v71D8TrC16VfATHx+PTqejsLAw6HhhYWGzBVLJycktnv/FF19QVFTEgAEDAo97vV4eeeQRnnvuObKyspq874oVK4KG02w2G2lpacydOxer1Xo2L68Rt9tNRkYGkydNZsPXR7BGWVmw4BLe+OIrHNVuZp1/EbGpESF5rr7C36eXX355j03XnkukP0NP+jS0pD9Dr7v61D/C0ha9KvgxGo1MmTKFjRs3snDhQkCt19m4cSNLly5t8pqZM2eyceNGHnroocCxjIwMZs6cCcBtt93GnDlzgq6ZN28et912W6CouikmkwmTydTouMFgCPmbQYta56M3aDEYDIHp7vi08s18ljrj69SXSX+GnvRpaEl/hl5X92l7nqtXBT8Ay5Yt44477mDq1KlMnz6d5557jpqamkCgcvvtt9OvXz9WrlwJwIMPPsjFF1/Mn/70J6688kreeustdu7cyUsvvQRAXFwccXFxQc9hMBhITk5m5MiRXfvimuELrPOjDssFpru7ZaFDIYQQ4ky9Lvi56aabKC4u5oknnqCgoICJEyeyfv36QFFzTk4OWm39DKjzzz+fNWvW8Pjjj/Ozn/2M4cOH88EHHzRa46cn8/n8U93V1+Wf7i6bmwohhBCN9brgB2Dp0qXNDnNt3ry50bEbbriBG264oc33b67Op7s0XOcHJPMjhBBCtKRTFoE5efJko2PNrbMjOs7rCc78BLa4kMyPEEII0UinBD833nhjUHbkk08+4Uc/+lFnPJWgcc2PTjY3FUIIIZrVKcHPa6+9xg033EBWVhZvv/02TzzxBJ988klnPJWgfthLFxj2ksyPEEII0ZxOqfkZO3Ysr776KldddRUJCQl8+umnREZGdsZTCRoWPKvBj15qfoQQQohmhTT4mTZtWtAqyOXl5QDMnj0bgK+//jqUTyfq+Pf20tbt46WX2V5CCCFEs0Ia/Lz77ruhvJ1oozNrfgKZH6n5EUIIIRoJafAzcODAUN5OtFH9VPe6dX6k5kcIIYRoVkgKnt9+++1Q3EacpTNrfmSdHyGEEKJ5IQl+li9f3uLj+fn5OJ3OUDyVaIJ/nR9dYNhLMj9CCCFEc0IS/CiK0uLjt912G+np6Tz66KOheDpxhvqaH3/Bs9T8dLbthVmsP3Wk1fe+EEKInickNT8NZ3g15dNPPwXgyJEjoXg6cYYzt7cIZH7ckvnpDJ/lHeUHX76DT1H43uDx/GbKAow6XXc3SwghRBu1OfhJSEhoMshRFIWKigpAzfD84x//aDTl3U+muneOwCKH+rrgRzI/neZweSEPbn8fX13G592T+/AqCs/MuKabWyaEEKKt2hz8FBcXt3rOH/7wB0CmvHe1M2d7Sean8zy191PsHjcXJA3m1mGT+dHWf/Pf7AM8Ou4SksOt3d08IYQQbRDSqe4pKSmATHnvas2v89Nzg58yp527Pv8XVw8Ywz3p53V3c9qkwG5je2EWAL+buoA0SzRT49PYWXKKd0/uY+mYWd3bQCGEEG3SoYLne+65h82bN4eoKeJsNVvz04OHvT7PP86B8gKe2b+J0zUV3d2cNvko5xAKMCW+P2mWaABuHjoJgP87sScwFCaEEKJn61DwU1xczPz580lLS2P58uXs3bs3VO0S7dBo2MvQ8zM/+XYbAG6fj1WHtnZza9rmP9kHAFg4cGzg2BX907EazOTaK/mi4ER3NU0IIUQ7dCj4+c9//kN+fj6/+MUv+Oabb5g8eTJjxozhqaeeIisrK0RNFK05FzM/efbKwP//fXIv2dXl3dia1n1XWcyhikIMWi1XpI0KHDfrDVxbFwytzTnUXc0TQgjRDh1e5ycmJoZ7772XzZs3k52dzZ133sk//vEPhg0bFor2iTbw1/zoGu3q7uux69Dk1WV+9BotXkVhXQ8PHDblHQVgVtIQYkzhQY/NT0sH1CnwHl/PzbYJIYRQhWSRQwC3283OnTvZsWMHWVlZJCUlherWohXNzfYC8PbQGV/+Ya8JcakA5PTwzM/2omwALkge3OixqfFpRBvDKHfVsrvkdFc3TQghRDt1OPjZtGkTS5YsISkpiTvvvBOr1cpHH33E6dPyS6CreP3BT2Cdn/ova0+t+/FnfqYnDADgdINhsJ7G5fWyq+QUADMTG89k1Gu1XJqqZjozcjO7tG1CCCHar0PBT79+/ViwYAElJSW89NJLFBYW8uqrrzJ79uxWV30WoXNm5ker0wbqf3ri5qZVLgfVbnWvt2n+4Ke6ohtb1LJ9ZXnYPW5ijGGMiEps8pzL+40A4NPc73rsUKMQQghVh9b5+dWvfsUNN9xAdHR0iJojzsaZ6/yAmv1xeb09MvPjz/pEG8MYHpUQOOb1+dBpQzYSGzJf1Q15zUgciLaZoH5W0hCMWh05NRVkVhaRHi3DvkII0VN1KPhZsmQJGzduZOPGjRQVFeE7o9jz1Vdf7VDjRNucOdsL1KJnl8OLuwfO+PIHP6nhVpLMFgxaLW6fj8LaKlIjorq5dY35g5/zmhjy8oswGLk4ZSgZud/xUc4hCX6EEKIH69Cf2U8++SRz585l48aNlJSUUF5eHvQhukZgby9d/ZfTYFZnfLlqPd3SppbkNwh+dFotqeFqwHOqBy526PJ62V2q1q/NTBrU4rlXDRgDqFPeZehLCCF6rg5lflavXs3rr7/ObbfdFqr2iLPQVOYnzGKgsqgWR427u5rVLP8aPyl1e2H1j4gmu7qc0zWVzOjOhjXhdE0FTq+HMJ2BoZFxLZ57WeowwnQGcmoq2F+ez/jY1C5qpRBCiPboUObH5XJx/vnnh6otIbNq1SoGDRqE2WxmxowZre4m/84775Ceno7ZbGbcuHGsW7cu8Jjb7eanP/0p48aNIyIigtTUVG6//Xby8vI6+2W0WVM1P2aLEQBHdc8LfvyZn5S6jE//uqGunrjNRXZ1GQADLTGtFvGH641cljocULfCEEII0TN1eG+vNWvWhKotIfH222+zbNkyfvnLX7J7924mTJjAvHnzKCoqavL8bdu2ccstt7B48WK+/fZbFi5cyMKFCzlwQN3KwG63s3v3bn7xi1+we/du3nvvPTIzM7nmmmu68mW16MzZXgBmiwGgR2Z+AsNeEfWZH+iZw15ZdesPDYqMbdP5Vw0YDcC/T+6juLYaUDdxfXb/Zv64bxMHyvI7pZ1CCCHarkPDXg6Hg5deeolPP/2U8ePHYzAYgh5/9tlnO9S4s/Hss8+yZMkS7rrrLkAdmlu7di2vvvoqjz32WKPzn3/+eebPn8/y5csB+M1vfkNGRgYvvvgiq1evJioqioyMjKBrXnzxRaZPn05OTg4DBgzo/BfVikDNj75B5idC/VrUtjPzU13uJDzKiFbbeUsV+AueU8KCg5/cmp631k92lRr8DLTEtOn8S1OHMSY6iYMVhTz2zUdckDSY/3doK+WuWgBWH97GHcOn8YtJl8tyEEII0U06lPnZt28fEydORKvVcuDAAb799tvAx549e0LUxLZzuVzs2rWLOXPmBI5ptVrmzJnD9u3bm7xm+/btQecDzJs3r9nzASorK9FoND1mir/X4x/2qv9yhvkzP+0IfgpOVPL3FVvZ8q/OW6hPURQKausLngHSenDmp+GwV1sYtDr+OOMajFodm/OP87s9n1LuqiU9KpEr+qejAf5+9Bte/a7loVghhBCdp0OZn02bNoWqHSFRUlKC1+tttLVGUlISR44cafKagoKCJs8vKCho8nyHw8FPf/pTbrnlFqxWa7NtcTqdOJ3OwOc2W90u5m43bndohqLcbjeKr34VZ61BCdzbEKYGQnabs83Pl32wBFCDoFC18Ux2jwt33ZIIEVo9brebpLq9sgrsNmqcDoxaXac8d1v4X7f/3+wqNfjpF2Ztc58MiYjh0bGX8NS+jYyKSuSmwRNZNGgcBq2O8TEpPL1/Eyv3fMooawLT4tM654X0EGf2p+g46dPQkv4Mve7q0/Y8X4eCn77G7XZz4403oigKf/3rX1s8d+XKlTz55JONjm/YsIHw8PAmrjg7Pnf90MnGTRlo6pI/tYV6IIzC3JKgAu6WlH5rBgyUF1W1+Zr2sinqm1MDbPokA41Gg6IoGNDgRuGtdf8lXmvqlOduj4yMDLyKwilnBQDHv/6WUs2BNl8fDzxlGoXJoUVzJI+MI2qBfKKiME0XzTfeCh774n0eNg5tduHE3uTMoWPRcdKnoSX9GXpd3ad2u73N53Y4+KmoqOCVV17h8OHDAIwePZrFixcTFdX1i9XFx8ej0+koLCwMOl5YWEhycnKT1yQnJ7fpfH/gk52dzWeffdZi1gdgxYoVLFu2LPC5zWYjLS2NuXPntnptW7ndbtZ98Cmgrutz5VULAo8VnKjkv7v3YTZEsGDBJW2639u7dlJLLT63lrlz5gV2hw+lk1VlkJGJxWDiyiuvDBz/0/pT5NltTDh/BhO6cYq42+0mIyODyy+/nHxnNb4NBzFp9dy84JqQBSkznXbmfvISuR4H7rEDuW7g2JDctydq2J9n1gSKsyN9GlrSn6HXXX3qH2Fpiw4FPzt37mTevHmEhYUxffp0AP785z/z1FNPsWHDBiZPntyR27eb0WhkypQpbNy4kYULFwLg8/nYuHEjS5cubfKamTNnsnHjRh566KHAsYyMDGbOnBn43B/4HD16lE2bNhEX1/J6LwAmkwmTqXEGw2AwhPTNoNRlfkzh+qD7WqLCAHDUeNr0fB6XF1txbeBzZ42PsAhzyNoZuC91Q156Y1C7Yoxh5NltVPvcPeIHkMFgILeyCoABlhhMRmPI7p1kiOL+MbN4eu9nPH/oCxYOHo9R131DfV0h1O97IX0aatKfodfVfdqe5+pQwfPDDz/MNddcQ1ZWFu+99x7vvfceJ0+e5KqrrgoKJrrSsmXLePnll/n73//O4cOHue+++6ipqQnM/rr99ttZsWJF4PwHH3yQ9evX86c//YkjR47wq1/9ip07dwaCJbfbzfe+9z127tzJm2++idfrpaCggIKCAlwuV7e8xob8w16msOAvun+qu6vWg9fb+v5eZfk1NFyUuKbc2fzJHVDjUfvMYggODKPr6n4qnLWNruku2XXT3AdGtq3YuT3uGD6NpDALBbVVfHzqcMjvL4QQonkdzvy8/PLL6PX1t9Hr9fzkJz9h6tSpHW7c2bjpppsoLi7miSeeoKCggIkTJ7J+/fpAUXNOTg7aBptnnn/++axZs4bHH3+cn/3sZwwfPpwPPviAsWPVoYjc3Fz++9//AjBx4sSg59q0aROXXHJJl7yu5vg89ZmfhkzhBrWwRlFnfEVEtVxHU5pbHfR5dUXnBD/+3dwt+uBMSpRRzTJVuByd8rxnIxD8tHGmV3uYdHq+P3QKfz7wOX8/+g3XDuq9Q19CCNHTdCj4sVqt5OTkkJ6eHnT81KlTREZGdqhhHbF06dJmh7k2b97c6NgNN9zADTfc0OT5gwYN6tH7NPncTQc/Wq0Gc7gBR40bR01bgp+aoM+ryzsnCKlxq5mfiDMzP0Z1mK7C1faCtc7W3mnu7XXz0EmsOvQle8vy2FOay8S4fp3yPEIIIYJ1aNjrpptuYvHixbz99tucOnWKU6dO8dZbb3HPPfdwyy23hKqNogXNBT/QYJXnNqz148/8hEepGZnqThv2Uu8bcUbmJ9pUF/w4e07mp8ShBoTJYZ0TyMebIwKbof7j6M5OeQ4hhBCNdSjz88wzz6DRaLj99tvxeNTdww0GA/fddx+///3vQ9JA0TJfXVxzZs0P1K/y3J7gZ+CYOA5vy++04KfK3UzNT13mp9LVc2p+/PVHUXVt6wy3DpvMe1n7WH/6CE+65zfqFyGEEKHXocyP0Wjk+eefp7y8nD179rBnzx7Kysr485//3ORMJxF6ir/mJ6L5zE9WcRm3bX6TncWnmryH0+6mtkoNkNJGq3tY1XRSzU+zmZ+6AKO8JwU/dfVHMabOC34mxKYyyBKLw+thw+nOW1lbCCFEvQ4FP37h4eGMGzeOcePGhXQBP9G6loa9/FtcHMjLZ1thFv841vTQSk2lK3CPmGT169dZNT/VgczPmcGPWvDcUzI/XsWHza32QWdmfjQaDQvrip0/yG77IopCCCHOXoeCn5UrV/Lqq682Ov7qq6/y9NNPd+TWoo3qp7o3n/nx2L0AHK0safIedpsakIRbjVii1SCktsqN1936FPn28md+zhze8QcYPWWqu63BrDP/TLTOsnDgOAC2FZ6kwN72RbqEEEKcnQ4FP3/7298azfQCGDNmDKtXr+7IrUUb1U91b6Lmpy748daqQczJqlLcPm+j8+w2NSAJtxoxRejRGdS3RWdMdw/M9jpj2Ms/tNRTprr722ExmDB08l5jaZZopsanoQAf5Rzq1OcSQgjRweCnoKCAlJSURscTEhLIz8/vyK1FG/kzP8YWhr2oVafqu3zewNo1Ddnrhr3Co0xoNBos0WpWpqYi9IFIdTOLHPozPza3A68v9Bmn9qqsG/KK7uSsj9/VA0YDsPaUBD9CCNHZOhT8pKWlsXXr1kbHt27dSmpq9+3P1Jco/tleTU11r5vtRYMY5mhlcaPzAsGPVc3GWGLUwKQzZnz5FzlsruAZ6gOP7uQffovuxHqfhuanpaPVaNhXlk9OEwGqEEKI0OlQ8LNkyRIeeughXnvtNbKzs8nOzubVV1/l4YcfZsmSJaFqo2iGoij1w15nTHXfUZTNpvLjAOhr6zfkbDL4sQUHP/5//cdDqTqwyGFw8KPXagPZoJ5Q9Fyf+ema4CfebOG8xIEArJWhLyGE6FQdWudn+fLllJaW8qMf/Siwz5XZbOanP/1p0P5ZonO4nV5Qmp7q/vjOj8ktq2CpbgYmu57EqgiKImv4rsngpy4bU7fAob9+yFnrCXmb/QXPkfrGSyFEG81Uu53qQofdt0A4ABWuzl/j50xXpY1mW2EWa08d4r7RF3TZ8wohRF/TocyPRqPh6aefpri4mK+++oq9e/dSVlbGE088Ear2iRa47GpwotVp0BuCv5SVLgdOg5eoUerU9bF5iQActTWe8VUTGPZSAxJ//ZD//qHk39j0zMwPdN0WF2X5NWQfLG3xHH/2qTPX+DnTvP7p6DVaDlcUccLWcvuEEEKcvZCs82OxWJg2bRpjx46VxQ27kLNWnbllCtej0WiCHnP51MAlbLxasDuqMB69V0tWVRlOb3BQExj28md+6qbNhzrzoyhK/camTaxkXB/8dF7NT221i/ee2cVHL+wla3/TU/8btqGzp7k3FG0K44LkwYAUPgshRGcKSfAjuofTrlY7G5tY48cf4Hj6+bCFOTF59YwoisOj+MiqKguc5/X6Attf+Gt9/MXTzhBnfpxeD966TWLPLHiGhvt7dV7Nz7b3juOsUV/XVx8cx+dretNa/7BXV9X8+F2ZVjfrS+p+hBCi00jwcw7zD0udOdNLURRcdev5VHtcHE5S63yG2+IAyGuwkF6tTQ18tFpNYHaYP5hyhTjzU+2pnz0W3lTwE8j8dE7wk3esgiPb1CUY9CYdpbk1fPd1QZPnVrq6tuDZb26/ERi1Oo7aSsisKOrS5xZCiL6i3cHPvn378PWAdVhE/bDXmZkfV4OFDMucdooj1BqaWIc6hOPw1m906i92DrMa0WiDV4sO9bBXYGsLvRHtGcN0UD/E1FmzvfZ9pu5tNuqCFKYtGATAlre+4+jOwkbnBoKfLqz5AYg0mrkoeQggQ19CCNFZ2h38TJo0iZIStVZiyJAhlJZKYWZ38Q9Lnbm1RcPgp7C2moow9Rd5hL1uCrunQfBzxho/0HkFzy0VOwPEGNXi7M7Y3NTr8ZFzSB3uGzOrH+Mv7U/q8GjcDi8b/vcgu9ZnBZ3fHbO9/K70L3iYcxhFaXpYTgghxNlrd/ATHR3NyZMnAcjKypIsUDfyD0udOezlalDQXFhbRaVZDX6MDh0Gj/aMzE9dQBJVH5B0XubHv8Bh00Xx9Zmf0Bc85x2twO3wEm41kjgwEr1Rx7UPTWTyPHVtna8+OBGUAfKv8xPTDcHPZanDMen0ZFWXcbC86WE5IYQQZ6/d6/wsWrSIiy++mJSUFDQaDVOnTkWna3rvoxMnTnS4gaJ5/uDkzGEvZ4PMT1FtFU6DF4fBg9mtJ8phprZB5qemsn5fLz//Oj8uhwfFpwSGwzqqxtP0ju5+/mnl5c7QT3XP2qdmKweOiwu8Hq1Oy8zrhuL1+Ni78RQbXz/MRd8fjldRqKoL1LpytpefxWDi0pRhrD99hLWnDjM2tvEWMkIIIc5eu4Ofl156ieuvv55jx47xwAMPsGTJEiIju3lFuj6quYLnhpmfgtoqAGrC3Zgr9UTXmqltIvMTHlWfjTGG1QWzihoANbVp6tloLfNjrcuyhDrzoyhKYFr7oHHxjR4/f9EwqkodnNhTzKY3MjEOMKIZoq4f2R3DXqAOfa0/fYR1pw7xk/GXNlrKQAghxNk7qxWe58+fD8CuXbt48MEHJfjpJgkDLJzKySU6OQxFUfgg+wBjYpKD6kT8GQyHxQOVEFVrCs78VDTO/OgNOnQGLV63D6e9Y8GPo9qNRqfBFKZvdmsLP2vd2j/+NodKeb4dW4kDnV5L2qjYRo9rtRrm3TuWnWtP8s26LFw5Zq5wDOfL8Tnotd0zIfLSlGGE6w2crqlkb1keE+P6dUs7hBCiN+rQ9havvfYaFRUV/OlPf+Lw4cMAjBkzhrvvvpuoqKiQNFA0b+wl/cix72Xg2Dj2leXx6I7/MimuH7+cPK/Rue5ItTarYebHVlIbKAKOSYkIOt8UpsfudnWo7sdV6+Ffv9mB3qjj1ifPqx/2ajbzow4xVbkdKIoSsmxH3rEKAFKGRWEwNT1Eq9VqmH71EKKSw8h49RDpRfEoWSF5+rMSpjcwO3UEH+YcZG3OIQl+RLMURcHt9FJb5aK2yo3P68P/94/eoCMi2ki41YhWJyubCOHXoeBn586dzJs3j7CwMKZPnw7As88+y+9+9zs2bNjA5MmTQ9JI0bp8uzq8VeqoabSCM4DXqv4bVWvGUZf52frvY3jdPvqNjKbfiOig803heuw2V4fW+sk+UBqYTWYrrm2wunNzmR81+PEqCnaPu9kMUXsVZqnrGiUPaT0gHzIxntrRFYQfjGFQbnRIg7D2unLAKD7MOci6U4dZMXFOk8sDiL6lttpFYVYFVScNbPpHJuX5dioK7HjcrUw80UCE1Uh8WiSJg6wkDbaSPCSq0UxRIfqKDr3zH374Ya655hpefvll9Hr1Vh6Ph3vuuYeHHnqILVu2hKSRonX+tXEcXk/QVPeAut/70bVmir0u8o5WcOLbYjRaDRfeOKLRL3h/EXVHVnk+sad+E9Wy/BpqFH/Bc9OZH7NOj0Grxe3zYXM7Qhf8nKgEIGmwtU3nVyZXYzhsJaxWT8npahLSumdY96LkoVgMJgpqq9hdcpqpCWnd0g7ROpfXy8HyAvaU5XLSVkp+rY0aj5taj4taj4cwvZ4oYxhRRjOJZgtDrHEMjYxniDWOeHNEo/v5vD7KC+2U5lZTerqakroP/x8TYKaS4EUw9UYtYRYjurp9/jQadfNje6ULn0+hptJFTWUp2QfU5Um0Wg3JQ6MYOC6OQWPjiU1t3A4heqsOZ34aBj4Aer2en/zkJ0ydOrXDjRNtZ/PX9ng9TWZ+9NHqcI/VaSLHVU3OIfUH4PCpicT1szQ639TBVZ49bm/ghyxAWV411fH+guemgxqNRkOkwUyZ047N5SAlvG3BSkucdjflBerssYjUtu07Z9d6yI6tZFhJLFn7Srot+DHp9FzebwTvZ+3no5xDEvygDvHYK13Yq1w47R5cdg8ed12wr1HfQwaTDlOYHmOYHrPFQHikMWQzFhvy+nx8XnCc/2QfYHPeMao9rtYvasIgfQxTNf0Z6owlrjoMT5GX8nw7Xk/T2RxrvBm3rorRU4aSOCCK2JQIIqJNzQ7pKj6F2mo3tpJairJtFGbZKDhhw1ZcS97RCvKOVrD9vePEpkYwfFoSI6YlYY3vnkJ/IbpKh4Ifq9VKTk4O6enpQcdPnTolRdBdrD7z4w5satqQyWpAowetR4PPplCWVwNA4sCmAwxjB/f3On24HLezwUrTeTXURNcVPDcT/IA69FXmtIes6LkoSx0OrAhz8IPd7/LvOXe2OoxVpXgojC9jWEksJ/eWMO3KwSFpy9m4Mm0072ft5+PTh/nFpMvRdVMBdnepqXBSlG2jKLuK4pwqirJt1Fa5W7+wAa1OQ0SUCUusiZiUCGIbfIRHGds9rOnyennn5B5eOrKd0zWVgeMxxjCmxPdneFQC/SOiiTAYCdcZMOsM1HrdVDhqqSiyU3a6hqr8WpQSBUulgUinGpS7cVFAfQClMWqI72chMc1KfH8L8f0txKZGoNEprFu3jilXDMRgaH0ygkarIdyq1v00HPqtLLaTfaCM7AMlnM4spyyvhh3/OcGO/5wgZWgU6TNTGDolUYbGRK/UoXf1TTfdxOLFi3nmmWc4//zzAdi6dSvLly/nlltuCUkDRdvY6qaHu3xeHJ7GAUu4wYghRo+r2IO2Qh2GAppNdXd0ocMTe9UhL2tCGLbiWsryaygf6l81ufm1cyLrhsRs7tBMdy84qf5yyrdWsbcsj415R5nTb0SL19Tg5WRcNQDFOVVUlzuxxLQtaxRqFyQNJspopsRRw47iHM5PGtQt7egKNZXOugCniuJsG0U5VQ2GeepptBrCIg2YwvSYwvXoDP6Mh4LiU4d6XLUeXA4Pjmo3Pq9CVZmDqjIH+ccqg+5lCtcTkxxBbGpdQJSqfoRbmw6KNuUd48ndn3CqpgJQ38uLBo3nygGjGR+bilajQVEUqsudlOfXUJZfQ1leDeW51ZTm1eB1+4hASwRnfN9ZocLq5JixlLzwKootNVSanRh0Wi5IGswVaaOY1z8eo0GP292+4K85UQnhjL80nPGX9sdR4+bEnmKOflNIbmY5+ccryT9eyRdvf8fgiQmMmplCv/QYtJ2QQROiO3Qo+HnmmWfQaDTcfvvteOp+4RoMBu677z5+//vfh6SBZ2PVqlX88Y9/pKCggAkTJvDCCy8ECrKb8s477/CLX/yCrKwshg8fztNPP82CBQsCjyuKwi9/+UtefvllKioquOCCC/jrX//K8OHDu+LltImtQaakqonAIUJvICLVhKvYg6XIgK1YDUSaDX46uMVFcY6acRl/aX++/L+jav2CXQ24mqpx8PPP+LKFaK2fwpNqsXO+VQ1mXjj4BbNTh7f413614sFudKNL0eHN95J9oIQxF3bPbCujTse8fiP5v5N7WZtzqFcEP7VVLsoLaijLt9cFB9WU5dU0mdHRaNT3aMKASBIHWkkYGEl8Pwt6Y9NDPGfyeX3YbS6qy53YSmoDwUhZfg224lqcdg8FJyopONE4KIpOCscSYyYy1oQvAj4pymRX5Wn0OphsSGFecjrTYtJQShWqj9rZUHGAqlIH5YV23I4m6u5QN9SNS40grr+F+H5qNieun6V+M2Gvlz2luWwpOM6nuUc5aitmc/5xNucf51e7PuGKtFEsGjA25NuemCMMjL4gldEXpFJT4SRzRwFHtudTXmDn6DeFHP2mkIhoEyPPSyb9vGRikqU+SJzbOhT8GI1Gnn/+eVauXMnx48cBGDp0KOHh4SFp3Nl4++23WbZsGatXr2bGjBk899xzzJs3j8zMTBITExudv23bNm655RZWrlzJVVddxZo1a1i4cCG7d+9m7NixAPzhD3/gL3/5C3//+98ZPHgwv/jFL5g3bx6HDh3CbO76FYCb0nAz0Momgp9wvZGoAeGU760hNceCoqg/4Buu79NQoOC59uz+yvSvH5Q6LBq9SYfH6cVd7gFDK8FPCDM/ik8h/0QFAAXWasw6PQfKC/i84DiXpAwD4GB5AX/ct4mHxl4UmE5epagBX9TwcMryqzh1qKzbgh9QFzz8v5N7+eT0EX41ZR4Gbdt+8XcnRVGoqXBRfLqSqiwDX7x1lMoiB2X5NTiqm3lPaSAmOYLEgZGBYCc+zYKhjYFOU7Q6LZYYM5YYc6PZfh63l4pCeyAYOjMoKjxpCwTPACmEcxX1WUMnDr7kaNPPq9UQlRRObEo4MSkRxKWqgU5UQliL9UdGnY7piQOYnjiAR8dfyjFbCR+fOsyH2Qc5XlXKe1n7eC9rH0kaE46sfVw3ZAImXWiHpSKiTUyeN5BJcwdQlF1F5vZ8vvumkJoKJ7vXZ7N7fTaJAyMZMimBIRMTJBA6hyiKgtPrwelTa0P9NaL+f/3H/R8exYdPUQIfCgpexYdPUe/lVXz4UFDqHtdqNGg1WjSKwhFPKZUnvsWg16PTaOs+1MeNWh1GnY4hkXEMimy89lpXCMl3TXh4OOPGjQvFrTrs2WefZcmSJdx1110ArF69mrVr1/Lqq6/y2GOPNTr/+eefZ/78+SxfvhyA3/zmN2RkZPDiiy+yevVqFEXhueee4/HHH+faa68F4I033iApKYkPPviAm2++ueteXAsaZkqaWiE5XG8kbpCFLIoxO9Uve2xKRLMZEP/ChmdT8+N1+wJ/xVtiTMQmh1OUXYWhXAOJLQc/kYG1fjpe81OUXYXL7sWh95A8wMqViWN45bsdvJb5NZekDMPp9fDQ9g84UVVKgtkSCH5qUF9zyqhoyrZUcTqzHJ/X123rpJyXOIhYUzhlTjvbC7O4KGVol7dBURS8Hh8epw+X04PH6cPt8qpBrdOLy+nBVlxLeYGd8gI7FYX2BjVfZioJ3qMsMs5MbEoEMcnhxPVTa1liUiI6FOi0l96gI75/JPH9g+sTPW4v5QV28vMreWffHk4XVmBxGonXhjMsPB6jV4dGq0Fv1KI36jCa9ViiTUTEmIiMMROdFE5UUhi6ELxfhlnj+fGYC1k6eha7S3N558Qe1uYcotDr5Oe71/PcoS+4Y/g0bhs+tdlZlGdLo9GQNMhK0iArF3xvOFn7SziyPZ/sg2UUZavDk199cILopHDS0mPoNzKGfiNiMFtCsyJ8X1PrcVPuqsXucdV9qLMFa87419EwWPG6cfq8dQGMG6fXq9Z9ej04fd66Y576403NBO5E7+/Jb/HxB8dcyANjL+qi1gTrVZVsLpeLXbt2sWLFisAxrVbLnDlz2L59e5PXbN++nWXLlgUdmzdvHh988AEAJ0+epKCggDlz5gQej4qKYsaMGWzfvr3Z4MfpdOJ01v8Ct9nUvyDdbnfIxuz993G73UEBT4Wj8d5YZo2W6CQzLp0Xo1f9BROVHNZsW3R1CSGnvf3trSpV26LVa9CZIDpFDX5ia8LRUIZFa2j2nhadIfAaOtpPJ/apU4FzYiq5IHkQ1w0cy6vf7eDLwpN8V1bIh6cOcaJKnZF2qro88LWpVtQfEKkDIjkWrsdp95B3vLzNU+U7w7zUEfzr5B4+zD7IzPgBnfpcHpeXnEPl5B+toDinmuoyJ7XVLpR27mGs0aozk5yaKkaMG0RcqoWY5HCiEsOamZnkw93aejVd5IiukJ/mr6Uwshq9VcuDoy/k7hHT0GnaFtD4fF58If5FMz4qifGT5vHwyAtY+el77NBXU+So5pn9m3klcwf3jjyPW4ZMxKzrnOBjwLgYBoyLwW5zkb2/lKx9peRmVlBRqAa7+z/PBdRhytQRUSQOjCS+vwVrYliPrhVq+HO0syiKQq7dxvGqErKry8mqLiffbqPMaafUaafMacfu7bznb4oWDWadHqNOj1mnx6TVYdIZMOl0mLTqcYNGi0ajqcvYaNCgqcvu1H2gZnLUx1AzRCi4vB7y8/OJT0xE0RDIIHkVBY/Pi0fx4fZ5STRFhLTf23OvXhX8lJSU4PV6SUpKCjqelJTEkSNHmrymoKCgyfMLCgoCj/uPNXdOU1auXMmTTz7Z6PiGDRtCPiyYkZFBsaO+ZuG7U9mNzjm8dz827VEKIvUMqFDT//llWaxb13Ta3lGsA8IpLixj3bp17WqPs1y9VmPw8vHHH1NVYQDMxNnDiEDHJx+vb/bafI8asBw8cYx1p2qbPa8tCreFAzpOxpUz9ISHfVk2RmkjOeSr4r5P13BKqb//8dIC1q1bh0vx4UT9Bbz7i21orRFgN/DZf78mavjZTWUOhVifWi+1Nvsg0wq8mNr4S7g9XDYt1VlGagv0KN4WfllpFbQ60OgU9UMPWp2CLkxBH+HDYPGhj/ChD/eh0VYRCZRxhLJioLj52/YEPkVho7eY9Z4iFCBBY+R/DGn0O17KJ8ebf992tUv18VyoxLLHUMmnnmKKXLU8vX8Tq/d/wRX6JKbqojt/UcyBkJwKzlI9jjIdzlIdnmqdOnxYN5sU1PeJwerFYPVhiKh7b0T40JkVetK6nRkZGSG7l6Io5CtOjviqyPLZyfLZqab1YFiHBiNaTGgxabQY0WLUqJ+r/9dgQFv3ocGg0aD3/x8t+rrH9WjqHvf/X9voXF3DzlcAb93H2b3iBv/XAAYwDoCKVi47dJp1h06f7ZM2Yre3fVPsXhX89CQrVqwIyijZbDbS0tKYO3cuVmtoMghut5t1Gz7hstmzcX58KPD+C4+LhmJb0LkXzZjJyKhENh7+IBD8zJo9lX4jY5q8d+FJG//ZuRezIYIFCy5pV7uO7y5m41dHiE+JZsGCi9XPjxwhwmkkxRrDgjkLmr227PhuPt77KdHJiSyY0fx5rbHbXPzz4x0AZMVWcNcV/4NZZ8BScIJ7t71LlqJ+k8xMGMj24mxseJl3xXxybeWw8RB6jZbrF1xFZkwhW/51lDBPPAsWTDzr9nSUT1H4cMPL5NRU4BszgAWDxofs3qW5NXzzYRZFB8sCxyLjzAwYG0vS4EiiEsIItxoxmHTojTq0urb/xnK73WRkZHD55Ze3aVp2d6pw1fLTb9byeaEagC8aOI6fT5hNeAtLM3QHf59eMXce1xgM/Mzn4z85B1l1eCt5tTbe8uSSaYUnJs5hVHRS6zcMIbvNRf5RdaaYujijOsPNVa7HVR58rt6oxRofRmScGUusicgYdTkCS4wJS4yZsEhDp6zPdKZQvUcVRWFveT4fnz7CxryjnLYHF9EbNFoGR8Yx0BLDIEsM/SOiiDdFEGsKJ84UTqwpnAh9+5de6Im66/veP8LSFr0q+ImPj0en01FYWBh0vLCwkOTk5CavSU5ObvF8/7+FhYWkpKQEnTNx4sRm22IymTCZGo/BGwyGkL0ZHvn6Q9Y6D/Pz3BTcDcYkmqqXsZrDsJrDyI+qChxLSItqti3hkWrtjavW0+72OqrUmpnIGDMGg4GIunuZPDoSwiwt3i/GrGbFqj2uDvVT/lF1F/dCSzXhUUYi6+57af8RjIpO5HBFEUtHz2LpmFmMffcPeBQfZR4nlT41uxNnCsdoNDJoXAJb/nWU4uwqPA6FsMju+0V409BJ/HHfJt7N3s/Nw6d0+H6uWg9f/fcE+zefBkWdQj5scgLjLk0jeYg1pD+EQ/m+7wz7yvJYuvU9cu2VmHR6fj15Pt8bMqG7m9Uif58agJuHT+a6IeP5+9FveOHgF3xblsuiTW9w27CpLBt3ccjrgZoTFWcgKi6C9PNSAfD5FCoK7BSfqqLkVJU6RFZUi624Fo/L1yhL1JBWp65PFBZpJDzKSHikkbC69YoafoRFGjGF6zv8fj3b92ilq5b3sw7w9olv+a6yPrVp0um5IGkQ0xMGMimuH+NiU0JenN7TdfX3fXueq1d9JYxGI1OmTGHjxo0sXLgQAJ/Px8aNG1m6dGmT18ycOZONGzfy0EMPBY5lZGQwc+ZMAAYPHkxycjIbN24MBDs2m40dO3Zw3333debLaZV/TZzDFcHL3DdX8GzS6cmLqqLa6CItMbrZmV7QYKp7rQfFp7TrLzD/TK+IaLV9pgj1XmaPnnhTyzNDQjHVXVEUDn2ZB8DJuAr6R0QHHtNqNKy59Daq3E76RagZsOTwSE7XVJJXU0mlUx0KizOpwVJkrJn4NAslp6o5sae4W2d9LRo0nj/v/5xvS3PJrChiZHTj2YttVZRtY/1LBwL1WUMnJ3LetUOITuq+mZrdQVEU1hzfzW+/zcDl8zLAEsOq869ndEzTfyz1ZCadnnvTZ3L1gDE8tedT1p06zN+PfsOnud/x1LQFzEoe0uVt0mo1gbWTRs6o71Ov10dViYOKIjtVpQ6qyx1UlTmprluPqabCic+rrpdUXd765AeNVoM5Qo85woDZYgj8G2YxYIpQPw9rcNxsMWAKN3SoFimnupxXMnfwzsm9gVX1zTo98/qnM6//SC5MHtLjsoaiXqcEP3PmzOHEiROcOHGiM27fomXLlnHHHXcwdepUpk+fznPPPUdNTU1g9tftt99Ov379WLlyJQAPPvggF198MX/605+48soreeutt9i5cycvvfQSoM54eOihh/jtb3/L8OHDA1PdU1NTAwFWd+kXrv7yPlwRnLnyTxO3GsyB//vTqTqzltdn7OHjBfe2+JeSf5FDRVEXjTO2Y5XXRsFP3cwxs1tPnLnl+/g3N+3IbK/vvi5UF7PTw/7UQi6NCF6PyWo0B4IsUPvxdE0luTWVOOs2fY0x1QcBw6YkUnKqmmO7iro1+EkIs3BZ6nA25Gbyz2O7+M3UK87qPoe+zGPLW9/h9fiIjDNz6a3ppI3unumm3cnucfH4zo/5T/YBAC7vN4I/Tr86MOPwXJUSbuWF86/nxoITPL5zHadrKrnj83/xvcHj+dnEOUQZu3/rCp1OS3RSeLPBts/ro6bSRW2VK7CdSdC/Nie1VW7slU5cDq+6hUeVu32rf2vUn3PmCAO17nDWnzpIuMUYCI7UgMmI2aLHHFF3PELPocpCXjryFR+fPoyvbr2lkVGJ3DJ0EtcOHBv0s0X0XJ0S/Fx33XWUlJR0xq1bddNNN1FcXMwTTzxBQUEBEydOZP369YGC5ZycHLQNtgg4//zzWbNmDY8//jg/+9nPGD58OB988EFgjR+An/zkJ9TU1HDvvfdSUVHBrFmzWL9+fbev8dMvQq0dOmYL7mt/4BBnDg8EP/6/QMw6A2V6O05Ny1PYdQYtOoNWnbZe7WpX8FNdF/xY6oIfc13mx+DTEadvOf3e0RWenbUetv77mNqOSR6qzK5Ahqc5qRFRUAy59kq0dXVTcQ2Cn6GTE/nqgxPkfldBbbWLMEv3/TV354hpbMjN5N2Te3lgzIUkhDXel605HpeXLW99x+Ft6vTTQePjmXPnqEBw2pecsJXyo63/5qitGJ1Gw/Lxl3HPyBm9ot7C78LkIaybdy/P7N/EP47u5N2T+9iSf4JfT53P5f1GdnfzWqTVaYmMNRMZ2/rPWI/bi6Pag6PGhaPajaPGg6PGjaPaVXfcTW21Wz1W48ZZ41aX8FDUpTzU5Tx05FSUtfpcADUGF1FmHVeZRhAZY2bSwP6MjU8h2hSO2derBlN6tXZ/pfbt28fYsWODAogz3X///R1qVEctXbq02WGuzZs3Nzp2ww03cMMNNzR7P41Gw69//Wt+/etfh6qJIdE/PBogqN6noXhzBCer1G9of/ATVjcN1tHKtEqNRkNUQhhleTVUFtUSldD24ZAzMz9Gsx4FBQ0aYpWW72MNrPPjQFGUdv8y+vq/J6i1uYhOCmf3kCwogrQGw15N8WfQcmsqiajrn9gGwU90Ynj90Ne33Tv0NT1hAJPi+vFtaS6vH/2G5eMvbdN1tpJa1r90gOKcKjQamHzVQGZcMaRLCkp7mnWnDvPY1x9R43GRYI7gLzOvZ3pi5y4f0F0iDEZ+OXkeV6aN5rFvPuJkVRk//PJdrkwbzS8nzyWuhTW3zhV6gw5LjK5dW9D4vL5AkFRdUcu2L3YwJn087lpffaBU7cZe5aK0sobaKhcGtxYNGiLcRiLcRqgCSiDvaBl51AdO4VFGohPVJR2iE8PV/yeFEZUQht7Q8xco7SvaHfxMmjSJ/Px8EhMTGTJkCN988w1xcXGd0TbRin6t7Hru/wVu0Gox6tRvujC9+su9tomd38/kD34qiuwMGNP4a+x1+zj9XTmpw6MDi9P5V/aF+uBHo9XgNvgwunVEKS3/JefP/Lh9PhxeT6C9bVFyukot3gUuumkEf8/aA0B/S3SL1/kzQ7n2SuKMap81DH6gfujru68LuzX40Wg0/HDU+fzgy3f457Fd3Jt+XqvDGEd3FrL5zSO4ar24jF7WjznGn6q3E/UfM+nRSVwzYAxXDhgd6PveyuX18vTejbx+9BsAZiQO5PnzFrYre3aumpqQxkdz7+EvB7/gfzO/Yu2pQ2wrPMkTk+dx9YDRvSrj1RZanTZQMB0ZbyTsOw/pM5MDBbOljhrWHN/Nm8d2UexQC7LDtHpuTJ3IooRxRDiMVJc7qC53UlXuwFZcS0VRrRowVapDc3lHK4KfVEPdIphhdcFReN3QXxiRseZuW0S1r2p38BMdHc3JkydJTEwkKysLn69nLErWF8WawjGgwU3T+/zE1RUXNyy682d+aj2tr1njH4+vKGq83o7H7eWjF/eRm1nO9KsHB3Y+d9Z48HrU90REdP3zOg0ejG4dEb6Wg5kIvRGtRoNPUbC5HW0OfhRFYctb36Eo6jBV/1ExnD6kTjXt38bMT15N08NeACOmJ7PjvyfJO1pByelq4vt33y/My1KHMyIqgRNlpax6YwtTlH44az1EJ4aTOEjdFsIUrqcsv4Y9n+aQc0D9qzTfWsVHY76jyqx+7StdDnYUZbOjKJvf793IHcOnceeIaUH1Tr1Fvt3Gj7e9x7el6kJ8Pxx1Pg+PvRh9Cxns3sasN/CTCZdxRdooHvv6I45UFvHwVx+w5vguHh57MTMSB3Z3E7uVoijsKjnNOyf28J/sA4HVkJPCLNw2bCo3D53U6veGo8ZNZVEtFUV2KovUmW2VReoikC6HN7DB7qnDwfP+tToNllgz1jj1IzJOXQLAGmfGGq8uNdEXs7Sdqd3Bz6JFi7j44otJSUlBo9EwdepUdLqmU3ndUfDcl2g0GmI1RgqVpouDR0QlYNTqGGaNDxxrT+YnOlH9Rq8sDF44SlEUPnn5ILmZ6jdwyanqwGP+eh9zhCGQ4vUpCjU6N5GYCPe0XC+j0WiwGsxUuGqxuRwkhUW2eL5feYGd/GOVaPUaZt0wjBJHDU6vB61GQ2orGbLUBpkff3B45g+5yFgzQyYmcHx3Efs3neLS20a1qV2dQavR8JOUS/liQyZRdgPHUGf7nTrUdM2CD4WvB+ZSMr6W5SMv4/ykwcSZwsmzV/J5/gnePbmXE1WlvHjoS1777mtuHTaFxSOnE28+9zMiiqLwYc5BfrnrE2xuB5EGE8/MuIY5/Ua0fnEvNS42hfcvv5u/HdnG/zu0lW+KT/H9Tf/k/KRBLB09i+kJA/pUJijPbuMzTzEvZLzCyer676FxMSncPXI68/uPCmTOW2OOMGAebGi0GryiqAXZFXWBkD8wUv9fi9fjw1ZcG9hw+kxavYbIuuAoMj6sLkAyY40Lwxofpq6J1Ie+ZqHQ7uDnpZde4vrrr+fYsWM88MADLFmyhMjItv2CEqEXozE0G/ykhlvZfNX9QcMZ5rp1Jmo9rc+KiE5Sh1MqioKDn+KcKrL21RdZ20rrv2HPrPcBdR0Mh14Ntoyu1v/SthpMVLhq2zXjy9+e/iNisMSY+a5EHf5KDotsdSNQf3Dk8Ho4XrfdxZmZH4Dxl/Xn+O4iMr8uZOZ1w7ptDyNbSS3H/55PnD2caqOLY0PKuXP8NJRShaIsG8U5VXg8PhxGD9/FlbJ3YAF3Tp/BPSPPC8p0WI3qsNeS9PPYcDqTVYe+5FBFIS8d2c7fj37DzUMmsST9PFJaCR57qjKnnSd2fszHp9XV3cfHpvD8zOsYYGl6Yc++xKjT8eMxF/K9wRNYfXgbb5/4lm2FWWwrzGK4NYHvD5vEdQPHnfMz35qTXV1OxulMPj51mD1l6rIYVKuZ8SvSRnHTkIlMie8fsoBCo9EEhtlSh0UHPab4FKornFSV1mIrcWArdVBVWktVqQNbiboMgM+jUFlUS2VRLVDe6P7+BSP9mSL/4pFRCeq/xlZm2fZFZ1XwPHfuXObPn8+uXbt48MEHJfjpRrGa+kyKUasL2rjOqNM3ypz4h8BaK3gGiKrL/FSVOvB6fOj06i9OW4k6E8tUt++Vrbg2UJzcVPBT6rTjMKjBj8/R9BBdQ5FGM9S0b8ZX1n41+Bk0Xs1yna6pAFof8gJ1fZQEcwTFjhpq6/qlqeAnZWgUCQMiKc6pYuf6LGZ9b3ijczqb2+Xl47/tx2n3EDfAwoejdnPUVcrhmhJ+c8EVTF8wlLXZh/h/B7/A4fOQFGbhr+ffyKT45uuUtBoN89PUtUk25x/jxYNfsqcsj78f/YY1x3exaNAEfjBq5jkTNPgUhX+f3Msf922m1FmDXqNl6ZhZ3Dfqgj41zNUWKeFWnpwyn3vTZ7L68Dbez9rPUVsxT+7ewNN7P+Oi5KHM7T+Sy1KH9Ygp8meryuVge1E2XxSc4MuCE+TU/XwAdTOGwZpw7pp4IVcPHtfltW8arSYwsy21iR8pXq+PmnKnGgyVOrAFAiP13+oKZ6sLRpothrqgyJ8tMmNNUIuwI2PMfXJIrUMFz59//jkuV/ftdyQgVlOffUgKi+RUg29qk7bxl9e/6aG9DZkf/5YGbqcXW0ktMclqDZE/wEkZGkXW/lJcDi9OuwdzhIGqcjVgscTW/wApcdQEMj+OmtafNzDd3dW2zE9ttYuC42p9z8BxamH26Zq21fv4TY1PC2QIoPGwF6h/vc24ZggfvbiXfRtPMWJaEokDuzYrsv2945ScqiYs0sBV943nElM6t21ew4mqUu754u2gcy9MHsIfp1/d5oJejUbDpanDuSRlGNuKslh18Et2FOfw1olvefvEt5yXOIiFA8cyr//IHpkR8Pp8rDt9mL8e2kZmpToUONwazx9nXMO42JRWru7b+kVE8ZupV/CT8ZfyfvZ+1hzbzVFbCRtyM9mQm4leo2VCXCrTEwYwLWEAk+P69cj3AKjBb3Z1GXtL89hblsfe0jwOlOfjVer/8NJrtExJSOOK/ulcljSUnZu2sGDwhB65CrlOpw1kc5r6E8br9lFVpgZFthI1KFI/1GPOGo+6BEC1m6Ksxts/6AxaouoCocAstSR1llp4VO/YbqMpUvB8jmuY+UkMswQFP02NU4fp1S95WzI/Go2GqMQwSk5VU1FobxT8RCWEE2atotbmwlZSiznCEBizjoqv/yux2FEdyPyoa2q0rH6hw7ZlfrIPlKIoENfPgjVOfd5T1WpqOK2VNX78fjdtAbVeN5vzjxOBjvBmdsYeODaO4dOSOPpNIZ+9cYTrH53crjWQOqIwy8b+z9XhvDl3jcYSY8aCmX9ddhsvHvyC9aePUOKoYWJcP64fNJ6bh046q80tNRoNFyQN5oKkwXxTnMOqQ1v5ouAE24uy2F6UxS92fcz5SYO4JGUYl6QMI62V2XSdze5xsTbnEH87sj2wtIPFYOKBMRdy27Cpba7XEGrW9fbh07ht2FQOVRSy4bQa/HxXWcyuktPsKjnNXw9vA9QlJEZGJ5IelcgASwwDLNH0j4gmKSyy8zdVRa2jKayt4ritlGO2Ek5Uqf8eKi9sMms8JDKOWcmDuTB5CNMTBgS2/OjM3dy7gs7Q8oKRzlpPUEBUVVJLpT9IKq7F624+a6Q36eqCogYz1BLDiEoMP+frjKTg+Rx3ZuanoaYyP/Wzvdr2DR+dFK4GPw1mfFU3GNqKijfXBT8OEgdasZWo51kbBD/bCk7ibEfmx2r0Z37aGPzsV+t0Bk+oL+z2j+O3dQuIKGMY/3vhTWzIOcyR3Xtb/KaedcNwTh0qozS3mg/+/C1X3j+eiKjOTZX7vD42v3kEFBgxPYkBo+uXHog3R/CrKfN5YvI8nO1cHqA10xIG8PrFAzhdU8GH2Qf5T/YBjtpK2Jx/nM35x4FPGGiJYUp8GlPi+zM5vj9DIuM6fXjJpyjsLjnNv0/uZd2pw1TXzV6MNoZx54hp3D586jk9TNPdNBoNY2KSGROTzMPjLuZUdQU7irP5uiiHr4tzOFVTEfj4NPe7oGuNWh2p4VEkhEUQ59+406xu3GnRmwjXGwnTG4io+9f/naagBjQK6h9n1W4nVW4X1W4n1R4nJY4aCmurKKqtpqC2iqLaKhzNTNww6fSMiU5mQlwqE+JSmRzXv9XFTnsrU5iehLRIEtIal6f4vGrWKDArraiWykJ7YNsRj9NL6elqSk9XN7rWGKYPBEL+zJE1Xv3XEN7zgyIpeD7HNcz8nBn8NJ358c/2amPwk+if7l5f9Fxf12MkMi6MghO2QNBTWVcPZI1XszdOr4f1pzNJM6hta0/mp6INwY+iKOR+V5flGaVu0VDutAc2GJwan9bqPfw0Gg2XpQ7Hsedoi+eFW41c/cAEPnpxL8U5Vfzz8e0Mm5pITHIEeqMOn9eHJcZM8hArlpjQDA3s/zyXklPVmML1XNBMrZFWowlp4NNQ/4ho7ht9AT8cdT7fVRbXBT/H2FVyiuzqcrKry3kvax+g/vIbao1jRFQi/cKslHjKsBaeZIA1lpRw61nvd1TrcbO9KItPc79jU94xihz1P5AHRERzy7DJfH/o5C7bxLMvSbNEk2aJ5nuD1c1ey512MiuLOVxRyHeVxZyuqeB0dQV5dhsun5es6jKyqtu2YnJH6DQaBlhiGGqNZ2hkHEOt8YyMSmBkdGKrEx2Eut5RVEK4uojtGWu5eT0+bCW1gan79QGSnepyJ65aD0XZVRRlVzW6r86gRWNStwyJrguO/IGRNS4MnaH7a+/OKl8/f/58ACl47gEi0BFlMFPpdjSqb2lqB+F2Z34S1b+eG053b1jU7A9ybKUO3E4vtTb1L3B/5ueLghPY3A5M4Wpg4rS3/rzxdavOljqbLt5rqLzATm2VG51BS9Igtf5mV91Mr2HW+E5bwTZxoJXrH53ChlcOUpxTxZHtBU2eN2xKIrNuGB5UAN5e1eVOdvxXzaKet3BoixvSdjaNRsPI6ERGRifyg1Ezsbkc7C49HRgS2V+Wh93j5nBFUdCGu/+39Z3A/y0GE3GmcOJMEcSZg/+N9X9eV3NVUFvF7pLT7CjOZm9pXlBBf4TeyBVp6SwaNIFpCWnndAr+XBNjCue8xIGcd8baQB6fj4JaG7k1lZQ67ZQ6aih11lDmsFPmtFPtcVHrcVPrcVHjcVPrdaEo4P/SaeryQGF6Axa9CYvBRITBiEVvJM4UQVJ4JIlhFpLDIkkMiyQlzCrDmp1Ep9cSkxwRKHdoyOP2UllcFxgV2qmsG0LzF2F73T5w68g5UEYOZwTBGoiwGrHEmhk9K5XRF6R20SsK1qFihddee40vvviCv/3tb5w4cYJ33nmHfv368Y9//IPBgwcza9asULVTNEOj0fDcjGspcdkbFekam/jLx9zezE+S+sYvK1CDH0VRqKlsGPyoQU5V3ZgyqLPAzBHq83yYcxCAKf36w+62ZX7868uUOFoPfvyrqCYPtgb+mvi6OAdoX9bnbEQnhXPDiqnkH6/k5N4SaqtceFxetDot5QU1lJxWN0PNOVjKgh+Np9+Is5st9eU73+F2eEkabGXMrO75QdEcq9EcqP0BdTgqt6aS7yqL+K6ymFPV5ezNPo7XYibfbqPaUzeM4XaSXd14ym5rUsOtzE4dzmWpw5mROLDJAF90H71WS/+I6DZPNBDnJr1BR1yqhbjUxpMpvF4f5YXVbFy3hfQh46guc1FZrNYbVZbU4nF6qal0UVPpCipV6God+snx73//m9tuu41bb72V3bt343SqvxQrKyt56qmnWLduXUgaKVo2M3EgBoOB7YVZQcdbyvw42pj5iUlRA6pam7ppoEYLHpda5G5pEPzY6qZeQn3Wx+n1sDFXHUK6cNBQ9pDVppqfhLpsTXFt43HmM/mDn9Th0YFj39QFP9MTOn+/Jo1GQ+qw6EZrdwAUn6pi8z+PUJRdxUcv7GXBfePbvXt61v4Sju8uRqPVcMmtI3v8lFStRhMYIpndbwRut5t1+etYMGcBBoOBKpeDYn82IJAZaPpfjUZDnCmcMTHJzEgcyIzEgQyIiJYMjxA9mE6nzh4zJ3gZfWFq0Aw6/2KPVWUOqkodxKZ2395yHQp+fvvb37J69Wpuv/123nrrrcDxCy64gN/+9rcdbpxonzPrPYxNFDyHt2OFZ1A3JbXEmqguc1KWX4Opbod2U7gevVGHNc4/7FVLZbE/+FGPnbCVUut1YzWYGZ+ayh6ycNo9rW5YmlCX+SluJfOjKAp5dfU+/uCnxu3iYLk6BDUtoXMzP61JSIvkukcns/5vB8g+UMq6v+3nez+ZQly/tk09d7u8fPG2Wkw64bL+xPc/94eXI41mIo1mhiD7AQrR1zRc7NFfptBdOlR1lJmZyUUXXdToeFRUFBUVFR25tTgL5jMyPU0OewXW+Wn7+kyxKeov67L8mkaLGFpiTGi0Gnwehfxj6to6/szPUZu68ODwqPjAMJjiU3A7vLQkIaxuqM1Zg6eFpRRsJbXUVLrQ6jQkDVFncnxbehqvotAvPCqwbUV30ht0XPHDcfRPj8Hj9LJu9f42Zb8Advz3BLYSB5YYE9OuGtzJLRVCiL6jQ8FPcnIyx44da3T8yy+/ZMiQIR25tTgLpgZr0+g1WnRNTDf2Z4fass6Pnz81WZZXH/xY6oIfrU5LZN2ChqePqIVtUQlq8HPMps64GmaNR2/QBlaIdrRS9BxjDEen0aDQctFzVt0U98SB1sCu8t8UnwLUKdo9hU6vZd49Y4mMM2MrriXj1YP4fC2vdH1ybzF7P1Vfy8W3jJTl6YUQIoQ6FPwsWbKEBx98kB07dqDRaMjLy+PNN9/k0Ucf5b777gtVG0UbNcz8NDcDon62V9uGvQBiU+qCn/zqQPAT3mD20tBJ6lo6rrqMjj/zc9ymBifDrQloNBpM4Wr7nDUtP7dOqw3sSN9c3Y/X42NPhlrbM2J6UuC4v96nu4e8zmS2GLjih+PQG7TkHCzj6/82vwZWWV4NG/9+GIAJl6UFtuwQQggRGh0Kfh577DG+//3vM3v2bKqrq7nooou45557+MEPfsCPf/zjULVRtFHD4KepBQ6hPvNT43GypzQXl7flIShoGPzYqalQh8ssDYKfyfMGYjTXB1v+4OdY3bDXsCj1l7epbuirLdPdA0XPzdT9ZO4ooLrcSbjVyKjz1a0LnF4P35bmAl1T7NxeCWmRXHpbOgC71meza30WihKcASrMsvH+n3bjtHtIGmxl5vVDu6OpQgjRq3Uol67RaPj5z3/O8uXLOXbsGNXV1YwePRqLpW0FnSK0whoMe7WW+Sl21LDo09e5a8R0Hp90eYv3bTjjqzRXzcQ0XLfGbDEwae4Advz3JBqtBkusCZfXS1bdVgPDrGrwY67L/DhayfwAxIdZoKKQEkfjzI/X62PX+mwAJs0dgL5uyGt/WT4un5c4UwSDI9s3q6qrjJieTFl+Dbs+zuarD06Qf7ySkTOS0em0ZO0v4chXBSg+hcRBVq66f0JgqFAIIUTohKSQwGg0Mnr06FDcSnSAqQ2Zn1hTOFqNBl9dxiG7DauwGs16ImPNVJU5yK/bQPTMRfvGX5ZG/rFKYpIj0Om0nKgsxqP4sOiNJNetPO3P/NRWtV5s3VLm58DnudiKawmLNDDmwvqt/hoOefXk6dDnXTsUS4yZLW99R/b+0sD2HH5DJiYw+85RUucjhBCdpMM/XSsqKnjllVc4fFitURg9ejSLFy8mKqr7Z9r0NRqNBpNOj9PrwdjM4m/RpjDevOR/2Jh3lP/N/Ipqd9tmfcWkRFBVVr/dRGRscPBjNOu5+oGJgc/9Q15DrfGBQMRfCF3ZYJ+w5tRPdw/O/Diq3Xzz0UkApl89BIOpPsP1TUnPK3ZuztiL+pE8JIrMHQWcOlSG3qiujTHukv4kD5HvHSGE6EwdCn527tzJvHnzCAsLY/r06QD8+c9/5qmnnmLDhg1Mnjw5JI0UbWeuC35MLexrMz1xAHavi//N/Ioat7NN9x08IZ6cg6VY482MmJ7c6lo1gXofa32xrn/X4Yb7hDUnEPycUfD89dqTOO0e4vpZGN1gtWOX1xvY1qKnFTs3J76/hfj+w2BRd7dECCH6lg4FPw8//DDXXHMNL7/8Mnq9eiuPx8M999zDQw89xJYtW0LSSNF2Zp2eSmg28+Nn0auZm+o2rvcz9qJ+jJiehMGka9OQ0pnFzgAxdcFPeWEbgp+wxgsdVpU5OLhFLWiedcMwtA1WO96Uf5Rqt5NEs4X0qLbt5C6EEKJv6nDmp2HgA6DX6/nJT37C1KlTO9w40X7+RQxbDX4M6uaYNe1Y7LA9NSgn66a5D42sX8k3OlkNfqpKavG6fS3u7Ftf81Of+fn2k2x8XoV+I6Lpnx5c0Pzuyb0AXD94fJPrGwkhhBB+HQp+rFYrOTk5pKenBx0/deqU7PTeTQLBTwvDXgARdZmfmjbW/LTXqRq1MDrNUr+ZZ7jViMGsw+1QdwRuaV+XMzc3rSy2c3BrHgBTFwziV7s+YX9ZHma9gUtShrE5/zgA3xs8vlNejxBCiN6jQ8HPTTfdxOLFi3nmmWc4//zzAdi6dSvLly/nlltuCUkDRfv41/ppbbfriLrMT63XjcfnQx/CbEmlqxabWy2OTmuwu7NGoyEmKZyi7CoqCu0tBj/+zE+N28UX7x/l4MZcfB6FlGFRuFJ9/OPjnYFzvypSp71PjU9jcKTsGSWEEKJlHfqN98wzz3D99ddz++23M2jQIAYNGsSdd97J9773PZ5++ulQtbHNysrKuPXWW7FarURHR7N48WKqq1veGdzhcHD//fcTFxeHxWJh0aJFFBYWBh7fu3cvt9xyC2lpaYSFhTFq1Cief/75zn4pZ80f/LSe+TEG/t+efb7a4lR1BQDx5ohGm61GB+p+Wt60NEJvJExnYFhJLPs+OYXX4yNlaBSX3T6K41XqkNogSyzLx18aeC3fHyoF9kIIIVrXocyP0Wjk+eefZ+XKlRw/rg47DB06lPDw8JA0rr1uvfVW8vPzycjIwO12c9ddd3HvvfeyZs2aZq95+OGHWbt2Le+88w5RUVEsXbqU66+/nq1btwKwa9cuEhMT+ec//0laWhrbtm3j3nvvRafTsXTp0q56aW1mCgQ/LX9pTTo9Rq0Ol89LtceF1WgOWRtO+4e8GmR9/AIzvs4oet636TQn9xbj9fhIHhLF5HkDSTRbmJGlruMz6fIBzLx+KBqNhhOH1eBnXGwKPxx1PtcPGseJqjLOSxwYstcghBCi9wrJKmrh4eGMGzcuFLc6a4cPH2b9+vV88803gWLrF154gQULFvDMM8+Qmpra6JrKykpeeeUV1qxZw2WXXQbAa6+9xqhRo/jqq68477zzuPvuu4OuGTJkCNu3b+e9997rkcGPP9NiamaF54Yi9EZcrto2T3dvq5yacqC14Kd+rZ/845V88fZ39Z8fq+TQl3lcljiImGozGNQtNPyzzPx7hg21qkNciWGRJIZJjZkQQoi26VDws3LlSpKSkhoFCK+++irFxcX89Kc/7VDj2mP79u1ER0cHzTKbM2cOWq2WHTt2cN111zW6ZteuXbjdbubMmRM4lp6ezoABA9i+fTvnnXdek89VWVlJbGzL2yc4nU6czvqgwmazAeB2u3G7276jekv892l4P6NGDXr0aFt9nnC9kXJXLRUOO+7w0LQJIMemrhqdGmZt1IbIOHWIqiy/hhN7C4mMM7P5zSMADBofx8BxcezfdJqyPDsxWWo2yjbChc5U/zqPVaq7xQ8Kjw5ZX/o11afi7El/hp70aWhJf4Zed/Vpe56vQ8HP3/72tyaHlMaMGcPNN9/cpcFPQUEBiYnB67vo9XpiY2MpKCho9hqj0Uh0dHTQ8aSkpGav2bZtG2+//TZr165tsT0rV67kySefbHR8w4YNIR8WzMjICPy/yJ0PQG52Duvy1rV4nc+pFiVv2volebrQ7ce225UFQPnxHNZlB7fB5wWw4Kr18PFfDwaOaw0KzoRsjpdlETYeYpP0FGZpKPV4+Domi9Hr1EBSURQynWpNVu6eQ6zb1/zu6B3RsE9Fx0l/hp70aWhJf4ZeV/ep3d76GnJ+HQp+CgoKSElJaXQ8ISGB/Pz8jtw64LHHHmu1eNq/tUZnO3DgANdeey2//OUvmTt3bovnrlixgmXLlgU+t9lspKWlMXfuXKxWa0ja43a7ycjI4PLLL8dgUIe7vjv4BTsytzMlfQwLRs5o8fp/fv4m+aW5jJk8kbn9RoSkTQB/2fAyVMMVM2dxXkLjOpxD0Xlk7SvFbnNTWayu+XPxLekMnxYcvGZVlzF/w/9i0uqZd8V8dBotRbXVOD4+iBYNt11xTavrGbVXU30qzp70Z+hJn4aW9GfodVef+kdY2qJDvznS0tLYunUrgwcPDjq+devWJmtszsYjjzzCnXfe2eI5Q4YMITk5maKioqDjHo+HsrIykpOTm7wuOTkZl8tFRUVFUPansLCw0TWHDh1i9uzZ3HvvvTz++OOttttkMmEymRodNxgMIX8zNLzn4lHn0c8SzVUDRrf6PBaD2j6H4g1Zm3yKQp5dfQMOjopv8r4TLhvIhMvUoMjnU3A7PJjCG583JCqBMJ2BWq+bXEcVQ63x5JT51w+KJsIcFpI2N6Uzvk59mfRn6Emfhpb0Z+h1dZ+257k6FPwsWbKEhx56CLfbHSgY3rhxIz/5yU945JFHOnLrgISEBBISElo9b+bMmVRUVLBr1y6mTJkCwGeffYbP52PGjKYzIFOmTMFgMLBx40YWLVI3WMrMzCQnJ4eZM2cGzjt48CCXXXYZd9xxB7/73e9C8Ko6T6wpnO8Pa9uUb3/wU+MJXcFzYW0VLp8XvUZLcljrGS6tVtNk4AOg02oZGZXAnrI8jlQUMdQaz4mq4GJnIYQQor06FPwsX76c0tJSfvSjH+FyqWvFmM1mfvrTn7JixYqQNLCtRo0axfz581myZAmrV6/G7XazdOlSbr755kAWKjc3l9mzZ/PGG28wffp0oqKiWLx4McuWLSM2Nhar1cqPf/xjZs6cGSh2PnDgAJdddhnz5s1j2bJlgVognU7XpqCsJ/Ovj9PWnd3b4nRNBQCp4daQLJw4MjqRPWV5HK4o5MoBo4N2ixdCCCHORoeCH41Gw9NPP80vfvELDh8+TFhYGMOHD29yuKcrvPnmmyxdupTZs2ej1WpZtGgRf/nLXwKPu91uMjMzg4qi/vznPwfOdTqdzJs3j//3//5f4PF3332X4uJi/vnPf/LPf/4zcHzgwIFkZWV1yevqLP7gpz37e7Ump26Bw/6W6JDcb1R0EgBHKtQhzUDwIys5CyGEOEshqRa1WCxMmzYtFLfqkNjY2BYXNBw0aBCKogQdM5vNrFq1ilWrVjV5za9+9St+9atfhbKZPUZg2CuE6/zsL1P33wpVcJIerRZBHyjPp8btYlfJaQDGx4ampkwIIUTfI9tf92H+/b2qQ5j5+bxAnXo+K3lISO43PjYVi8FEsaOGvxz8AqfXQ/+IKEZEndtDjkIIIbqPBD99mCVQ8xOazM/JqjJyqssxaLUh22rCpNMzv/9IAF79bgcAs1NHBFZ7FkIIIdqr04KfAwcOdNatRYhE6P2zvUKT+dmSr+7vNjV+QGBILRSuHahuneKrG7Kc3W94yO4thBCi7wlp8FNVVcVLL73E9OnTmTBhQihvLTqBpW7YqyZEs722FKjBz0UpoRny8puRMICkMHUFaovBxLT4ASG9vxBCiL4lJMHPli1buOOOO0hJSeGZZ57hsssu46uvvgrFrUUnijCEJvOzteAk9335LtsKswC4OHloR5sWRKfVcs3AsQBcmjIMYxs2bRVCCCGac9azvQoKCnj99dd55ZVXsNls3HjjjTidTj744ANGjx4dyjaKThIRgpqffaV53PPF27jUTbsYGhnXKcXID4y5kHhTBNfWBUFCCCHE2TqrzM/VV1/NyJEj2bdvH8899xx5eXm88MILoW6b6GSWZmZ7fVuSy/IdH1LiqG7x+jKnnR9t+zcun5eLU4by6kU38+85d3ZKMXK43sg96eeREBa6DViFEEL0TWeV+fn444954IEHuO+++xg+XIpPz1WWuoJnu8eFoiiBoOWVzK/4+PQRxsQkc+eI5tdvevPYLvLtNgZZYnn+vIVEGs1d0m4hhBCiI84q8/Pll19SVVXFlClTmDFjBi+++CIlJSWhbpvoZP51fnyKQq3XHThe5lRXwG4t85NdXQ7AjUMmSOAjhBDinHFWwc95553Hyy+/TH5+Pj/4wQ946623SE1NxefzkZGRQVVVVajbKTpBmM6Ati7b03DGV6XLAUCpo6bF6wvs6te5LRuYCiGEED1Fh2Z7RUREcPfdd/Pll1+yf/9+HnnkEX7/+9+TmJjINddcE6o2ik6i0WgI9xc9N9jZvdKtBj/+DFBzCmptACSHR3ZSC4UQQojQC9k6PyNHjuQPf/gDp0+f5l//+leobis6maWJnd0rXbUAlLYQ/CiKUp/5CZfMjxBCiHNHyFd41ul0LFy4kP/+97+hvrXoBJYz1vpxeb3YPWr9T0vBj83tCNQJJYdJ5kcIIcS5Q/b26uP8a/34d3a3uWsDj5W1UPPjz/rEmsIx6c56uSghhBCiy0nw08f5Z3z5Mz/+YmdQ1/9xej1NXpfvr/eRrI8QQohzjAQ/fZy5LmvjqAtyKhoEP9D80Fd9vY8EP0IIIc4tEvz0cWadAQBHXf2OzVUb9Hhz093z7f7MjxQ7CyGEOLdI8NPHmc7I/FSekflpbrq7THMXQghxrpLgp4/zD3s5mxv2aibzIwscCiGEOFdJ8NPH1Q97qcFPo2GvZjM/UvMjhBDi3CTBTx8XKHiuW9vnzMxPs8NedTU/KZL5EUIIcY6R4KePa67mx2pQNyptatiryu2kum5qfJJMdRdCCHGOkeCnjztz2Mu/tcVQaxzQdObHn/WxGsyBdYKEEEKIc4UEP31cfcGzOuzlz/wMjlSDn1Jn48xPrr0SgBTZ00sIIcQ5SIKfPu7MRQ5tdTu6D4mMBZrO/OTWqMFPWkRUVzRRCCGECKleFfyUlZVx6623YrVaiY6OZvHixVRXV7d4jcPh4P777ycuLg6LxcKiRYsoLCxs8tzS0lL69++PRqOhoqKiE15B1zOdMexVUTfsNaRu2KvU0Tj4OV0X/PSLiO6CFgohhBCh1auCn1tvvZWDBw+SkZHBRx99xJYtW7j33ntbvObhhx/mww8/5J133uHzzz8nLy+P66+/vslzFy9ezPjx4zuj6d2mPvPjRlEUbHXDXoMsauan1uvGXlfc7JcbCH4k8yOEEOLc02uCn8OHD7N+/Xr+93//lxkzZjBr1ixeeOEF3nrrLfLy8pq8prKykldeeYVnn32Wyy67jClTpvDaa6+xbds2vvrqq6Bz//rXv1JRUcGjjz7aFS+nyzRc5LDW68bl8wKQGhFFWF1WqLBuTR+/3JoKAPpL8COEEOIc1GuCn+3btxMdHc3UqVMDx+bMmYNWq2XHjh1NXrNr1y7cbjdz5swJHEtPT2fAgAFs3749cOzQoUP8+te/5o033kCr7TVdBgTP9vIXO+s0Gix6Y6Du52hlSdA1p+sKnvuFS/AjhBDi3KPv7gaESkFBAYmJiUHH9Ho9sbGxFBQUNHuN0WgkOjo66HhSUlLgGqfTyS233MIf//hHBgwYwIkTJ9rUHqfTidPpDHxus6nTw91uN263u60vq0X++3TkfnpF/dfhcVNqV+ujooxheDwehkbGcbCikMzyQi5NGqKe53VTUrf2T5IpImSvpacIRZ+KetKfoSd9GlrSn6HXXX3anufr8cHPY489xtNPP93iOYcPH+6051+xYgWjRo3if/7nf9p13cqVK3nyyScbHd+wYQPh4eGhah4AGRkZZ31tvk/N9thqa/jki80A6Fwe1q1bh9dTCsCWI/sYcKIcgEKfGtCZ0LI14zM0Gs3ZN7wH60ifisakP0NP+jS0pD9Dr6v71G5vekeCpvT44OeRRx7hzjvvbPGcIUOGkJycTFFRUdBxj8dDWVkZycnJTV6XnJyMy+WioqIiKPtTWFgYuOazzz5j//79vPvuuwAoipoqiY+P5+c//3mTAQ6oQdOyZcsCn9tsNtLS0pg7dy5Wa2jWx3G73WRkZHD55ZdjMBjO6h451eX8ccMxfHotoydPhK9Okhodx4JLF2DOO8rar97HHmliwewFAHxRcAK2HWWgNY4r51wZktfRk4SiT0U96c/Qkz4NLenP0OuuPvWPsLRFjw9+EhISSEhIaPW8mTNnUlFRwa5du5gyZQqgBi4+n48ZM2Y0ec2UKVMwGAxs3LiRRYsWAZCZmUlOTg4zZ84E4N///je1tfWbfX7zzTfcfffdfPHFFwwdOrTZ9phMJkwmU6PjBoMh5G+GjtzTYg4D1ILnGp+aMowyhWEwGEiPSwHgRFUpWp0OnVZLgVMdGkuzRPfqHxSd8XXqy6Q/Q0/6NLSkP0Ovq/u0Pc/V44Oftho1ahTz589nyZIlrF69GrfbzdKlS7n55ptJTU0FIDc3l9mzZ/PGG28wffp0oqKiWLx4McuWLSM2Nhar1cqPf/xjZs6cyXnnnQfQKMApKSkJPN+ZtULnIv9sL6+iUO5Ug7zIun29+odHYdbpcXg95NRUMDgytsEaP1LsLIQQ4tzUq6Yuvfnmm6SnpzN79mwWLFjArFmzeOmllwKPu91uMjMzg8YF//znP3PVVVexaNEiLrroIpKTk3nvvfe6o/ndwj/bC6DYoWZ1LHX7dem0WobWbXNxtLIYaLDAocz0EkIIcY7qNZkfgNjYWNasWdPs44MGDQrU7PiZzWZWrVrFqlWr2vQcl1xySaN7nMuMWh0aQKF+B3eLoX64bnhUAgcrCvl/h7bym283BBZB7C+rOwshhDhH9argR7SfRqPBVDe05Z/CHnlG8AOwvzw/6LpBkTFd10ghhBAihCT4EZh1hqDgp2HmJz1aXTtJq9Hw0NiL0Gm0RBpMpEcndUtbhRBCiI6S4EcEip6L/ZkffX3wc2HSEH464TImxKYyI3Fgt7RPCCGECCUJfgSmuuCn3KUWgjfM/Oi0Wu5Nn9kt7RJCCCE6Q6+a7SXOjn/Gl6+ukLthzY8QQgjR20jwIwLDXn7+qe5CCCFEbyTBj2gi+JHMjxBCiN5Lgh8RqPnxk+BHCCFEbybBjwha5Rmk5kcIIUTvJsGPCBr20mo0hOlkcz8hhBC9lwQ/Iij4sehNaDSabmyNEEII0bkk+BGYGmR6ZMhLCCFEbyfBj8Csb5D5keBHCCFELyfBjwge9pI1foQQQvRyEvyIoNleMuwlhBCit5PgRwSt8yPDXkIIIXo7CX5Eo9leQgghRG8mwY8IGvaSzI8QQojeToIfEZT5kZofIYQQvZ0EP+KM2V4S/AghhOjdJPgRQYscylR3IYQQvZ0EP0KGvYQQQvQpEvwIGfYSQgjRp0jwI4IXOZSp7kIIIXo5CX6EZH6EEEL0Kb0q+CkrK+PWW2/FarUSHR3N4sWLqa6ubvEah8PB/fffT1xcHBaLhUWLFlFYWNjovNdff53x48djNptJTEzk/vvv76yX0eVMUvMjhBCiD+lVwc+tt97KwYMHycjI4KOPPmLLli3ce++9LV7z8MMP8+GHH/LOO+/w+eefk5eXx/XXXx90zrPPPsvPf/5zHnvsMQ4ePMinn37KvHnzOvOldCmLwYRJp8ek02M1mru7OUIIIUSn0rd+yrnh8OHDrF+/nm+++YapU6cC8MILL7BgwQKeeeYZUlNTG11TWVnJK6+8wpo1a7jssssAeO211xg1ahRfffUV5513HuXl5Tz++ON8+OGHzJ49O3Dt+PHju+aFdQGTTs/fZt2AhuAskBBCCNEb9ZrMz/bt24mOjg4EPgBz5sxBq9WyY8eOJq/ZtWsXbrebOXPmBI6lp6czYMAAtm/fDkBGRgY+n4/c3FxGjRpF//79ufHGGzl16lTnvqAudmHyEGYlD+nuZgghhBCdrtf8mV9QUEBiYmLQMb1eT2xsLAUFBc1eYzQaiY6ODjqelJQUuObEiRP4fD6eeuopnn/+eaKionj88ce5/PLL2bdvH0Zj04sCOp1OnE5n4HObzQaA2+3G7Xaf7csM4r9PqO4npE9DTfoz9KRPQ0v6M/S6q0/b83w9Pvh57LHHePrpp1s85/Dhw532/D6fD7fbzV/+8hfmzp0LwL/+9S+Sk5PZtGlTs7U/K1eu5Mknn2x0fMOGDYSHh4e0jRkZGSG9n5A+DTXpz9CTPg0t6c/Q6+o+tdvtbT63xwc/jzzyCHfeeWeL5wwZMoTk5GSKioqCjns8HsrKykhOTm7yuuTkZFwuFxUVFUHZn8LCwsA1KSkpAIwePTrweEJCAvHx8eTk5DTbphUrVrBs2bLA5zabjbS0NObOnYvVam3x9bSV2+0mIyODyy+/HIPB0PoFolXSp6El/Rl60qehJf0Zet3Vp/4Rlrbo8cFPQkICCQkJrZ43c+ZMKioq2LVrF1OmTAHgs88+w+fzMWPGjCavmTJlCgaDgY0bN7Jo0SIAMjMzycnJYebMmQBccMEFgeP9+/cH1Cn1JSUlDBw4sNn2mEwmTKbG08YNBkPI3wydcc++Tvo0tKQ/Q0/6NLSkP0Ovq/u0Pc/VawqeR40axfz581myZAlff/01W7duZenSpdx8882BmV65ubmkp6fz9ddfAxAVFcXixYtZtmwZmzZtYteuXdx1113MnDmT8847D4ARI0Zw7bXX8uCDD7Jt2zYOHDjAHXfcQXp6Opdeemm3vV4hhBBCnJ1eE/wAvPnmm6SnpzN79mwWLFjArFmzeOmllwKPu91uMjMzg8YF//znP3PVVVexaNEiLrroIpKTk3nvvfeC7vvGG28wY8YMrrzySi6++GIMBgPr16+XvxKEEEKIc1CPH/Zqj9jYWNasWdPs44MGDUJRlKBjZrOZVatWsWrVqmavs1qtvPLKK7zyyisha6sQQgghukevyvwIIYQQQrSmV2V+ejJ/xqk91eitcbvd2O12bDabDMGFiPRpaEl/hp70aWhJf4Zed/Wp//frmSM8TZHgp4tUVVUBkJaW1s0tEUIIIXqvqqoqoqKiWjxHo7QlRBId5vP5yMvLIzIyEo1GE5J7+tcOOnXqVMjWDurrpE9DS/oz9KRPQ0v6M/S6q08VRaGqqorU1FS02pareiTz00W0Wm1gnaBQs1qt8k0bYtKnoSX9GXrSp6El/Rl63dGnrWV8/KTgWQghhBB9igQ/QgghhOhTJPg5h5lMJn75y182uY2GODvSp6El/Rl60qehJf0ZeudCn0rBsxBCCCH6FMn8CCGEEKJPkeBHCCGEEH2KBD9CCCGE6FMk+DmHrVq1ikGDBmE2m5kxYwZff/11dzfpnPCrX/0KjUYT9JGenh543OFwcP/99xMXF4fFYmHRokUUFhZ2Y4t7ni1btnD11VeTmpqKRqPhgw8+CHpcURSeeOIJUlJSCAsLY86cORw9ejTonLKyMm699VasVivR0dEsXryY6urqLnwVPUdr/XnnnXc2es/Onz8/6Bzpz3orV65k2rRpREZGkpiYyMKFC8nMzAw6py3f5zk5OVx55ZWEh4eTmJjI8uXL8Xg8XflSeoy29Okll1zS6H36wx/+MOicntKnEvyco95++22WLVvGL3/5S3bv3s2ECROYN28eRUVF3d20c8KYMWPIz88PfHz55ZeBxx5++GE+/PBD3nnnHT7//HPy8vK4/vrru7G1PU9NTQ0TJkxg1apVTT7+hz/8gb/85S+sXr2aHTt2EBERwbx583A4HIFzbr31Vg4ePEhGRgYfffQRW7Zs4d577+2ql9CjtNafAPPnzw96z/7rX/8Kelz6s97nn3/O/fffz1dffUVGRgZut5u5c+dSU1MTOKe173Ov18uVV16Jy+Vi27Zt/P3vf+f111/niSee6I6X1O3a0qcAS5YsCXqf/uEPfwg81qP6VBHnpOnTpyv3339/4HOv16ukpqYqK1eu7MZWnRt++ctfKhMmTGjysYqKCsVgMCjvvPNO4Njhw4cVQNm+fXsXtfDcAijvv/9+4HOfz6ckJycrf/zjHwPHKioqFJPJpPzrX/9SFEVRDh06pADKN998Ezjn448/VjQajZKbm9tlbe+JzuxPRVGUO+64Q7n22mubvUb6s2VFRUUKoHz++eeKorTt+3zdunWKVqtVCgoKAuf89a9/VaxWq+J0Orv2BfRAZ/apoijKxRdfrDz44IPNXtOT+lQyP+cgl8vFrl27mDNnTuCYVqtlzpw5bN++vRtbdu44evQoqampDBkyhFtvvZWcnBwAdu3ahdvtDurb9PR0BgwYIH3bRidPnqSgoCCoD6OiopgxY0agD7dv3050dDRTp04NnDNnzhy0Wi07duzo8jafCzZv3kxiYiIjR47kvvvuo7S0NPCY9GfLKisrAYiNjQXa9n2+fft2xo0bR1JSUuCcefPmYbPZOHjwYBe2vmc6s0/93nzzTeLj4xk7diwrVqzAbrcHHutJfSp7e52DSkpK8Hq9QW8ggKSkJI4cOdJNrTp3zJgxg9dff52RI0eSn5/Pk08+yYUXXsiBAwcoKCjAaDQSHR0ddE1SUhIFBQXd0+BzjL+fmnp/+h8rKCggMTEx6HG9Xk9sbKz0cxPmz5/P9ddfz+DBgzl+/Dg/+9nPuOKKK9i+fTs6nU76swU+n4+HHnqICy64gLFjxwK06fu8oKCgyfew/7G+rKk+Bfj+97/PwIEDSU1NZd++ffz0pz8lMzOT9957D+hZfSrBj+hzrrjiisD/x48fz4wZMxg4cCD/93//R1hYWDe2TIim3XzzzYH/jxs3jvHjxzN06FA2b97M7Nmzu7FlPd/999/PgQMHgur6RMc016cNa8zGjRtHSkoKs2fP5vjx4wwdOrSrm9kiGfY6B8XHx6PT6RrNTCgsLCQ5ObmbWnXuio6OZsSIERw7dozk5GRcLhcVFRVB50jftp2/n1p6fyYnJzcqzvd4PJSVlUk/t8GQIUOIj4/n2LFjgPRnc5YuXcpHH33Epk2b6N+/f+B4W77Pk5OTm3wP+x/rq5rr06bMmDEDIOh92lP6VIKfc5DRaGTKlCls3LgxcMzn87Fx40ZmzpzZjS07N1VXV3P8+HFSUlKYMmUKBoMhqG8zMzPJycmRvm2jwYMHk5ycHNSHNpuNHTt2BPpw5syZVFRUsGvXrsA5n332GT6fL/ADUzTv9OnTlJaWkpKSAkh/nklRFJYuXcr777/PZ599xuDBg4Meb8v3+cyZM9m/f39QUJmRkYHVamX06NFd80J6kNb6tCl79uwBCHqf9pg+7dLyahEyb731lmIymZTXX39dOXTokHLvvfcq0dHRQVX0ommPPPKIsnnzZuXkyZPK1q1blTlz5ijx8fFKUVGRoiiK8sMf/lAZMGCA8tlnnyk7d+5UZs6cqcycObObW92zVFVVKd9++63y7bffKoDy7LPPKt9++62SnZ2tKIqi/P73v1eio6OV//znP8q+ffuUa6+9Vhk8eLBSW1sbuMf8+fOVSZMmKTt27FC+/PJLZfjw4cott9zSXS+pW7XUn1VVVcqjjz6qbN++XTl58qTy6aefKpMnT1aGDx+uOByOwD2kP+vdd999SlRUlLJ582YlPz8/8GG32wPntPZ97vF4lLFjxypz585V9uzZo6xfv15JSEhQVqxY0R0vqdu11qfHjh1Tfv3rXys7d+5UTp48qfznP/9RhgwZolx00UWBe/SkPpXg5xz2wgsvKAMGDFCMRqMyffp05auvvuruJp0TbrrpJiUlJUUxGo1Kv379lJtuukk5duxY4PHa2lrlRz/6kRITE6OEh4cr1113nZKfn9+NLe55Nm3apACNPu644w5FUdTp7r/4xS+UpKQkxWQyKbNnz1YyMzOD7lFaWqrccsstisViUaxWq3LXXXcpVVVV3fBqul9L/Wm325W5c+cqCQkJisFgUAYOHKgsWbKk0R860p/1mupLQHnttdcC57Tl+zwrK0u54oorlLCwMCU+Pl555JFHFLfb3cWvpmdorU9zcnKUiy66SImNjVVMJpMybNgwZfny5UplZWXQfXpKn8qu7kIIIYToU6TmRwghhBB9igQ/QgghhOhTJPgRQgghRJ8iwY8QQggh+hQJfoQQQgjRp0jwI4QQQog+RYIfIYQQQvQpEvwIIYQQok+R4EcIIYQQfYoEP0IIIYToUyT4EUKILvDoo4+ycOHC7m6GEAIJfoQQ56g777zznAom9uzZw8SJE7u7GUIIJPgRQoiQcLlcLT6+d+9eCX6E6CEk+BFC9Drr169n1qxZREdHExcXx1VXXcXx48cDj7/xxhvExcXhdDqDrlu4cCG33XYbAD6fj5UrVzJ48GDCwsKYMGEC7777buDcSy65hKVLl/LQQw8RHx/PvHnzmm3P6dOnKSkpCQQ/FRUVXH311cyaNYuCgoIQvnIhRFtI8COE6HVqampYtmwZO3fuZOPGjWi1Wq677jp8Ph8AN9xwA16vl//+97+Ba4qKili7di133303ACtXruSNN95g9erVHDx4kIcffpj/+Z//4fPPPw9c8/e//x2j0cjWrVtZvXp1s+3Zs2cP0dHRDBo0iP379zNt2jT69evHpk2bSE5O7qReEEI0R6MoitLdjRBCiPa68847qaio4IMPPmj13JKSEhISEti/fz9jx44F4Ec/+hFZWVmsW7cOgGeffZZVq1Zx7NgxXC4XsbGxfPrpp8ycOTNwn3vuuQe73c6aNWu45JJLsNls7N69u9Xn/+1vf8unn37Kvffey9KlS3n66adZsmTJ2b1wIUSH6bu7AUIIEWpHjx7liSeeYMeOHZSUlAQyPjk5OYHgZ8mSJUybNo3c3Fz69evH66+/zp133olGo+HYsWPY7XYuv/zyoPu6XC4mTZoU+HzKlCltas+ePXvYt28fS5cuZe3atUEBlRCi60nwI4Toda6++moGDhzIyy+/TGpqKj6fj7FjxwYVJU+aNIkJEybwxhtvMHfuXA4ePMjatWsBqK6uBmDt2rX069cv6N4mkynw/4iIiDa1Z8+ePVx//fWsWbOGioqKDr46IURHSfAjhOhVSktLyczM5OWXX+bCCy8E4Msvv2zy3HvuuYfnnnuO3Nxc5syZQ1paGgCjR4/GZDKRk5PDxRdf3KH2VFVVceLECd555x3OP/98br75ZrZt28aYMWM6dF8hxNmT4EcIcc6qrKxkz549QcdiYmKIi4vjpZdeIiUlhZycHB577LEmr//+97/Po48+yssvv8wbb7wROB4ZGcmjjz7Kww8/jM/nY9asWVRWVrJ161asVit33HFHm9u4d+9edDodo0ePZtKkSRw4cICrr76ar7/+mvj4+LN63UKIjpHgRwhxztq8eXNQDQ7A4sWLeeutt3jggQcYO3YsI0eO5C9/+QuXXHJJo+ujoqJYtGgRa9eubbRg4m9+8xsSEhJYuXIlJ06cIDo6msmTJ/Ozn/2sXW3cs2cP6enpgeGyP/7xjxw+fJjrr7+eTz/9FKPR2K77CSE6TmZ7CSH6tNmzZzNmzBj+8pe/dHdThBBdRIIfIUSfVF5ezubNm/ne977HoUOHGDlyZHc3SQjRRWTYSwjRJ02aNIny8nKefvppCXyE6GMk8yOEEEKIPkW2txBCCCFEnyLBjxBCCCH6FAl+hBBCCNGnSPAjhBBCiD5Fgh8hhBBC9CkS/AghhBCiT5HgRwghhBB9igQ/QgghhOhTJPgRQgghRJ8iwY8QQggh+hQJfoQQQgjRp/x/gezI9QfBNL0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 585x325 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_plot = 1\n",
    "\n",
    "index = np.random.choice(conv1_flatten.shape[0], n_plot)  \n",
    "\n",
    "\n",
    "a, b = 4.5, 2.5\n",
    "p = 1.3\n",
    "lw = .3\n",
    "ms = .2\n",
    "\n",
    "color1 = '#9467BD'  # Purple\n",
    "color2 =  plt.cm.viridis(.6) #'#FFA500'  # Yellow-Orange\n",
    "\n",
    "plt.figure(figsize=(p * a, p * b))\n",
    "\n",
    "plt.plot(conv1_flatten[:, index], color=color2, label=\"$i=1$\")\n",
    "plt.xlabel(\"Layer $k$\")\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.plot(conv2_flatten[:, index], color=color1, label=\"$i=2$\")\n",
    "plt.xlabel(\"Layer $k$\")\n",
    "plt.ylabel('A coeff. of $\\mathrm{conv_{i,k}^L}$')\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
