{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e7ae3742-88fe-4e60-bb2b-ddb5a1db23b8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_101/1836336639.py:79: UserWarning: Creating a tensor from a list of numpy.ndarrays is extremely slow. Please consider converting the list to a single numpy.ndarray with numpy.array() before converting to a tensor. (Triggered internally at /opt/pytorch/pytorch/torch/csrc/utils/tensor_new.cpp:230.)\n",
      "  D = torch.tensor(D, dtype=torch.float32).cuda()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n"
     ]
    }
   ],
   "source": [
    "import math\n",
    "import numpy\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch import nn, optim\n",
    "\n",
    "M = 2\n",
    "d = 1024\n",
    "n_ = 100\n",
    "dh = 512\n",
    "dv = 512\n",
    "cp = 4\n",
    "class TF(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.q = nn.Linear(d, dh, bias=False)\n",
    "        self.k = nn.Linear(d, dh, bias=False)\n",
    "        self.v = nn.Linear(d, dv, bias=False)\n",
    "        self.fc = nn.Linear(dv, 1, bias=False)\n",
    "        self.fc.requires_grad_(False)\n",
    "        self.q.weight.data /= 16\n",
    "        self.k.weight.data /= 16\n",
    "        self.v.weight.data /= 16\n",
    "\n",
    "\n",
    "    def forward(self, x):\n",
    "        q = self.q(x)\n",
    "        k = self.k(x)\n",
    "        v = self.v(x)\n",
    "        qk = torch.matmul(q, k.transpose(1, 2))\n",
    "        attn = qk.softmax(dim=2)\n",
    "        attn = torch.sum(attn, dim=1).unsqueeze(1)\n",
    "        attn /= M\n",
    "        z = torch.matmul(attn, v).squeeze(1)\n",
    "        return self.fc(z)\n",
    "\n",
    "def make_mu1(mu):\n",
    "    mu1 = numpy.zeros(d)\n",
    "    mu1[0] = mu\n",
    "    return mu1\n",
    "\n",
    "def make_mu2(mu):\n",
    "    mu2 = numpy.zeros(d)\n",
    "    mu2[1] = mu\n",
    "    return mu2\n",
    "\n",
    "def make_noise(strength):\n",
    "    return numpy.random.normal(0, strength, size=d)\n",
    "\n",
    "\n",
    "def Get_test_loss(n, mu):\n",
    "    D = []\n",
    "    D_Y = []\n",
    "    D_ = []\n",
    "    D_Y_ = []\n",
    "\n",
    "    mu1 = make_mu1(mu)\n",
    "    mu2 = make_mu2(mu)\n",
    "\n",
    "    D_mu = []\n",
    "    D_mu_ = []\n",
    "\n",
    "    for i in range(int(n / 2)):\n",
    "        X = mu1.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        D_Y.append([1.])\n",
    "        D_mu.append(mu1.reshape(1, d))\n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D.append(X)\n",
    "        D_Y.append([-1.])\n",
    "        D_mu.append(mu2.reshape(1, d))\n",
    "\n",
    "    D = torch.tensor(D, dtype=torch.float32).cuda()\n",
    "    D_Y = torch.tensor(D_Y).cuda()\n",
    "\n",
    "    for i in range(int(n_ / 2)):\n",
    "        X = mu1.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D_.append(X)\n",
    "        D_Y_.append([1.])\n",
    "        D_mu_.append(mu1.reshape(1, d))\n",
    "        X = mu2.copy().reshape(1, d)\n",
    "        X = numpy.concatenate((X, (make_noise(cp)).reshape(1, d)), 0)\n",
    "        for j in range(M - 2):\n",
    "            X = numpy.concatenate((X, (make_noise(0.2)).reshape(1, d)), 0)\n",
    "        D_.append(X)\n",
    "        D_Y_.append([-1.])\n",
    "        D_mu_.append(mu2.reshape(1, d))\n",
    "\n",
    "    D_ = torch.tensor(D_, dtype=torch.float32).cuda()\n",
    "    D_Y_ = torch.tensor(D_Y_).cuda()\n",
    "\n",
    "    model = TF().cuda()\n",
    "\n",
    "    optimizer = optim.SGD(model.parameters(), lr=0.1, momentum=0)\n",
    "    loss_fn = nn.SoftMarginLoss().cuda()\n",
    "    EPOCHS = 1000\n",
    "\n",
    "    test_losses = []\n",
    "    for epoch in range(1, EPOCHS + 1):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        output = model(D)\n",
    "\n",
    "        training_loss = loss_fn(output, D_Y)\n",
    "        training_loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        model.eval()\n",
    "        output = model(D_)\n",
    "        test_loss = loss_fn(output, D_Y_)\n",
    "        # return test_loss\n",
    "        if epoch%10 == 0:\n",
    "            test_losses.append(test_loss.item())\n",
    "\n",
    "    return test_losses  \n",
    "        \n",
    "        \n",
    "size = 20\n",
    "n_scale = 2\n",
    "mu_scale = 1\n",
    "# matrix = np.zeros((size, 100))\n",
    "# for n in range(size):\n",
    "#     print(n)\n",
    "#     for mu in range(100):\n",
    "#         matrix[n, mu] = get_test_loss(100, (mu + 1) * mu_scale)\n",
    "# np.savetxt('n100.npy', matrix)\n",
    "\n",
    "matrix1 = np.zeros((20, 100))\n",
    "for n in range(20):\n",
    "    print(n)\n",
    "    test_losses = Get_test_loss(100, 16)\n",
    "    matrix1[n, :] = test_losses\n",
    "np.savetxt('16.npy', matrix1)\n",
    "                                      \n",
    "matrix2 = np.zeros((20, 100))\n",
    "for n in range(20):\n",
    "    print(n)\n",
    "    test_losses = Get_test_loss(100, 36)\n",
    "    matrix2[n, :] = test_losses\n",
    "np.savetxt('36.npy', matrix2)\n",
    "\n",
    "matrix3 = np.zeros((20, 100))\n",
    "for n in range(20):\n",
    "    print(n)\n",
    "    test_losses = Get_test_loss(100, 64)\n",
    "    matrix3[n, :] = test_losses\n",
    "np.savetxt('64.npy', matrix3)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4a276e87-c21b-4bdd-8b3b-9fe052a70319",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmwAAAHOCAYAAAAlqVVdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACAsUlEQVR4nO3dd3gUVdsG8HvSliSbKhAghYTekRJQUsDQpAgCgoCKwQKKoCh+QsACioLoK4IgRZQIihQFlCa9g9QAAtIDhNASID2kbM73x7pjNtndbLJJdrK5f9c1V2Znzpx5TnZhn5yZOUcSQggQERERkWLZWTsAIiIiIjKNCRsRERGRwjFhIyIiIlI4JmxERERECseEjYiIiEjhmLARERERKRwTNiIiIiKFY8JGREREpHBM2IiIiIgUzmYTtlWrVqFTp07w8vKCq6srWrZsiRkzZiAnJ6dY9Rw4cACjRo3C448/Dl9fX1SpUgWurq5o0qQJxowZg6tXr5o8/tKlS4iMjISfnx9UKhX8/PwQGRmJK1euWNA6IiIiqkwkW5yaauzYsZg1axYcHBwQEREBtVqNHTt2ICkpCaGhodiyZQucnZ3Nquv999/Hp59+ioCAANStWxc+Pj5ITk7G8ePHcefOHbi6umL9+vXo1KlToWP379+Pbt26ISMjA02bNkWzZs1w+vRpnDlzBq6urti2bRsee+yxUm49ERER2RqbS9jWrl2Lfv36Qa1WY/fu3WjdujUAIDExEREREfj7778xbtw4fPnll2bV988//8DZ2RmBgYF627Ozs/Hee+9h1qxZ8PPzw9WrV2Fvby/vz8jIQP369XHz5k1ERUXhs88+k/dNnDgR06ZNg7+/P86fP2928ggAeXl5uHnzJtzc3CBJktnHERERkfUIIZCamopatWrBzq4EFziFjQkODhYAxNSpUwvt27t3rwAgVCqVSEpKsvhc2dnZokqVKgKAOHXqlN6+uXPnCgCiQYMGQqPR6O3TaDSiQYMGAoCYP39+sc4ZFxcnAHDhwoULFy5cKuASFxdXopzDATYkPj4eR44cAQAMHTq00P7Q0FD4+/sjLi4OGzduxJAhQyw6nyRJcpasUqn09q1ZswYAMHjw4EKZtJ2dHZ599ll88sknWL16NUaOHGn2Od3c3AAAcXFxcHd3tyR8IiIiKicpKSnw9/eXv8eLy6YStpiYGACAt7c3goKCDJZp27Yt4uLiEBMTY1HCptFoMGXKFGRkZKBJkyaoV6+ewVjatm1rNI785cyluwzq7u7OhI2IiKiCKentTDaVsMXGxgIAAgICjJbx9/fXK2uu69ev48MPPwQA3L9/HzExMbhx4wbq1auHlStX6vWipaam4t69eyZj0cWRkJCA9PR0uLq6FiseIiIiqjxsKmFLTU0FAJPJj1qtBqDtmiyO+/fv48cff9Tb1rp1a/zwww9o2rSpwThMxaKLQxeLsXJZWVnIysrSK0tERESVi82Ow1baHn30UQghkJeXhxs3bmDlypXIyMhAmzZtMHv27DI777Rp0+Dh4SEvup45IiIiqjxsKmHT3ciXnp5utExaWhoAlPj+L0mS4Ovri4EDB+LgwYPw8fHB22+/jZMnTxaKw1QsujiKiiUqKgrJycnyEhcXV6K4iYiIqOKyqYRNN1aaqaRGt6/guGol4enpiX79+iEvLw9//PGHvN3NzQ3e3t4AtPe+mYqjatWqJi/hqlQq+QEDPmhARERUOdlUwtaqVSsAwL1794w+VHD06FEAkAfUtZQu2bp7967edl39uvOVdRxERERku2zqoQM/Pz8EBwfjyJEjWLZsGSZNmqS3f9++fYiLi4NKpULPnj1L5Zw7duwAADRo0EBve79+/bBt2zYsX74cH330kd5TpHl5eVixYgUAoH///qUSBxERKVdOTg40Go21w6BSZG9vD0dHx3I7X6WZmurevXt44oknDE5NtWbNGkRFRcHX1xfbt2/Xq2/atGl45ZVXUK1aNb3tDx48wIcffog5c+bAw8MD58+fh4+Pj7w//9RUEydOxKeffirvmzRpEj777DP4+fnhwoULxZqaKiUlBR4eHkhOTublUSIihUtJSUFiYqLe0/5kO1QqFapWrWrW97Gl3982l7ABwFtvvYXZs2fD0dERnTt3hqurK7Zv346kpCSEhIRg69ateklSdHQ0hg8fjtq1a+Pq1at6dUmSBHt7ezRv3hx169aFg4MD4uPjERMTg/T0dHh4eGDVqlXo2rVroTjyT/7erFkzefL306dPl3jydyZsREQVQ0pKCuLj46FWq+Hh4QFHR0fOAW0jhBDIyclBcnIy0tLS4OvrW+R3sqXf3zZ1SVRn1qxZCAkJwdy5c3HgwAHk5OSgbt26mDBhAt5++204OTmZXdecOXOwd+9exMTEYPv27UhLS4ObmxuaN2+O7t274/XXX9frWcsvJCQEJ0+exCeffIJt27bht99+Q7Vq1TBs2DB8+OGHqFu3bmk1mYiIFCYxMRFqtRp+fn5M1GyQs7Mz3NzccOPGDSQmJpZ5J4pN9rDZMvawEREpX05ODi5dumRWzwtVbLqe1Hr16pm8p83S72+bekqUiIhICXQPGJTnTelkHbr3uKwfKmHCRrKjR4GEBGtHQURkO3gp1PaV13vMhI0AAO++CwQHA199Ze1IiIiIqCAmbAQACA/X/pw7F3jwwLqxEBERkT4mbAQA6N0baNECSE0FvvnG2tEQERFRfkzYCABgZwfoJob4+mtt4kZERFSRfPPNNxg+fDhatGgBBwcHSJKEXbt2FXncyZMnMXToUPj6+kKlUqFWrVro0aMHdu7cWfZBm8kmx2GjkhkwAGjYEDh/Hpg3D3jvPWtHREREZL4333wTAFCzZk1Uq1YNt2/fLvKYJUuW4KWXXoKHhwd69+4NX19fJCYm4ujRozhw4ACeeOKJsg7bLEzYSGZvD0ycCLz4IvC//wGjRwMuLtaOioiIyDzr169HmzZtUKNGDbz22mtYsGCByfLHjh3Dyy+/jODgYGzcuBFeXl56+3Nzc8sy3GLhJVHSM2QIEBgI3L0LLFpk7WiIiKiiio6OhiRJiI6OLrRv165dkCQJkydPLtVz9urVCzVq1DC7/KRJk6DRaLB06dJCyRoAODgop1+LCRvpcXQEJkzQrs+YAXC+YiIiskVJSUnYsmULWrVqhXr16mH37t344osvMHPmTBw4cMDa4RWinNSRFCMyEvj4YyA+HvjxR2DECGtHRERkG4QAMjKsHUXRXFyA8h7zd9euXWY9IKATGBiIyMjIEp/v+PHjEELA398fTz31FNavX6+3v2vXrli1ahU8PDxKfI7SxISNClGptA8cjB0LTJ8OvPQSoKBeYSKiCisjA1CrrR1F0dLSAFfX8j3nrl27MGXKFLPLd+zY0aKE7e7duwC0971VrVoVa9euxRNPPIGbN29i/Pjx+OOPPzBixAisWLGixOcoTbwkSga9+ipQrRoQGwv88ou1oyEiIls3efJkCCHMXorTG2dIXl4eAO0coPPnz0ffvn3h7u6ORo0aYeXKlQgICMCqVasQFxdXCq2zHPtNyCAXF2DcOO39bJ99Bgwdqn2KlIiISs7FRdt7pXSVYYQA3aVOe3t79OrVS2+fSqVCt27dsGjRIhw7dgz+/v7WCFEPEzYy6vXXgc8/B86dA1avBgYOtHZEREQVmySV/6VGaxNCFNr28OHDQtvK+x62hg0bAgBcXFzg6OhYaL+npycAIDMzs8TnKE1M2Mgod3fgrbeAyZOBqVOBZ54p/5tQiYioYrt582ahbRcvXiy0rbzvYatbty4CAgJw/fp13LhxA35+fnr7z549C0CbGCoB72Ejk8aM0d4ge+oUUOABGiIioiL9/PPPej1qKSkpmDt3LgD9gWnL+x42SZLw2muvAQAmTpwo39MGALt378amTZsQGBiI4OBgi85TWtjDRiZ5ewNvvKG9NDp1qnaSePayERGRue7evYtmzZqhZ8+eyMnJwYYNG+QBaZctWwaNRoNp06aVyrmmT5+Oc+fOAQAOHjwob9MN3vv000/j6aeflsu/8847WL9+PZYuXYqzZ88iPDwct27dwm+//QaVSoUffvhBMYPnKiMKUrR33gFmzwYOHwa2bQO6drV2REREVFFMnjwZx44dw9KlS5GTk4Pu3btjzpw5ePfdd7F69WpcunSp1M71559/Yvfu3XrbNm/eLK8HBgbqJWwqlQpbt27F9OnT8csvv2Du3LlQq9Xo3bs3PvroI7Rs2bLUYrOUJAzdDUiKlZKSAg8PDyQnJ8Pd3b3czjt2LDBrFtCxI2BhLzQRkc17+PAhYmNjERQUhCpVqlg7HKuIjo7G8OHDsXjxYovuNVM6c99rS7+/eQ8bmeXddwEnJ2D3bmDvXmtHQ0REVLkwYSOz+PkBw4dr1z/91LqxEBERVTZM2Mhs48drB8/dvBk4csTa0RAREVUeTNjIbEFBwPPPa9fZy0ZERKZERkZCCGHT96+VJyZsVCxRUdphPX7/XTs2GxEREZU9JmxULA0b/jdF1WefWTcWIiKiyoIJGxXbpEnanytXAufPWzcWIiKiyoAJGxVbixZAnz6AEMD06daOhoiIyPYxYaMS0fWyLV0KXL1q1VCIiIhsHhM2KpF27YBu3QCNRjvPKBEREZUdJmxUYu+/r/35ww9AfLx1YyEiIrJlTNioxMLCgPBwIDsb+PJLa0dDRERku5iwkUV097ItWADcvWvdWIiIiGwVEzaySNeuQHAwkJkJzJxp7WiIiIhsExM2sogk/Xcv29y5wIMH1o2HiIgqpzt37mD06NFo3749fHx8oFKp4Ofnh86dO2P16tUQQhg99uTJkxg6dCh8fX2hUqlQq1Yt9OjRAzt37izHFpjGhI0s1ru3dmy21FTgm2+sHQ0REVVGcXFxWLJkCTw8PNCvXz+MGzcOTz75JE6fPo0BAwZgxIgRBo9bsmQJ2rRpg82bN6NLly4YN24cevfujTt37uDAgQPl3ArjJGEq5STFSUlJgYeHB5KTk+Hu7m7tcGQrVwLPPgt4eQHXrgFubtaOiIjIeh4+fIjY2FgEBQWhSpUq1g6nUsjJyYGdnR3s7e31tqempqJ9+/b4559/cPr0aTRt2lTed+zYMTz22GNo27YtNm7cCC8vL71jc3Nz4eDgYPK85r7Xln5/s4eNSsWAAdp5Rh88AObNs3Y0RERkbdHR0ZAkCdHR0YX27dq1C5IkYfLkyaV2PkdHx0LJGgC4ubnhySefBABcunRJb9+kSZOg0WiwdOnSQskagCKTtfLEhI1Khb09MHGidv1//wMyMqwbDxEREaDtAduxYwckSdLrXUtKSsKWLVvQqlUr1KtXD7t378YXX3yBmTNnKupSqI5yUkeq8IYMASZPBmJjgUWLgDfftHZEREQKI0TF+IvWxUX7VFk52rVrF3bt2mV2+cDAQERGRhbafvfuXXz77bfIy8vD3bt3sXHjRsTFxeGjjz5CvXr15HLHjx+HEAL+/v546qmnsH79er16unbtilWrVsHDw6OkTSpVTNio1Dg6AuPHA6+9BsyYAYwcCahU1o6KiEhBMjIAtdraURQtLQ1wdS3XU+7atQtTpkwxu3zHjh2NJmz563F0dMQXX3yBcePGFSoHAOvXr0fVqlWxdu1aPPHEE7h58ybGjx+PP/74AyNGjMCKFStK1qBSZrOXRFetWoVOnTrBy8sLrq6uaNmyJWbMmIGcnJxi1RMTE4Np06ahc+fO8PHxgaOjI7y8vBAWFoa5c+carU93fd7UMn/+/NJoqqJERgK1ammnqvrxR2tHQ0REFcXkyZMhhDB7MdYb16xZMwghkJubi9jYWEyZMgWTJk3CgAEDkJubK5fLy8sDAGg0GsyfPx99+/aFu7s7GjVqhJUrVyIgIACrVq1CXFxceTS/SDbZwzZ27FjMmjULDg4OiIiIgFqtxo4dOzB+/HisW7cOW7ZsgbOzc5H15ObmonXr1gAAtVqN4OBg+Pj44MaNGzh48CD27duHJUuWYPPmzfD09DRYh4+Pj3yzY0ENGzYscRuVSqUC3nsPGDsWmD4deOklQEH3bBIRWZeLi7b3SulcXKwdgcXs7e0RGBiIqKgoODg44L333sN3332H119/HQDkS5329vbo1auX3rEqlQrdunXDokWLcOzYMfj7+5d7/AXZ3Ffp2rVrMWvWLKjVauzevVtOuBITExEREYF9+/bhgw8+wJdmTn7Zpk0bjB8/Hn369IEq3/W9v//+G927d8fhw4fxzjvv4IcffjB4fKNGjQw+IWPLXn0V+PRT7b1sv/wCvPCCtSMiIlIISSr3S43WZmj0sIcPHxbaVlr3sBnSrVs3vPfee9i1a5ecsOk6TVxcXODo6FjoGF1HTGZmptkxlSWbS9g+++wzAMCECRPkZA0Aqlatim+//RZhYWGYM2cOPvjggyJvJHRwcMDRo0cN7mvevDlmzJiBF154AcuXL8eCBQsMvuGVkYsLMG4cMGEC8NlnwNCh2qdIiYio8rl582ahbRcvXiy0rbTuYTMVQ/7v6bp16yIgIADXr1/HjRs34Ofnp3fM2bNnAWgTQyWwqXvY4uPjceTIEQDA0KFDC+0PDQ2Fv78/srKysHHjRovP16pVKwDa7DsxMdHi+mzJ669rB9E9dw5Yvdra0RARkbX8/PPPej1qKSkpmDt3LgDo3VNm6T1sJ0+eNHhf+f379zHx33GnevbsKW+XJAmvvfYaAGDixInyPW0AsHv3bmzatAmBgYEIDg62/JdQCmyqhy0mJgYA4O3tjaCgIINl2rZti7i4OMTExGDIkCEWnU/3F4KTkxO8vb0Nlrlz5w4+/vhjxMfHo0qVKmjUqBF69eqFgIAAi86tdO7uwFtvaYf5mDoVeOaZcn9CnIiIFODu3bto1qwZevbsiZycHGzYsEEekHbZsmXQaDSYNm2axeeZOXMm1q9fj5CQEAQEBMDZ2RnXrl3Dhg0bkJ6ejoEDBxb63n/nnXewfv16LF26FGfPnkV4eDhu3bqF3377DSqVCj/88INiBs9VRhSlJDY2FgBMJkO6Gwd1ZUtKCIEZM2YAAHr37q13f1t+586dw0cffaS3zcHBAWPGjMGMGTMU80EoC2PGaAfRPXUKWL8eeOopa0dERETlbfLkyTh27BiWLl2KnJwcdO/eHXPmzMG7776L1atXF5p9oKReeOEF5OXl4dChQ9i5cycyMzPxyCOPIDw8HC+++CKeffbZQseoVCps3boV06dPxy+//IK5c+dCrVajd+/e+Oijj9CyZctSia002FS2kJqaCgBwNXFDp/rf8W9SUlIsOteUKVNw8OBBqNVqTJ8+vdB+Dw8PjB07Fv369UODBg3g7u6Oy5cvY/HixZgzZw5mzpyJtLQ0LFy40OR5srKykJWVJb+2NO7y5O0NjBoFfP65tpetd2/2shERVTZqtRqLFy/G4sWL9bb//PPPpXqezp07o3PnzsU+zsXFBR9//DE+/vjjUo2ntNnUPWzlZcmSJfj4449hZ2eHH374AfXr1y9UplWrVpg5cybCw8NRo0YNuLi4oHnz5vjqq6+wfPlyAMB3332HEydOmDzXtGnT4OHhIS9KeLS4ON55B3B2Bg4fBrZts3Y0REREFZNNJWxubm4AgPT0dKNl0v4d/8bd3b1E51i1ahVeeuklANqEa+DAgcWuo3///nj00UcBAOvWrTNZNioqCsnJyfKilAH8zFW9OjBihHb900+tGwsREVFFZVMJm+7RW1NJjW5fSR7TXb16NYYOHYq8vDwsWLBATtxKonHjxgCAGzdumCynUqng7u6ut1Q0774LODkBu3cDe/daOxoiIqKKx6YSNt0wG/fu3TP6UIFuXLX8Y7SZY+3atRg8eDA0Gg3mzZuHV1991aJY7927B+C/XkFb5ucHDB+uXWcvGxFR5RAZGQkhhNljpZFpNpWw+fn5yeOlLFu2rND+ffv2IS4uDiqVSm8slqKsW7cOgwYNQm5uLubNm4eRI0daFGd8fDz2/tvV1K5dO4vqqijGj9cOnrt5M/DvUHlERERkJptK2ADIg+NNnz4dx48fl7ffu3cPo0aNAgCMHj1ab5aDNWvWoFGjRgafLtm4cSOeeeYZ5ObmYv78+WYna7NmzTI4mO6pU6fw1FNPITMzE3Xr1kXfvn2L1b6KKigIeP557Tp72YiIiIpHEoYm+arg3nrrLcyePRuOjo7o3LkzXF1dsX37diQlJSEkJARbt27Vm/w9Ojoaw4cPR+3atXH16lV5+927dxEQEICsrCz4+fmZfFz4yy+/RNWqVeXXnp6eSEtLw6OPPoqgoCDY2dnh8uXLiImJQV5eHgICAvDnn3/K97KZKyUlBR4eHkhOTq5w97OdPw80bgwIAZw8CbRoYe2IiIjKxsOHDxEbG4ugoCBUqVLF2uFQGTL3vbb0+9umxmHTmTVrFkJCQjB37lwcOHAAOTk5qFu3LiZMmIC3334bTk5OZtWTkZEhj4F248YN/Pjjj0bLTp48WS9hmzRpEvbv348zZ85g69atSE9Ph7u7Ozp06IC+ffti5MiRleL+tfwaNgQGDgRWrtTOMfrv6CZERERUBJvsYbNlFbmHDdDOetCypXYA3X/+0SZxRES2hj1slUd59bDZ3D1spGwtWgB9+mgvixqYIIKIiIgMYMJG5W7SJO3PpUuBfLcMEhERkRFM2KjctWsHdOsGaDTaeUaJiIjINCZsZBXvv6/9+cMPQHy8dWMhIiJSOiZsZBVhYUB4OJCdDXz5pbWjISIiUjYmbGQ1ul62BQuAu3etGwsREdmGvLw8/PDDDwgNDYWnpydcXFzQoEEDDB8+HKmpqSaPPXjwIOzt7SFJEqYr7Mk4JmxkNV26AMHBQGYmMHOmtaMhIqKKLisrC3379sXLL7+M1NRUREZGYsyYMWjTpg02btyI5ORko8dmZGTgxRdf1BtYX0lscuBcqhgkSdvL1rcvMHcu8N57gJeXtaMiIqKKasKECVi/fj2mT5+O8ePH6+3Ly8szeez48eNx9+5dREVF4X3dJSAFYQ8bWVXv3tqx2VJTgW++sXY0RERUWqKjoyFJEqKjowvt27VrFyRJwuTJk0vtfPHx8ZgzZw7CwsIKJWsAYGdnBzs7w2nPzp07MXfuXHz11Vfw9fUttZhKE3vYyKrs7LTjsj37LPD118DbbwOVbMYuIqpEhBDIyMmwdhhFcnF0gSRJ1g6jWH799Vfk5uZi4MCBSE1NxR9//IHr16/Dx8cH3bt3N5qIpaamYvjw4ejWrRteeuklgwmmEjBhI6sbMEA7RdX588C8edpLo0REtigjJwPqaWprh1GktKg0uDq5lus5d+3ahV27dpldPjAwEJGRkfLrY8eOAQCSkpLQsGFD3Lp1S97n5OSE6dOn4+233y5Uz9tvv40HDx7gu+++K3Hs5YEJG1mdvT0wcSLw4ovA//4HjB4NuLhYOyoiIipPu3btwpQpU8wu37FjR72E7e6/ww1MmTIFXbt2xbZt2+Dv7489e/ZgxIgReOedd9CoUSP06NFDPmbTpk34/vvvsWDBAvj7+5daW8oCEzZShCFDgMmTgdhYYNEi4M03rR0REVHpc3F0QVpUmrXDKJKLY/n/1Tx58mSL7mnTPVRQvXp1/Pbbb3D59y//Xr16YdGiRejZsyf+97//yQnbgwcP8Morr6Bz584YMWKExfGXNSZspAiOjsCECcDIkcCMGdqfKpW1oyIiKl2SJJX7pcbKwsPDAwDQpUsXOVnT6d69O1QqFY4ePSpve+edd5CcnIxFixaVa5wlxYSNFOPFF4GPP9ZOVfXjj0AF+IOHiIiKIIQotO3hw4eFtll6D1vDhg0BAJ6enoXK2tnZwc3NDSkpKfK2mJgYpKenIygoyGD9UVFRiIqKwltvvYWvv/7a7LjKChM2UgyVCvi//wPGjgWmTwdeeglw4CeUiKhCu3nzZqFtFy9eLLTN0nvYIiIi8Omnn+Ls2bOFyiYkJCAxMRENGjSQt/Xv3x9t27Y1GNuePXsQHByMFi1a4PHHHzc7prLEr0NSlFdfBT79VHsv2y+/AC+8YO2IiIjIEj///DPGjRuHKlWqAABSUlIwd+5cAEBubq5cztJ72Dp27IjGjRtj+/bt2Lp1K7p27QpA28M3ceJEAMCgQYPk8h9++KHBeqKjo7Fnzx70798fEyZMKHE8pY0JGymKiwswbpz2frbPPgOGDtU+RUpERBXT3bt30axZM/Ts2RM5OTnYsGEDHP69fLJs2TJoNBpMmzbN4vPY29tj8eLFiIiIQM+ePdG/f3/4+flh3759OHz4MFq3bq2oBKy4ONMBKc7rr2unqDp3Dli92trREBGRJSZPnoywsDAsXboUS5cuRXBwMPbv34+hQ4fi1q1buHTpUqmdq3379jh8+DD69u2L7du345tvvsG9e/cQFRWF3bt3w9W14j7wIQlDdwOSYqWkpMDDwwPJyclwd3e3djhlZsoU7TAfLVoAJ05o5x0lIqooHj58iNjYWAQFBcmXAiub6OhoDB8+HIsXL9a718zWmPteW/r9zR42UqQxY7RTVJ06Baxfb+1oiIiIrIsJGymStzfwxhva9alTAfYDExFRZcaEjRTr7bcBZ2fg8GFg2zZrR0NERGQ9TNhIsapX/2/w3E8/tW4sRERUPJGRkRBC2PT9a+WJCRsp2rvvAk5OwO7dwN691o6GiIjIOpiwkaL5+QHDh2vX2ctGRESVFRM2Urzx47WD527eDBw5Yu1oiIjMx5GzbF95vcdM2EjxgoKA55/XrrOXjYgqAvt/p2jJycmxciRU1nTvsX0ZT8vDhI0qhKgo7eC5v/+uHZuNiEjJHB0doVKpkJyczF42GyaEQHJyMlQqFRwdHcv0XJxLlCqEhg2BQYOAFSu0c4wuX27tiIiITKtatSri4+Nx48YNeHh4wNHRERKnbbEJQgjk5OQgOTkZaWlp8PX1LfNzcmqqCqayTE1lyKlTQMuW2p62f/7RJnFEREqWkpKCxMREZGVlWTsUKgMqlQpVq1Y16/vY0u9v9rBRhdGiBdCnD/DHH8D06cDixdaOiIjINHd3d7i7uyMnJwcajcba4VApsre3L/PLoPmVWw+bEAIrV67En3/+idu3b8Pb2xtPPPEEnn/++Uo7MW5JVOYeNkA760H79tqnRi9dAgIDrR0RERFR0Sz9/rYoYcvMzMTw4cORl5cHFxcXLF682OD1+ZSUFPTu3Rv79+8vtK9+/fpYv3496tWrV9IwKpXKnrABQPfuwJYtwGuvAfPmWTsaIiKioln6/W3RU6IbN27EypUr8dtvv6FKlSpGb6Z8/fXXsW/fPvlJGSGEvFy4cAFPPvkk0tPTLQmFKpH339f+/OEHID7eurEQERGVB4sStt27d8vrAwcONFjm5MmT+OWXX+RkztvbG3369EFERATs7LSnj42NxfTp0y0JhSqRsDAgPBzIzga+/NLa0RAREZU9ixK2kydPAgAcHBwQHh5usMz3338vrzdp0gRnzpzB2rVrsW3bNqxevRqSJEEIge+//55j1ZDZdL1sCxYAd+9aNxYiIqKyZlHCdvXqVQBA3bp1jT4p8ccff8jrn3zyCapXry6/7tOnD/r06QMAuHPnjpwAEhWlSxegXTsgMxOYOdPa0RAREZUtixK2+/fvQ5IkVKtWzeD+q1ev4vr16wAAtVqN3r17FyrTq1cvef3vv/+2JByqRCQJmDRJuz53LvDggXXjISIiKksWJWwPHz4EAKPDcvz1118AAEmSEB4ebrAXrm7duvJ6QkKCJeFQJdO7t3ZsttRU4JtvrB0NERFR2bEoYdMlaikpKQb35x/GIywszGAZlUolr2dmZloSDlUydnb/9bJ9/bU2cSMiIrJFFiVs1apVgxACFy9eNLh/8+bN8nqHDh0MlklOTpbXnZ2dLQlHz6pVq9CpUyd4eXnB1dUVLVu2xIwZM5CTk1OsemJiYjBt2jR07twZPj4+cHR0hJeXF8LCwjB37twi67t06RIiIyPh5+cHlUoFPz8/REZG4sqVK5Y0j/41YIB2iqoHDzgmGxER2S6LErYWLVoAAB48eIBdu3bp7Tt8+DAuXboEQJuItW/f3mAdunvcAOg9kGCJsWPHYtCgQdi/fz/atWuHJ598EtevX8f48eMRERFhdk9ebm4uWrdujYkTJ+Lw4cNo2rQpnnnmGTRr1gwHDx7E6NGjERoaiqSkJIPH79+/Hy1btsSPP/4IT09P9OvXD56envjxxx/RokUL+ZIxlZy9PTBxonb9f/8DMjKsGw8REVGZEBZYsGCBkCRJ2NnZiYYNG4pLly4JIYS4efOmaNWqlbxv4MCBRusYMWKEXG7//v2WhCOEEGLNmjUCgFCr1eLYsWPy9oSEBNG8eXMBQIwbN86sunJyckSbNm3EypUrxcOHD/X2nTp1StSsWVMAEMOHDy90bHp6uqhVq5YAIKKiovT2RUVFCQDC399fZGRkFKt9ycnJAoBITk4u1nG2LDtbiKAgIQAhZs2ydjRERESFWfr9bVHClpKSImrUqCHs7OyEnZ2dsLe3FzVr1hT29vbCzs5OTsT27dtntI6AgAAhSZJwcHAQ6enploQjhBAiODhYABBTp04ttG/v3r0CgFCpVCIpKcnicy1dulQAEM7OziI7O1tv39y5cwUA0aBBA6HRaPT2aTQa0aBBAwFAzJ8/v1jnZMJm2IIF2oTN11eIArk1ERGR1Vn6/W3RJVE3NzcsWrQI9vb2AIC8vDzcvn0beXl5cpmXX34ZISEhBo8/cOAA4uLiIEkSWrRoARcXF0vCQXx8PI4cOQIAGDp0aKH9oaGh8Pf3R1ZWFjZu3GjRuQCgVatWALQPSyQmJurtW7NmDQBg8ODB8owOOnZ2dnj22WcBAKtXr7Y4DgJefBHw9dVOVfXjj9aOhoiIqHRZlLAB2nHUtm7dipYtW+ptd3V1xfvvv4/58+cbPXbWrFkAtHOL9ujRw9JQEBMTA0A7/VVQUJDBMm3bttUrawndwxZOTk7w9vY2GIvufGUZBwEqFfB//6ddnz4dyM21bjxERESlyaE0KunYsSOOHz+O+Ph4xMXFwdnZGU2aNDE6+4FOnz590LNnTwBARESExXHExsYCAAICAoyW8ff31ytbUkIIzJgxAwDQu3dvveFJUlNTce/ePZOx6OJISEhAeno6XF1dLYqHgFdfBT79FIiNBT74AHjtNaB2bWtHRUREZLlSSdh0fH194evra3b55557rjRPj9R/B+Iylfyo1WoAxseOM9eUKVNw8OBBqNXqQhPXp+YbEMxYLLo4dLEYK5eVlYWsrCy9smSYiwvw7rvA+PHaXrbp07VDfnTrpl06dQLy/dqJiIgqDIsviVZGS5Yswccffww7Ozv88MMPqF+/fpmda9q0afDw8JAXXc8cGTZuHPDll0BIiHbIj/PntbMgPPUU4O0NPPEEMG0acPw4kO9WSyIiIkWzqYTNzc0NAJCenm60TFpaGgDA3d29ROdYtWoVXnrpJQDAd999h4EDBxqNw1QsujiKiiUqKgrJycnyEhcXV6K4Kwt7e23Stm8fkJgIrF6tvTQaFATk5AC7dmnHbWvTBvDxAYYO1T6kcPOmtSMnIiIyrlQviZqSnp6OOXPm4M8//8Tt27fh7e2NiIgIjBkzptQGzA0MDAQAk0mNbp+ubHGsXr0aQ4cORV5eHhYsWCAnbgW5ubnB29sb9+/fx/Xr1ws9kJE/jqpVq5q8hKtSqfTujyPzeXoC/fppFyGAy5eBLVuAzZuBHTu0Cd0vv2gXAGjWDOjeXXv5NCwMKMWJN4iIiCxiUcKWnJyM7t27Iy8vD15eXvjzzz8hSVKhcrdu3UJERAQuXLigt/2vv/7CggULsH79erRr186SUAD8N8zGvXv3EBsba/BJ0aNHjwIAWrduXay6165di8GDB0Oj0WDevHl49dVXTZZv3bo1tm3bhqNHj+Kpp54qtTioZCQJqFdPu4wape1t++svbfK2ZQtw9Chw+rR2+d//tE+dhof/l8A1a6atg4iIyBosuiS6bt06HD58GMeOHUOLFi0MJmsAEBkZifPnz0NoB+qVFwBITExE7969C41jVhJ+fn4IDg4GACxbtqzQ/n379iEuLg4qlUp+OtUc69atw6BBg5Cbm4t58+Zh5MiRRR7Tr18/AMDy5cv1xqUDtOPVrVixAgDQv39/s+Og0uPoqO1FmzoVOHwYSEgAli8HXnpJO55bVhawdav2IYYWLbTbIiOBZcuAu3etHT0REVU6lozaO3LkSHk2gwMHDhgss2fPHrmMJEmiYcOG4q233hIvv/yycHV1lWdJGDNmjCWhyIxNTZWYmGh0aqrVq1eLhg0bioiIiEL1bdiwQTg5OQlJksSCBQvMjiP/1FQTJ07U2zdx4kQBQPj5+XFqKgXKyxPizBkhZs4UokcPIZydtbMo5F9atxZiwgQhduwQIivL2hETEZHSWfr9LQnxb1dXCXTo0AF//fUXVCoV0tPTC43oD2hnOli8eDEkScLjjz+OrVu3wvnfm4MOHz6MsLAw5OTkwMvLC7dv3y5y7DZzvPXWW5g9ezYcHR3RuXNnuLq6Yvv27UhKSkJISIheDAAQHR2N4cOHo3bt2rh69aq8/e7duwgICEBWVhb8/PzQuXNno+f88ssvUbVqVb1t+/fvR7du3ZCRkYFmzZqhWbNmOH36NE6fPg1XV1ds27YNjz32WLHalpKSAg8PDyQnJ5f4wQkqnocPgf37/7v/7eRJ/f2urtohQ3TDhzRsyMunRESkz+Lvb0uyRV9fX2FnZyeaN29utEyNGjXkHratW7cW2v/888/L+w8dOmRJOHpWrFghwsPDhbu7u3B2dhbNmjUT06dPF1kGukMWL14sAIjatWvrbY+NjRUAzFpiY2MNxnHx4kUxbNgwUatWLeHo6Chq1aolhg0bJi5dulSidrGHzfpu3RJi6VIhnn9eiOrVC/e+BQQI8corQqxcKcS9e9aOloiIlMCqPWxqtRqZmZkIDw/Hzp07C+0/d+4cmjRpAgB45JFHcPfu3UL3uS1ZsgSRkZGQJAmLFi3C8OHDSxpOpcAeNmXJywP+/vu/hxf27gWys//bb2cHBAdre966dwfatdPeP0dERJWLpd/fFj0lqhuB39hlzEOHDgEAJElCx44dDT6UUDvf3EH379+3JByicmdnB7RsqV3eew/IyAB279Ymb1u2AGfPAocOaZdPPgHc3YGIiP+ePq1Tx9otICKiisCihM3FxQVpaWl48OCBwf179+6V18PDww0H4PBfCPmnYCKqiFxcgB49tAsAxMVpnzbdskX78/59YO1a7QIAdev+1/v2xBPahI6IiKggi4b1qFGjBoQQuHDhQqGhKwBg8+bN8nqHDh0M1pGUlCSvu7i4WBIOkeL4+2uHClm+XDscyOHD2qFEwsIABwftYL7z5gFPP62dOiv/UCMajbWjJyIipbCoh+3RRx/FxYsXkZaWhnXr1qFv377yvq1btyI+Ph6AduqlNm3aGKzj8uXL8nqNGjUsCYdI0ezttfezBQcDkyYBKSnaqbJ0979duqSdUmvfPuCDD7QJXKtW2l64OnX0f3p4WLs1RERUnixK2Pr27YtVq1YBAF5//XW4ubkhNDQUMTEx8uCykiShX79+RgfVPXbsmLxer149S8IhqlDc3YE+fbQLAFy58t+9b9u3ay+fbt+uXQry9jacyNWpox3k196+fNtCRERly6KnRLOzs9GkSRPExsYa3C+EgJ2dHU6cOIFmzZoV2p+Xl4eaNWsiISEBTk5OSElJgZOTU0nDqRT4lGjlkJurnS7r3DltInf58n8/ExJMH+vkBAQGGk7ogoK048YREVH5supTok5OTvj555/RtWtXpKWlydslSZKnnnr//fcNJmsAsG3bNiQkJECSJLRt25bJGtG/HByAxx7TLgWlpgKxsfpJnO7n1avaYUUuXNAuhtSoYbhnrm5dwMeHg/4SESmRRQkbALRv3x5Hjx7FhAkTsGnTJmRlZUEIgQYNGuC9997DSy+9ZPTYmTNnAtD2xPXQPVZHRCa5uWnnN23RovC+3Fzgxo3CiZzuZ1IScPu2djlwoPDxLi7a5C1/IqdbDwwEVKqybh0RERli0SXRgjQaDRISEuDs7AwPM+6K3rNnj9wT17x5c3h7e5dWKDaLl0TJEg8eGE/m4uK0AwEbI0mAn99/CVzBHjpvb/bOEREZY+n3d6kmbFT2mLBRWcnOBq5dM57QpaebPt7Dw3DPXJ062kSPdzwQUWXGhK2SYcJG1iCE9mGHgomcbv3mzaLrcHcHqlcHqlXTLvnXDb3m5VcisiVWfeiAiCoHSdImVNWrA48/Xnh/Zqb2QQhDvXNXrgBZWdpx51JStOPNmcPd3XAyZ2ydCR4R2bJST9hycnKwb98+HDhwAJcuXcKDBw/w8OFDeHp6onr16mjbti06duyoN4coEVVszs5AkybapaC8PO3DDgkJ/y137xpfT0zUPjyhS/Dyja1tkptb8XrwqlQp1V8BEVGZKrWELSsrC9OnT8f8+fNx9+7dIst3794dH374IR4zNG4BEdkMOzvtAwne3kDDhkWXF0Kb4OVP5EwleQkJ2gQvNVW7FCfBKyqxy7/OBI+IrKlU7mH7559/8Mwzz+DcuXPyU5/5x2LTO2G+7fb29pg4cSKmTJliaQiVBu9hI9KnS/DM6b3Ln+AVl1oNPPKI9uEKd3ftT91izmt3d+34ekRUOVn9HrZr166hS5cuuH37tt52lUqFJk2aoFq1alCpVEhJScHly5cRFxcHQJu4aTQaTJ06Vf5JRFRckgR4eWmXBg2KLi8EkJxsuseu4L7cXCAtTbtYwtW15Amfbp09fUSVk8U9bBEREdi1a5fccxYREYFx48ahW7dusDcwoWF8fDyio6Px5ZdfIiUlBUIISJKEXbt2ISwszJJQKgX2sBGVr/wJ3oMH2vvqkpP1l4LbCr5++LD04nFyKpzQFTfpU6s5Zh5RebPqsB7btm1Dt27dIEkSJEnCzJkzMWbMGLOOvXXrFnr06IFTp04BAEJCQrB3796ShlJpMGEjqniys/WTuJIkfamppRuTi4u2x8/QYmqfOcc4OpZurES2wKqXRH/77Td5/d133zU7WQOAmjVrYtOmTWjatCmSkpJw4MAB3L59GzVq1LAkJCIixXFyAqpW1S4llZenTdosSfqSkwGNRltfRoZ2SUgonTbm5+hYvASvOEmhszN7B6lysihh0/WIOTo6IioqqtjH16xZE6+++iq++OILAMC+ffvwzDPPWBISEZFNsrP775JmSQmhHTMvNVU7c4WxJSPD9H5j5XXJYE6O9kGQpKTSaLk+SdJP9qpU0SZxZfmzShXt75/ImixK2G7dugVJktC8eXOz5g41JDw8XE7Ybt26ZUk4RERkgi7ZcXEp/bqF0F76LU6CV5yEUHcfoBD/bS9PTk5lmxCqVPqLk9N/646O7FUkCxO29H//xVhyL5Wbm1uh+oiIqGKRpP8SDG/v0q9foymc6OkSuczMsvmZf/iX7Gztkpxc+m0zR/4EzlBSV5xtpXUch6kpXxb9uqtWrYqbN2/i2rVrJa7j+vXr8vojjzxiSThERGSj7O21gx3n+xu/zOXmlm1CmP9ndrZ2Cjfdoru8rKNLGEv74RNL2NkVTuIcHbXbnJz+Wy/405r7DAxeUWFYlLAFBQXh5s2biI2NxalTp9CiRYti17F69Wp5vU6dOpaEQ0REVGocHLRDoKjV5X9ujaZwEpeVZXibse2lvS0rSz/GvDxtwlmaw9aUNUkyL9EbPhx44w1rR6vPooSte/fu2L9/PwBg1KhR2LFjB5ycnMw+fv369Vi7di0AwNnZmeOwERERQdsT5OysXZRCCG2vo6nELidHu63gT0PbynpfdrY25oJtMJR8FvTkk2X3eywpixK2F154AZ9++imys7Nx8OBBdO/eHdHR0WZN7P7999/Lw4BIkoTnn3++WMkeERERlR9J0vY+OTpap9exJDSakiWBdetaO/LCLJ7pICoqCp9//jmkfx9hUalU6NevH5566im0bNkS1apVg5OTE1JTU3H58mUcOHAAP//8M86ePSvPKerl5YWzZ8/Cx8fH8hbZOA6cS0REVPFYdaYDAMjLy0O/fv2wbt06eXoqqYjnj3VlhBCoUqUKtm7dipCQEEvCqDSYsBEREVU8ln5/WzwUoJ2dHX777TdERUUVStSEEIWW/PsaN26MAwcOMFkjIiIiMqFUxm52cHDAp59+irNnz+KNN95AzZo1YazjztHREWFhYVi6dClOnDiBRx99tDRCICIiIrJZFl8SNSYuLg4XL17EgwcPkJWVBU9PT1SvXh3NmzeHSqUqi1NWCrwkSkREVPFYdfJ3U/z9/eHv719W1RMRERFVGlafztbFxQX29vZw4BwXRERERAZZPUsq+DACEREREemzeg8bEREREZnGhI2IiIhI4ZiwERERESkcEzYiIiIihWPCRkRERKRwTNiIiIiIFI4JGxEREZHCMWEjIiIiUjibTdhWrVqFTp06wcvLC66urmjZsiVmzJiBnJycYtVz7949REdHY8yYMejQoQNcXFwgSRK6dOli8rhdu3ZBkiSTy/z58y1pIhEREVUSVp/poCyMHTsWs2bNgoODAyIiIqBWq7Fjxw6MHz8e69atw5YtW+Ds7GxWXXv37sXw4cNLHIuPjw+efPJJg/saNmxY4nqJiIio8jArYduzZ0+ZBZCXl1eq9a1duxazZs2CWq3G7t270bp1awBAYmIiIiIisG/fPnzwwQf48ssvzarPx8cHI0eOROvWrdG6dWscO3YMr732mtnxNGrUCNHR0SVpChEREREAMxO2Tp06QZKkso6lVHz22WcAgAkTJsjJGgBUrVoV3377LcLCwjBnzhx88MEH8PDwKLK+xx9/HI8//rj8+vTp06UfNBEREZEJxbqHTTdRe2kupSk+Ph5HjhwBAAwdOrTQ/tDQUPj7+yMrKwsbN24s1XMTERERlRWz72Er7eSqLOqNiYkBAHh7eyMoKMhgmbZt2yIuLg4xMTEYMmRIqZ3bmDt37uDjjz9GfHw8qlSpgkaNGqFXr14ICAgo83MTERGRbTArYVu8eHFZx1EqYmNjAcBkMuTv769XtqydO3cOH330kd42BwcHjBkzBjNmzICDg+m3ICsrC1lZWfLrlJSUMomTiIiIlMushO3FF18s6zhKRWpqKgDA1dXVaBm1Wg2g7BMfDw8PjB07Fv369UODBg3g7u6Oy5cvY/HixZgzZw5mzpyJtLQ0LFy40GQ906ZNw5QpU8o0ViIiIlI2mx2HzdpatWqFmTNnIjw8HDVq1ICLiwuaN2+Or776CsuXLwcAfPfddzhx4oTJeqKiopCcnCwvcXFx5RA9ERERKYnix2FbtmwZLl26BAD48MMPTZZ1c3MDAKSnpxstk5aWBgBwd3cvpQiLr3///nj00Udx4sQJrFu3Do8++qjRsiqVCiqVqvyCIyIiIsVRfMK2dOlSbN68GZIkFZmwBQYGAoDJXijdPl1Za2ncuDFOnDiBGzduWDUOIiIiUj6buiTaqlUrANrppIw9VHD06FEA0BujzRru3bsH4L9eQSIiIiJjbCph8/PzQ3BwMADtpdSC9u3bh7i4OKhUKvTs2bO8w5PFx8dj7969AIB27dpZLQ4iIiKqGGwqYQOAiRMnAgCmT5+O48ePy9vv3buHUaNGAQBGjx6tN8vBmjVr0KhRI3Tu3LnU4pg1axYSExMLbT916hSeeuopZGZmom7duujbt2+pnZOIiIhsk+LvYSuup59+Gm+++SZmz56Nxx57DJ07d4arqyu2b9+OpKQkhISE4JNPPtE7Jjk5GefPn8fDhw8N1vnYY4/J6wkJCQCAI0eO6G3/4IMP0KtXL/n1Rx99hHHjxuHRRx9FUFAQ7OzscPnyZcTExCAvLw8BAQFYt24dHyggIiKiItlcwgZoe7dCQkIwd+5cHDhwADk5Oahbty4mTJiAt99+G05OTsWq79ChQ4W2paSk6G3XJXI6kyZNwv79+3HmzBls3boV6enpcHd3R4cOHdC3b1+MHDmS968RERGRWSRRVnNOlZIePXrIT4lqNBprh2N1KSkp8PDwQHJyslWHJiEiIiLzWfr9bXP3sBERERHZGiZsRERERArHhI2IiIhI4ZiwERERESkcEzYiIiIihWPCRkRERKRwTNiIiIiIFI4JGxEREZHCMWEjIiIiUjgmbEREREQKx4SNiIiISOEsmvx9z549AABvb280a9asRHWcPXsWiYmJAIDw8PBC+2fMmIEJEyaUPEgiIiKiCs6iyd/t7OwgSRK6d++OjRs3lqiOfv364Y8//oAkScjNzS1pKJUGJ38nIiKqeCz9/raoh620WJAzEhEREdk83sNGREREpHBWT9h0l0EdHBTR2UdERESkOFZP2OLj4wEAbm5uVo6EiIiISJmsmrCdPHkSJ0+ehCRJqFOnjjVDISIiIlIss69Dfvzxx0b3Xbp0yeT+/IQQyMzMxIULF7BlyxYIISBJEkJDQ80NhYiIiKhSMXtYD90QHvnpDi243Vy6452cnBATE4PGjRuXqJ7KhMN6EBERVTzlOqyHsdzOkmE5XFxcMH/+fCZrREREREaYnbCFh4cX6knbvXs3JEmCp6cnWrRoYVY9dnZ2UKvVqFmzJtq0aYMBAwbA29u7eFETERERVSJmJ2y7du0qtM3OTvvMQvv27Us80wERERERmWbxU6KcpYCIiIiobFk0Wm1sbCwAwNnZuVSCISIiIqLCLErYateuXVpxEBEREZER5T5wbk5ODu7cuYPs7OzyPjURERFRhWRxwpaZmYmMjAxkZGSYLHfy5En06NEDbm5uqFWrFpydnREWFobt27dbGgIRERGRTbMoYbt+/TrUajXc3Nzw6KOPGi33119/ITQ0FFu2bEF2djaEEBBCYP/+/ejWrRsWLFhgSRhERERENs2ihG3t2rXyU6IjRowwWEaj0WDYsGFIT08vtE+SJAghMGbMGJw6dcqSUIiIiIhslkUJ219//SWv9+nTx2CZVatW4dKlS/Kgu8899xxWr16NJUuWoFGjRgC0Sd3kyZMtCYWIiIjIZln0lOj58+cBAO7u7mjQoIHBMsuWLZPXhw0bhsWLF8uvu3fvjsaNG+P+/fvYuHEjUlJSOD8mERERUQEW9bDFxcVBkiTUq1fP4P7c3Fzs3LlTfv3OO+/o7a9WrRoiIyMBaJ8ePXr0qCXhEBEREdkkixK21NRUAICnp6fB/cePH0d6ejokSUJQUBCaN29eqMzjjz8ur1+8eNGScIiIiIhskkUJm0ajAQDk5eUZ3J//HrdOnToZLOPj4yOvJyUlWRIOERERkU2yKGFzc3MDACQkJBjcv2fPHnk9NDTUYBld0gdwXlIiIiIiQyxK2AICAiCEwIULFwoN25GVlYWtW7fKr40lbPfv35fX1Wq1JeEQERER2SSLErZ27doB0D4wMH/+fL19S5YsQWpqKiRJgr+/v9EHE/755x953c/Pz5JwiIiIiGySRcN6PPvss/juu+8AAJMmTUJycjJCQ0MRExODKVOmyOWef/55o3UcOnRIXm/YsKEl4RARERHZJElYeONY586dsXPnTnlgXB1dte7u7rh06RKqVq1a6Nj09HRUq1YNDx8+hIeHBx48eGBJKJVCSkoKPDw8kJyczDHriIiIKghLv78tnvx9+fLlaNq0qTw/qG4BAJVKhZ9++slgsgYAK1euxMOHDyFJktF73IiIiIgqO4sTtmrVquHYsWP4+uuv0blzZzRo0AAtW7bEiBEjcOzYMfTu3dvosV999RUAbW9cr169LA1Fz6pVq9CpUyd4eXnB1dUVLVu2xIwZM5CTk1Oseu7du4fo6GiMGTMGHTp0gIuLCyRJQpcuXcw6/tKlS4iMjISfnx9UKhX8/PwQGRmJK1eulKRZREREVAlZfElUicaOHYtZs2bBwcEBERERUKvV2LFjB5KSkhAaGootW7bA2dnZrLrWrl2Lfv36FdreuXNnbNu2zeSx+/fvR7du3ZCRkYGmTZuiWbNmOH36NM6cOQNXV1ds27YNjz32WLHaxkuiREREFY/VL4kqzdq1azFr1iyo1WocOnQImzdvxm+//YaLFy+iefPm2LdvHz744AOz6/Px8cHIkSOxYMECHDlypNDTsMZkZGRg0KBByMjIQFRUFE6fPo3ly5fj9OnTiIqKQnp6OgYNGoTMzMySNpWIiIgqCZtL2D777DMAwIQJE9C6dWt5e9WqVfHtt98CAObMmYPk5GSz6nv88ccxf/58jBgxAm3btoVKpTLruOjoaNy8eRMNGjTA1KlT9fZNnToVDRo0QFxcHJYsWWJWfURERFR5lWnClpqaihs3buD69etleRpZfHw8jhw5AgAYOnRoof2hoaHw9/dHVlYWNm7cWKaxrFmzBgAwePBg2Nnp/5rt7Ozw7LPPAgBWr15dpnEQERFRxWfROGwF3bp1CwsWLMC2bdtw7NgxZGdnAwAkSUJubm6h8suXL5fLDB06FA4OloUTExMDAPD29kZQUJDBMm3btkVcXBxiYmIwZMgQi85nTixt27Y1Gkf+ckRERETGlErClpeXh8mTJ+s9hWnOswybNm3CTz/9BEA7XtvTTz9tURyxsbEAtFNmGePv769Xtiykpqbi3r17JmPRxZGQkID09HS4urqWWTxERERUsVl8SVSj0aBPnz749NNPkZ2drTcOW1HGjBkjl/3ll18sDQWpqakAYDL50c1XmpKSYvH5iorDVCz55001FUtWVhZSUlL0FiIiIqpcLE7Yxo0bp3c/WEREBH788UecOHEC4eHhJo9t27YtAgMDIYTA9u3bLQ3FJk2bNg0eHh7youuZIyIiosrDooTt/PnzmDt3LgDtfWq6+9deeOEFtGjRwqyxzrp27QoAePDggd5E8CXh5uYGQDvllTFpaWkAUKZjmOniMBWLLo6iYomKikJycrK8xMXFlV6gREREVCFYlLBFR0dDo9FAkiT83//9H1599dVi1/Hoo4/K6+fOnbMkHAQGBgKAyaRGt09Xtiy4ubnB29sbAIw+IauLo2rVqiYv4apUKri7u+stREREVLlYlLDpLmM6ODhgwoQJJaoj/0358fHxloSDVq1aAdBOJ2XsoYKjR48CgN4YbWVBV7/ufNaKg4iIiCo+ixK2a9euQZIkNGvWDB4eHiWqI/9x+S8TloSfnx+Cg4MBAMuWLSu0f9++fYiLi4NKpULPnj0tOldRdNNZLV++HHl5eXr78vLysGLFCgBA//79yzQOIiIiqvgsStiSkpIAQL78VxJZWVnyuqOjoyXhAAAmTpwIAJg+fTqOHz8ub7937x5GjRoFABg9erReorhmzRo0atQInTt3tvj8OpGRkahVqxYuXLhQaCqsDz74ABcuXICfnx+GDRtWauckIiIi22TROGxeXl5ISEiQE7eSyH8ZtGrVqpaEAwB4+umn8eabb2L27Nl47LHH0LlzZ7i6umL79u1ISkpCSEgIPvnkE71jkpOTcf78eTx8+NBgnfknaE9ISAAAHDlyRG/7Bx98gF69esmvXVxcsHLlSnTr1g2fffYZ/vjjD3ny99OnT8PV1RWrVq0yexJ6IiIiqrwsSthq1aqFu3fv4uzZs8jNzS3RTAV79+6V1+vVq2dJOLJZs2YhJCQEc+fOxYEDB5CTk4O6detiwoQJePvtt+Hk5FSs+g4dOlRoW0pKit52XSKXX0hICE6ePIlPPvkE27Ztw2+//YZq1aph2LBh+PDDD1G3bt3iN46IiIgqHUmYO8qtAW+//TZmzZoFSZLw888/Y/DgwXr7e/Togc2bN0OSJGg0mkLHJyUlISAgAGlpaXB1dcWDBw8snp7K1qWkpMDDwwPJycl8YpSIiKiCsPT726x72K5fv47r168X6kXKf8P8+PHj8eDBg2Kd/PXXX0daWhokSUK/fv2YrBEREREZYFbCFhgYiKCgIERGRuptDwsLQ0REBIQQuHHjBjp16mTWWGoPHjzA0KFDsXLlSm0QdnbywwJEREREpK9YXVqGrp4uWLAAjz32GO7fv4+///4bLVu2RM+ePdGlSxfcuXNHLvfbb7/hzp07OHjwIH7//Xekp6dDCAFJkvDxxx+jUaNGlreGiIiIyAaZdQ+bnZ0dJElC9+7d9eYN1Tl48CD69u2LxMREbaWSJO/TVW9oGwC89tpr+Pbbb0vegkqG97ARERFVPOVyD1tRHn/8ccTExKB79+4AtAlZ/kTNULLm7e2N+fPnM1kjIiIiKkKp3eXv6+uLTZs24eTJk4iOjsbu3btx+vRp5ObmymXUajU6dOiAHj164OWXX4ZarS6t0xMRERHZrFJ/LLNly5aYOXOm/Do5ORnp6enw9PSEi4tLaZ+OiIiIyOaV+TgaHh4eJZ5nlIiIiIhK6R42IiIiIio7TNiIiIiIFK5Yl0R3796NOnXqlEkgkiTh8uXLZVI3ERERUUVWrIQtMzMTV69eLZNA8g/9QURERET/4SVRIiIiIoUrVg+bl5cXWrRoUVaxEBEREZEBxUrY2rdvb3BqKiIiIiIqO7wkSkRERKRwTNiIiIiIFI4JGxEREZHCMWEjIiIiUjgmbEREREQKx4SNiIiISOGYsBEREREpnNkJmxCiLOMgIiIiIiPMGjg3NjYWAODs7FymwRARERFRYWYlbLVr1y7rOIiIiIjICN7DRkRERKRwTNiIiIiIFI4JGwEAziacxRf7v8BfN/5CjibH2uEQERFRPmbdw0a274/zfyBqexQAwMXRBY/5PYbwgHCE1Q7DY36PwcXRxcoREhERVV5M2AgA0PCRhujTsA/2Xd+H+5n3sSN2B3bE7gAAONg5oG2ttggLCEN47XCE+IfAy9nLyhETERFVHpLgAGsVSkpKCjw8PJCcnAx3d/dSrz9P5OGfhH+w59oe7L2+F3uu7UF8arxeGQkSmvs0lxO4sIAw1HSrWeqxEBER2QpLv7+ZsFUwZZ2wFSSEwNWkq3ICt/f6Xly4d6FQubpedeXkLbx2OOp41YEkSWUeHxERUUXAhK2SKe+EzZDbabex7/o+OYk7efskBPQ/RjXVNeUELqx2GJpVbwY7ic+4EBFR5cSErZJRQsJWUNLDJByIO4C91/Ziz/U9OBJ/BDl5+k+aelXxQkhAiPwgQ5uabeBo72iliImIiMoXE7ZKRokJW0GZOZk4HH9Y7oE7EHcA6TnpemWcHZzxuP/j8iVUPolKRES2jAlbJVMREraCcjQ5OHH7hPwQw77r+3Av855emfxPooYFhCE0IJRPohIRkc1gwlbJVMSErSDdk6i6BG7v9b24kXJDr4wECc2qN9O7D66WWy0rRUxERGQZJmyVjC0kbAUJIXAt+Zo2efv3PjhjT6KG1Q6T74Or61WXT6ISEVGFwIStkrHFhM2QO2l3tMOIXNMOJXLi9gmDT6KG1Q6T74Pjk6hEZEt0X8+6//uKel2SY8x9XZp1VoQ6qrlWQw11DZQmJmyVTGVJ2ApKfpiMA3EH5EuoR24eQbYmW6+MZxVPhAaEItQ/FN7O3gC0/wiFECZ/AiiyTP5/1KVVnzllC56zYHlT+/XKFvPYYtVdjLp02yvyax1DX2QFt5d0X2mfy1R9xo63pHx5n6M031slJDxkfVGhUfis82elWqel39+cmooqBI8qHuhRvwd61O8B4L8nUXWD+e6/vh9JD5Ow/sJ6rL+w3srREhFVbhK0t6vkv22l4DZjr0urTHHOXXCbq6NrMVtc9mw2YVu1ahXmzp2LkydPIjs7G/Xq1cNzzz2Ht99+G46OxR//69ixY5g+fTr27NmD5ORk1KxZE71798YHH3yA6tWrFyp/9epVBAUFmaxz/PjxmD59erFjIcDZ0RkdAzuiY2BHAEBuXi5O3D6BPdf24FD8ITzMfQgJkt4/TkmSTP4EUGQZs8uV4nkL1pO/fMFj85cti+NK4xy67aX9uizrLthmHUNfHkXty7/d1L7yrK8gU/eGlvdx5h5bHu9/RXhdlucwtwyVDZu8JDp27FjMmjULDg4OiIiIgFqtxo4dO5CUlITQ0FBs2bIFzs7OZtf366+/YsiQIcjNzUVwcDCCgoJw9OhRXLlyBT4+Pti3bx/q1aund4wuYXN1dcUzzzxjsN5evXph4MCBxWpbZb0kSkREVJHxHrYC1q5di379+kGtVmP37t1o3bo1ACAxMRERERH4+++/MW7cOHz55Zdm1Xfz5k3Ur18fGRkZWLBgAUaMGAEA0Gg0iIyMxE8//YTg4GAcOnRI7y8MXcJWu3ZtXL16tdTax4SNiIio4rH0+9vmHqn77DPtTYITJkyQkzUAqFq1Kr799lsAwJw5c5CcnGxWfV9//TUyMjLQpUsXOVkDAHt7e8ybNw8eHh44cuQItmzZUoqtICIiIvqPTSVs8fHxOHLkCABg6NChhfaHhobC398fWVlZ2Lhxo1l1rlmzxmh9arUaffr0AQCsXr26pGETERERmWRTCVtMTAwAwNvb2+gN/23bttUra0pqaiouXbqkd1xx60tPT8f06dPx2muvYcyYMfj6669x/vz5Is9NREREpGNTT4nGxsYCAAICAoyW8ff31ytrSv57z4zVWVR9iYmJiIqK0tv2zjvv4LnnnsO8efOgVquLjIOIiIgqN5vqYUtNTQUAuLoaHz9FlyClpKSYXZ+pOo3Vp1Kp8Oqrr2Lz5s2Ii4tDRkYGzpw5g08++QQuLi746aefMGDAAKODRepkZWUhJSVFbyEiIqLKxaYSNiWpWbMmFi5ciG7dusHPzw/Ozs5o0qQJ3n//fezYsQP29vbYsmULfv/9d5P1TJs2DR4eHvKi69EjIiKiysOmEjY3NzcA2vvGjElLSwMAsx6p1dVnqs7i1KfTrl07PPXUUwCAdevWmSwbFRWF5ORkeYmLizP7PERERGQbbCphCwwMBACTSY1un66sKbVr15bXr1+/bnF9+TVu3BgAcOPGDZPlVCoV3N3d9RYiIiKqXGwqYWvVqhUA4N69e0YfAjh69CgA6I3RZoy7u7s8g4HuOEvqy+/evXsA9HvxiIiIiAyxqYTNz88PwcHBAIBly5YV2r9v3z7ExcVBpVKhZ8+eZtXZr18/o/WlpaXJlzT79+9vdpzp6enyce3atTP7OCIiIqqcbCphA4CJEycCAKZPn47jx4/L2+/du4dRo0YBAEaPHg0PDw9535o1a9CoUSN07ty5UH1jx46Fi4sLtm3bhu+++07ertFoMGrUKCQlJSE4OBjdunXTO27hwoUGL83Gxsaib9++uHXrFjw9PfHSSy9Z1mAiIiKyeTY3lygAvPXWW5g9ezYcHR3RuXNnuLq6Yvv27UhKSkJISAi2bt2qN/l7dHQ0hg8fbnTez1WrVmHIkCHQaDRo3749AgMDceTIEZOTvz/66KM4deoUmjZtigYNGsDJyQmxsbE4ceIEsrKy8Mgjj2D16tUIDw8vVts4lygREVHFw7lEDZg1axZWrFiBxx9/HAcOHMDGjRvh5+eH6dOnY8eOHXrJmjkGDhyIQ4cOoX///rhy5QrWrFkDjUaDN954AydPniyUrAHAm2++iYEDByI3Nxe7du3Cr7/+ivPnz6NFixb46KOPcPbs2WIna0RERFQ52WQPmy1jDxsREVHFwx42IiIiIhvHhI2IiIhI4ZiwERERESkcEzYiIiIihWPCRkRERKRwTNiIiIiIFI4JGxEREZHCMWEjIiIiUjgmbEREREQKx4SNiIiISOGYsBEREREpHBM2IiIiIoVjwkZERESkcEzYiIiIiBSOCRsRERGRwjFhIyIiIlI4JmxERERECseEjYiIiEjhmLARERERKRwTNiIiIiKFY8JGREREpHBM2IiIiIgUjgkbERERkcIxYSMiIiJSOCZsRERERArHhI2IiIhI4ZiwERERESkcEzYiIiIihWPCRkRERKRwTNiIiIiIFI4JGxEREZHCMWEjIiIiUjgmbEREREQKx4SNiIiISOGYsBEREREpHBM20tJoACGsHQUREREZ4GDtAEghliwBxo0DmjQBmjbV/tSt16wJSJK1IyQiIqq0mLCR1tmzwIMHwP792iU/T8//Erj8CZ2vLxM5IiKiciAJwetgFUlKSgo8PDyQnJwMd3f30qs4MxO4cAE4c0abvOl+XroE5OUZPsbd3XCPnJ8fEzkiIqJ8LP3+ZsJWwZRZwmbMw4faRC5/Enf2LHDxova+N0Pc3Ar3xjVpAgQEMJEjIqJKiQlbJVPuCZsxWVnapK1gj9zFi0BuruFj1GqgceP/kjjdz4AAwI7PvxARke1iwmbEqlWrMHfuXJw8eRLZ2dmoV68ennvuObz99ttwdHQsdn3Hjh3D9OnTsWfPHiQnJ6NmzZro3bs3PvjgA1SvXt3ocXfu3MEnn3yCDRs24ObNm/D09ER4eDiioqLQunXrYsehmITNmOxsbdJWsEfuwgUgJ8fwMa6u2kQufxLXtClQuzYTOSIisglM2AwYO3YsZs2aBQcHB0RERECtVmPHjh1ISkpCaGgotmzZAmdnZ7Pr+/XXXzFkyBDk5uYiODgYQUFBOHr0KK5cuQIfHx/s27cP9erVK3TchQsXEBYWhrt376JOnTpo27YtYmNjceTIETg4OGDlypXo169fsdqm+ITNmJwc7f1w+ZO4M2eA8+eNJ3LOzoZ75IKCmMgREVGFwoStgLVr16Jfv35Qq9XYvXu33IuVmJiIiIgI/P333xg3bhy+/PJLs+q7efMm6tevj4yMDCxYsAAjRowAAGg0GkRGRuKnn35CcHAwDh06BCnf/VlCCLRp0wYxMTF44YUXsHjxYtjb2wMAFi5ciJEjR0KtVuPixYuoUaOG2e2rsAmbMbm52kQufxJ39ixw7py2t84QZ2egUaPCPXJBQcC/v2MiIiIlYcJWQLt27XDkyBFMnToVkyZN0tu3b98+hIWFQaVS4c6dO/Dw8Ciyvvfeew9ffPEFunTpgq1bt+rtS0tLg5+fH5KTk/Hnn3+ie/fu8r6NGzeiV69e8PT0RFxcHNRqtd6xXbp0wfbt2zFhwgRMmzbN7PbZXMJmTG4ucOWKfhJ35ow2kcvKMnyMSvVfIufpCTg5aRdHR/2fpb3N3p4PUxARkUmWfn/b1Dhs8fHxOHLkCABg6NChhfaHhobC398fcXFx2LhxI4YMGVJknWvWrDFan1qtRp8+fbB06VKsXr1aL2HTHdenT59CyZquvu3bt2P16tXFStgqDQcHoEED7fL00/9t12iA2NjCDzv884/2idaTJ7VLeZIk8xK7kiSH9vbaxc7uv5/51yvKT90iSUxuiYhKwKYStpiYGACAt7c3goKCDJZp27Yt4uLiEBMTU2TClpqaikuXLsnHGatv6dKl8rkLxmLqOAC4ePEi0tPT4erqajIW+pe9PVCvnnbp2/e/7RoNcPXqf5dT09O1l1Szs7X3yOX/ae42Y/sKPgUrxH/lyDySpJ/A6dZL+2dZ1VnUomtjRVkKxluc15YcW5p169aN/SyPMqV1jvw/LS1jrXMUta0895ekLnd3wMsLSmJTCVtsbCwAICAgwGgZf39/vbKmXL16VV43Vqex+oqKRXecEAJXr15F06ZNi4yHTLC3B+rW1S5PPVW258rL0yZuliR95mzLztYmonl55fPT0jqKQwjj4/gREVlbVBTw2WfWjkKPTSVsqampAGCyt0p3eTIlJcXs+kzVaay+omLJf5nUVCxZWVnIynfPljlxUxmzs9PeL6dSWTsSZcnLM53QCVH0T3PKFPdnadWVv77iLEDJjiuvJX98BWM19VqJ+4z9LI8ypXWO/D8tLWOtcxS1rTz3l7QuB+WlR8qLiPRMmzYNU6ZMsXYYREXT3aemwP/oiIgqOpsazMrNzQ0AkJ6ebrRMWloaAJj1hIauPlN1GquvqFh0xxUVS1RUFJKTk+UlLi6uyLiJiIjItthUwhYYGAgAJpMa3T5dWVNq164tr1+/fr1Y9eleF3WcJEl65ylIpVLB3d1dbyEiIqLKxaYStlatWgEA7t27Z/ShgqNHjwKAWdNCubu7yzMY6I4ztz7d66KOq1+/vsFhP4iIiIh0bCph8/PzQ3BwMABg2bJlhfbv27cPcXFxUKlU6Nmzp1l16qaOMlRfWloa1q1bBwDo37+/weP++OMPg5dFdfUVPI6IiIioIJtK2ABg4sSJAIDp06fj+PHj8vZ79+5h1KhRAIDRo0frzXKwZs0aNGrUCJ07dy5U39ixY+Hi4oJt27bhu+++k7drNBqMGjUKSUlJCA4ORrdu3fSO69GjB1q1aoWkpCSMGjUKmnxDGCxcuBDbt2+HWq3GW2+9VToNJyIiIptlc1NTAcBbb72F2bNnw9HREZ07d4arqyu2b9+OpKQkhISEYOvWrXqTv0dHR2P48OGoXbu23thrOqtWrcKQIUOg0WjQvn17BAYG4siRI0VO/n7+/HmEhYUhISEBderUQXBwMGJjY3H48OHKN/k7ERFRJWbp97fN9bABwKxZs7BixQo8/vjjOHDgADZu3Ag/Pz9Mnz4dO3bs0EvWzDFw4EAcOnQI/fv3x5UrV7BmzRpoNBq88cYbOHnypMFkDQAaNmyIU6dO4Y033oBGo8GaNWsQGxuL/v3749ChQ8VO1oiIiKhysskeNlvGHjYiIqKKhz1sRERERDaOCRsRERGRwjFhIyIiIlI4JmxERERECseEjYiIiEjhmLARERERKZyDtQOg4tGNwpKSkmLlSIiIiMhcuu/tko6mxoStgklNTQUA+Pv7WzkSIiIiKq7U1FS96THNxYFzK5i8vDzcvHkTbm5ukCSpVOtOSUmBv78/4uLiKvSgvGyHsrAdysJ2KAvboSxl2Q4hBFJTU1GrVi3Y2RX/jjT2sFUwdnZ28PPzK9NzuLu7V+h/cDpsh7KwHcrCdigL26EsZdWOkvSs6fChAyIiIiKFY8JGREREpHBM2EimUqnw0UcfQaVSWTsUi7AdysJ2KAvboSxsh7IouR186ICIiIhI4djDRkRERKRwTNiIiIiIFI4JGxEREZHCMWGzAefPn8c333yDyMhING/eHA4ODpAkCVOnTi3y2G3btqFnz56oWrUqnJ2d0ahRI0yaNAlpaWkmj7t06RIiIyPh5+cHlUoFPz8/REZG4sqVKyVqQ05ODrZv347/+7//Q3BwMDw9PeHo6IgaNWqgT58+2LBhQ4VoBwD8/PPPGDZsGFq2bInq1avD0dERHh4eaNeuHaZNm2YyJiW1w5D33nsPkiQV+flSUjsiIyPlmI0tDx8+NHjssWPHMHDgQPj4+KBKlSoICgrCmDFjcPfuXZPnvHPnDkaPHo2goCCoVCr4+Phg4MCBOH78eInboZOdnY3Zs2cjNDQU3t7eqFKlCvz8/NCjRw+sWLHC4DFKej+uXr1a5PuhW/bs2aPotly/fh2jR49Gw4YN4ezsLH9GXnzxRZw8edLocUpqAwDExcVh9OjRqFu3LlQqFapWrYru3bsr7v/divRdl5qaiokTJ8qfjapVq6JXr17YsWNHkbEaJajCe+uttwSAQssnn3xi8rivvvpKABCSJInw8HAxcOBAUaNGDQFANGzYUCQkJBg8bt++fcLFxUUAEE2bNhXPPvusaNq0qQAgXF1dxcGDB4vdhq1bt8px16hRQ/Tq1UsMGjRINGvWTN4+YsQIkZeXp+h2CCFESEiIkCRJNGnSRHTv3l0MGTJERERECGdnZwFA1KtXT8THxyu+HQXt379f2NnZCUmSTH6+lNaOF198UQAQISEh4sUXXzS4ZGdnFzpu1apVwsHBQQAQwcHBYtCgQaJOnToCgPDx8REXL140eL7z58+L6tWrCwCiTp06YtCgQSI4OFgAEA4ODmL16tUlaocQQsTFxYkmTZoIAKJq1aqid+/e4tlnnxUdOnQQLi4uYsCAAYWOUdr7kZCQYPR9ePHFF+XflZubm0hLS1NsW/766y/h5uYmAAhfX1/Rp08f0a9fPxEUFCS/1ytXrix0nJLaIIQQhw8fFt7e3gKAqFmzpujbt68IDQ0Vjo6OAoD48MMPDR5njXZUlO+6O3fuiAYNGsi/04EDB4rw8HAhSZKQJEnMnj3bZLzGMGGzAd9995149913xc8//yz++ecf8cILLxT5IT5+/LiQJEnY29uLjRs3ytvT09NF586dBQCD//mnp6eLWrVqCQAiKipKb19UVJQAIPz9/UVGRkax2rB9+3YxYMAAsWfPnkL7li9fLuzt7QUA8eOPPyq6HUJo/yO/d+9eoe2JiYkiNDRUABCDBw9WfDsKnqd+/frC19dXPP3000Y/X0pshy5hW7x4sdnHxMfHy/9RL1iwQN6em5srnn/+eTmJK/gHRF5enmjVqpUAIF544QWRm5sr71uwYIEAINRqtbh161ax25GRkSEaNWokAIjJkycXSjLT09NFTEyM3jYlvh9F6dGjhwAgXn31VUW3pUWLFvIfkvnfC41GI95//30BQHh6eorMzEzFtiEzM1P4+/sLAOLZZ5/VO/7w4cPikUceEQDEli1b9I6zVjsqyndd3759BQDRuXNnkZ6eLm/fsGGDsLe3F3Z2duLkyZNGYzaGCZsN0n1BmfoQDxw4UAAQr7zySqF9V69eFXZ2dgKA+Oeff/T2zZ07VwAQDRo0EBqNRm+fRqOR/6qYP39+6TTmXy+//LL8D6Ait2PPnj0CgPD29q5Q7XjzzTcFALFhwwaTny8ltqMkCdv//d//CQCiS5cuhfalpqYKDw8PAUD8+eefevs2bNggf1GnpqYWOlb3BTFhwoRit+ODDz6QEwRzKfH9MOXGjRtyTH/99Zdi25KYmCj37ty9e7fQ/tzcXLlH/fjx44psgxBCLFu2TP68PnjwoND+WbNmCQAiNDRUb7tS2qHE77ozZ84IAMLe3l5cvXq10Dl132UF/2g3B+9hq4Sys7PlexOGDh1aaH/t2rUREhICAFizZo3ePt3rwYMHF5q81s7ODs8++ywAYPXq1aUac6tWrQBo77XQqYjtcHDQTt+bf1BGpbdj165d+OabbzBs2DD07NnTaDmlt6M4dPEYaodarUafPn0MxqM7rk+fPlCr1YWO1dVX3Hbk5ORg3rx5AID/+7//M+uYivh+REdHIy8vD02bNkX79u3l7UprS3EGVa1atSoA5bUBAI4cOQIAaNOmDTw9PQvt79KlCwBg//79uH37tmLbYYw1YtUdFxISgtq1axc6py6OdevWIScnp1jtYcJWCV24cAEZGRkAgLZt2xoso9seExOjt133urjHWerixYsAgJo1a8rbKlo7UlNTMXnyZACQv/ABZbcjLS0NL730Enx8fPD111+bLKvkdgDAzp07MW7cOIwYMQJRUVFYs2YNsrKyCpVLTU3FpUuXShSPue24ePEi0tPTzY79+PHjSExMRK1atVCvXj38/fffmDJlCkaOHIkJEyZgw4YNyMvL0ztG6e+HIdHR0QCAl19+WW+70tqiVqsRFhYGAHj//ff1vnjz8vIwefJkZGZmokePHvD391dkGwDIN9w/8sgjBvfrkk0hhPzAjBLbYYw1YjX3uPT0dPl7zVwOxSpNNiE2NhYA4OnpCTc3N4NldP/J6MoC2i+ye/fuAQACAgJMHpeQkID09HS4urpaHO/t27fl/8gHDBggb1d6O7Zs2YJly5YhLy8Pd+7cwcGDB5Gamoonn3wSn3/+eYVox7vvvovY2FisWbMGXl5eJssquR0AsGTJkkLbatasiR9++AFPPvmkvO3q1avyelHx5G9H/tdFHSeEwNWrV9G0aVOzYj916hQAwM/PDxMmTMCMGTMg8k1S8/nnn6NVq1ZYu3atfG6lvx8F7d69G5cuXYKTkxNeeOEFvX1KbMt3332Hnj17YuHChdiwYQPatm0Le3t7xMTEID4+Hi+88ALmzJmj6DZUr14dAIw+8Zh/uy4mJbbDGGvEWtT/Ae7u7nB3d0dKSgpiY2PRpEkTs9vDHrZKKDU1FQBM/mPQXc5JSUkpdJypY/NfBsp/bEnl5ubi+eefR3JyMpo3b46RI0cWikep7Th79ix+/PFHLF26FFu2bEFqaiqGDh2K6OhoeHh4KL4dW7ZswYIFCzB48GA8/fTTRZZXajtatmyJWbNm4fTp00hJScGdO3ewZcsWdOjQAbdu3UKfPn2wa9euEsVTMJaifgclbYfuyyMmJgaff/45Ro0ahfPnzyM5ORlbt25FgwYNEBMTg169esm9PUp9P4z54YcfAGh7n3U9OwVjUlJbGjZsiIMHD6Jbt26Ij4/H77//jtWrVyM2Nhb16tVDp06d4O7urug2REREANAOX2OoV2v+/PmF6lViO4yxRqwlPac5mLCRor322mvYvn07HnnkEfz6669wcnKydkhmGzt2LIQQyM7OxqVLl/C///0PmzZtQpMmTQyOL6UkycnJePnll1GtWjV888031g7HIm+//TbefPNNNG3aFG5ubqhevTq6du2Kffv2oW/fvsjJycHYsWOtHaZJut60nJwcDBkyBHPmzEGDBg3g7u6OLl26YOvWrahSpQpOnz6N5cuXWzna4ktJScGvv/4KAHjppZesHI159u/fj+bNm+P06dNYtmwZbt++jfv378v3Jr388suFLu0qTUREBMLDwyGEQJ8+fbBu3TokJyfjypUrePfdd7FkyRI4OjoCQKH7uKj88R2ohHRdw6buodHd25D/L8T8XcrGjs0/CGH+Y0virbfewvfffw8vLy+5FyG/itIOR0dH1K1bF++88w42bdqEBw8e4Pnnn0dmZqZePEpqx9ixY3Hjxg3MmTOnUG+HMUpshymSJGHKlCkAgJMnT8oPtBQnnoKxFPU7KGk78seUv5dZJyAgAL169QKgHSDUnFjyx2Pt92P58uXIyMiAn58funfvXmi/0tqSlJSEfv36ISEhAatXr8aQIUPg4+MDLy8v9O7dG3/++SdcXFzwww8/YOfOnYpsg86qVasQEhKCGzduoE+fPvD09ETdunXxv//9D2+99RZatmwJAPD29lZ0OwyxRqwlPac5mLBVQoGBgQC0/+nk7/rNT/flpSsLaD+Iun+0169fN3lc1apVLbr/YNy4cZg9ezY8PT2xZcsW+SnR/CpCOwpq3749mjRpgri4OBw9elQvNiW1Y82aNXBwcMC3336LTp066S1//vknAOD7779Hp06dMHjwYMW2oyiNGzeW12/cuAEAek92FRVP/nbkf13UcZIkGXyCzJg6deoYXDdU5tatW3qxVIT3Q3c5NDIy0mBPjtLasmHDBiQkJKBOnTp6T7Pq5N+uS6CV1gad6tWrY+/evdiyZQsmTJiAV199Fe+//z6OHDmCmTNnIj4+HgDQvHlzRbfDEGvEWtT/ASkpKfKl0IL/fxSFCVsl1LBhQ7i4uACAnDQUpNveunVrve2618U9rjjee+89fPXVV/Dw8MCWLVuMPm2j9HYYo/vHrZveSKntyM3Nxe7duwstd+7cAaC9OX/37t3466+/FN0OU3T3hgH//WXs7u6OevXqlSgec9tRv359g8N+GNO6dWtIkgQASExMNFhGt11Xb0V5P86ePYtDhw5BkiQMHz7cYBmltUX3ZWyqh0R3n+r9+/cBKK8N+UmShK5du2LatGlYuHAhPvnkE7Rt2xaXL1/GrVu38Mgjj8h1K7kdBVkjVnOPc3V1LXTVqEjFHrmNFK80BhPUzSxQ3gNqjh8/XgAQHh4e4vDhw0WWV2o7jElISBAqlUoAEKdOnaqQ7bBk4FwltUOI/6ascXd31xutvqiBcz09PQWKGDi34LRKQlg2cG5YWJgAIGbMmFFoX3Z2tjxt1rRp0+TtFeH9eOeddwQAERERYbKcktry448/CgDC2dlZJCUlFdqfnZ0tAgICBADx+eefK7IN5njttdcEDIz0r5R2KPG77vTp0wL/Dpx77dq1Que0ZOBcJmw2yJwP8bFjx+TpOjZt2iRvL850HRMnTtTbN3HiRAFA+Pn5lWjKmkmTJslfduYka0psx5kzZ8RPP/2kNx2Nzvnz50WnTp0EAPHYY48puh2mmPp8Ka0dMTEx4vfffxc5OTl62zUajVi0aJGoUqWKACDef/99vf35p6ZauHChvD03N1eeDqeoqamGDRtWqlNTbdu2TQAQXl5eenMY5uTkiDFjxghAO//m7du35X1Kez8Kys7Oludd/fnnn02WVVJb7t69K1xdXQUAMXDgQL1ZLbKyssQbb7whAAhHR0dx+fJlRbZB58yZMyI5OVlvW05Ojvj000+FJEmiXr16hf74UEo7lPpdp5uaqkuXLnr7N27cyKmpKrtjx46J9u3by0vVqlXlD1P+7Tdv3tQ7Lv+EuJ06dRKDBg0SNWvWFID5E+I2a9ZMDB48WJ6kvaSTEP/+++8C/0710rZtW6MTQ48bN67QsUpqx86dO+XjQ0NDxeDBg0X//v1F27Zt5SlQGjdubPAvLyW1w5Si/pNUUjvWrFkjJzmdO3cWQ4cOFT179pR7PwCIIUOGFErohBBi5cqV8l/f7du3F88++6xZk7+fO3dOVKtWTQDayd+fffZZ0a5dOwFYPvn7J598ItfToUMH0b9/fxEYGCj39qxfv77QMUp6PwpavXq1/EeaoT9ylNyWpUuXCgcHBwFAVKtWTfTs2VP07dtX+Pr6CgDCzs5OzJs3T9FtEEI7oXqVKlVESEiIGDRokOjbt6/w8fERAES9evVEbGysweOs0Y6K8l13584dUb9+fQFoJ38fNGiQ6NSpk5AkSQAQs2bNMtpGU5iw2QBdklDUYugf3tatW8WTTz4pvL29hUqlEvXr1xdRUVEiJSXF5DkvXrwohg0bJmrVqiUcHR1FrVq1xLBhw8SlS5dK1IbFixeb1YbatWsbPF4p7bh796749NNPxZNPPikCAwOFq6urcHJyEjVq1BBdu3YV8+bNEw8fPjR6vFLaYYo5f9UqpR1XrlwRY8eOFaGhocLX11dUqVJFqFQqERAQIJ555hmxYcMGk8cfPXpU9O/fX1SrVk04OTmJ2rVrizfeeEOvF8uQW7duiTfeeEPUrl1bODk5iWrVqon+/fuLY8eOlagd+W3evFn06NFDeHt7C0dHR+Hv7y8iIyMLXdLJTynvR0G9e/cWAMSoUaPMPkZJbTlx4oSIjIwUderUESqVSv6MPPfcc+LQoUMVog2bN28Wffv2Ff7+/kKlUgl3d3cRHBwsZsyYUWRPV3m3oyJ91yUnJ4sJEyaI+vXrC5VKJby9vcWTTz4ptm3bZvI4UyQh8g2XTURERESKw6dEiYiIiBSOCRsRERGRwjFhIyIiIlI4JmxERERECseEjYiIiEjhmLARERERKRwTNiIiIiKFY8JGREREpHBM2IgqIEmS5GXXrl3lfv6rV6/qxXD16tVyj4GooE6dOsmfycmTJ1s7HKJSxYSNbE7BZKI0FyYmZEj+RCEwMNDa4RCRDWLCRkRUTnbt2qX3BwAZZu0eZPpPdHQ0/xhRCAdrB0BU2pydndG9e/ciyx0+fBgPHjwAAFSpUgUdO3Y0q24iIqLyxoSNbI6Pjw/+/PPPIst16tQJu3fvLtYxSiGEsOr5AwMDrR4DUUHsjSNbxkuiRERERArHhI2IiIhI4ZiwERXB0A3QmZmZWLJkCZ566inUrVsXrq6ukCQJY8eOLXT87du38eOPP+Lll19Gu3btUK1aNTg5OUGtViMgIAA9e/bEF198gXv37lkUU0HGht7IzMzE4sWL0aVLF/j7+0OlUqF69ero1KkTZs2ahYcPHxZ5fnOH9TB2k31SUhK++eYbhIaGombNmlCpVKhZsyZ69OiBxYsXQ6PRmP270LVpzpw5eOKJJ1CzZk1UqVIFAQEB6Ny5MxYtWoSMjAyT8ZS1yMhISJKEJ554Qm+7saeRO3XqZLK+3NxcrFixAsOGDUOjRo3g7e0NlUoFX19fdO7cGV988QXu379vVmxK+Xznv7k9vyeeeMLo76mgkgzrkZqaim+//Ra9e/dGYGAgXFxc4Obmhrp162LQoEFYsmQJsrOzzarL2Pn379+Pl156CY0aNYJarYa7uzuaNm2KN998E5cuXTKrbgDIy8vD2rVr8cILL6Bp06bw9PSEg4MDnJ2dUaNGDQQHByMyMhILFy7EnTt3zK7XVFuGDx8ub7t27ZrR9yIyMtKi85EZBFEl1bFjRwFAABC1a9c2Wk5XBoDYuXOnOHHihGjcuLHedt3y1ltv6R07fPhwYWdnZ7BswcXV1VV8++23ZsVeMCZDYmNj9crFxsaKkydPGo1dt9SrV09cvnzZ5PkN1W3Izp079crptvn6+pqMoV27diIhIcGs38Vff/0l6tSpY7K+Ro0aib///ttgPKWhqM/Siy++aNZnQLd07NjR6Ln+/PNPUb9+/SLr8PT0FN9//32RsSvl87148eJi/Y4MvX/534ePPvqoyLb//PPPonr16kWep27dumL79u1F1lfw/Onp6eKVV14xWbejo6NYtGhRkXVfuHBBtGrVyuzfTbVq1Yqs09y2mLO8+OKLFp2PisaHDoiKITY2FgMGDJB7L/z8/BAUFITs7GyDfymfOnUKeXl58uuAgADUqlULarUa6enpuHDhgtzzkJ6ejlGjRiEpKQlRUVGlHvv58+cxePBgJCUlAQDq168PX19fZGRk4OTJk8jKygIAXLp0Cd26dcOpU6fg4uJSqjHs3bsX3bt3R3Z2NiRJQuPGjeHj44OkpCScOnVK7lk7fPgwnn76aezZswd2dsYvBBw+fBhdu3ZFamqqvK1KlSpo1qwZ1Go1rl27htjYWJw7dw4RERGYOXNmqbbHXM2bN0f37t1x//59HDlyRN5u7GnmFi1aGNw+b948jBkzRq8H0tvbGw0aNICzszNu3LiBixcvAtD2Yr788su4desWJk2aZFac1vx8+/r6yr+PzZs3y9uDg4Ph7e1tVvzFMWPGDIwfP15vW7Vq1dCgQQNoNBr8888/SE5OBgBcvnwZTz75JH766ScMGjTIrPrz8vIwaNAgbNiwAYD2fWrYsCGcnJxw/vx53L59GwCQk5ODV155BX5+fkY/D4mJiejYsSNu3bolb6tSpQoaNmyIRx55BBqNBklJSbh48aLcm5z/fSmJdu3aoUqVKoiPj8fp06flcxp7mr558+YWnY/MYO2MkchaStLD5u7uLgCIDh06iMOHD+uVy8nJKdTT9Pjjj4vBgweLX3/9VSQlJRms/8CBAyI8PFw+h729vTh27JjJ2PPHZG4PW9WqVQUAMWDAAHHx4kW9sklJSeKll17SKz916lSj5y9pD5suhpEjR4qbN2/qlb1165bo1auXXvmffvrJaAzp6el6PWv29vZiypQpIiUlRa/csWPHRLt27eReh/z1lxZzP0uW9PBt3LhRSJIkH9uhQwexe/dukZeXp1fuwoULonfv3nI5SZLE5s2bjdZbUT/fhpjbw7Z582a932WtWrXE6tWrhUajkctkZWWJRYsWyb8TAMLZ2VmcOXPGrPPrPuuBgYHi999/16s7Ly9PrFixQri4uMjl69evX+i91Hn77bflcmq1WixatEhkZmYWKqfRaMTx48fFhx9+KJo3b27Gb6xo+Xs+TX22qewxYaNKqyQJGwAREREhHj58aNY5UlNTzSqXk5Ojl6wMHTrUZPmSJGwAxOuvv26y3i5dushl69SpY7RcSRM2AOLzzz83Wm9WVpbe5biIiAijZT/++GO9ehcvXmy0bHp6uggODi4US2kp64QtNTVVL9kcOnSoyM3NNVo+Ly9PPPfcc3L5pk2bGi1bUT/fhpiTsOXm5oratWvL5apXr27yFoCDBw8KZ2dnuXx4eLhZ59cla7dv3zZafunSpXrl9+zZY7Bc3bp15TILFy40Wl/BdpYGJmzKwYcOiIrB0dERixcvhkqlMqu8Wq02q5yDg4Pe5bo//vij2DfeFyUwMBBff/21yTL/93//J69fuXIFN2/eLNUYQkJC8N577xnd7+TkpHdj+8GDBw3+HjQaDRYuXCi/7tatm8mbnl1cXLBo0aIKO7vAokWLkJCQAAAICgrC999/D3t7e6PlJUnCt99+C09PTwDAmTNnsGPHjiLPU5E/3+Zau3Ytrl27Jr+eOXMm6tSpY7T8Y489hgkTJsiv9+zZg5iYGLPOtXDhQvj4+BjdP3ToUPj6+sqv9+7da7BcXFycvB4WFmbWuU19PqhiYsJGVAw9evRAQEBAmdRdv359PPLIIwCAtLQ0nD17tlTrf/XVV+Hk5GSyTGhoqN49Y2fOnCnVGEaNGlVkmfz3yGRmZuLKlSuFypw8eRI3btwoVr0tWrRASEiImZEqS3R0tLw+evRoVKlSpchj3N3d0a9fP/n1tm3bijymIn++zbV69Wp53dfXF4MHDy7ymDFjxuglsfnrMKZ+/fro2rWryTJ2dnZ6CZixf2/5Z1gxN1kk28OHDoiKITw8vMTHxsTEYP/+/Th79izu37+P1NTUQr0M6enp8vqNGzdK9UZec5IVFxcXeHt7IzExEQDkBxTKMwY/Pz+914ZiOHTokLwuSRIiIiLMOn9ERAT27dtnVlmlSEpKwt9//y2/LioJyK9ly5by+tGjR4ssX5E/3+Y6ePCgvN6zZ0+TD7XoeHl5ISwsTE56Dxw4UOQx5v5xkP/zbuzfW/v27bFlyxYA2oTdwcEB/fv3Zy9aJcOEjagY6tatW+xj/vjjD0yYMAH//PNPsY4r7WSpRo0aZpVzdXWVEzbdE2flGYOrq6vea0Mx5L+k5evrCzc3N7PO36RJE7PKKcnff/+t98Tf2LFj4ejoaNax8fHx8rrukqopFfnzbY7c3FzExsbKr/MntEVp0aKFnLCZM3Zacf696Rj79/buu+9i69atEELg/v37GDRoEKpWrYru3bsjLCwM7du3R4sWLcxKPqniYsJGVAzu7u7FKv/+++/j008/LdG5dMNslBZz70vKT5TyfKGlFUP+L3vdfVrmKE5ZpSg44Kw596IZohuiwpSK/Pk2R8EksVq1amYfm7/sgwcPiixfmv/eunbtinnz5uHNN9+UB/FNTEzEzz//jJ9//hmA9rPdrVs3DBs2DD179qyw92uScUzHiYqhOH/B/v7773pfZr6+vvjwww+xbds2XLlyBampqcjNzYXQPq0NIQRq165dFmFTBZb/MqIlzBmXy9Y/3wWTxKLu6cwvfwJmzmwgpW3kyJE4d+4cRo8ebTDRTEpKwsqVK9G7d28EBwfj3Llz5R4jlS32sBGVkU8++UReDw4OxtatW+Hh4WHymPwDwJJx+XvKinNpzRqX4SxVsFfw7t27xeoZKisV8fNd8HdZnHhSUlKM1lNegoKC8M0332D27Nn4+++/sX//fuzduxe7du3SG1T32LFjCA8Px7Fjx+Dv72+VWKn0sYeNqAwkJCTg2LFj8uvPP/+8yC+ztLS0CplQWEP+npr4+Hizv3it9WSiJQreC2XpHJGloaJ+vl1dXfVm77h8+bLZx+YvW7169VKNq7gkSUKLFi3w+uuvY9myZYiPj8f+/fvRq1cvuUxCQgKmTp1qxSiptDFhIyoD169f13vdrl27Io85cOCAxdPJVBbt27eX14UQZt/XVdL7v0pLwUuO5twj2KJFC70b0/M/5WgtZf35zn//VWnfR9mmTRu9mMyVv2zbtm1LNSZLSZKEDh064I8//tB70vfPP/+0uO78n9nSfi+oeJiwEZWBnJycYh/z/fffl0Ektqlly5Z6wyHMmzevyGNOnTqF/fv3l2VYRSo40GxmZmaRxzg6OqJLly7y6x9++KHU4yqusv585/89mfM7Ko5OnTrJ6zt27NB7ktaY/fv36/Ww5a9DSezs7PD000/Lr3XzlVqiLN8LKh4mbERloFatWnqv9+zZY7L89u3bsWrVqrIMyabY29tjxIgR8uvNmzfrDS5bUEZGBl555RWr9xDUrFlT7/WFCxfMOi7/DBR//fWXWQlqWSrrz3f+35O5vyNzvfzyy/L4ZRqNxuTMG7oy+X//Xl5eZk8AXxqK+5lNS0uT1729vS0+f/73IiEhweqXtSszJmxEZSAgIEBvTKt333230PAMOrt27cKAAQOsnkxUNO+8847elEKvvPIKPv7440L3s8XExCAiIgJHjhyx+s36NWvW1PsC/Oqrr5Cbm1vkcSEhIXoj8o8ZMwaff/55kcfm5ORg3bp1eOKJJ/TGrrNUWX++81+2/P77743WXRK1a9fWm8Zs2bJl+OCDDwxers3KysLw4cP1LkO/9957evfBlbVr167h8ccfx6+//lrkUCiXL1/G3Llz5ddPPPGExedv0aKF3rh/X3zxBf+vshI+JUpURsaNGydPmXT27Fk0b94co0aNQvv27eHk5IRr167h999/x5o1ayCEQM+ePXH69OlC9weRYa6urvjll1/QpUsXeVT9jz76CNOmTUPz5s3h6uqK69evy1NbVatWDTNnzsTzzz8PoHhDOpSmYcOG4fPPPwcALF26FJs2bUKLFi30Bv9t1qxZoRvGv//+e1y4cAHHjx+HRqPBhAkT8O2332LQoEFo3749qlWrBiEEkpKScOHCBRw7dgxbtmyRe0RK+0u2LD/fw4YNwy+//AIAOH36NPz9/dG6dWt4e3vr3VO1du3aEsU+c+ZM7N69Wx4Ad+rUqdi0aRMiIyPRuHFjaDQanDx5EosWLdLr4QsPD9frbSsvf/31FwYOHAh3d3d0794dwcHBaNCgAby8vABoH7zZvXs3fvrpJ3kYGCcnJ0ycONHic7u6uqJ///5YsWIFAOCzzz5DdHQ0mjZtqpe4RkRE4M0337T4fGRCOU40T6QoHTt2FAAEAFG7dm2j5XRlAIidO3eaXX9eXp4YMGCA3vHGltatW4sHDx6I2rVry9sWL15sUUyxsbF65WJjY82K25wYzK17586deuXMVZzf+cGDB0VQUJDJ32/Dhg3F33//LTZt2iRvq1atmtnxFMXcz5IQQqSmpoq2bduajLdjx45GjzX3M1VwMfYeKfHzLYQQr732WpH1FpT/ffjoo49M1h8fHy+aN29u9u+va9euIjU11WSdxTm/zkcffWTyfS/4b82cxdnZWaxZs8as85sjPj5e1KlTx+Q5X3zxxVI7HxnGS6JEZUSSJKxYsQIff/yx0RHkvby8MGHCBBw8eLBCjsKvBI899hjOnDmD2bNno2PHjqhevTqcnJzg5+eHiIgILFy4EMePH0ezZs30hsSw1uVRtVqN/fv34/vvv0fv3r1Ru3ZtuLi4mDUyvVqtxq+//opNmzahU6dORc4lGRgYiNdffx379u1DYGBgKbVAq6w/3/PmzcOff/6J559/Ho0bN4abm1upTr1Uq1YtHD58GNOmTTM5TEdQUBC+++47bNq0qdBDI+XBx8cHX375JSIiIvQmgTfE2dkZzz33HE6fPq338IGlatWqhRMnTuDrr79G165d4evrW2QsVPokIXgxmqispaWlYc+ePbhw4QIyMzNRrVo1BAYGomPHjmbPC0mWGzVqlHzD/nPPPYeffvrJyhFZJjk5Gfv378eNGzdw7949SJIEDw8PBAYGokmTJuU2s0BF/3wLIXD06FGcPn0aCQkJsLOzQ/Xq1dG6dWs0a9bM2uHJcnJycPr0aVy8eBE3b95EWloaHB0d4eXlhUaNGqFNmzaF5uIl28GEjYgqhbS0NAQEBMjzQM6bNw+vvfaalaMiIjIPL4kSUYVl7t+bGo0GI0aMkJM1FxcXvacuiYiUjgkbEVVYp06dQmhoKBYvXoy7d+8W2p+Xl4c9e/YgIiJCfuoQ0D7hyHsGiagi4SVRIqqwTpw4gVatWsmv/fz8EBAQABcXF6SkpOD8+fNITk7WO+aJJ57Ali1b4ODAUY2IqOLg/1hEVGEVfGrwxo0buHHjhsGyutkRvv76ayZrRFThsIeNiCq0f/75Bxs2bMDBgwdx7tw5xMfHIz09HY6OjvD29kb9+vXRsWNHvPDCC3qj8xMRVSRM2IiIiIgUjg8dEBERESkcEzYiIiIihWPCRkRERKRwTNiIiIiIFI4JGxEREZHCMWEjIiIiUjgmbEREREQKx4SNiIiISOGYsBEREREp3P8Dpa/RAKFw3oIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('16.npy')\n",
    "matrix2 = np.loadtxt('36.npy')\n",
    "matrix3 = np.loadtxt('64.npy')\n",
    "\n",
    "matplotlib.rcParams['xtick.labelsize'] = 16\n",
    "matplotlib.rcParams['ytick.labelsize'] = 16\n",
    "# 计算每个矩阵列方向的平均值\n",
    "mean_matrix1 = np.mean(matrix1, axis=0)\n",
    "mean_matrix2 = np.mean(matrix2, axis=0)\n",
    "mean_matrix3 = np.mean(matrix3, axis=0)\n",
    "\n",
    "\n",
    "# 假设要均匀抽出10条数据\n",
    "num_samples = 10\n",
    "sample_indices = np.linspace(0, len(mean_matrix1) - 1, num_samples, dtype=int)\n",
    "\n",
    "# 抽取数据\n",
    "sampled_matrix1 = mean_matrix1[sample_indices]\n",
    "sampled_matrix2 = mean_matrix2[sample_indices]\n",
    "sampled_matrix3 = mean_matrix3[sample_indices]\n",
    "\n",
    "\n",
    "# 生成x轴数据\n",
    "x = np.arange(num_samples)\n",
    "\n",
    "# 绘制折线图\n",
    "plt.plot(x, sampled_matrix1, label='μ=16', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='μ=36', color='red')\n",
    "plt.plot(x, sampled_matrix3, label='μ=64', color='green')\n",
    "\n",
    "\n",
    "# 添加图例\n",
    "plt.legend(fontsize=14)\n",
    "\n",
    "# 添加标题和坐标轴标签\n",
    "\n",
    "\n",
    "plt.xlabel('Training Iterations t',size=26)\n",
    "plt.ylabel('Test_Loss',size=26)\n",
    "plt.xticks(x,[100,200,300,400,500,600,700,800,900,1000])\n",
    "# 显示折线图\n",
    "\n",
    "plt.savefig('mu.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b09138d-6497-40fe-97f8-6a1db2ff95d8",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
