{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e4760c69-bb95-4804-8f60-e2384c8cd0fb",
   "metadata": {},
   "source": [
    "第一部分的实验是针对噪声的方差，特别是x2的方差。\n",
    "1：噪声方差作为横坐标\n",
    "2：训练批次作为横坐标，看不同的方差对损失的影响\n",
    "\n",
    "\n",
    "第二部分预计变化x3到x16的方差，但是可能m后边要改为2，所以暂时不进行实验"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4abe0306-efd5-4d86-95f6-b845d3e38b65",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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",
      "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",
    "\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,cp):\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(cp)).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(cp)).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(cp)).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(cp)).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",
    "\n",
    "# 噪声强度（方差）作为横坐标\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, 36, (mu+1)*0.1)\n",
    "# np.savetxt('噪声方差.npy', matrix)\n",
    "\n",
    "# 迭代次数作为横坐标，探究不同的噪声方差对损失的影响\n",
    "matrix1 = np.zeros((20, 100))\n",
    "for n in range(20):\n",
    "    print(n)\n",
    "    test_losses = Get_test_loss(100, 16, 0.5)\n",
    "    matrix1[n, :] = test_losses\n",
    "np.savetxt('0.5_.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, 16,4)\n",
    "    matrix2[n, :] = test_losses\n",
    "np.savetxt('4_.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, 16, 16)\n",
    "    matrix3[n, :] = test_losses\n",
    "np.savetxt('16_.npy', matrix3)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "07a3c271-e36b-4da8-ac33-a4046c29dc4a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAl4AAAHKCAYAAADSPkVOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACCGklEQVR4nO3dd1gUV9sG8HtoS0cRbICCXRSN3QiWQNRYPkuMxhZrjNHYUu2JqZbkTdQYTYzGkmgssUSjRmzRYC8Eu6KiIjZA6UXK+f4Yd2VlFxZ22V2W+3ddczE7c+bMM+zqPpw5c44khBAgIiIiohJnZeoAiIiIiMoKJl5ERERERsLEi4iIiMhImHgRERERGQkTLyIiIiIjYeJFREREZCRMvIiIiIiMxMbUAZRVubm5uHv3LlxcXCBJkqnDISIiIh0IIZCcnIyqVavCyqro7VdMvEzk7t278PHxMXUYREREVAzR0dHw9vYu8nFMvEzExcUFgPzGubq6mjgaIiIi0kVSUhJ8fHxU3+NFxcTLRJS3F11dXZl4ERERlTLF7SbEzvVERERERsLEi4iIiMhImHgRERERGQkTLyIiIiIjYeJFREREZCRMvIiIiIiMhIkXERERkZEw8SIiIiIyEiZeREREREbCxIuIiIjISJh4ERERERkJEy8iIiIiI+Ek2URERGR0QggICAghkCtyC10XePpaw7q24yo5VYKDrYOpL1UNEy8iojJG+cWk/HJSrhe25D1Op/LFrDvvl6qmusy9rNpr5GpNCp4/pqB9mhKOouwr7vl1TXCKmhgJCKN81ncP3o1ONTsZ5Vy6YuJFRCVCCIEckYNckYuc3BzkiJxCfxalbE7u0/I6ln2+fuWXprIeZV3F3l4SdeqwvTjJDpElkSDBSrKCJEka180NEy+iEiCEQHZuNjJzMvEk5wmycrKQnZttkCUr17R16ZocGesvWip5yi+wwhZJ0q2c2jHP1a2sI+/2vPVq2q5XWWg/rrC6ni9b0PmeTwqKsk/5uiT2FZSwFGVd2/lK6jjlemnExIssghACT3KeIDMnE5nZmaqfGdkZ+bYV66eGbRnZGQUex8SjYBIkWFtZw1qyVv20kqzybSvop5VkpXPZ5+tXriu/eJX1KetUrWvZXpxjDFnX8/s0JTFFToI0JE7KL0EiMgwmXmQ2EjIScCn2Ei7GXsSF2Au48fgG0rLSdEqMnuQ8MXX4hbKxsoGNlQ1srWxV64ZYbK1tYSMZsC4t+6wla9hY2RgsOeKXORGVRUy8yOgepz9WJVcXYy+q1u8m3zXYOWytbKGwUUBhrSjST3tr+2Idl68eG3vVup21HRMNIiICwMSLSlB8Wny+5Opi7EXcT7mv9RhvV2/4e/rD38MfdSrUgbOdc7ESHSvJ/DpUEhERMfEivcWmxmpMsB6mPtR6TDW3aqoEq0HFBvD39Ed9j/pws3czYuRERETGxcSLdCKEwIPUB8+Sq4cXcDFOXo9Li9N6nG85X/h7+qOBp5xcKRMsF4WLEaMnIiIyD0y8SI0QAvdS7mlMsB6lP9J4jAQJfuX9NCZYTnZORr4CIiIi88XEq4wSQiAmOeZZchV7UZVgJWQkaDxGgoSa7jXVkit/T3/U86gHR1tH414AERFRKcTEy8IJIRCdFK0xwUrKTNJ4jJVkhVrutdQSrAaeDVCnQh2zm/OKiIioNGHiZWH23diHM/fOqJKri7EXkfIkRWNZa8katSvU1phgKWwURo6ciIjI8jHxsjCfHvwU/97+V22brZUt6lSoo5Zc+Xv6o3aF2rCztjNRpERERGUPEy8L07lmZ1R1qaqWYNVyrwVba1tTh0ZERFTmMfGyMNPbTTd1CERERKQFh/cmIiIiMhKLTbw2btyIDh06oHz58nByckLjxo0xb948ZGVlFakeX19fSJJU6PLZZ5+V0JUQERGRpbDIW42TJk3CggULYGNjg+DgYDg7O2P//v2YPHkytm/fjtDQUDg46DYswmuvvYa4OM0jsz969Ajbt28HALz00ksGi5+IiIgskySEEKYOwpC2bt2K3r17w9nZGQcPHkTTpk0BAHFxcQgODsa5c+fw/vvv45tvvtH7XPPmzcPkyZNRp04dXLlypUjHJiUlwc3NDYmJiXB1ddU7FiIiIip5+n5/W9ytxq+++goAMGXKFFXSBQAeHh5YvHgxAGDRokVITEzU+1y//PILAGDEiBF610VERESWz6ISr5iYGJw8eRIAMHDgwHz7g4KC4OPjg8zMTOzcuVOvcx0+fBhXrlyBjY0Nhg4dqlddREREVDZYVOIVHh4OAHB3d4efn5/GMs2bN1crW1zK1q6uXbuicuXKetVFREREZYNFda6PiooCAFSrVk1rGR8fH7WyxZGamooNGzYAAEaOHKnTMZmZmcjMzFS9TkrSPE8iERERWS6LavFKTk4GADg5OWkt4+zsDEC/xGfDhg1ISUlB5cqV0bVrV52OmT17Ntzc3FSLMgEkIiKissOiEi9jWb58OQBgyJAhsLHRrdFw6tSpSExMVC3R0dElGSIRERGZIYu61eji4gJAvhWoTUpKCgAUewiHq1ev4vDhwwCK9jSjQqGAQqEo1jmJiIjIMlhUi5evry8AFNiapNynLFtUyk71QUFBqFu3brHqICIiorLJohKvJk2aAADi4+O1dp4/deoUAKiN8aWrnJwcrF69GoDuneqJiIiIlCwq8fL29kaLFi0AAGvXrs23PywsDNHR0VAoFDp3is9r586duHfvHlxcXNC3b1+94yUiIqKyxaISLwCYNm0aAGDOnDk4c+aMant8fDzGjh0LABg3bhzc3NxU+7Zs2YJ69eohJCSkwLqVtxn79+9f4JOTRERERJpYVOd6AOjVqxcmTJiAhQsXonXr1ggJCYGTkxP27duHhIQEBAYG4vPPP1c7JjExEVeuXEFGRobWeh8+fIgdO3YA4G1GIiIiKh6La/ECgAULFmD9+vV48cUXceTIEezcuRPe3t6YM2cO9u/fDwcHhyLX+euvvyIrKwsNGjRAq1atSiBqIiIisnSSEEKYOoiySN/ZzYmIiMj49P3+tsgWLyIiIiJzxMSLiIiIyEiYeBEREREZCRMvIiIiIiNh4kVERERkJEy8iIiIiIyEiRcRERGRkTDxIiIiIjISJl5ERERERsLEyxJlZpo6AiIiItKAiZclyc0FFi0CatQAoqNNHQ0RERE9h4mXJRECCT+sAe7eRdobowFOw0lERGRWmHhZEmtrjHf6BRlQwPHgLmD1alNHRERERHkw8bIwFYLqYxZmyS8mTQLu3TNlOERERJQHEy8L07Qp8A0+wGXnZkBCAjBmDG85EhERmQkmXhamWTMgBzYYmrMCwtYW+PNPYN06U4dFREREYOJlcerWBRwcgBPpAYh/e4a8cfx44OFD0wZGRERETLwsjY0N0LixvL6/5RSgUSMgPh4YN860gRERERETL0vUtKn889RZO2DFCsDaGti4Edi0ybSBERERlXFMvCyQMvE6ffrpiylT5A1jx8qtX0RERGQSTLwsULNm8s8zZ54+0DhzJuDvL/fzmjjRpLERERGVZUy8LJC/P2BnJ48mcfMmAIVCvuVoZQWsWQNs327iCImIiMomJl4WyM4OCAiQ18+cebqxZUvg/ffl9dGj5ayMiIiIjIqJl4VS6+el9OmnQJ068mj2771nkriIiIjKMiZeFipvPy8VBwfgl18ASZJvPe7ebZLYiIiIyiomXhZK2eKl6mCvFBgITJggr48aBSQlGT02IiKisoqJl4UKCJCH74qNBWJintv55ZdAjRpAdDTw0UcmiY+IiKgsYuJloeztgQYN5HW1240A4OQELF8ur//0E7B/v1FjIyIiKquYeFkwjR3slTp0AMaMkdfffBNISTFWWERERGUWEy8LprGDfV5z5wLVqgFRUcC0aUaLi4iIqKxi4mXB8naw18jFBfj5Z3n9+++Bf/81SlxERERllcUmXhs3bkSHDh1Qvnx5ODk5oXHjxpg3bx6ysrKKXeeff/6JHj16oHLlyrCzs0PFihXRpk0bfPbZZwaM3HAaN5ZHjrh7F7h/X0uhTp2AkSPl9ZEjgbQ0o8VHRERU1khCqA02YBEmTZqEBQsWwMbGBsHBwXB2dsb+/fuRkJCAoKAghIaGwsHBQef6njx5gsGDB2Pjxo1wcHDAiy++iEqVKuH+/fu4cOECcnJyEBcXV6QYk5KS4ObmhsTERLi6uhb1EnXm7w9cugTs2AF07aqlUEKC3BP/7l15dPtvvimxeIiIiEozfb+/La7Fa+vWrViwYAGcnZ1x/Phx7N69G5s2bUJkZCQCAgIQFhaGmTNnFqnOUaNGYePGjejVqxdu376Nffv2Ye3atdi/fz/u3buHv/76q4SuRn+F9vMCgHLl5KcbAeC774Bjx0o6LCIiojLJ4hKvr776CgAwZcoUNFV2cgLg4eGBxYsXAwAWLVqExMREnerbt28fVq9ejYYNG2LDhg3w8PBQ229lZYXWrVsbKHrDK7Sfl1L37sDgwUBuLjBiBJCRUeKxERERlTUWlXjFxMTg5MmTAICBAwfm2x8UFAQfHx9kZmZi586dOtX5/fffA5BvX9ra2houWCPROfECgAULgEqV5HuTZtpvjYiIqDSzqMQrPDwcAODu7g4/Pz+NZZo3b65WtiA5OTnYt28fAKBdu3a4f/8+5s+fjzFjxmDSpElYtWoVUsx8/KsXXpB/3roFxMcXUtjdHViyRF6fN0/LAGBERERUXDamDsCQoqKiAADVqlXTWsbHx0etbEFu3LihSqyOHTuGsWPH5ku0PvzwQ6xbtw7BwcEF1pWZmYnMzEzV6yQjzZHo5gbUqgVcuya3enXsWMgBvXsD/foBGzYAw4cDp04BdnZGiZWIiMjSWVSLV3JyMgDAyclJaxlnZ2cAuiU+8XmaiEaOHIlmzZrh5MmTSE5Oxn///YeuXbsiNjYWPXv2RGRkZIF1zZ49G25ubqpFmQAag04d7PNatAjw8ADOnQNmzy6xuIiIiMoai0q8DC3vSBteXl7YvXs3mjdvDmdnZzRu3Bjbtm1Dw4YNkZKSgjlz5hRY19SpU5GYmKhaoqOjSzp8lSL18wIAT085+QKAL74Azp4tkbiIiIjKGotKvFxcXAAAqampWssobxXqMvaGsj4AGDZsGBQKhdp+a2trjB49GgCwd+/eAutSKBRwdXVVW4ylyIkXIN9u7NULyM6WbznqMfAsERERySwq8fL19QWAAluTlPuUZQurT5IkAECNGjU0llFuv3fvXhEiNa4mTeSf164BOo6iIQ95v2QJUL68nLFxUFUiIiK9WVTi1eRphhEfH6+18/ypU6cAQG2ML22cnZ1Rt25dANA6Mr1yu7LvmDmqUAFQ5pk6PMz5TOXK8hATADBrFnDxooEjIyIiKlssKvHy9vZGixYtAABr167Ntz8sLAzR0dFQKBToqnX+HHV9+/YFoP1W4p49ewAALVu2LE7IRlOs242APKhq167AkyfywKo5OQaPjYiIqKywqMQLAKZNmwYAmDNnDs7kyTLi4+MxduxYAMC4cePg5uam2rdlyxbUq1cPISEh+eqbMGECypcvj507d+In5bQ6T61btw5r1qxRlTNnxU68JEmeTsjVFTh+HJg/39ChERERlRkWl3j16tULEyZMQEpKClq3bo0uXbrgtddeQ61atXDu3DkEBgbi888/VzsmMTERV65cwfXr1/PV5+HhgfXr18Pe3h5vv/02GjZsiL59+6Jp06YYMGAAhBCYOXOmzi1opqJMvIo1Jqq3N/Dtt/L6jBnA1asGi4uIiKgssbjECwAWLFiA9evX48UXX8SRI0ewc+dOeHt7Y86cOdi/fz8cHByKVF/Hjh0RERGBoUOHIiEhAX/++Sdu376Nrl27Yvfu3fisFEyvo0y8rlwBijXY/ogR8uirGRnAyJHynI5ERERUJJLIO1gVGU1SUhLc3NyQmJhotKElvL2BmBggLAwIDCxGBbduAQ0bypnbwoXA+PEGj5GIiMic6fv9bZEtXqRZsft5KVWvLs/hCABTpgA3bhgkLiIiorKCiVcZonfiBQCjRwMdOgBpacCbbwJsMCUiItIZE68yRK8O9kpWVsCyZYCjI3DgALB0qUFiIyIiKguYeJUhysmyL14E0tP1qKhmTeCrr+T1Dz8Ebt/WOzYiIqKygIlXGVK1KlCxojwG6rlzelY2bhzQpg2QnAy89RZvORIREemAiVcZIkkG6ucFANbWwC+/AAoFsHs3sHKlvuERERFZPKMlXkIIrF+/HsOHD0eXLl0waNAgLFu2DBkZGcYKgWCgfl5KdesCyjHM3n1XHquCiIiItNJrHK/09HQMHz4cubm5cHR0xIoVKyBJUr5ySUlJ6N69Ow4fPpxvX+3atfHXX3+hVq1axQ2jVDLFOF4AsGkT8NprcgJmkOQrO1u+5XjyJNC9O7Btm9y0RkREZIFMOo7Xzp07sWHDBmzatAn29vYaky4AGDNmDMLCwqDM8YQQquXq1at45ZVXkJqaqk8opCNlB/tz5+R5r/VmYwOsWAHY2gJ//QVomJyciIiIZHolXgcPHlSt9+3bV2OZiIgI/P7776qkzN3dHT169EBwcDCsrOTTR0VFYc6cOfqEQjqqXh0oXx7IygIuXDBQpQ0aAB9/LK9PmADcv2+giomIiCyLXolXREQEAMDGxgbt2rXTWGb58uWqdX9/f1y4cAFbt27F3r17sXnzZkiSBCEEli9fDs5eVPIM2sE+r8mTgSZNgEeP5CceiYiIKB+9Eq+bN28CAGrWrAlbW1uNZbZt26Za//zzz1GxYkXV6x49eqBHjx4AgAcPHqgSOSpZBu1gr2RrKz/laGMjdyTbuNGAlRMREVkGvRKvR48eQZIkeHp6atx/8+ZN3H46uKazszO6d++er0y3bt1U6+f0HlyKdKHs52XQFi8AeOEFYOpUef2dd4DYWAOfgIiIqHTTK/FSDgVhb2+vcf+xY8cAAJIkoV27dhpbxWrWrKlaj+UXtVEoW7wiIuSHEg1qxgygYUM56Zo40cCVExERlW56JV7KhCspKUnj/rzDR7Rt21ZjGYVCoVpP12seG9JVzZqAiwuQkQFcvmzgyu3s5KccrayA338H/vzTwCcgIiIqvfRKvDw9PSGEQGRkpMb9u3fvVq23adNGY5nExETVuoODgz7hkI6srOR+8ICB+3kpNW8uz+EIAG+/DTx+XAInISIiKn30SrwaNWoEAHj8+DH++ecftX0nTpzAtWvXAMgJVatWrTTWcTvPBMt5O95TySqRJxvzmjULqFdPHlri3XdL6CRERESli16JV9euXVXrb7/9Nq5fvw4AuHfvHt5++20Acv+url27an3q8Uyeb/4aNWroEw4VQYl1sFeyt5efcpQkYNUqYNeuEjoRERFR6aHXlEHJycmoU6cOHj58KFcmSahYsSIePnyoGplekiQcOnQIgYGBGuuoXr06oqOjYW1tjcTERDg6OhY3nFLFVFMGKV28KI976uQEJCXJtx9LxHvvAd99B3h7A+fPA25uJXQiIiKikmfSKYNcXFywbNkyWFtbAwByc3Nx//595ObmqsqMHDlSa9J15MgRREdHQ5IkNGrUqMwkXeagbl3AwQFITQW0dNEzjC++AGrVAu7cedbvi4iIqIzSu52jW7du2LNnDxo3bqy23cnJCTNmzMCPP/6o9dgFCxYAkOdu7NKli76hUBFYW8vDbgEl1MFeydERUM5e8PPPwN69JXgyIiIi82ZjiErat2+PM2fOICYmBtHR0XBwcIC/v7/Wfl1KPXr0UPUTCw4ONkQoVATNmgFHj8r9vAYOLMETtWsnD6j6ww/Am2/KtxydnUvwhERERObJIImXkpeXF7y8vHQuP2jQIEOenoqoxJ9szGvOHGDHDuDmTWDKFGDRIiOclIiIyLyUVJdqKgXyJl4lPj+5szOwbJm8/sMPwMGDJXxCIiIi88PEqwzz9wcUCiAxEbhxwwgnDAkBRo2S10eOBNLSjHBSIiIi82G0xCs1NRVz587FSy+9hPr16yMwMBAzZ85UDUVBxmdrCzwdA9c4txsB4Ouv5aElrl+X53UkIiIqQ/RKvBITE9G6dWu0bNkSnTt3hrYhwe7du4fmzZtj2rRpOHToEK5evYpjx47hq6++QsOGDXHixAl9wiA9GLWfFyCP47V0qbw+fz5w5IiRTkxERGR6eiVe27dvx4kTJ3D69Gk0atQIkiRpLDds2DBcuXJFNaiqcgGAuLg4dO/eHXFxcfqEQsVk9MQLALp0AYYOlTuWjRghz9ZNRERUBuiVeIWFhanWX331VY1l/v33X+zZs0eVlNWpUwcTJkzAiBEj4ODgAEmSEB8fj88++0yfUKiYjNrBPq/vvgMqVwauXJHndSQiIioD9Eq8zp49CwCws7PTOgn2ypUrVett2rRBeHg45s+fj2XLlmH//v2wsbGBEAJr1qxBVlaWPuFQMTRsCNjYAHFxQHS0EU9cvjygHFz366+BkyeNeHIiIiLT0Cvxun37NiRJQu3atWGlZbK/nTt3qtZnzZoFBwcH1euWLVuiX79+AICEhASEh4frE46ajRs3okOHDihfvjycnJzQuHFjzJs3r8jJ3cqVKyFJUoHL33//bbC4jc3eXk6+ACPfbgSAnj2BAQOA3Fz5lmNmppEDICIiMi69BlBNSEgAAFSoUEHj/suXL+PBgwcAAHd3d4SEhOQr07FjR6xZswYAcOHCBbRs2VKfkAAAkyZNwoIFC2BjY4Pg4GA4Oztj//79mDx5MrZv347Q0FC1BFAXNWvWRFBQkMZ9RRk01hw1bQr895+cePXqZeSTL1woTyN0/jzw5ZcAbzkTEZEF0yvxynzaQqFtaqDjx48DACRJQvv27TV2vq9evbpq/dGjR/qEAwDYunUrFixYAGdnZxw8eBBNn3ZiiouLQ3BwMMLCwjBz5kx88803Rao3KChI7bapJWnaFPjlFxO0eAGAh4c8oGq/fsDs2cCrrz6bRJKIqIiysrKQk5Nj6jCoFLG2ti50ikND0ivxcnR0REpKCh4/fqxx/7///qtab9euneYAbJ6FkGmAW01fffUVAGDKlCmqpAsAPDw8sHjxYrRt2xaLFi3CzJkz4ebmpvf5LIHy11Sik2UXpG9foE8fYNMmYPhw4MQJeZAxIiIdJSUlIS4uziDfI1T2KBQKeHh4wNXVtcTPpVfiVblyZURGRuLq1avIzc3N189r9+7dqvU2bdporEN5uxKQEzl9xMTE4OTTTtoDNcz6HBQUBB8fH0RHR2Pnzp0YMGCAXuezFI0bA1ZWwP37wL17QJUqJgjihx+AAwfke55z53JwVSLSWVJSEmJiYuDs7AwPDw/Y2tpqHd6IKC8hBLKyspCYmIiYmBgAKPHkS6/E64UXXkBkZCRSUlKwfft29OzZU7Vvz549ahfRrFkzjXVcv35dtV65cmV9wlF1znd3d4efn5/GMs2bN0d0dDTCw8OLlHhdu3YNM2bMwMOHD+Hs7IyGDRuiR48e8PDw0Ctmc+DoCNSvD1y4IN9u7NbNBEFUqiT39xo8WO7n1bs30KCBCQIhotImLi4Ozs7O8Pb2ZsJFRebg4AAXFxfcuXMHcXFx5p149ezZExs3bgQAjBkzBi4uLggKCkJ4eDhGjx4NQO7f1bt3b63/GE7nub9Vq1YtfcJBVFQUAKBatWpay/j4+KiV1dXhw4dx+PBhtW329vaYNWsWJk+eXOjxmZmZak3gSUlJRTp/SWva1MSJFwAMHAisXw9s3y7fcjxyRB7rgohIi6ysLGRmZsLDw4NJFxWbJElwc3NDTEwMsrKySrTPl17DSbz22muoUaMGAODBgwfo2LEjHBwc0KZNG9y6dQuAfDHvvfeexuNzc3NVQzHY2tqikXLiwGJKTk4GADg5OWkt4+zsDED3xKdy5cqYPn06jh8/jtjYWCQlJeHkyZMYMmQIMjMzMWXKFFW/soLMnj0bbm5uqkWZAJoLk4xg/zxJksf2cnOTx/X69lsTBkNEpYGyI70xO0eTZVJ+hkr64Qy9Ei87OzusWbMGTk5O+aYCUv6cMWMGGioHinrO3r17ERsbC0mS0Lx5c9jZ2ekTTol45ZVX8MUXX6Bly5bw8PCAi4sLmjdvjlWrVqmejPzss89Uw2ZoM3XqVCQmJqqWaKOOVlo4k3ewV6paVR7VHgA+/hgYPRr4/HP5scvdu+VmuYQEIw+zT0Tmjq1dpC9jfYb0vo/TqlUrnDp1ClOmTMGuXbuQmZkJIQTq1KmDjz76CCNGjNB67HdPv2CFEOjSpYu+ocDFxQUAkJqaqrVMSkoKAMN0nps4cSJmz56NuLg4hIaG4o033tBaVqFQQKFQ6H3OktKkifwzOhqIjQU8PU0YzLBhwMaNwK5dzybUfp6TE+DlJS/e3uo/lesVKwLW1kYNnYiIqCAG6UBTp04dbN68GTk5OYiNjYWDg4NOQzVMnToVU6ZMAQAEBAToHYevry8AFNiapNynLKsPa2tr1K5dG3Fxcbhz547e9ZmSiwtQpw5w9SoQHg506mTCYCQJ2LxZ7u8VFQXcuQPExDz7+fgxkJoqB3v1qvZ6rK3lRzS1JWbKdXt7410bERGVaQbtuWxtbV2kJxO1je1VXE2eNtvEx8cjKipK45ONp06dAgC1Mb70ER8fD+BZa1tp1rSpnMecOWPixAuQk6GhQzXvS0uTEzDl8nxiFhMjj4uRkyNvKywprlCh4JYzLy+gXDk5ISQiItKDRT0y5u3tjRYtWuDkyZNYu3Ytpk+frrY/LCwM0dHRUCgU6Nq1q97nO3PmDK4+bXExxFRHpta0KbBunRn08yqMoyNQu7a8aJOdDTx4oJ6MaUrQ0tOB+Hh5eTrpu9Zzamoty5usVarEW5tERFQgi0q8AGDatGno3bs35syZgy5duqhatuLj4zF27FgAwLhx49RuhW7ZsgVTp06Fl5cX9u3bp9qelpaGFStWYMiQIflatA4dOoShT1tkgoKCLCLxUg61ZtInGw3FxuZZcqSNEPJty4ISszt3gEeP5Fa2yEh50cbaGqhcOX/LWdWq8pOaLi6As/Ozn8qFyRoRlVEnT57EJ598giNHjiArKwsBAQF477330K9fvyLV4+vrqxpN4Xnt27fHP//8Y4BoDcPgiVdWVhbCwsJw5MgRXLt2DY8fP0ZGRgbKlSuHihUronnz5mjfvr3aHI2G1KtXL0yYMAELFy5E69atERISAicnJ+zbtw8JCQkIDAzE559/rnZMYmIirly5goyMDLXtT548wbhx4/D++++jSZMmqFatGrKzs3H16lWcP38egNw3bcOGDSVyLcam7GB/44acj5Qvb9p4SpwkAe7u8lJQH8P0dM23NvOuK29tKrcXhYODejKmKUF7fltB+xwceFuUiMzegQMH0LlzZ9jb26N///5wcXHBpk2b8PrrryM6Ohrvv/9+kepzc3PDpEmT8m03RJ9uQ5KEMMxz+ZmZmZgzZw5+/PFHPHz4sNDynTt3xscff4zWrVsb4vT5bNiwAT/88AP+++8/ZGVloWbNmhg8eDDefffdfMNWrFy5EsOHD0f16tVx8+ZN1fYnT57giy++wKlTp3D58mXExcUhPT0d5cuXR+PGjdG3b18MGzasWMNgJCUlwc3NDYmJiUaZG0pXNWrI/dn37wdeesnU0ZQiOTnyrU1NLWf37gFJSUBKCpCc/OxnSY0VY2WVPynTNWnTts0Mh3ohAoCMjAxVn157PihTamRnZ6NevXq4c+cOjh07hhdeeAGA3BDSsmVL3Lx5E1evXtW5kUaZXOX9Di8qXT9L+n5/GyTxunTpEl577TVcvnxZNX6XJEnQVHXe7dbW1pg2bRo+/fRTfUModcw18XrtNXmu6q+/Bj74wNTRWDAhgMxM9WTs+cRM2zZt+woYRkVvdnbPWtMUCvnhB+XPvOu67NN1W959dnZyQkn0HCZez8TFxWHevHn466+/cPPmTaSnp+crExgYiLCwMBNEpy40NBSdO3fG8OHD8csvv6jtW7VqFYYNG4ZPP/0UH3/8sU71labES+9bjbdu3cLLL7+M+/fvq21XKBTw9/eHp6cnFAoFkpKScP36ddVwDpIkIScnB1988YXqJ5le06Zy4mUR/bzMmSQ9SyoMNd9nbq7cF02X5E3Xbcpprp48kfu6mZKdnX7JW95tdnZyP0DlYmureb2gfYWVs7bmLV8ymlu3bqFt27aIjo5G27Zt0bNnT8TGxuL3339HWloa3Nzc4OHhgeDgYFOHCgCqPledNDxC37lzZwDAwYMHi1RnZmYmVq5cibt378LV1RUtWrRAq1at9I7V0PROvIYPH4579+6pWrKCg4Px/vvvo1OnTrDW0Gk4JiYGK1euxDfffIOkpCQIITB79mx07twZbdu21Tcc0pNFdbAva/LeYjSUrCz1pCwjQ07G8v7UtK2gfUUpn7fV/MkTeXk6NVipYG2tX/JW2D5r64IXK6vCy5jLsVZWBk9UhZD/FjF3jo76XXpubi769euH6OhoLFq0CO+8845qX+/evdG9e3fUr18fR48e1SvO+fPnIyEhQefyvXr1Ut1CfF7k0weVamt4Or1y5cpwdnZWldHV/fv3MXz4cLVtLVq0wO+//46aNWsWqa6SpFfitXfvXvzzzz+QJAmSJGH+/PkYP358gcd4eXlh+vTpGDFiBLp06YKzZ89CCIFp06bh33//1SccMgBlB/urV+XvNwsYnoz0YWsrP2VhiicthJATP0MndhkZ8nAj2dly/ZrWi7pPW3+9nBx5UbYcUuGsrIq2+PgAX34pJ+WS9CyDkSSkpUlwbtXAtNejg5TLd+DkKNSzr+czMW37JAnbdu3CiRMn8GrXrnjntdfk/qZP973StClcXVxw6tQpiIcPn02LU1D9Wl7P//Zb3CrCdHe+lSrhhafzOT9fZ+LTMTDdbGzkP+ye2+/q4oLExMT8mbOmDFWSMPyNN9A2MBAN/f3h7OKCq5GR+HbBAvy6di1CQkJw7tw5sxlvU6/Ea9OmTar1Dz74oNCkK68qVapg165daNCgARISEnDkyBHcv3+/SAOwkuFVrCiPgnDnDhARAQQFmToiKrMkSb4lWBo69gshJ1jFTeaKk/QpE76CltzcwssY81hduhTn5sqLrhQKue6srPz7MktJv8CHDwGHIlzzc9auXQsAmNizpzzvWx7WABxsbZGalgZx8yYkPfpK3ty8uegHaZtdRJlQ3bih+b3Lzpbf14sXdTrNJz17yisPHwIPH+IFKyusfvddICcHv65fj59//hnvvfde0eMvAXolXsoWKltbW0ydOrXIx1epUgWjRo3C119/DUAe4PS1117TJyQygKZN5cTr9GkmXkQ6kaRntwHLeAfvAikTVE2JWnGXnJxnLV8KxbPkTgg4CiDlXrLaNrVYNP0sbJu2/ZrKFVRHnteODhUBFF5O276ws2fh5OiIwJdeejYu4NNy6RkZeJScDD9vb1i5u+sck8Z9hZUvQhm3p53SE588UX/fnkpKTUV5V1e51V3Xc2nYP3rECPy6fj0OHz5sGYmXsm9XQECATnMzatKuXTtV4nXv3j19wiEDadYM2LaN/byIyMDyJqiGkpEhj4Hj6Jgv6ZUAOJnPQ+MlIjMzE/cePoSfnx+sNfSXCv3zT2RlZSG4c2egVi0Ackd8X19fLFq0CIsXL8aNGzcQEBCA1atXo169elrPZcg+XrWbNwf27EGkEGj23DiK9+/fR0paGlq2bg00bqzz+TTxuHIFAJBakk99F5Fen37lhegzHELee67m9Ispy5TTWDLxIiIqHZKSkpCbmwurPLcShRD49ttvAQBvvvmmantERAQA4Ndff8Xy5cvh6OiIESNGYMyYMThw4IDWc8yfP1/r6PCa+Pr6ak282rdvj9mzZyM0NBT9+/dX27d7925VGX0dP35cFYu50OsGuIeHB4QQRXojnnf79m3VeoUKFfQJhwxEmXhdvFg6nggiIiqrFAoF6tevj/j4eFXCojRz5kwcOnQIQ4YMQYsWLVTbIyIi4OjoiG3btqF169Zo1KgRpk6diqNHj2ocf1Pp5s2bEELovAwbNkxrXSEhIahRowbWrl2L//77T7U9MTERX331Fezs7DBkyBC1Y65fv47Lly8j67k+YZcvX0aahi+ry5cvY/LkyQCAgQMHao3F2PRq8fLz88Pdu3cRFRWFs2fPolGjRkWuY3Oezno18j79QCZTpYo83/ODB/K80SU0uQARERnA9OnTMXjwYPTp0weDBg1ChQoVsHfvXpw+fRqdOnXCjz/+qFY+IiICAwcORMWKFVXbFAoFADx76rGE2djYYNmyZejcuTPatWunNmXQrVu38M033+RrpQoJCcGtW7cQFRWltm/dunX49ttv0a5dO1SvXh1OTk64evUqdu7ciaysLEydOhXt2rUzynXpQq/Eq3Pnzjh8+DAAYOzYsdi/f3+Rps/566+/sHXrVgCAg4MDx/EyE5Ikt3rt2iXfbmTiRURkvgYNGgQrKyv873//w5o1a2BlZYVGjRph2bJlGD58uNrtR0BOvCZOnKi27cyZM2isZ3+qonrppZcQFhaGTz75BOvXr1dNkj137ly8/vrrRarn0qVLCA8Px7///ou0tDR4eHiga9euGDt2rMZBWk1Jr8TrjTfewJdffoknT57g6NGj6Ny5M1auXKnT3ErLly9XDT8hSRIGDx5crDkPqWQ0a/Ys8SIiIvM2YMAADBgwoNByKSkpuH79OnLyjD2XkZGBpUuXYsaMGSUZokYtW7bErl27dCqrbTqg9u3bG6Q/mLHolXhVr14dkyZNwty5cyFJEg4dOoT69eujd+/e+L//+z80btwYnp6esLOzQ3JyMq5fv44jR45gzZo1uHjxoupecrly5crkfI3mjB3siYgsz7lz52BnZ4eff/4ZgYGBsLOzw7vvvgsfHx+MHDnS1OGVCXo/0/vll1/i4sWL2L59OyRJQkZGBtatW4d169ZpPUYIobqPbG9vj23btqFSpUr6hkIGpEy8zp+XB91+evufiIhKsYiICDRs2BCjR49Gt27dkJ6ejl69emH+/PmwzTtmFpUYvYf1tbKywqZNmzB16tR8nfI0PeWQd1/9+vVx5MgRBAYG6hsGGVi1aoC7uzyg8Pnzpo6GiIgMISIiAgEBARg1ahQePHiApKQkrF69Gu7KwVWpxBlkPgUbGxtVy9c777yDKlWqaH0k1dbWFm3btsWvv/6K//77T+sYH2RaksQJs4mILI0y8SLTMeDwwUCdOnXw/fff4/vvv0d0dDQiIyPx+PFjZGZmoly5cqhYsSICAgJUj62SeWvaFNizh4kXEZElEELg3LlzmDVrlqlDKdMMmnjl5ePjAx8fn5KqnoyAHeyJiCyHJElITk42dRhlnsmnbnd0dIS1tTVsDDl3FxmEMvGKiNA8eTwREREVjckTL00d78k81KgBuLrKTzVeumTqaIiIiEo/kydeZL6srHi7kYiIyJCYeFGBmHgREREZDhMvKhATLyIiIsNh4kUFUiZe4eFAnqm9iIiIqBiYeFGB6tQBnJyAtDTg6lVTR0NERFS6MfGiAllbA8rJBXi7kYiISD9MvKhQ7OdFRERkGEy8qFDKxOv0adPGQUREVNox8aJC5e1gn5tr2liIiIhKMyZeVCh/f8DeHkhKAm7cMHU0REREpZdOEyQeOnSoxALIZROK2bOxARo1Ak6ckPt51apl6oiIiIhKJ50Srw4dOkCSpJKOxaA2btyIH374AREREXjy5Alq1aqFQYMG4d1334Wtra1ede/cuRPdunUDAISEhGDv3r2GCNmsNW36LPHq18/U0RARkaWZO3cupkyZAgA4evQoWrdubeKISkaRbjXmndDaUEtJmDRpEvr164fDhw+jZcuWeOWVV3D79m1MnjwZwcHBSE9PL3bdjx8/xqhRo0pdIqovdrAnIqKScv78eXzyySdwcnIydSglTufEq6SSJEPXu3XrVixYsADOzs44fvw4du/ejU2bNiEyMhIBAQEICwvDzJkzi13/+PHj8eDBA7z99tsGjNr8NWsm/zxzBiihjwIREZVBWVlZGDp0KF544QX07t3b1OGUOJ1uNa5YsaKk4zCYr776CgAwZcoUNFU20wDw8PDA4sWL0bZtWyxatAgzZ86Em5tbkeresmUL1qxZgw8//BD+/v5YsmSJQWM3Zw0aALa2wKNHwO3bQPXqpo6IiIjyiouLw7x58/DXX3/h5s2bGu/uBAYGIiwszATRaffll1/iwoULOHPmDObNm2fqcEqcTonX0KFDSzoOg4iJicHJkycBAAMHDsy3PygoCD4+PoiOjsbOnTsxYMAAneuOi4vD22+/jbp16+Kzzz7DunXrDBZ3aaBQAA0bykNKnDnDxIuIyJzcunULbdu2RXR0NNq2bYuePXsiNjYWv//+O9LS0uDm5gYPDw8EBwebOlQ1Z86cwZdffonPPvsM/v7+pg7HKHRKvEqL8PBwAIC7uzv8/Pw0lmnevDmio6MRHh5epMRrzJgxiIuLw+bNm2Fvb2+QeEubpk3lxOv0aaAMtAYTUWknhDzRrLlzdAT06Decm5uLfv36ITo6GosWLcI777yj2te7d290794d9evXx9GjR/UKc/78+UhISNC5fK9evfCCcs45DTIzMzFkyBC88MIL+Oijj/SKrTQx+8Rr7dq1uHbtGgDg448/LrBsVFQUAKBatWpay/j4+KiV1cW6devwxx9/YOLEiQgMDNT5uLwyMzORmZmpep2UlFSsekypaVNg+XJOHUREpURaGuDsbOooCpeSAujRqXzbtm04ceIEXn31VbWkCwBeeeUVuLq64tSpUxBC6PVg2Pz583Hr1i2dy/v6+haYeH388ceIjIzE6dOnYW1tXey4ShuzT7x+/fVX7N69G5IkFZp4JScnA0CBT0U4P/1HqGvic//+fbzzzjuoWbOmqv9YccyePRuffvppsY83B8oO9qdPy39IlrEHO4mIzNLatWsBABMnTsy3z9raGg4ODkhNTdU78bp582axj33e0aNH8c0332DWrFlo2LChweotDcw+8TK1t956C48fP8amTZvg6OhY7HqmTp2K9957T/U6KSlJ1fpWWjRqBFhbAw8fAvfuAVWrmjoiIqICODrKrUnmTo/vFgAICwuDk5OTxjsy6enpePToEfz8/GBlZR6T1WRnZ2Po0KFo1KiRatyussSiEi8XFxcAQGpqqtYyKU//Ebq6uhZa36pVq7B9+3aMGTMGHTp00Cs2hUIBhUKhVx2m5uAA1K8PnD8v325k4kVEZk2S9LqFVxpkZmbi3r178PPz03i7LjQ0FFlZWWqd6m/dugVfX18sWrQIixcvxo0bNxAQEIDVq1ejXr16Ws9lqD5eKSkpiIyMBADY2dlpPPbFF18EII8m0KtXL53PWRpYVOLl6+sLAIiOjtZaRrlPWbYgW7ZsAQCcPHkyX+J1//59AMDp06dV+9atW4fKlSsXLehSpmlTOfE6fRro3t3U0RARESDfRcnNzVVr1RJC4NtvvwUAvPnmm6rtERERAOSuPMuXL4ejoyNGjBiBMWPG4MCBA1rPYag+XgqFAiNHjtR4zKFDhxAZGYkePXrA09NTp+/q0saiEq8mTZoAAOLj4xEVFaXxycZTp04BgNoYX4VRHqNJQkICDh48CADIyMgoSrilUrNmwOrV7GBPRGQOFAoF6tevj0uXLmH37t3o0qWLat/MmTNx6NAhDBkyBC1atFBtj4iIgKOjI7Zt24aKFSsCkLvDDBo0qMB+YIbq4+Xg4IBly5Zp3Dds2DBERkZi6tSpnDKoNPD29lZ9uJSdDfMKCwtDdHQ0FAoFunbtWmh9W7du1TrVkXJQ2ZCQENU2S8zMn6fMV5l4ERGZh+nTpwMA+vTpg1GjRmHKlClo3rw5vvzyS3Tq1Ak//vijWvmIiAgMHDhQlXQBUHWFKWvT4ZmCRSVeADBt2jQAwJw5c3AmT3YQHx+PsWPHAgDGjRunNmr9li1bUK9ePYSEhBg32FKocWO528SdO3IneyIiMq1BgwZh7dq18Pf3x5o1a7Bo0SLY2dlh2bJl2LVrFxwcHNTKR0REoHHjxmrbzpw5k28blQyLutUIyJ35JkyYgIULF6J169YICQmBk5MT9u3bh4SEBAQGBuLzzz9XOyYxMRFXrlwpE7cK9eXiAtSpA1y5Ird6vfKKqSMiIqIBAwboNCh4SkoKrl+/jpycHNW2jIwMLF26FDNmzCjJEHWycuVKrFy50tRhlCiLa/ECgAULFmD9+vV48cUXceTIEezcuRPe3t6YM2cO9u/fny/7p6Lh7UYiotLp3LlzsLOzw88//4xTp07h7Nmz6NatG3x8fLR2eCfDssjECwD69euHgwcPIjExEWlpaTh37hwmT56s8dHVYcOGQQhRpI6DymP27t1rwKhLB+VAqky8iIhKl4iICDRs2BATJ05Et27dEBQUBC8vL+zYsQO2tramDq9MsLhbjVTy2OJFRFQ6RUREICAgAKNGjcKoUaNMHU6ZZLEtXlRyno7agago4NEj08ZCRES6UyZeZDpMvKjIypUDatSQ18PDTRoKERHpSAiBc+fOlbm5Ec0NbzVSsTRrBty4Id9u5CgcRETmT5IkJCcnmzqMMo8tXlQs7OdFRERUdEy8qFiYeBERERUdEy8qFmUH+6tXgaQk08ZCRERUWjDxomLx9AR8fOT1//4zaShERESlhl6d6w8dOgQAcHd3L/ZTEhcvXkRcXBwAoF27dvn2z5s3D1OmTCl+kFRimjUDoqPl240a3joiIiJ6jl6JV4cOHSBJEjp37oydO3cWq47p06dj27ZtkCQJ2dnZ+fZzvBHz1bQpsHUr+3kRERHpyiyGkxBCmDoEKgZlB/vTp00bBxERUWnBPl5UbMrE6/JlIDXVtLEQERGVBiZPvJS3F21szKLxjYqgShV5yc0Fzp41dTRERETmz+SJV0xMDADAxcXFxJFQcXA8LyIiIt2ZNPGKiIhAREQEJElCDeXkf1SqMPEiIiLSnc739z777DOt+65du1bg/ryEEEhPT8fVq1cRGhoKIQQkSUJQUJCuoZAZYQd7IiIi3UlCx0cKraysIEmS2jbloc9v15XyeDs7O4SHh6N+/frFqqc0SkpKgpubGxITE+Hq6mrqcIrt9m2genXAxgZITgbs7U0dERGVJRkZGYiKioKfnx/s+R8Q6UHXz5K+399FutUohFBbtG3XdQEAR0dHLFu2rEwlXZbExwfw8ACys4Hz500dDRERlRa//fYbRo8ejebNm0OhUECSJKxcubLQ47Zs2YKOHTuiQoUKsLe3h5+fHwYMGIDo6OiSD9oAdL7V2K5du3wtWwcPHoQkSShXrhwaNWqkUz1WVlZwdnZGlSpV0KxZM/Tp0wfu7u5Fi5rMhiTJtxtDQ+V+Xs2bmzoiIiIqDWbMmIFbt27Bw8MDVapUwa1btwosL4TA22+/jaVLl6JmzZro378/XFxccPfuXRw8eBC3bt2Cj3IuOzOmc+L1zz//5NtmZSU3mLVq1arYI9dT6adMvNjPi4iIdLVs2TLUrl0b1atXx5w5czB16tQCyy9cuBBLly7F2LFjsXDhQlhbW6vt1zT7jTnS+6lGjjpPfLKRiMj04uLi8NFHH8Hf3x+Ojo6QJCnfYk4Psr388suoXr26TmXT09Px6aefokaNGliwYEG+pAsoPeOB6hVlVFQUAMDBwcEgwVDp1KyZ/PPsWSArC7C1NW08RERlza1bt9C2bVtER0ejbdu26NmzJ2JjY/H7778jLS0Nbm5u8PDwQHBwsKlDLZbQ0FA8fvwYw4cPR05ODrZt24arV6+iXLlyePnll1GrVi1Th6gzvRIvXTNVsmx+foCbG5CYCFy8CDRubOqIiIjkOzJpWWmmDqNQjraOxR4dAAByc3PRr18/REdHY9GiRXjnnXdU+3r37o3u3bujfv36OHr0qF5xzp8/HwkJCTqX79WrF1544QW9zql0+mlfFmtrazRq1AhXr15V7bOyssK7776Lb775xiDnKmlGb5fLysrCo0ePUL58edjZ2Rn79FQClB3sDxyQbzcy8SIic5CWlQbn2c6mDqNQKVNT4GTnVOzjt23bhhMnTuDVV19VS7oA4JVXXoGrqytOnTqlGjezuObPn19oB/i8fH19DZZ4PXz4EADw7bffomnTpjhx4gTq16+P8PBwvPXWW/jf//6HmjVrYsyYMQY5X0nSu49Xeno60tLSkJZW8F8VERER6NKlC1xcXFC1alU4ODigbdu22Ldvn74hkBngQKpERKaxdu1aAMDEiRPz7bO2toaDg0O+YaCK4+bNm0UaMmrYsGF6nS+v3NxcAPK4n1u3bkWLFi3g7OyMtm3bYuPGjbCyssL//vc/g52vJOnV4nX79m34+fkBAGrWrKnW9JfXsWPH0LFjR6Slpam98YcPH0anTp2wePFijB49Wp9QyMSU/bzYwZ6IzIWjrSNSpqaYOoxCOdo66nV8WFgYnJycEBgYmG9feno6Hj16BD8/P9VIBKWRm5sbAKB58+aoWrWq2r6GDRuiRo0auHbtGhISElCuXDkTRKg7vRKvrVu3qpou33rrLY1lcnJyMGTIEKSmpuZr4pQkCUIIjB8/Hi+++KLOY4GR+VG2eP33H5CTA2h44ISIyKgkSdLrFl5pkJmZiXv37sHPz0/jk36hoaHIyspS61R/69Yt+Pr6YtGiRVi8eDFu3LiBgIAArF69GvXq1dN6LlP28apbty4AaE2qlNvT09MtO/E6duyYar1Hjx4ay2zcuBHXrl1TJV2DBg1Cnz59kJKSgtmzZ+PSpUvIycnBrFmzsHnzZn3CIROqXRtwdgZSUoArVwB/f1NHRERUdiQlJSE3N1etVUsIgW+//RYA8Oabb6q2R0REAAB+/fVXLF++HI6OjhgxYgTGjBmDAwcOaD2HKft4vfTSSwCAS5cu5duXlZWFa9euwcnJCZ6engY5X0nSq93xypUrAABXV1fUqVNHYxnlvWcAGDJkCH799Vf06tULgwcPxj///AN3d3cIIbBz504kJSXpEw6ZkJUVoPz3xX5eRETGoVAoUL9+fcTHx2P37t1q+2bOnIlDhw5hyJAhaNGihWp7REQEHB0dsW3bNrRu3RqNGjXC1KlTcfTo0QL7gZmyj1fNmjXRqVMnXLt2DcuWLVPbN2fOHCQkJKB3796lYiwvvSKMjo6GJElax8/Izs5Wy57fe+89tf2enp4YNmwYvv32W2RlZeHUqVOldowRkm83hoXJ/bzeeMPU0RARlQ3Tp0/H4MGD0adPHwwaNAgVKlTA3r17cfr0aXTq1Ak//vijWvmIiAgMHDgQFStWVG1TKBQAoNdTj0W1bNkyhIWFAQDOnTun2qacKScoKEitpW7x4sVo06YNRo0aha1bt6JevXoIDw/H/v37Ub16dXz99ddGi10ferV4JScnA9B+z/XMmTOqvl1+fn4ICAjIV+bFF19UrUdGRuoTjpqNGzeiQ4cOKF++PJycnNC4cWPMmzcPWVlZRarnyJEjGDt2LF588UV4eXnB3t4eTk5O8Pf3x/jx43Hz5k2DxVzasYM9EZHxDRo0CGvXroW/vz/WrFmDRYsWwc7ODsuWLcOuXbvyDXIeERGBxs+N+3PmzJl820paWFgYVq1ahVWrVuHM0y+Ow4cPq7YpkzKlmjVr4tSpUxg2bBhOnz6NhQsXIjIyEu+88w5OnDiBypUrGzX+4tKrxSsnJwfAs8c8n5e3D1iHDh00lqlUqZJqvSid9goyadIkLFiwADY2NggODoazszP279+PyZMnY/v27QgNDdV5tP2dO3diyZIlqFatGurWrYtKlSohMTERZ86cwaJFi7BixQr89ddfWq+vLFF2sA8PB3Jz5duPRERU8gYMGIABAwYUWi4lJQXXr19XfX8DQEZGBpYuXYoZM2aUZIj5rFy5EitXrizSMT4+PlixYkXJBGQken01uri4AABiY2M17j906JBqXdv8UHnffEPM+7h161YsWLAAzs7OOH78OHbv3o1NmzYhMjISAQEBCAsLw8yZM3Wub9CgQYiKisKtW7ewf/9+/P7779i5cydu376NiRMnIjU1FW+88YbadZRV9eoB9vZAcjJw/bqpoyEiouedO3cOdnZ2+Pnnn3Hq1CmcPXsW3bp1g4+PD0aOHGnq8MoEvRKvatWqQQiBq1evIjU1VW1fZmYm9uzZo3qtLfF69OiRat3ZWf8Rhr/66isAwJQpU9BU2QQDwMPDA4sXLwYALFq0CImJiTrVV79+ffj6+ubbbmdnh6+//hr29va4c+cOLl68qHfspZ2NzbNR69nBnojI/ERERKBhw4aYOHEiunXrhqCgIHh5eWHHjh2w5US7RqFX4tWyZUsA8qOcz3feW716NZKTkyFJEnx8fLR2wM/7aKi3t7c+4SAmJgYnT54EAAwcODDf/qCgIPj4+CAzMxM7d+7U61yA3AlR+eiusmNiWcd+XkRE5isiIgIBAQEYNWoUHjx4gKSkJKxevRru7u6mDq3M0Cvxev3111Xr06dPx8cff4zQ0FDMnTtXbeqCwYMHa63j+PHjqnXlAGnFFR4eDgBwd3dXjaj/vObNm6uVLa6cnBx8+umnSEtLg7+/f6maGb0kKRsZmXgREZkfZeJFpqNX5/rg4GC89NJLOHDgALKysvDll1+q9in7a7m4uGDSpEkaj09NTVXdjnR1dUX9+vX1CQdRUVEA5Fug2vj4+KiV1dXt27fx8ccfA5Bvj4aHh+POnTuoVasWNmzYUKqnYjCkvImXEPIE2kREZHpCCJw7dw6zZs0ydShlmt4jja1btw7BwcG4cOFCvn0KhQK//fYbPDw8NB67YcMGZGRkQJIkrX3AikI5vIWTk/YpIpT9yIo6WOujR4+watUqtW1NmzbFL7/8ggYNGhR6fGZmJjIzM1WvLXWw2AYNAFtb4PFj4OZNQEvDIxERGZkkSarvSTIdvZtpPD09cfr0acyfPx8hISGoU6cOGjdujLfeegunT59G9+7dtR6rnMpACIFu3brpG0qJeuGFFyCEQG5uLu7cuYMNGzYgLS0NzZo1w8KFCws9fvbs2XBzc1MtypY3S2NnByhbsXm7kYiISJ1Bxta3s7PDhAkTMGHChCIdpxyp1lCUw1s8/4RlXikp8kz1rq6uxTqHJEnw8vJC37590bFjRzRo0ADvvvsu2rdvX+Dgc1OnTlUbuT8pKclik69mzeSk68wZoE8fU0dDRERkPiyqY5Jy2Ifo6GitZZT7NA0RUVTlypVD7969kZubi23bthVYVqFQwNXVVW2xVOxgT0REpJlFJV5NmjQBAMTHx2vtPH/q1CkAUBvjSx/K/mQPHz40SH2WQPmrPX1a7mBPREREshJNvJKTk3Hnzh3cvn27JE+j4u3trZqBfe3atfn2h4WFITo6GgqFAl27djXIOffv3w8AqFOnjkHqswQBAYC1NRAbC8TEmDoaIiIi82HQxOvevXuYNWsWgoKC4ODggHLlyqF69eqoUaOGxvLr1q3D6tWrsXr1amRnZxskhmnTpgEA5syZo5p0E5BbwcaOHQsAGDduHNzc3FT7tmzZgnr16iEkJCRffbNnz9Y4JdLjx48xfvx4nDp1Cm5ubujXr59B4rcEDg7y040AbzcSkXEYYso5KtuM9RkySOf63NxczJo1C/PmzUNWVhYA3S5g165d+O233wDInd179eqldyy9evXChAkTsHDhQrRu3RohISFwcnLCvn37kJCQgMDAQHz++edqxyQmJuLKlSvIyMjIV9+0adMwc+ZMBAQEoGbNmrCxsUFMTAzCw8ORmpoKNzc3bNy4UW2yb5JvN549KydePXqYOhoislTW1tYA5BlUHBwcTBwNlWbK/EX5mSoperd45eTkoEePHvjyyy/x5MkTCCF0zhrHjx+vKvv777/rG4rKggULsH79erz44os4cuQIdu7cCW9vb8yZMwf79+8v0j/ORYsW4bXXXkNaWhr27duHTZs24cKFCwgICMAnn3yCK1euoGPHjgaL3VKwgz0RGYOtrS0UCgUSExPZ6kXFJoRAYmIiFApFic9ZKQk9P6mTJk3CwoULIUkShBAIDg7G0KFD0bhxY0yYMAGHDh2CJEnIycnReHyNGjVw8+ZNuLu7Iy4uTp9QSpWkpCS4ubkhMTHRIp9wPHwYCAoCqlZlPy8iKllJSUmIiYmBs7Mz3NzcYGtrC4nTZpAOhBDIyspCYmIiUlJS4OXlVeh3sr7f33rdarxy5Qp++OEHAPL4Vj/++CNGjRql2q9Ly1LHjh3x888/4/Hjx7h06ZLe0waReWjcWJ4u6O5d4P59oHJlU0dERJZK+eUXFxeHGP6lR8WgUCh0SroMQa/Ea+XKlcjJyYEkSfjwww/Vki5dvfDCC6r1y5cvM/GyEM7OQL16wKVLQHg40KWLqSMiIkumHB8xKytL6x0WIk2sra1L/PZiXnolXvv27ZMrsbHBlClTilVH3gmt+ZeKZWnaVE68zpxh4kVExmFra2vUL1GiotKrc/2tW7cgSRIaNmyoNjxDUeQ9TjmdD1kGdrAnIiJSp1filZCQAABwd3cvdh2ZmZmqdf6VYlnyjmBPREREeiZe5cuXB/AsASuOvLcXPTw89AmHzMzTGZxw6xYQH2/aWIiIiMyBXolX1apVIYTAxYsXiz3y/L///qtar1Wrlj7hkJlxcwOUb2l4uGljISIiMgd6JV7t27cHAGRkZOCPP/4o8vEJCQlYv349AMDR0RGtWrXSJxwyQ+znRURE9IxOidft27dx+/btfHMWvvrqq6r1yZMn4/Hjx0U6+ZgxY5CSkgJJktC7d2/Y2BhkBiMyI+znRURE9IxOiZevry/8/PwwbNgwte1t27ZFcHAwhBC4c+cOOnTogMuXLxda3+PHjzFw4EBs2LBBDsLKSjW5NVkWtngRERE9U6QmJk2zC/30009o3bo1Hj16hHPnzqFx48bo2rUrXn75ZTx48EBVbtOmTXjw4AGOHj2KP//8E6mpqRBCQJIkfPbZZ6hXr57+V0NmR5l4XbsGJCbK/b6IiIjKKp3marSysoIkSejcuTN27tyZb//Ro0fRs2dP1VyLeefIUlavaRsAvP3221i8eHHxr6CUsvS5GvPy9ZWfbPznH+Bpt0AiIqJSSd/vb7061yu9+OKLCA8PR+fOnQHIiVXehEtT0uXu7o4ff/yxTCZdZQ37eREREckMkngBgJeXF3bt2oXw8HBMnDgRL7zwAqytrVVJmBACTk5O6NSpE7777jvcvHkTb731lqFOT2aM/byIiIhkBn+MsHHjxvjuu+9UrxMTE5Gamopy5crB0dHR0KejUqBZM/knEy8iIirrSnz8Bjc3t2LP40iWQdnidfkykJoKODmZNh4iIiJTMditRiJtKlUCqlYFhAAiIkwdDRERkekw8SKjYAd7IiKiIt5qPHjwIGrUqFEigUiShOvXr5dI3WR6TZsCf/3Ffl5ERFS2FSnxSk9Px82bN0skkLxDTpDlYQd7IiIi3mokI1HearxwAcjIMG0sREREplKkFq/y5cujUaNGJRULWTAvL8DTE4iNBc6eBVq2NHVERERExlekxKtVq1YapwwiKowkya1eu3fLtxuZeBERUVnEW41kNOznRUREZR0TLzIaTh1ERERlHRMvMhpl4nXuHPDkiWljISIiMgUmXmQ0vr5AuXJy0nXhgqmjISIiMj4mXmQ0yg72AG83EhFR2cTEi4yKHeyJiKgsY+JFRsUWLyIiKst0TryEECUZB5URysQrIgLIzjZtLERERMamU+IVFRWFqKgorFy5soTDMZyNGzeiQ4cOKF++PJycnNC4cWPMmzcPWVlZRaonPDwcs2fPRkhICCpVqgRbW1uUL18ebdu2xQ8//FDk+sq6WrUAFxcgPR24fNnU0RARERmXJCywKWvSpElYsGABbGxsEBwcDGdnZ+zfvx8JCQkICgpCaGgoHBwcCq0nOzsbtra2AABnZ2e0aNEClSpVwp07d3D06FHk5OSgZcuW2L17N8qVK1ekGJOSkuDm5obExES4uroW5zJLrfbtgUOHgFWrgCFDTB0NERGR7vT9/ra4Pl5bt27FggUL4OzsjOPHj2P37t3YtGkTIiMjERAQgLCwMMycOVPn+po1a4YNGzYgLi4O+/fvx++//45///0X4eHhqFKlCk6cOIH33nuvBK/I8rCfFxERlVUWl3h99dVXAIApU6agqfIbHoCHhwcWL14MAFi0aBESExMLrcvGxganTp1C3759oVAo1PYFBARg3rx5AIB169bxlmMRMPEiIqKyyqISr5iYGJw8eRIAMHDgwHz7g4KC4OPjg8zMTINM9t2kSRMAQHp6OuLi4vSur6xQJl7h4UBurmljISIiMiaLSrzCw8MBAO7u7vDz89NYpnnz5mpl9REZGQkAsLOzg7u7u971lRV16wIODkBKCvD0V0hERFQmWFTiFRUVBQCoVq2a1jI+Pj5qZYtLCKG61di9e/d8tyKfl5mZiaSkJLWlrLKxAV54QV7n7UYiIipLLCrxSk5OBgA4OTlpLePs7AwAeic+n376KY4ePQpnZ2fMmTOn0PKzZ8+Gm5ubalEmgGUV+3kREVFZZFGJl7GsXr0an332GaysrPDLL7+gdu3ahR4zdepUJCYmqpbo6GgjRGq+lInX6dOmjYOIiMiYbEwdgCG5uLgAAFJTU7WWSUlJAYBij521ceNGjBgxAgDw888/o2/fvjodp1AoCr0dWZbkbfESQp5Am4iIyNJZVIuXr68vABTYmqTcpyxbFJs3b8bAgQORm5uLn376SZWAUdE1aADY2QGJiYCe3e2IiIhKDYtKvJTDO8THx2vtPH/q1CkAUBvjSxdbt25F//79kZOTgyVLlmDUqFH6BVvG2doCjRrJ6+znRUREZYVFJV7e3t5o0aIFAGDt2rX59oeFhSE6OhoKhQJdu3bVud7t27ejX79+yM7OxpIlSzB69GiDxVyWsYM9ERGVNRaVeAHAtGnTAABz5szBmTzf6PHx8Rg7diwAYNy4cXBzc1Pt27JlC+rVq4eQkJB89e3cuROvvfYasrOz8eOPPzLpMiB2sCciorLGojrXA0CvXr0wYcIELFy4EK1bt0ZISAicnJywb98+JCQkIDAwEJ9//rnaMYmJibhy5QoyMjLUtj98+BCvvvoqnjx5Am9vbxw5cgRHjhzReN5vvvkGHh4eJXZdlogd7ImIqKyxuMQLABYsWIDAwED88MMPOHLkCLKyslCzZk1MmTIF7777Luzs7HSqJy0tDZmZmQCAO3fuYNWqVVrLzpo1i4lXEQUEyIOpxsUBd+4AZXxoMyIiKgMkIYQwdRBlUVJSEtzc3JCYmFjsoS0swQsvABERwNatQM+epo6GiIioYPp+f1tcHy8qXdjPi4iIyhImXmRSfLKRiIjKEiZeZFLNmsk/mXgREVFZwMSLTKpRI8DKCrh3T16IiIgsGRMvMiknJ6BePXk9PNy0sRAREZU0Jl5kcuxgT0REZQUTLzI5drAnIqKygokXmRw72BMRUVnBxItM7oUX5J+3b8uj2BMREVkqJl5kcq6uQO3a8jpbvYiIyJIx8SKzwH5eRERUFjDxIrPAfl5ERFQWMPEis8AWLyIiKguYeJFZaNJE/nn9OpCQYNJQiIiISgwTLzIL7u6Ar6+8zhHsiYjIUjHxIrPB241ERGTpmHiR2WAHeyIisnRMvMhssMWLiIgsHRMvMhvKDvZXrgDJyaaNhYiIqCQw8SKzUakS4OUFCAFERJg6GiIiIsNj4kVmhf28iIjIkjHxIrPCfl5ERGTJmHiRWVEmXqdPmzYOIiKiksDEi8yKMvG6eBFISzNtLERERIbGxIvMStWqcif73Fzg3DlTR0NERGRYTLzIrEgS+3kREZHlYuJFZoeJFxERWSomXmR22MGeiIgsFRMvMjvKxOv8eSAz07SxEBERGRITLzI71asD7u5AVhZw4YKpoyEiIjIci028Nm7ciA4dOqB8+fJwcnJC48aNMW/ePGRlZRWpnvj4eKxcuRLjx49HmzZt4OjoCEmS8PLLL5dQ5JS3g/24ccD69Wz5IiIiy2Bj6gBKwqRJk7BgwQLY2NggODgYzs7O2L9/PyZPnozt27cjNDQUDg4OOtX177//Yvjw4SUcMT1vwABg3z7g6FF5qVABeOMN4M03gQYNTB0dERFR8Vhci9fWrVuxYMECODs74/jx49i9ezc2bdqEyMhIBAQEICwsDDNnztS5vkqVKmH06NH46aefcPLkSfz4448lGD0pjRgB3LgBfPwx4O0NxMcD8+cDDRsCL74ILF8OpKSYOkoiIqKikYQQwtRBGFLLli1x8uRJfPHFF5g+fbravrCwMLRt2xYKhQIPHjyAm5tbketfuXIlhg8fjpCQEOzdu7fYcSYlJcHNzQ2JiYlwdXUtdj1lQU4OEBoKLFsGbNsGZGfL252dgf79gVGjgBYt5FuUREREJUnf72+LavGKiYnByZMnAQADBw7Mtz8oKAg+Pj7IzMzEzp07jR0eFZO1NdClC7BpExAdDcydC9SuLbd4LVsGtGoFNG4MLFwIPHpk6miJiIi0s6jEKzw8HADg7u4OPz8/jWWaN2+uVpZKl8qVgY8+Aq5cAQ4elPt92dvL0wtNnChPOTRwILB/vzztEBERkTmxqMQrKioKAFCtWjWtZXx8fNTKGktmZiaSkpLUFio+SQLatQNWrwbu3QN++AF44QX56cfffwdCQuRWsa++Au7eNXW0REREMotKvJKTkwEATk5OWss4OzsDgNETn9mzZ8PNzU21KBNA0l+5csDYsUB4uDza/ZgxgKur3Dl/+nTAxwfo0UO9fxgREZEpWFTiZc6mTp2KxMRE1RIdHW3qkCxS06bA4sVyK9jKlUBQkHzLcft2oGdPoFo1YNo04Pp1U0dKRERlkUUlXi4uLgCA1NRUrWVSno5BYOwnCRUKBVxdXdUWKjmOjsDQocC//wKXLgEffAB4esoJ2ezZQK1aQHAwsHYtkJFh6miJiKissKjEy9fXFwAKbE1S7lOWJctXrx7w9dfAnTvAH38Ar7wi9xE7cAAYNEjukD9hAnD2rKkjJSIiS2dRiVeTJk0AyNP8aOs8f+rUKQBAU+WcNFRm2NkBffoAu3YBN28Cs2bJ/b8ePwa+/14ekqJVK+Dnn4Gn3QWJiIgMyqISL29vb7Ro0QIAsHbt2nz7w8LCEB0dDYVCga5duxo7PDIj1aoBn3wCREUBf/8NvPYaYGMDnDgBvPUWUKUKMHKkPF2RZQ0xTEREpmRRiRcATJs2DQAwZ84cnDlzRrU9Pj4eY8eOBQCMGzdObdT6LVu2oF69eggJCTFusGRy1tZA587Axo1ATIx8S7JuXSA1FfjlF6BNG3maou++A+LiTB0tERGVdhY3ZRAATJw4EQsXLoStrS1CQkLg5OSEffv2ISEhAYGBgdizZ4/aJNnKaYCqV6+Omzdv5quvdevWqvXY2FjcuHEDrq6uqF+/vmr7zJkz0a1bN51j5JRB5ksI4PBheVT8DRuA9HR5u60t0Lu3PFF3SAhgZXF/thARUWH0/f62KYGYTG7BggUIDAzEDz/8gCNHjiArKws1a9bElClT8O6778LOzq5I9R0/fjzftqSkJLXtsbGxesdN5kGS5GEogoKABQvkAVmXLZPHCNuwQV58feWJvIcPlyfxJiIi0oVFtniVBmzxKn3Cw4Hly4HffgMSE+VtVlbyU5Jvvgl07y63ihERkeXiJNlERtKkCbBokTwW2K+/ylMW5eYCO3cCr74qPyE5eTIQGWnqSImIyFyxxctE2OJlGa5elVvBVq4EHj58tr19e7kVrE8fIE93QiIiKuX0/f5m4mUiTLwsS1YW8Ndfcl+wv/+WW8IAwM0NGDgQaNZMbhGrVk3+WcB0okREZMaYeJVSTLwsV3S03AK2fDlw65bmMuXLP0vCNP2sWpX9xYiIzBETr1KKiZfly80F9u0DtmyRR8q/fVtOypKSCj/WykoexFVbYubjI889KUklfhlERJQHE69SiolX2ZWYKCdg0dHPkrG8P+/cAZ48KbwehUJOwApKzp7OG09ERAbCcbyIShk3N3lp2FDz/txcuaN+3oTs+eTs/n0gMxO4dk1etClXruDEzMtLnsOSiIiMgy1eJsIWL9LHkyfyFEfaWs2io4GEhMLrkSSgcuX8CVne9YoVOUo/EZESbzWWUky8qKQlJxd8SzM6Wm41K4ydnTw6v48P4OEht6Lpsjg5sQ8aEVke3mokIo1cXAB/f3nRRAggNlZzQqZcv3dPbl27cUNeisLaWvckjYkbEZUVTLyIyihJkm8jVqwojzOmSVYWcPfus2Ts8WP5FmZBy+PHQHY2kJMDxMfLS3EwcSMiS8TEi4i0srUFqleXF10JAaSnF56gmTJxc3YGHB3l5MzJ6dm6tp/KdTs7JnNEpB8mXkRkUJIkJymOjvJAsEVlLombJtbW2pMyXRK3wvbZ2zOxI7J0TLyIyKwYI3FLSQHS0oDU1Pw/NW3LypLrzsmRH1pITjbQxT4n77Xrkrg5OMjJmr29PK6bpvXC9tnaMtkjMiYmXkRkUfRN3DTJytKeqBWUsBW0L++68ulSIZ7ti401TOy60Dd507ZP13J2dhyyhMoOJl5ERIWwtX028G1JyMmRk7CiJnEZGc+WzMzC15Wvnx9GRLnPlGxs5ARM02Jrq32fMZa857e1ZZJI+mHiRURkYtbW8vAfxpriKTdXHiaksARN10SuuHXkHUUyO1te0tKM8zvQh7Yk0dZWfbGxyb9N23Zdtxn6eGtr3mo2NiZeRERljJXVs9t8JdWKVxgh5Fu4GRlyEmiIJSvLcHUpl8xM9QQRKF1Joi40JWk2NoZfSqregpaKFeXPuTlh4kVEREYnSc9aisxdTo7uSV9WlvqSnZ1/m6m2Z2drvj7l/vR04/5ejeHvv4HOnU0dhTomXkRERAWwtpafIHVwMHUk+hFCTiJ1SdJycp617JXmxdbW1L/1/Jh4ERERlQGS9OwWXGlPIkszPptBREREZCRMvIiIiIiMhIkXERERkZEw8SIiIiIyEiZeREREREbCxIuIiIjISJh4ERERERkJEy8iIiIiI2HiRURERGQkTLyIiIiIjISJFxEREZGRMPEiIiIiMhImXkRERERGwsSLiIiIyEhsTB1AWSWEAAAkJSWZOBIiIiLSlfJ7W/k9XlRMvEwkOTkZAODj42PiSIiIiKiokpOT4ebmVuTjJFHclI30kpubi7t378LFxQWSJBms3qSkJPj4+CA6Ohqurq4Gq9fYLOU6AMu5Fl6HeeF1mBdeh3kpyesQQiA5ORlVq1aFlVXRe2yxxctErKys4O3tXWL1u7q6lup/NEqWch2A5VwLr8O88DrMC6/DvJTUdRSnpUuJneuJiIiIjISJFxEREZGRMPGyMAqFAp988gkUCoWpQ9GLpVwHYDnXwuswL7wO88LrMC/mfB3sXE9ERERkJGzxIiIiIjISJl5ERERERsLEi4iIiMhImHiZiStXruD777/HsGHDEBAQABsbG0iShC+++KLQY/fu3YuuXbvCw8MDDg4OqFevHqZPn46UlJQCj7t27RqGDRsGb29vKBQKeHt7Y9iwYbhx40axryMrKwv79u3Dhx9+iBYtWqBcuXKwtbVF5cqV0aNHD+zYsaPUXMuaNWswZMgQNG7cGBUrVoStrS3c3NzQsmVLzJ49u8CYzOk6nvfRRx9BkqRCP1/mdg3Dhg1Txa1tycjI0Hjs6dOn0bdvX1SqVAn29vbw8/PD+PHj8fDhwwLP+eDBA4wbNw5+fn5QKBSoVKkS+vbtizNnzuh1LQDw5MkTLFy4EEFBQXB3d4e9vT28vb3RpUsXrF+/XuMx5vKe3Lx5s9D3QrkcOnTIbK9D6fbt2xg3bhzq1q0LBwcH1Wdk6NChiIiI0HqcuV1HdHQ0xo0bh5o1a0KhUMDDwwOdO3c2u/93S9P3XXJyMqZNm6b6bHh4eKBbt27Yv39/obFqJcgsTJw4UQDIt3z++ecFHvftt98KAEKSJNGuXTvRt29fUblyZQFA1K1bV8TGxmo8LiwsTDg6OgoAokGDBuL1118XDRo0EACEk5OTOHr0aLGuY8+eParYK1euLLp16yb69esnGjZsqNr+1ltvidzcXLO/lsDAQCFJkvD39xedO3cWAwYMEMHBwcLBwUEAELVq1RIxMTFmfx15HT58WFhZWQlJkgr8fJnjNQwdOlQAEIGBgWLo0KEalydPnuQ7buPGjcLGxkYAEC1atBD9+vUTNWrUEABEpUqVRGRkpMbzXblyRVSsWFEAEDVq1BD9+vUTLVq0EACEjY2N2Lx5c7GvJTo6Wvj7+wsAwsPDQ3Tv3l28/vrrok2bNsLR0VH06dMn3zHm9J7ExsZqfQ+GDh2q+j25uLiIlJQUs70OIYQ4duyYcHFxEQCEl5eX6NGjh+jdu7fw8/NTvdcbNmzId5y5XceJEyeEu7u7ACCqVKkievbsKYKCgoStra0AID7++GONx5niOkrL992DBw9EnTp1VL/Tvn37inbt2glJkoQkSWLhwoUFxqsNEy8z8fPPP4sPPvhArFmzRly6dEm88cYbhX4Qz5w5IyRJEtbW1mLnzp2q7ampqSIkJEQA0PgfeGpqqqhataoAIKZOnaq2b+rUqQKA8PHxEWlpaUW+jn379ok+ffqIQ4cO5du3bt06YW1tLQCIVatWmf21HDt2TMTHx+fbHhcXJ4KCggQA0b9/f7O/jrznqF27tvDy8hK9evXS+vky12tQJl4rVqzQ+ZiYmBjVf7g//fSTant2drYYPHiwKhl7/g+B3Nxc0aRJEwFAvPHGGyI7O1u176effhIAhLOzs7h3716RryMtLU3Uq1dPABCzZs3KlyympqaK8PBwtW3m+p5o06VLFwFAjBo1yuyvo1GjRqo/CPO+Fzk5OWLGjBkCgChXrpxIT0832+tIT08XPj4+AoB4/fXX1Y4/ceKEqFChggAgQkND1Y4z1XWUlu+7nj17CgAiJCREpKamqrbv2LFDWFtbCysrKxEREaE1Zm2YeJkp5ZdMQR/Evn37CgDizTffzLfv5s2bwsrKSgAQly5dUtv3ww8/CACiTp06IicnR21fTk6OKsP/8ccfDXMxeYwcOVL1QS7N13Lo0CEBQLi7u5ea65gwYYIAIHbs2FHg58tcr6E4ideHH34oAIiXX345377k5GTh5uYmAIi///5bbd+OHTtUX7jJycn5jlX+Rz9lypQiX8fMmTNVX/S6Mtf3RJM7d+6o4jl27JhZX0dcXJyqteXhw4f59mdnZ6tauM+cOWO217F27VrV5/Xx48f59i9YsEAAEEFBQWrbzeU6zPH77sKFCwKAsLa2Fjdv3sx3TuV32fN/fOuCfbxKqSdPnqju2w8cODDf/urVqyMwMBAAsGXLFrV9ytf9+/fPN8GnlZUVXn/9dQDA5s2bDR53kyZNAMh9EZRK47XY2MjTnOYdnM+cr+Off/7B999/jyFDhqBr165ay5nzNRSHMiZN1+Ls7IwePXpojEl5XI8ePeDs7JzvWGV9Rb2WrKwsLFmyBADw4Ycf6nRMaXtPVq5cidzcXDRo0ACtWrUy6+soyuCaHh4eAMzzOk6ePAkAaNasGcqVK5dv/8svvwwAOHz4MO7fv2+216GNKWJVHhcYGIjq1avnO6cyju3btyMrK6tI18PEq5S6evUq0tLSAADNmzfXWEa5PTw8XG278nVRjzOEyMhIAECVKlVU20rbtSQnJ2PWrFkAoPriBsz3OlJSUjBixAhUqlQJ8+fPL7CsuV5DXgcOHMD777+Pt956C1OnTsWWLVuQmZmZr1xycjKuXbtWrJh0vZbIyEikpqbqHPuZM2cQFxeHqlWrolatWjh37hw+/fRTjB49GlOmTMGOHTuQm5urdkxpeE/yWrlyJQBg5MiRatvN8TqcnZ3Rtm1bAMCMGTPUvkBzc3Mxa9YspKeno0uXLvDx8THb61B2LK9QoYLG/cqkUQihejDEHK9DG1PEqutxqampqu81XdkUqTSZjaioKABAuXLl4OLiorGM8j8KZVlA/jKKj48HAFSrVq3A42JjY5GamgonJyeDxHz//n3Vf8p9+vRRbTf3awkNDcXatWuRm5uLBw8e4OjRo0hOTsYrr7yCuXPnmv11fPDBB4iKisKWLVtQvnz5Asua6zXktXr16nzbqlSpgl9++QWvvPKKatvNmzdV64XFlPda8r4u7DghBG7evIkGDRroFPvZs2cBAN7e3pgyZQrmzZsHkWfykLlz56JJkybYunWr6tyl4T1ROnjwIK5duwY7Ozu88cYbavvM9Tp+/vlndO3aFUuXLsWOHTvQvHlzWFtbIzw8HDExMXjjjTewaNEis76OihUrAoDWJ/TyblfGZI7XoY0pYi3s/wBXV1e4uroiKSkJUVFR8Pf31/l62OJVSiUnJwNAgR9o5S2SpKSkfMcVdGzeWyt5j9VHdnY2Bg8ejMTERAQEBGD06NH5YjLXa7l48SJWrVqFX3/9FaGhoUhOTsbAgQOxcuVKuLm5mfV1hIaG4qeffkL//v3Rq1evQsub4zUoNW7cGAsWLMD58+eRlJSEBw8eIDQ0FG3atMG9e/fQo0cP/PPPP8WK6fl4Cvs9FPdalF8C4eHhmDt3LsaOHYsrV64gMTERe/bsQZ06dRAeHo5u3bqpWl/M+T153i+//AJAbglWtrI8H4+5XUfdunVx9OhRdOrUCTExMfjzzz+xefNmREVFoVatWujQoQNcXV3N+jqCg4MByMOmaGpl+vHHH/PVa47XoY0pYi3uOXXBxIuM4u2338a+fftQoUIF/PHHH7CzszN1SDqbNGkShBB48uQJrl27hv/973/YtWsX/P39NY5RZC4SExMxcuRIeHp64vvvvzd1OHp79913MWHCBDRo0AAuLi6oWLEiOnbsiLCwMPTs2RNZWVmYNGmSqcMskLJ1KysrCwMGDMCiRYtQp04duLq64uWXX8aePXtgb2+P8+fPY926dSaOtmiSkpLwxx9/AABGjBhh4mh0d/jwYQQEBOD8+fNYu3Yt7t+/j0ePHqn67owcOTLfbVNzExwcjHbt2kEIgR49emD79u1ITEzEjRs38MEHH2D16tWwtbUFgHz9nMj4+A6UUsrm1oL6lyjv++f9ay1vM622Y/MORJf32OKaOHEili9fjvLly6v+qs+rtFyLra0tatasiffeew+7du3C48ePMXjwYKSnp6vFYy7XMWnSJNy5cweLFi3K1/qgjbldgy4kScKnn34KAIiIiFA9uFGUmJ6Pp7DfQ3GvJW9MeVt9lapVq4Zu3boBkAeK1CWWvPGY8j1Zt24d0tLS4O3tjc6dO+fbb47XkZCQgN69eyM2NhabN2/GgAEDUKlSJZQvXx7du3fH33//DUdHR/zyyy84cOCA2V4HAGzcuBGBgYG4c+cOevTogXLlyqFmzZr43//+h4kTJ6Jx48YAAHd3d7O+Dk1MEWtxz6kLJl6llK+vLwD5P468zal5Kb+AlGUB+cOk/Id3+/btAo/z8PDQ+978+++/j4ULF6JcuXIIDQ1VPdWYV2m5lrxatWoFf39/REdH49SpU2qxmct1bNmyBTY2Nli8eDE6dOigtvz9998AgOXLl6NDhw7o37+/WV6DrurXr69av3PnDgCoPYlUWEx5ryXv68KOkyRJ4xNP2tSoUUPjuqYy9+7dU4vF3N8T5W3GYcOGaWxVMcfr2LFjB2JjY1GjRg21JzCV8m5XJsLmeB2A3M/r33//RWhoKKZMmYJRo0ZhxowZOHnyJL777jvExMQAAAICAsz6OjQxRayF/R+QlJSkusX4/P8fhWHiVUrVrVsXjo6OAKD64n+ecnvTpk3VtitfF/W4ovroo4/w7bffws3NDaGhoVqfDikN16KJ8h+pctoZc7yO7OxsHDx4MN/y4MEDAHIH9IMHD+LYsWNmew26UPadAp79perq6opatWoVKyZdr6V27doah5vQpmnTppAkCQAQFxensYxyu7Le0vCeXLx4EcePH4ckSRg+fLjGMuZ4Hcov1YJaLJT9OB89egTAPK9DSZIkdOzYEbNnz8bSpUvx+eefo3nz5rh+/Tru3buHChUqqOo25+t4nili1fU4JyenfHdxClXkkb/IKAwxoJxylHhTDKo4efJkAUC4ubmJEydOFFrenK9Fk9jYWKFQKAQAcfbs2VJ3HfoMoGou15CXcioRV1dXtdHHCxtAtVy5cgKFDKD6/JQ3Qug3gGrbtm0FADFv3rx8+548eaKazmj27Nmq7eb+nrz33nsCgAgODi6wnLldx6pVqwQA4eDgIBISEvLtf/LkiahWrZoAIObOnWu211GYt99+W0DDyO3mch3m+H13/vx5gacDqN66dSvfOfUZQJWJl5nS5YN4+vRp1RQKu3btUm0vyhQK06ZNU9s3bdo0AUB4e3sXexqR6dOnq760dEm6zPFaLly4IH777Te1aUKUrly5Ijp06CAAiNatW5v1dWhT0OfLHK8hPDxc/PnnnyIrK0tte05Ojli2bJmwt7cXAMSMGTPU9uedMmjp0qWq7dnZ2appSgqbMmjIkCEGnTJo7969AoAoX7682hxxWVlZYvz48QKQ5zi8f/++ap85vidKT548Uc1puWbNmgLLmtt1PHz4UDg5OQkAom/fvmqzFGRmZop33nlHABC2trbi+vXrZnsdQsj/ZyUmJqpty8rKEl9++aWQJEnUqlUr3x8R5nId5vp9p5wy6OWXX1bbv3PnTk4ZZAlOnz4tWrVqpVo8PDxUH4i82+/evat2XN5JQzt06CD69esnqlSpIgDdJw1t2LCh6N+/v2oia30mav3zzz8Fnk7B0bx5c62T6L7//vv5jjWnazlw4IDq+KCgING/f3/x6quviubNm6umpqhfv77Gv4TM6Tq0Kew/OnO7hi1btqiSlZCQEDFw4EDRtWtXVWsEADFgwIB8iZkQQmzYsEH113CrVq3E66+/rtMk2ZcvXxaenp4CkCfJfv3110XLli0FoP8k2Z9//rmqnjZt2ohXX31V+Pr6qlpf/vrrr3zHmNt7orR582bVH1qa/lAx9+v49ddfVZOoe3p6iq5du4qePXsKLy8vAUBYWVmJJUuWmP11TJw4Udjb24vAwEDRr18/0bNnT1GpUiUBQNSqVUtERUVpPM4U11Favu8ePHggateuLQB5kux+/fqJDh06CEmSBACxYMECrddYECZeZkL5RV/Youkfz549e8Qrr7wi3N3dhUKhELVr1xZTp04VSUlJBZ4zMjJSDBkyRFStWlXY2tqKqlWriiFDhohr164V+zpWrFih03VUr15d4/Hmci0PHz4UX375pXjllVeEr6+vcHJyEnZ2dqJy5cqiY8eOYsmSJSIjI0Pr8eZyHdro8hemOV3DjRs3xKRJk0RQUJDw8vIS9vb2QqFQiGrVqonXXntN7Nixo8DjT506JV599VXh6ekp7OzsRPXq1cU777yj1qqkyb1798Q777wjqlevLuzs7ISnp6d49dVXxenTp4t9LUq7d+8WXbp0Ee7u7sLW1lb4+PiIYcOG5btVkpc5vSdK3bt3FwDE2LFjdT7G3K7jv//+E8OGDRM1atQQCoVC9RkZNGiQOH78eKm4jt27d4uePXsKHx8foVAohKurq2jRooWYN29eoS1Pxr6O0vR9l5iYKKZMmSJq164tFAqFcHd3F6+88orYu3dvgccVRBIiz7DJRERERFRi+FQjERERkZEw8SIiIiIyEiZeREREREbCxIuIiIjISJh4ERERERkJEy8iIiIiI2HiRURERGQkTLyIiIiIjISJFxEREZGRMPEiMiFJklTLP//8Y/Tz37x5Uy2GmzdvGj0Goud16NBB9ZmcNWuWqcMhMigmXmS2nk8KDLkwwSBN8n7h+/r6mjocIrJATLyIiIron3/+UUvkSTNTt+jSMytXruQfFWbCxtQBEGnj4OCAzp07F1ruxIkTePz4MQDA3t4e7du316luIiIiY2PiRWarUqVK+Pvvvwst16FDBxw8eLBIx5gLIYRJz+/r62vyGIiex9YxsmS81UhERERkJEy8iIiIiIyEiReVGZo6+qanp2P16tX4v//7P9SsWRNOTk6QJAmTJk3Kd/z9+/exatUqjBw5Ei1btoSnpyfs7Ozg7OyMatWqoWvXrvj6668RHx+vV0zP0zbkQ3p6OlasWIGXX34ZPj4+UCgUqFixIjp06IAFCxYgIyOj0PPrOpyEts7kCQkJ+P777xEUFIQqVapAoVCgSpUq6NKlC1asWIGcnBydfxfKa1q0aBFeeuklVKlSBfb29qhWrRpCQkKwbNkypKWlFRhPSRs2bBgkScJLL72ktl3b07MdOnQosL7s7GysX78eQ4YMQb169eDu7g6FQgEvLy+EhITg66+/xqNHj3SKzVw+33k7cef10ksvaf09Pa84w0kkJydj8eLF6N69O3x9feHo6AgXFxfUrFkT/fr1w+rVq/HkyROd6tJ2/sOHD2PEiBGoV68enJ2d4erqigYNGmDChAm4du2aTnUDQG5uLrZu3Yo33ngDDRo0QLly5WBjYwMHBwdUrlwZLVq0wLBhw7B06VI8ePBA53oLupbhw4ertt26dUvrezFs2DC9zkc6EESlXPv27QUAAUBUr15dazllGQDiwIED4r///hP169dX265cJk6cqHbs8OHDhZWVlcayzy9OTk5i8eLFOsX+fEyaREVFqZWLiooSERERWmNXLrVq1RLXr18v8Pya6tbkwIEDauWU27y8vAqMoWXLliI2Nlan38WxY8dEjRo1CqyvXr164ty5cxrjMYTCPktDhw7V6TOgXNq3b6/1XH///beoXbt2oXWUK1dOLF++vNDYzeXzvWLFiiL9jjS9f3nfh08++aTQa1+zZo2oWLFioeepWbOm2LdvX6H1PX/+1NRU8eabbxZYt62trVi2bFmhdV+9elU0adJE59+Np6dnoXXqei26LEOHDtXrfFQ4dq6nMikqKgp9+vRRtSZ4e3vDz88PT5480fiX69mzZ5Gbm6t6Xa1aNVStWhXOzs5ITU3F1atXVS0BqampGDt2LBISEjB16lSDx37lyhX0798fCQkJAIDatWvDy8sLaWlpiIiIQGZmJgDg2rVr6NSpE86ePQtHR0eDxvDvv/+ic+fOePLkCSRJQv369VGpUiUkJCTg7NmzqpauEydOoFevXjh06BCsrLQ3sJ84cQIdO3ZEcnKyapu9vT0aNmwIZ2dn3Lp1C1FRUbh8+TKCg4Px3XffGfR6dBUQEIDOnTvj0aNHOHnypGq7tqdvGzVqpHH7kiVLMH78eLUWQXd3d9SpUwcODg64c+cOIiMjAcitiiNHjsS9e/cwffp0neI05efby8tL9fvYvXu3anuLFi3g7u6uU/xFMW/ePEyePFltm6enJ+rUqYOcnBxcunQJiYmJAIDr16/jlVdewW+//YZ+/frpVH9ubi769euHHTt2AJDfp7p168LOzg5XrlzB/fv3AQBZWVl488034e3trfXzEBcXh/bt2+PevXuqbfb2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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "# x2的变化方差\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('0.5.npy')\n",
    "matrix2 = np.loadtxt('4.npy')\n",
    "matrix3 = np.loadtxt('16.npy')\n",
    "\n",
    "\n",
    "matplotlib.rcParams['xtick.labelsize'] = 16\n",
    "matplotlib.rcParams['ytick.labelsize'] = 16\n",
    "\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='$\\sigma_p=0.5$', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='$\\sigma_p=4$', color='red')\n",
    "plt.plot(x, sampled_matrix3, label='$\\sigma_p=16$', color='green')\n",
    "\n",
    "\n",
    "# 添加图例\n",
    "plt.legend(loc='center right',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",
    "plt.savefig('sigma.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ac3f7b34-8f72-4632-bdf0-43ab0e38e871",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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gIuLC/z9/bFu3Tr5StM5c+YgJiamVPY/b948aDQaedKNzBEREVHlUaECm4uLCwAgOTnZZJukpCQAgFqtLvH+Jk6cCA8PD6Snp2Pv3r1FqkVXR0G1hISEQKvVylN0dHSJ6yYiIqLypUKdw+bj4wMA+YYa3TJd25KwtrZGgwYNEBsbizt37hjU8vjxY9y+fTvfOiRJQp06dUzuQ6VSQaVSlbhWIiIiKr8q1Aibn58fACAuLs7kRQVnz54FAL17tJVEXFwcgH9G1HR029ftz1QdDRo0MHrbDyIiIiKdChXYPD090aZNGwDAhg0bDJYfO3YM0dHRUKlU6NWrV4n3Fx4ejsjISABA27Zt9ZbpHjm1Y8cOo4dFdfUNGDCgxHUQERFRxVahAhsATJs2DQAwf/58vQesx8XFYdy4cQCA8ePHQ6PRyMvCwsLQuHFjdO7cWW9bKSkpWLZsmXzFZ15Hjx7FwIEDAeTekPfpwNazZ0/4+fkhPj4e48aNQ3Z2trzsm2++wYEDB+Ds7IyJEyeWsMdERERU0UlCCGHpIsxt4sSJ+Oqrr2Bra4vOnTvDyckJBw4cQHx8PAICArBv3z69h7+vXbsWY8aMQZ06dXDr1i15fnx8PNzc3KBSqeDn5wdvb29kZWUhMjISFy9eBAC0aNECv/76K2rWrGlQx9WrV9G+fXs8evQI9erVQ5s2bRAVFYXTp0/DxsamWA9/T0hIgEajgVarNcuFE0RERFT6Svr9XeFG2ABg8eLF2LRpE55//nmcOHECu3fvhqenJ+bPn4+DBw/qhbX8ODo6YubMmejUqRNiYmLwyy+/YMeOHYiJiUGXLl3w9ddf4+zZs0bDGgA0atQIFy5cwDvvvIPs7GyEhYUhKioKAwYMwKlTp4oc1oiIiKhyqpAjbBUZR9iIiIjKH46wEREREVVwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfARkRERKRwDGxERERECsfA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jQAAO3YAU6b8897LC2jQIDfANWjwz+u6dQE7O8vVSUREVBkxsBEAwM0NaNMGiIwEtFogOjp3OnhQv52VFeDjox/kdGGuTh3A2toi5RMREVVokhBCWLqI0rBlyxYsW7YM58+fR0ZGBurXr49XX30V7733HmxtbYu8vT/++APz58/H0aNHodVqUbNmTfTp0wczZ85EtWrVTK4XExODuXPnYteuXbh37x5cXV3RoUMHhISEoHXr1kWuIyEhARqNBlqtFmq1usjrF0QIIDY29xDptWu5AU73+to1IDnZ9Lq2tkC9esbDXO3auWGPiIioMirp93eFDGyTJk3C4sWLYWNjg06dOsHZ2RkHDx5EfHw8AgMDsXfvXjgU4SStrVu3YtiwYcjKykKbNm1Qt25dnD17Fjdv3kT16tVx7Ngx1K9f32C9yMhItG/fHg8fPkS9evXg7++PqKgonDlzBjY2Nti8eTNefvnlIvWttANbfoQA7t83HuSuXwfS002va28P1K9vPMxVrw5IUtn1g4iIqKwxsD1l+/btePnll+Hs7IwjR47Io1ixsbHo1KkT/vzzT0yePBmLFi0q1Pbu3buHBg0aICUlBV9//TXeeustAEB2djaCg4Px/fffo02bNjh16hSkPKlDCIFnn30WERERGDlyJNasWQPr/x0v/OabbzB27Fg4Ozvj2rVrqFGjRqH7Z8nAlp/sbODOHcMwFxkJREUBWVmm13V2NjxfTve+SpWy6wMREVFpYWB7Stu2bXHmzBl88sknmD59ut6yY8eOoX379lCpVIiJiYFGoylwe//+97/x2WefoUuXLti3b5/esqSkJHh6ekKr1WLPnj3o3r27vGz37t3o3bs3XF1dER0dDWdnZ711u3TpggMHDmDq1KmYN29eofun1MCWn8xM4O+/jYe5v//OHbkzxc3NeJhr0AAoxMdHRESkCCX9/q5QFx3cvXsXZ86cAQAMHz7cYHlgYCC8vLwQHR2N3bt3Y9iwYQVuMywszOT2nJ2d0a9fP6xfvx7btm3TC2y69fr162cQ1nTbO3DgALZt21akwFYe2drmHg6tXx/o2VN/WXo6cPOm8TB39y7w5Alw+nTu9LRq1YyHufr1ASensukbERFRWahQgS0iIgIA4O7ujrp16xpt4+/vj+joaERERBQY2BITE3H9+nV5PVPbW79+vbzvp2vJbz0A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sX/kKLkv69evFzY2NgKAqFq1qujVq5fo37+/qF27tgAgrKysxIoVKxTdByFyH6hub28vAgICxODBg0X//v1F9erVBQBRv359ERUVZXQ9S/SjvHzXxcTEiAYNGggg9+HvgwcPFh07dhSSJAkAYvHixSb7mB8GtgpAFxIKmoz9h7dv3z7Ro0cP4e7uLlQqlWjQoIEICQkRCQkJ+e7z2rVrYtSoUaJWrVrC1tZW1KpVS4waNUpcv369WH1Ys2ZNofpQp04do+srpR8PHz4Un376qejRo4fw8fERTk5Ows7OTtSoUUN07dpVrFixQqSlpZlcXyn9yE9h/lWrlH7cvHlTTJo0SQQGBoratWsLe3t7oVKphLe3t3jllVfErl278l3/7NmzYsCAAaJq1arCzs5O1KlTR7zzzjt6o1jG3L9/X7zzzjuiTp06ws7OTlStWlUMGDBA/PHHH8XqR16//vqr6Nmzp3B3dxe2trbCy8tLBAcHGxzSyUspn8fT+vTpIwCIcePGFXodJfXl3LlzIjg4WNSrV0+oVCr5b+TVV18Vp06dKhd9+PXXX0X//v2Fl5eXUKlUQq1WizZt2oiFCxcWONJV1v0oT991Wq1WTJ06VTRo0ECoVCrh7u4uevToIfbv35/vevmRhMhzu2wiIiIiUhxeJUpERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZERESkcAxsRERERArHwEZEZCFXr17F9OnTERQUBE9PTzg5OUGSpEJNPj4+li6fiMqQjaULICKqbDIzMzF+/Hj85z//QU5OjqXLIaJygIGNiKiMDRw4EDt37tSb5+bmhkaNGsHGxgbXr1/HgwcPLFQdESkRAxsRURlavny5XlirWrUqFi9ejEGDBsHGJvd/yUIIHDhwAP/6179w/fp1uW1wcDCCgoIAAM7OzmVbOBFZlCSEEJYugoioMsjMzIS3t7c8eqZWq3HixAk0a9bMaPv79++jbdu2uHPnDgCgcePG+PPPP+VgR0SVBy86ICIqI9u3b9c71Dlr1iyTYQ0Aatasic8++0x+f+XKFezZs6dUayQiZWJgIyIqIwcOHJBfOzk54a233ipwncGDB6N27dry+x9//LFUaiMiZWNgIyIqI6dPn5ZfBwUFFeo8NCsrK/Tq1Ut+//vvv5dKbUSkbAxsRERl5N69e/LrZ555ptDrtWrVSn598+ZNZGRkmLMsIioHGNiIiMpIfHy8/LpKlSqFXs/Dw8PkdoiocmBgIyKyAGtr60K3ffqqUN5sl6jyYWAjIiojrq6u8mutVlvo9Z5u6+bmZq6SiKicYGAjIiojtWrVkl9fu3at0OtdvXpVfu3m5gaVSmXWuohI+RjYiIjKSNu2beXXJ06cKPR6x48fN7oNIqo8GNiIiMpI586d5de3bt3C0aNHC1zn+vXreoHtxRdfLJXaiEjZ+GgqIqIykpGRAW9vb8TExAAA2rVrh+PHj+d7AUK/fv3kZ4/a2dkhOjoa1apVK5N6iUg5OMJGRFRG7OzsMGvWLPn9qVOnMGbMGKSnpxu0zc7Oxvvvv6/3oPh3332XYY2okuIIGxFRGevbty9+/vln+X2DBg3w5ptvomXLlrC2tsbly5exevVqnDt3Tm7TqlUr/P7777zggKiSYmAjIipjaWlpGDJkCHbs2FGo9u3atcPu3bvh7u5eypURkVLxkCgRURmzt7fH9u3bsW7dOtSvX99ku1q1auH//u//8NtvvzGsEVVyHGEjIrKwS5cuITw8HDExMcjJyUHVqlXxzDPPoHXr1pAkydLlEZECMLARERERKRwPiRIREREpHAMbERERkcIxsBEREREpHAMbERERkcIxsBEREREpHAMbERERkcIxsBEREREpHAMbERERkcIxsBEREREpHAMbERERkcIxsBEREREpHAMbERERkcIxsBEREREpHAMbERERkcL9P7pBsUkf8CffAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "# x3到x16\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 加载npy文件中的矩阵\n",
    "matrix1 = np.loadtxt('0.5_.npy')\n",
    "matrix2 = np.loadtxt('4_.npy')\n",
    "matrix3 = np.loadtxt('16_.npy')\n",
    "\n",
    "matplotlib.rcParams['xtick.labelsize'] = 16\n",
    "matplotlib.rcParams['ytick.labelsize'] = 16\n",
    "\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='σ=0.5', color='blue')\n",
    "plt.plot(x, sampled_matrix2, label='σ=4', color='red')\n",
    "plt.plot(x, sampled_matrix3, label='σ=16', color='green')\n",
    "\n",
    "\n",
    "# 添加图例\n",
    "plt.legend(fontsize=14)\n",
    "\n",
    "# 添加标题和坐标轴标签\n",
    "\n",
    "plt.title('Column Mean Values of Matrices')\n",
    "plt.xlabel('σ',size=26)\n",
    "plt.ylabel('loss',size=26)\n",
    "plt.xticks(x,[100,200,300,400,500,600,700,800,900,1000])\n",
    "# 显示折线图\n",
    "plt.show()\n",
    "\n",
    "plt.savefig('不同噪声方差对损失的影响.png', dpi=300, bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3012869d-76f1-4f27-89a9-2f2ae5a91cdb",
   "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
}
