{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import e3nn\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "S2Activation (1x0e+1x1o -> 1x0e+1x1o)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "e3nn.nn.S2Activation(e3nn.io.SphericalTensor(1,1,-1), torch.relu, 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [],
   "source": [
    "class S2NetDot(torch.nn.Module):\n",
    "    def __init__(self, input_irreps, l_max=1, act = torch.relu, res=100, *args, **kwargs):\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.hidden_reps = e3nn.io.SphericalTensor(l_max, 1, -1)\n",
    "        self.lay1 = e3nn.o3.Linear(input_irreps, self.hidden_reps)\n",
    "        self.lay2 = e3nn.nn.S2Activation(self.hidden_reps, act, res)\n",
    "    \n",
    "    def forward(self, x):\n",
    "        h1 = self.lay1(x)\n",
    "        h2 = self.lay2(h1)\n",
    "        return torch.sum(h2*h2, dim=-1)\n",
    "        # return h2[:,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[Parameter containing:\n",
       " tensor([-0.6394, -0.6608, -0.1433], requires_grad=True)]"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "irreps_in = e3nn.o3.Irreps('1x0e+2x1o')\n",
    "\n",
    "test_model = S2NetDot(irreps_in)\n",
    "list(test_model.parameters())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = torch.randn(5000,irreps_in.dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "irreps_in = e3nn.o3.Irreps('1x0e+1x1o')\n",
    "\n",
    "torch.manual_seed(1)\n",
    "\n",
    "teacher = S2NetDot(irreps_in)\n",
    "student = S2NetDot(irreps_in)\n",
    "\n",
    "N_train = 500\n",
    "data = torch.randn(N_train,irreps_in.dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.3774, grad_fn=<DivBackward0>)\n",
      "tensor(1.0781, grad_fn=<DivBackward0>)\n",
      "tensor(0.8673, grad_fn=<DivBackward0>)\n",
      "tensor(0.7036, grad_fn=<DivBackward0>)\n",
      "tensor(0.5752, grad_fn=<DivBackward0>)\n",
      "tensor(0.4728, grad_fn=<DivBackward0>)\n",
      "tensor(0.3880, grad_fn=<DivBackward0>)\n",
      "tensor(0.3171, grad_fn=<DivBackward0>)\n",
      "tensor(0.2582, grad_fn=<DivBackward0>)\n",
      "tensor(0.2094, grad_fn=<DivBackward0>)\n",
      "tensor(0.1689, grad_fn=<DivBackward0>)\n",
      "tensor(0.1356, grad_fn=<DivBackward0>)\n",
      "tensor(0.1083, grad_fn=<DivBackward0>)\n",
      "tensor(0.0861, grad_fn=<DivBackward0>)\n",
      "tensor(0.0684, grad_fn=<DivBackward0>)\n",
      "tensor(0.0542, grad_fn=<DivBackward0>)\n",
      "tensor(0.0431, grad_fn=<DivBackward0>)\n",
      "tensor(0.0342, grad_fn=<DivBackward0>)\n",
      "tensor(0.0273, grad_fn=<DivBackward0>)\n",
      "tensor(0.0218, grad_fn=<DivBackward0>)\n",
      "tensor(0.0174, grad_fn=<DivBackward0>)\n",
      "tensor(0.0140, grad_fn=<DivBackward0>)\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[69], line 11\u001b[0m\n\u001b[1;32m      8\u001b[0m y2 \u001b[38;5;241m=\u001b[39m teacher(data)\n\u001b[1;32m      9\u001b[0m loss \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39msum((y1\u001b[38;5;241m-\u001b[39my2)\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m2\u001b[39m)\u001b[38;5;241m/\u001b[39mN_train\n\u001b[0;32m---> 11\u001b[0m \u001b[43mloss\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     12\u001b[0m opt\u001b[38;5;241m.\u001b[39mstep()\n\u001b[1;32m     13\u001b[0m opt\u001b[38;5;241m.\u001b[39mzero_grad()\n",
      "File \u001b[0;32m~/envs/e3nn/lib/python3.10/site-packages/torch/_tensor.py:581\u001b[0m, in \u001b[0;36mTensor.backward\u001b[0;34m(self, gradient, retain_graph, create_graph, inputs)\u001b[0m\n\u001b[1;32m    571\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m has_torch_function_unary(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    572\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m handle_torch_function(\n\u001b[1;32m    573\u001b[0m         Tensor\u001b[38;5;241m.\u001b[39mbackward,\n\u001b[1;32m    574\u001b[0m         (\u001b[38;5;28mself\u001b[39m,),\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    579\u001b[0m         inputs\u001b[38;5;241m=\u001b[39minputs,\n\u001b[1;32m    580\u001b[0m     )\n\u001b[0;32m--> 581\u001b[0m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mautograd\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mbackward\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    582\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mgradient\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minputs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minputs\u001b[49m\n\u001b[1;32m    583\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:347\u001b[0m, in \u001b[0;36mbackward\u001b[0;34m(tensors, grad_tensors, retain_graph, create_graph, grad_variables, inputs)\u001b[0m\n\u001b[1;32m    342\u001b[0m     retain_graph \u001b[38;5;241m=\u001b[39m create_graph\n\u001b[1;32m    344\u001b[0m \u001b[38;5;66;03m# The reason we repeat the same comment below is that\u001b[39;00m\n\u001b[1;32m    345\u001b[0m \u001b[38;5;66;03m# some Python versions print out the first line of a multi-line function\u001b[39;00m\n\u001b[1;32m    346\u001b[0m \u001b[38;5;66;03m# calls in the traceback and some print out the last line\u001b[39;00m\n\u001b[0;32m--> 347\u001b[0m \u001b[43m_engine_run_backward\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    348\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtensors\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    349\u001b[0m \u001b[43m    \u001b[49m\u001b[43mgrad_tensors_\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    350\u001b[0m \u001b[43m    \u001b[49m\u001b[43mretain_graph\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    351\u001b[0m \u001b[43m    \u001b[49m\u001b[43mcreate_graph\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    352\u001b[0m \u001b[43m    \u001b[49m\u001b[43minputs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    353\u001b[0m \u001b[43m    \u001b[49m\u001b[43mallow_unreachable\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[1;32m    354\u001b[0m \u001b[43m    \u001b[49m\u001b[43maccumulate_grad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[1;32m    355\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/envs/e3nn/lib/python3.10/site-packages/torch/autograd/graph.py:825\u001b[0m, in \u001b[0;36m_engine_run_backward\u001b[0;34m(t_outputs, *args, **kwargs)\u001b[0m\n\u001b[1;32m    823\u001b[0m     unregister_hooks \u001b[38;5;241m=\u001b[39m _register_logging_hooks_on_whole_graph(t_outputs)\n\u001b[1;32m    824\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[0;32m--> 825\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mVariable\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_execution_engine\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrun_backward\u001b[49m\u001b[43m(\u001b[49m\u001b[43m  \u001b[49m\u001b[38;5;66;43;03m# Calls into the C++ engine to run the backward pass\u001b[39;49;00m\n\u001b[1;32m    826\u001b[0m \u001b[43m        \u001b[49m\u001b[43mt_outputs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\n\u001b[1;32m    827\u001b[0m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# Calls into the C++ engine to run the backward pass\u001b[39;00m\n\u001b[1;32m    828\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m    829\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m attach_logging_hooks:\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "opt = torch.optim.SGD(student.parameters(),lr = 1e-2)\n",
    "\n",
    "losses = []\n",
    "\n",
    "iters = 1000\n",
    "for i in range(iters):\n",
    "    y1 = student(data)\n",
    "    y2 = teacher(data)\n",
    "    loss = torch.sum((y1-y2)**2)/N_train\n",
    "\n",
    "    loss.backward()\n",
    "    opt.step()\n",
    "    opt.zero_grad()\n",
    "\n",
    "    losses.append(loss.detach().clone().numpy())\n",
    "    if i%2==0:\n",
    "        print(loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 363,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([ 0.2713, -1.2729,  0.5027])"
      ]
     },
     "execution_count": 363,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "irreps_in = e3nn.o3.Irreps('1x0e+1x2e+1x4e')\n",
    "torch.manual_seed(8)\n",
    "teacher = S2NetDot(irreps_in, l_max = 4)\n",
    "list(teacher.parameters())[0].data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.2739, 1.6313, 4.0662, 0.8161])"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "irreps_in = e3nn.o3.Irreps('1x2e')\n",
    "\n",
    "def gen_rand_irrep_data(N_train, sh_vs_rand = None):\n",
    "    data = []\n",
    "    for i, (mul, irrep) in enumerate(irreps_in):\n",
    "        for m in range(mul):\n",
    "            # print(i,m)\n",
    "            if sh_vs_rand == None or sh_vs_rand[i][m]==False:\n",
    "                data.append(torch.randn(N_train, irrep.l*2+1))\n",
    "            else:\n",
    "                vecs = torch.randn(N_train, 3)\n",
    "                vecs = vecs/torch.norm(vecs)\n",
    "                data.append(e3nn.o3.spherical_harmonics(irrep.l, vecs.clone(), False)*torch.randn(N_train,1)*(2*irrep.l+1)**2)\n",
    "    return torch.cat(data,dim=1)\n",
    "\n",
    "gen_rand_irrep_data(4, [[True]]).norm(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n",
      "100%|██████████| 101/101 [01:21<00:00,  1.24it/s]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "from multiprocessing import Pool\n",
    "import tqdm\n",
    "\n",
    "path = os.path.dirname(os.getcwd())\n",
    "folder_name = path + '/s2_phase/'\n",
    "try:\n",
    "    os.mkdir(folder_name)\n",
    "except:\n",
    "    pass\n",
    "\n",
    "irreps_in = e3nn.o3.Irreps('1x2e+1x6e')\n",
    "lmax = 6\n",
    "\n",
    "torch.manual_seed(1)\n",
    "\n",
    "N_train = 50\n",
    "\n",
    "# # random data\n",
    "data = gen_rand_irrep_data(N_train,[[False],[False]])\n",
    "\n",
    "# SH generated data\n",
    "# gen_rand_irrep_data(N_train)\n",
    "\n",
    "# parameter sweep values\n",
    "size = [101,101]\n",
    "loss_mat = np.zeros(size)\n",
    "ranges = [[-1.5,1.5],[-1.5,1.5]]\n",
    "grad_mat = np.zeros(size+[2])\n",
    "\n",
    "def gen_phase_diagram(seed):\n",
    "    torch.manual_seed(seed)\n",
    "    teacher = S2NetDot(irreps_in, l_max = lmax)\n",
    "    # for parameter in teacher.parameters():\n",
    "    #     parameter.data[0] = 1.\n",
    "    #     parameter.data[1] = 0.\n",
    "    y1 = teacher(data)\n",
    "\n",
    "    student = S2NetDot(irreps_in, l_max = lmax)\n",
    "    for a in tqdm.tqdm(range(size[0])):\n",
    "        for b in range(size[1]):\n",
    "            param1 = (ranges[0][0]*(size[0]-a)+ranges[0][1]*a)/size[0]\n",
    "            param2 = (ranges[1][0]*(size[0]-b)+ranges[1][1]*b)/size[0]\n",
    "            teacher_params = list(teacher.parameters())[0].data\n",
    "            for parameter in student.parameters():\n",
    "                parameter.data = teacher_params\n",
    "                parameter.data[0] = param1\n",
    "                parameter.data[1] = param2\n",
    "            y2 = student(data)\n",
    "            loss = torch.sum((y1-y2)**2)/N_train\n",
    "            # print(list(student.parameters())[0])\n",
    "            grads = torch.autograd.grad(loss, list(student.parameters())[0])[0][:2]\n",
    "            loss_mat[a,b] = loss.detach().clone().numpy()\n",
    "            grad_mat[a, b, :] = grads.detach().clone().numpy()\n",
    "            # print(a,b,list(student.parameters()), param1, param2)\n",
    "    name = 's2_activation_in_'\n",
    "    name += str(irreps_in)+'_'\n",
    "    name += 'lmax_' + str(lmax)\n",
    "    np.savetxt(folder_name+name+f'_{seed}.csv',loss_mat,delimiter = ',')\n",
    "\n",
    "    np.savetxt(folder_name+name+f'_{seed}_grads.csv',grad_mat.reshape(grad_mat.shape[0],-1),delimiter = ',')\n",
    "\n",
    "# with Pool(10) as p:\n",
    "#     p.map(gen_phas_diagram,list(range(10)))\n",
    "gen_phase_diagram(10)\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[334.83370972 313.09805298 292.66409302 ... 294.07977295 314.33944702\n",
      "  335.84658813]\n",
      " [318.10012817 296.81436157 276.82092285 ... 277.85391235 297.62585449\n",
      "  318.63711548]\n",
      " [302.19897461 281.35510254 261.79437256 ... 262.4473877  281.74359131\n",
      "  302.27404785]\n",
      " ...\n",
      " [303.84906006 280.70956421 258.95199585 ... 231.68208313 251.53327942\n",
      "  272.67987061]\n",
      " [317.46572876 293.80984497 271.54910278 ... 243.39085388 263.71905518\n",
      "  285.35510254]\n",
      " [331.67776489 307.49710083 284.72677612 ... 255.64758301 276.46594238\n",
      "  298.59951782]]\n"
     ]
    },
    {
     "data": {
      "image/png": "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Q4ZIko4cOaJ77rlH//d//6eioiItXbrUVmOBAAA0J9bRMQtpj86mTZt0++23+4IcSerZs6c++ugj3XnnnVq+fLkmTZpUa94OAABAY4U00Dl79qz69u1b5Xx4eLhef/11TZo0SW+88Ybuvvtueb3eUDalXoqKijR//nz169dPkZGR6t69u6ZOnapjx441uK6cnBw98MADSk5OlsvlUnJysh588EGdO3fO+oYDAHBBxayrYB+NYeX3qFVCOnTVrVs3ZWdnV1vmcDi0dOlSGYahFStWyOv1qk+fPqFsTq2Ki4t18803a8uWLUpISNDYsWN1+PBhLV26VOvXr9eWLVvUq1evetV1+vRpDR48WAcOHFCvXr10++23a8+ePXrhhRf03nvvafPmzerYsWOI7wgA0BY119CVld+jVgppj05qaqr++c9/1ljucDi0bNky3XPPPVq5cqVefPHFUDanVk888YS2bNmiwYMHa9++fVq5cqU+//xzPfvss8rOztbUqVPrXdeDDz6oAwcOaPz48UpPT9fKlSu1e/duzZw5U/v27dOcOXNCeCcAADQ9K79HreQwQpgg8/zzz2vOnDn6+OOPNXTo0BpfZxiG7r33Xi1fvlwOh0MejydUTapWaWmpLr74YuXm5mrHjh0aOHCgqXzAgAHatWuXtm3bpmuuuabWurKyspSYmKjw8HAdOXJEXbt29ZWVlJQoKSlJZ8+e1fHjx3XxxRfXu41ut1txcXEKv+IuOcIiGnaDAIBmZXhKVf6fN5Sbm6vY2NiQvEfF98SxrBNBv4fb7VaPhG71bq+V36NWC2mPzo9+9CM9+uijOnPmTK2vqxjGmj9/viZNmhTKJlVr06ZNys3NVe/evat8OJI0YcIESdK6devqrOv999+X1+vV0KFDTUGOJLlcLo0ePVoej0cbN260pvEAAPhxOhyWPBrCyu9Rq4U0R6d79+5KS0ur12sdDocWLlwYyubU6Msvv5QkXX311dWWV5zftWuXJXW99tpr9aoLAIDWwMrvUas1KtApKyvTu+++qw0bNmjfvn06efKkwsPDFR0drZSUFPXp00cDBw7UTTfdpISEBKvbbLkjR45IkhITE6strzifkZHRZHWVlJSopKTEd+x2u+t8bwAAHI7zj2DrkKp+97hcLrlcriqvt/J71GoNDnQ2b96sKVOm6MCBA75zFWk+DodD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rwxJxuDBg428vDzf+WeffdaQZAwbNqzedd11112GJGP8+PFGWVmZ7/zMmTMNScbkyZMtbHlwrLzv5ORkozX88/zUU08Z8+bNM959910jKyvLcLlcjW53a/qsrbzv1vJZt2b8dFu4tLQ02wc6gYK95//+7/82JBkPPPBAlbLnnnvOkGTMmDEjuEZa4OmnnzYkGWPHjq1StmbNGkOSMWrUqHrX1xI+65KSEiMuLs6QZOzYsaNK+ZVXXmlIMrZt21ZnXcePHzecTqcRERFhnDhxwlRWXFxsdOnSxQgLCzNOnjxpWfsby8r7NozW++XX2C/81vRZV4dAp2UjRwe2U5GHM2HChCplFefWrVvXpG2qTm3tHDlypCIjI/Xhhx+quLi4qZvWaJs2bVJubq569+6tgQMHVilvyM///fffl9fr1dChQ9W1a1dTmcvl0ujRo+XxeLRx40ZrGh8EK++7LWpNnzVaH3J02ojt27fr5z//udxut7p166abb75Zw4YNa+5mWe7cuXM6cuSIJFX7hZOUlKTOnTsrIyNDbre7WTcU/PLLLyVVv0p2RESELr/8cm3btk379u3TlVdeWe96m/Ozru2e/M/v2rXLkrpee+21etUValbet78lS5bo4MGDcrlcuuyyyzRu3Dh16dIluMa2QK3psw6VtvJZNwcCnTZi/fr1Wr9+ve/48ccf17Bhw7Ry5coq/4NqzSqCnIsuuqjG/cQSExN1+vRpZWRk6IorrmjK5vm43W7l5ub62lOdxMREbdu2TRkZGQ0KdJrzs674+dd2T5JqXbMqFHWFWqja+sgjj5iOZ8+erZdeeklTp05tRCtbrtb0WYdKW/msmwNDVzaXkJCghQsX6osvvlBubq5OnDihd999V6mpqfr44481atQoeTye5m6mZfLz8yVJUVFRNb6mIgDKy8trkjZVp6KdUs1tbWg7W8JnXdfPvyH3ZGVdoWZ1W8eMGaM1a9YoIyNDhYWF2r17t+bMmaOSkhJNnz7d8hk/za01fdZWa2ufdXOgR8di48aN09dff92ga5YvX67rr78+JO259dZbdeutt/qOY2NjNXr0aH3nO9/RNddco23btumtt97SxIkTG/0eLe2em0pLu++m+KzRNF588UXT8WWXXaZnn31Wqamp+slPfqJHH31UY8eObabWwUp81qFHoGOxQ4cOKT09vUHXFBYWhqg1NYuJidGsWbM0Y8YM/fWvfw3qy68l3XNMTEyd9RcUFEiSOnToENR7BXPfFe2sOFddrpBV7bTys67Pe0k1//wbck9W1hVqTdXWadOm6bHHHlN6eroOHz5s2nqmNWtNn3VTsetn3RwIdCy2c+fO5m5CvfXt21eSfJuZNlZLuueePXtKOr/CakFBQbV5OkePHpV0fv+yYARz37GxsYqLi1Nubq6OHj2qSy+9tMprrGqnZN1nXZeKn39F2wM15J6srCvUmqqtTqdTvXv31qlTp5SVlWWbL7/W9Fk3Fbt+1s2BHJ02LCcnR5JqTNptjeLj433/aH7xxRdVyjMzM3X69GklJyc364wr6fwKxpK0Y8eOKmVlZWXavXu3IiMj1a9fv6Dfq6k+69ruyf98fZKrrawr1JqyrXb8u21Nn3VTsuNn3RwIdNqw1atXS6p5SmdrNXLkSEnSqlWrqpRVnBs9enSTtqk6tbVz/fr1Ki4u1i233KLIyMig36upPushQ4YoLi5OBw8erLbHqyE//9tuu01Op1OffPKJTp06ZSorKSnRunXrFBYWphEjRljS9mBYed+12bNnj9LT0xUVFaXU1NSg6mpJWtNn3VTs+lk3i+ZesRC1q+8qwf379zf69+9vHD161HT+17/+tZGdnW06V1paaixcuNCQZLRv377KNc0t2Hv23wJi8+bNvvP79u1rFVtAnDx5stYtIFr6Z12xFcK3v/1tIz8/33e+pq0QXnrpJaN///7GL37xiyp1VWwL8IMf/MC0LcCsWbNa3LYAVt33hg0bjI8++qhK/V9++aVxySWXGJKMWbNmheQeglXXCsF2+awDNfa+W/Nn3ZoQ6LRAt99+uzFo0CBj0KBBRlJSkiHJ6NGjh+/c7bffXuUaSYYk49ChQ1XOu1wuY8iQIcadd95pjBgxwujevbshyYiMjDR9wTYnK+/ZMCq3eggPDzf+67/+yxg7dqzRvn17Q5Lx4osvNsEd1c+qVasMp9NpOBwO4zvf+Y4xYcIEIz4+3pBkzJkzp9prWvpnXVRUZAwaNMiQZCQkJBg/+tGPfMddunQxDh48aHr9ggULavwiy87ONnr37m1IMnr37m3ccccdxuWXX25IMvr27WucOXOmSe6pPqy674rzycnJxpgxY4w777zTuP76643w8HBDkjF8+HCjsLCwCe+sZuvXr/f9jQ4aNMhwOByGJNO59evX+15vl8/aqvtuTZ91a0ag0wJV7H1S0yM5ObnKNTV9+c2fP9/43ve+Z/Ts2dNo3769ERkZafTp08e47777jL179zbNDdWDlfdc4d133zWGDh1qxMTEGDExMcbQoUONdevWhfZGGuHTTz81brvtNiM+Pt6Iiooyrr32WmPZsmU1vr41fNaFhYXGvHnzjN69exsRERFGt27djClTphiZmZlVXlvbl59hnO/5mjlzppGUlGREREQYSUlJxqxZs4ycnJzQ3kQjWHHfn332mTF16lTjiiuu8PVAduzY0Rg+fLjxhz/8wSgvL2+iu6lbxf5qtT2WLl3qe71dPmur7rs1fdatmcMwDKOeo1wAAACtCsnIAADAtgh0AACAbRHoAAAA2yLQAQAAtkWgAwAAbItABwAA2BaBDgAAsC0CHQAAYFsEOgAAwLYIdAAAgG0R6AAAANsi0AHQpLZu3ap7771X3/rWtxQZGamkpCTdc889+vrrr5u7aQBsiE09ATQJj8ejhx9+WC+88IKq+2enQ4cOeu+99zRkyJBmaB0AuyLQARByXq9XkyZN0htvvCFJuueee3TXXXcpNjZW69at09NPPy2v16s+ffpo9+7dcrlczdxiAHYR3twNAGB/Tz/9tN544w05HA4tXbpUkydP9pUNHjxYTqdTTz75pA4cOKB3331XP/zhD5uxtQDshB4dACG1e/duXX311SorK9Ps2bP13HPPVXnN2bNn1aVLF3m9Xk2ePFnLli1r+oYCsCWSkQGE1Pz581VWVqb4+HgtXLiw2td07NhRKSkpkqR9+/Y1XeMA2B6BDoCQSU9P19q1ayVJ06ZNU2xsbI2vjY+PlySdPHmyCVoGoK0g0AEQMitWrPDNsJo0aVKtr/V4PJKk8HBSBwFYh0AHQMisXLlSktS7d29deeWVtb42Pz9fkhQdHR3ydgFoO/ivE4CQyMzM1IEDByRJAwcO1O7du2t9/ZkzZyTJl6sDAFYg0AEQEp988onv+apVq7Rq1ap6XdenT59QNQlAG8TQFYCQ2LlzZ6OuGzhwoLUNAdCmEegACIn9+/dLOp9zYxhGrY958+b5rrvpppt8z19//XXdd999uvbaa+VyueRwOFhjB0CDMHQFICQyMjIkST179qzztX/7298kSf369VOPHj185x977DFlZGSoc+fOSkhI8NUJAPVFjw6AkCgsLJQkderUqdbXHTt2TJ9//rkk6Y477jCVvfrqqzp8+LCys7P105/+NDQNBWBr9OgACIny8nJJqnODztdff12GYcjhcOjuu+82ld1yyy0hax+AtoEeHQAh0bVrV0mS2+2u8TXFxcV68cUXJUkTJkxQv379mqRtANoOAh0AIdG3b19J0p49e1RaWlrta5544gkdP35cERERWrRoUVM2D0AbQaADICRGjBgh6Xyuzv/+7/9WKf/Tn/6ktLQ0SdKTTz6pSy65pEnbB6BtIEcHQEiMGTNGvXr10jfffKOHHnpI586d0/e//3253W698cYb+uMf/yhJmjx5sh566KFmbi0AuyLQARASkZGRWrp0qUaOHKn8/HzNnz9f8+fP95U7nU7NmTNHTz/9tBwORzO2FICdMXQFIGRuuukmbd68WRMnTlSPHj3kcrmUkpKiKVOm6PPPP9eSJUvkdPLPEIDQoUcHQEhdfvnlevPNN5u7GQDaKP4rBQAAbMthGIbR3I0AgOq8+uqr+vTTTyVJ//nPf7Rjxw4NGTLEt8P5jTfeqOnTpzdnEwG0cAxdAWixPv30U9/srAqbNm3Spk2bfMcEOgBqQ48OAACwLXJ0AACAbRHoAAAA2yLQAQAAtkWgAwAAbItABwAA2BaBDgAAsC0CHQAAYFsEOgAAwLYIdAAAgG0R6AAAANsi0AEAALb1/wGBgssAKDM9VgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "try:\n",
    "    os.mkdir(folder_name+'/landscape_s2')\n",
    "except:\n",
    "    pass\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "loss_mat = np.loadtxt(folder_name+'s2_activation_in_1x2e+1x6e_lmax_6_10.csv',delimiter = ',')\n",
    "print(loss_mat)\n",
    "vmax = loss_mat.max()\n",
    "vmax = 5\n",
    "# plt.imshow(loss_mat,cmap='RdBu', vmax = vmax, vmin=-vmax, origin='lower', interpolation='bilinear')\n",
    "plt.clf()\n",
    "plt.imshow(loss_mat.T,cmap='RdBu', vmax = vmax, vmin=-vmax, origin=\"lower\",extent=ranges[1]+ranges[0],aspect=1)\n",
    "plt.xlabel('$\\\\theta_1$',fontsize=20)\n",
    "plt.ylabel('$\\\\theta_2$',fontsize=20)\n",
    "plt.xticks(fontsize=15)\n",
    "plt.yticks(fontsize=15)\n",
    "# plt.colorbar(fontsize=15)\n",
    "cbar = plt.colorbar()\n",
    "cbar.ax.tick_params(labelsize=15)\n",
    "plt.savefig(folder_name+f'landscape_s2/2+6_10',bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 8.69226646  8.32514095  7.97408533 ... 10.57361889 10.95709705\n",
      "  11.35530758]\n",
      " [ 8.29612637  7.93735123  7.59445286 ... 10.21906185 10.59520531\n",
      "  10.98591995]\n",
      " [ 7.91701269  7.56638575  7.23145056 ...  9.87945271 10.24843407\n",
      "  10.63182354]\n",
      " ...\n",
      " [10.4480629  10.1180706   9.80242634 ... 10.72456932 11.05235577\n",
      "  11.39387226]\n",
      " [10.8490181  10.51177406 10.18901634 ... 11.08913517 11.42358685\n",
      "  11.77193832]\n",
      " [11.26512241 10.92045116 10.59042168 ... 11.46922398 11.81052399\n",
      "  12.16586304]]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7cb276ba06a0>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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tm/frvLycuXk5KikpORbnTMYDCoYDPpcKb4J33dLbPTJ0FP5Hmr33nuvZs2a5fXGhg4dqo8++khVVVUqKSlRdna2JCkSiah///7e5yKRiC677DK/ywEAJBDfe2pffPGFkpJiT5ucnKy2tjZJUn5+vrKzs1VdXe29H41GVVtbq8LCQr/LAQAkEN9natddd53mzp2rvLw8DR48WNu2bdMTTzyhW265RZIUCARUXl6uRx55RAMHDvQu6c/JydGkSZP8Lged4GyWpli6jB+WFJEIfA+1J598UrNnz9add96p/fv3KycnR7/+9a81Z84c75iZM2fq0KFDmjZtmpqamjR27FitXbuW76gBAM5KwJ14q48eIhqNKhQKKWVosQLJqfEuBx3ATC1+mKmhO3GtR/TVjmVqbm5WRkaGb+fl3o8AADN49Ay6FP24jmOGBbQfMzUAgBmEGgDADEINAGAGPTX0GPSWAJwJMzUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzCDUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzCDUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzCDUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzCDUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzCDUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzCDUAgBmEGgDADEINAGAGoQYAMINQAwCYQagBAMwg1AAAZhBqAAAzOhxqb775pq677jrl5OQoEAho9erVMe875zRnzhz1799f6enpKioq0p49e2KO+fzzz1VcXKyMjAxlZmbq1ltv1cGDB8/qDwIAQIdD7dChQ7r00ku1cOHC077/+OOPa8GCBVq0aJFqa2t17rnnavz48Tp8+LB3THFxsd59912tW7dOa9as0Ztvvqlp06Z9+z8FAACSAs45960/HAho1apVmjRpkqRjs7ScnBzdc889+s1vfiNJam5uVjgc1pIlSzRlyhS99957uvjii7VlyxaNGDFCkrR27Vpde+21+te//qWcnJxTfk5LS4taWlq819FoVLm5uUoZWqxAcuq3LR8AECeu9Yi+2rFMzc3NysjI8O28vvbU9u7dq8bGRhUVFXn7QqGQRo0apZqaGklSTU2NMjMzvUCTpKKiIiUlJam2tva0562qqlIoFPK23NxcP8sGABiR4ufJGhsbJUnhcDhmfzgc9t5rbGxUv379YotISVHfvn29Y05WWVmpiooK73Vzc7Py8vLkWo/6WT4AoIsc//19FouFp+VrqHWWYDCoYDDovY5Go5Kk1l0vxqskAIAPDhw4oFAo5Nv5fA217OxsSVIkElH//v29/ZFIRJdddpl3zP79+2M+99VXX+nzzz/3Pn8mOTk5amhokHNOeXl5amho8HVN1pLj/UfG6OsxRmfGGLUP43Rmx8do3759CgQCp72O4mz4Gmr5+fnKzs5WdXW1F2LRaFS1tbW64447JEmFhYVqampSXV2dhg8fLklav3692traNGrUqHb9nKSkJF1wwQXejC0jI4O/QGfAGJ0ZY3RmjFH7ME5nFgqFOmWMOhxqBw8e1AcffOC93rt3r7Zv366+ffsqLy9P5eXleuSRRzRw4EDl5+dr9uzZysnJ8a6QHDRokK6++mrddtttWrRokY4ePaqysjJNmTLF98QGACSWDofa1q1b9eMf/9h7ffwCjpKSEi1ZskQzZ87UoUOHNG3aNDU1NWns2LFau3at0tLSvM8sW7ZMZWVlGjdunJKSkjR58mQtWLDAhz8OACCRdTjUfvSjH33j1SqBQEAPPfSQHnrooa89pm/fvlq+fHlHf/QpgsGgfve738VcRIJYjNGZMUZnxhi1D+N0Zp09Rmf15WsAALoTbmgMADCDUAMAmEGoAQDMINQAAGYQagAAM3psqC1cuFADBgxQWlqaRo0apc2bN8e7pLipqqrSFVdcoT59+qhfv36aNGmS6uvrY445fPiwSktLlZWVpd69e2vy5MmKRCJxqjj+5s2bp0AgoPLycm8fY3TMxx9/rJtuuklZWVlKT0/X0KFDtXXrVu/99jwI2LLW1lbNnj1b+fn5Sk9P10UXXaSHH3445qtOiTZG3erh0a4HWrFihUtNTXV//vOf3bvvvutuu+02l5mZ6SKRSLxLi4vx48e7xYsXu507d7rt27e7a6+91uXl5bmDBw96x9x+++0uNzfXVVdXu61bt7orr7zSjR49Oo5Vx8/mzZvdgAED3CWXXOKmT5/u7WeMnPv888/dhRde6G6++WZXW1vrPvzwQ/f666+7Dz74wDtm3rx5LhQKudWrV7t33nnH/fSnP3X5+fnuyy+/jGPlXWfu3LkuKyvLrVmzxu3du9etXLnS9e7d2/3xj3/0jkm0Mfrb3/7m7r//fvfSSy85SW7VqlUx77dnPK6++mp36aWXuk2bNrl//OMf7vvf/7678cYbO1xLjwy1kSNHutLSUu91a2ury8nJcVVVVXGsqvvYv3+/k+Q2bNjgnHOuqanJ9erVy61cudI75r333nOSXE1NTbzKjIsDBw64gQMHunXr1rkf/vCHXqgxRsfcd999buzYsV/7fltbm8vOzna///3vvX1NTU0uGAy6F154oStKjLsJEya4W265JWbf9ddf74qLi51zjNHJodae8di1a5eT5LZs2eId89prr7lAIOA+/vjjDv38Hrf8eOTIEdXV1cU8iDQpKUlFRUXeg0gTXXNzs6Rjd26RpLq6Oh09ejRmzAoKCpSXl5dwY1ZaWqoJEybEjIXEGB33yiuvaMSIEbrhhhvUr18/DRs2TM8++6z3fnseBGzd6NGjVV1drd27d0uS3nnnHW3cuFHXXHONJMboZJ318Oiv0yOep3aizz77TK2trad9EOn7778fp6q6j7a2NpWXl2vMmDEaMmSIpGMPZk1NTVVmZmbMsSc+vDURrFixQm+//ba2bNlyynuM0TEffvihnn76aVVUVOi3v/2ttmzZorvvvlupqakqKSlp14OArZs1a5ai0agKCgqUnJys1tZWzZ07V8XFxZLa97DkRNJZD4/+Oj0u1PDNSktLtXPnTm3cuDHepXQrDQ0Nmj59utatWxdzc23Eamtr04gRI/Too49KkoYNG6adO3dq0aJFKikpiXN13cOLL76oZcuWafny5Ro8eLC2b9+u8vJy5eTkMEbdQI9bfjz//POVnJx8ylVpkUik3Q8ZtaqsrExr1qzRG2+8oQsuuMDbn52drSNHjqipqSnm+EQas7q6Ou3fv1+XX365UlJSlJKSog0bNmjBggVKSUlROBxO+DGSpP79++viiy+O2Tdo0CDt27dPUuyDgE+USON07733atasWZoyZYqGDh2qX/7yl5oxY4aqqqokMUYna894+PHw6ON6XKilpqZq+PDhqq6u9va1tbWpurpahYWFcawsfpxzKisr06pVq7R+/Xrl5+fHvD98+HD16tUrZszq6+u1b9++hBmzcePGaceOHdq+fbu3jRgxQsXFxd4/J/oYSdKYMWNO+TrI7t27deGFF0qKfRDwcccfBJwo4/TFF18oKSn2V2dycrLa2tokMUYna894nPjw6OM6+vBoz1ld5hInK1ascMFg0C1ZssTt2rXLTZs2zWVmZrrGxsZ4lxYXd9xxhwuFQu7vf/+7+/TTT73tiy++8I65/fbbXV5enlu/fr3bunWrKywsdIWFhXGsOv5OvPrROcbIuWNfd0hJSXFz5851e/bsccuWLXPnnHOO+8tf/uIdM2/ePJeZmelefvll989//tNNnDjR9OXqJyspKXHf/e53vUv6X3rpJXf++ee7mTNnesck2hgdOHDAbdu2zW3bts1Jck888YTbtm2b++ijj5xz7RuPq6++2g0bNszV1ta6jRs3uoEDBybOJf3OOffkk0+6vLw8l5qa6kaOHOk2bdoU75LiRtJpt8WLF3vHfPnll+7OO+905513njvnnHPcz372M/fpp5/Gr+hu4ORQY4yOefXVV92QIUNcMBh0BQUF7plnnol5v62tzc2ePduFw2EXDAbduHHjXH19fZyq7XrRaNRNnz7d5eXlubS0NPe9733P3X///a6lpcU7JtHG6I033jjt76CSkhLnXPvG4z//+Y+78cYbXe/evV1GRoabOnWqO3DgQIdr4XlqAAAzelxPDQCAr0OoAQDMINQAAGYQagAAMwg1AIAZhBoAwAxCDQBgBqEGADCDUAMAmEGoAQDMINQAAGb8f+zDXndDlfJeAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "loss_mat = np.loadtxt(folder_name+'s2_activation_in_5x2e+5x1o_lmax_2_5.csv',delimiter = ',')\n",
    "print(loss_mat)\n",
    "vmax = loss_mat.max()\n",
    "vmax = 2.4\n",
    "loss_mat = np.where(loss_mat<vmax, 0, 1)\n",
    "vmax = 1\n",
    "plt.imshow(loss_mat,cmap='RdBu', vmax = vmax, vmin=-vmax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x76167f3d4be0>"
      ]
     },
     "execution_count": 151,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjQAAAERCAYAAABsAj0bAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABq5ElEQVR4nO2df5AmRX3/3zPP/riDu93zQHbv4E5OJUFEwQCeJ8aYcOVpLEuUGDH3rUIkEvUwwvkDLt8AwainJKUWihAtC0wFf1EJGPmWWOTQI+hx4IFRRE8wRBDYRSW3ez+4/THT3z9meqa7p7un59fzPLP7eV1t7fPMdH+659ndnve9+9M9HmOMgSAIgiAIosX4ve4AQRAEQRBEVUjQEARBEATRekjQEARBEATRekjQEARBEATRekjQEARBEATRekjQEARBEATRekjQEARBEATRekjQEARBEATRekjQEARBEATRekjQEARBEATRenoqaK699locf/zxWLJkCdavX4977723l90hCKIF0LhBEISOngmar3/969i6dSuuvPJK3H///TjllFOwadMmPP30073qEkEQfQ6NGwRBmPB69XDK9evX44wzzsDnPvc5AEAYhlizZg3e97734bLLLrPWDcMQTz75JJYvXw7P87rRXYIgFBhj2L9/P1avXg3f787/jaqMG7w8jR0E0TuaHDcGao3myOzsLPbs2YNt27Ylx3zfx8aNG7Fr165M+ZmZGczMzCTvn3jiCZx00kld6StBEHYef/xxHHfccY23U3TcAGjsIIh+pYlxoyeC5re//S2CIMDY2Jh0fGxsDD//+c8z5bdv346rrroqc3wzjsUQ5TUTRE+YRYib8ASWL1/elfaKjhuAeez4n//8d4yMjACeD+b5gB8NhczvAJ4P+F50Lj4enffBvOg4PB+s00nPeT4YgJAh/c4YQgAsfp0eB0LGEMTeeIDoRRCm5aIyAANL6jAAQcjiugwsBAIh1lwYAgDmwyheGEblQoboe5i+ZozFseJzYAjCKFYYnwviOLPzLInLY0bnw6TM3HwYX0N0bj5kaV9DJpyD8l7ta/SehQwsbo9PIgRxGyw+xnjd+IMM48+E14vOhUn8qB7SNubFcyFYGMRf0esoZiAfD8RyURmEARgLEIa8fwFYEEjlGD/HsscWGyyYQ/DQNxoZN3oiaIqybds2bN26NXk/PT2NNWvWYAg+CRqC6DH9PHVjGjtGlh2JkeXLACASLVyk+LFI6QxkzunKMPUc9KImuYlzERMqAgcsFTGCEMoTNWGIRAgETBYG8vusqAlVUcNSUQMAs7EYWBKyjFCRRUmYHAuUsmkZtU72ffKapYJEFDYDgthJBYpYNj4niJ1EBDEm1QOAINCIJ0HMiIIkVERMJG7kY+H8bFIvFMtmxI2uzuITN02MGz0RNEcffTQ6nQ4mJyel45OTkxgfH8+UHx4exvDwcLe6RxBEH1J03AByxg4WAp4Pj4XgiYQei12YMAR8+Rw8X6qHMITnIz0PwPN8+F4kXHwPCOHBZ9Gb6H4cCRn4HoKQoeMBAYAOPASI34dRndCLVm2EzIPvRSIHDBjwPczz+5/PgJDfGBg6ccBOfA2djgefeQhDFhf1EDAGPxTiZt7zq4muN/BTAdLRihVPcHMC4bgsXGYUF8fldeCnDk4iPDwGv5MVKcyPBJ4PLxE3nu/FPzLZ8YnOiYKGC7kOWDiQETi+IkBCjfviDwwlxzrICiIACOdS0cPCQKoDqc7iEzh10BNBMzQ0hNNOOw07duzA2WefDSBK1tuxYwcuuuiiXnSJIIg+p85xw+NrIbg44bAQHnwwD5Go6cSixvOjskB0HvENJ66uihpPei8KFC8SEB4SkRNLHDAW33w9BngePAZJ5ERaJSrb8T104MHnN3gGhGEkVgY7kaAahI+AMQCJugLA4Hse5hDJFZOwSS4OgB966HgsI2wASK6NiOra8D7rnBvxtVHceGZxIwoTUdwAXvw+/kw7SNwb67SU5yH0GXwALPTBwk4ibrzYnfM1YiUzvSQ4M1wQsVjAJIIoyLpBOoeIBI4bPZty2rp1K8477zycfvrpePnLX47PfOYzOHjwIM4///xedYkgiD6n1nGDixn1u+kcx/PhMRaJHhYCEERPjO9F00WxQRA5NojcGBHPAzyWvgaQiCEfQKK74oOibGAsEgkwuDUQzwnuDQ8eMnALKG01eQ8M+rEgEuJ2Op4kbICoD9x9GRrw4+M+gDARMWLZTpgVOWo5UeCI54Iw/iD9SKx4whQSFzeiWPG81LkBAC/0wDyG0I/qAoDPYwl1I5cnFTdefE2puOkkwsNXhEgiVvyoPJCddvIE0WITN+p7Ejd2eiZo3va2t+E3v/kNrrjiCkxMTODUU0/F7bffnkn4IwiC4NQ1biQJnTFGFybSK/AgiAkubrjKSO+Wabx46ilMxEosCMDgeen0UxQmFSHxbTjKn/Gim3nIonohoqmpSCgxwIsSiU1uTeIKxVNO3L0BEE9LITMNBXiY89IkW+7YDPppng13bNBJ82xUQRK5Nr4iUkKrC5PWy5mGUt8zjXMTctdLeR+meTfJjzGU827UqSk5NpLPRpyaiurFTs+8PK0UZsRJmOvMuObgqHk9i52e7UNThenpaYyOjuJ8rKGkYILoEbMIcQMex9TUVLRiqAXwseOZH34HIytGo4N8lZKa4MtXNPm+/jxPDubHfKFMvDqKJwGrScJ8tQ0/DmQTh8skCwPpaidTwnBUJr1R65KGo37Iq5SSMkLyMI+nExu2BGKxjnTtBYWNdNyQTBx9ltmkYJuwkYSMQdjoVmRF74XVTooACSSxkxU2aj2bsFHLinH7GRbMYv4nNzUybrRilRNBEETdRNNGnuDKKLkwJpcmdnI8Fv1nKpl6EvNpwnnA89ERVj6JScI8nyYiblVJHA4RuytelM8BL7Z8vOglY17UpziR1/O9OFLUrzmEUc6O4tZExKJHcHAGEU0nceFic2x8L85RicUNd2zSJd0MQ8gu4wb8jMDhryGUF+sCkPJ0bKum8lZLARaRIjk9qcAR66sCSaovuTcMgJxcDAC+4t5E9c0rqMSy2jqO01Q87kKHBA1BEEQRbLk3FuI8YEnUMJYVUnLZVNQwhni6KmuqCzm/aV4Kn8pScmsChvRcfIznpHA6XrTEKhTjANmcm0x8JA/U4fkvdvjnVs/Nll87EE3PzXLhhljwhZE4DMO0aR+IVp3FeUC+Hzljnu9FOTchQ+gjfs+FDeB1op8Fr8+FjR96QMdLxFDH9xDMx20NDEX9mZ+F50d5OJ34u+jGeHH+DRcsvGySZAwAfgehLwgYwcFRyydlWuDgVIEEDUEQiw9+4+DJvYBBqHQS9yWTSxOTu+oJgB8LnlynxgM85iVTUqKoiYqxZAUUA0ucmlDIq0ndGuHm3kEmtwZAssSbHxuEh7l4zkvMrwGguDOpYwN4CJMcmyiGOCXlkjPDnRsx30ZXR3VtdMfF10OZPB59zg0A+B1f67wA5ukp/jrPvel0+M8/bnOgI5zPTlHx97r8GwCZPXBMDo6trL7NdosdEjQEQSxKWBDA63TSJF9PWaKdrGYquAFYvNxbigtZ5OQ5NZ6yxJvnznii9vGy+9Xwk14cjK+CClnstAhuSsgYfO6gCNMl8jHBjdG6M/yaza5Np5OKInVVE8D31ZFXM3X8Tnw+lF0XJflYRFdOV6fDhZ6wWoo7NwB3w6L+JEIljK4jWjEVXWsHWfcGiMWOLgaivHG+cip6z8D4zyNeIi6KDc8kUhQHRxUmUj2Di6Or16ZcHB0kaAiCICwYXRyxjOjSxMIIgLxySlj5lAoXwx414KaQl3VqAMCPk4UhixreGxb3xoPerZGcmXjjPx98A76o3BxvnzsYgmMThtF+NuKeNR0gdmzEvW3i7vKVUUCyn4wkMgzOTRDf7G35NuqeOLoy1uRiIf8nDPn+M9lN/ABhBZTi3PBfjaSMZtUUL6+uuuJ1dRv7Refkzf1c8m94ObG8zvkxlTXV63eRQ4KGIAhCQF3CnQiYEOnuwZr9atSpJ/jZvW1EUSMu6/YBSdQwCDk0iqgB5GRhUdQkscSpIUByawDEm+9FLopJ2HCFNMc/mDC71FvcswZAskEfBMETsEgUhCxaZh4dZ9KeNjzXRt17Rt2RmL+OvmeXgZuFkXnaSxI9nfi9ZhM/AJldinmZ6MfLl4TLuxWrG/qhA+v0FPM8pY4HoJOZngLMe+CIZXRJxqo4CtU6hhVVYp1+nKYiQUMQBAFkxIct0VcralQ0U08cSdTwqRrGpKkm0/QTwDfqy4oaAJkpKPGxCR1lignxjZuroahfDLJ6Eo4ldWPBoggbIBZIGWETh4pv1J04zwaQp6QAeVqKb8LHp6UAUZT46Pj2fBsAhrqKQyRMUUll4h2K0ykjeVop+rHKTowXHzdt6KfG4QKHb+wHxO9DAB0vcW/SnYsZwjBeYcc37uPJwIoLw19jYDBxWHRLxTMCR5mmEs/Z3ZzeihsSNARBLDrE/4l6nXjbOtOKJdF94atjdA4OLFNPQjgvXsodlU91AhO0hW36CYh0UshSp6YjJgfHCTlenJuTuDV8uospm/ExBvgsdmai9nwv6kcQpbEkLk7Sv3ipt+jYAHBIIFaEVnzNPJFYNy3Fv5vcF11CscmF4a/VZeC6MlZXh+mmjdIN+cT3UhlliioRMMoUFQAEQSi9l6a6lCXiXNjoXBxVdKiPaohe25ON+WtdsrFYztSm2EaTkKAhCILQYXNpXNwcYZpKPa7uJAzIS7LznBpAWdYN8ZgaJxIRDMK0VRxUenQCkF2CzR+hAABhvD8Nzzj2uaiR0pmjMsnFmRKIIZ0LGUOHz7uJlNo3NfKsbKhTWupx2+uow6mzFCr1E6em46WPU1DqMcbiZfHRr0kHsYMjOlXxxasJxkAqbpIl4oYkYyBycdLl4J00YdjvaMWN1+kkYoUv/+Zl1GRj20oqNW4ietTnf9QICRqCIBYn8aCewSZWbLk0MYlLw8+pT+XmOTeKqJGezg03p4brkQ68eDO+dBM+j8WOQHTPSxycjodkMz7+9G6eNBxNI7FMfk3SH8ZvlkzO25GOx30VXBvxoZeiazOYJCtHfeOPWOCb9knOTQeZnYn5Bnz8WDq15CfH0vL2qams8+Pm3mSOKcvCo18P4ZjBwRE39ouOyQ5OUk6sxzTxtS7OgFQmOh824uJEbZhXVoWzg4i35akdEjQEQRAlUR9KKaHkzqhLwgHJvwCQdViiYw5ODRdFybJjXjZO+IXo1ohtpVNdkiPBl3gDQCgsu+bTULxMerFy0PhY0pZkRxlcGOE8d4J0zk3AXDbsS0mTjuvbxE+3/Dx5LeQeqRsWJkvDNQ6OFy8D54Ye39yPhcLqMWWDPx5L3SQw5GoVkFwcFgpOj9+Jl4orK/ZKujji62SzQAibAsa5OAibkjMkaAiCICJEoaFxXzz46Z40POFXqactK049Kcu9Ebs0gN6pSVcu6Z2aqF52BVSUQ5Mu7e5A79aouTXcrQGgya+JjxucmYD3wxOSlg2OTRSfX3dx5waIVkyFzO7ciK4LP2/bxA8wOzC6JeG6eq7uDZA6LtIxywoqfkxcIs4/M1s8fs60XJyFA3I8g4ujrqgSj/PygD6/hr8OO+5itCgkaAiCIDiOjzHIlNWsZPIY0089KVNYYpIwRxI1ybHsVFPixCBNdQmEYKIrI7o1SQx1JRQAsHR6zJceexCt2lGdmYBxB0bJsRE7ygMnvYU1p8btPNPm3Ohck0wODMRybs4NL69uBKgrI7apW0GVrOwSNvZL82+QPFYhdVOEcvEGfwDkVVQh0+TTpC6O6AjxeJ6fbvYHIFs3dnGANBcncWkMLg6AZOM/QCNugmQjgNohQUMQBKFBN52UESmGVVFRYb3Y8Vgo59NAFiShICjEjfcAQ1Kw4NQA8gooAOnDLSG4NfFarFQzeJFzo2zIByCzKV/ANCui4n1lTI4NoHNz4pye+ObO+2JzbtTz6TleN6qjPiwTgDbnBsiuluLndM6NKY5pQz9TfekY3/tG496I39X8G21Zw0Z//PNzjZnd8A9goQ/xgZvRseyKKnVVlHrc9f8LZSBBQxAEYcLBsTHuScOXe+umnsT4SSBxr980NybrrGRFDaAXO0C6tDsqI+bbCGIjPu5B2ZAPgLopX4LOIRGcGXGXYdO5KCdH3qtGFDjpjsRiu/F34VzHEzfwk/vF46mOie3xC9F3/jqaljLV5/vlAKm4UV0Z03ftMWXpuuseOLys34mnnjQuDuJzfOM+3X441o0Dw8jF8ZM2/fh7Jy43KE1T+WE2YbjJZU4kaAiCIFywiJvEdXH876euPL8FJ0JGeA2oAiQSL5kyqthh8bRTvLQ7mYLieTLKZnyAxhkBhNVQkIRNR9hxWMZN2CTXIogb6dNQxAvvXyRe4qRhIF2hFYsbnXOT7E6sETcAckSJl5yLvuvzblRxA6j5O+4uTvJds3txKij0YgSQRQ4vw3geUsi0uxmLj31wETjRd7luJHLMD98cCJegKUjQEARBFMW0xww/BwhTTMI0lVpPkyQMqCJFFiDpiiVF1MQh1GRhAOnSbpadguJxkUxhxedEYcP7Iwgb/pBHvtQ7ioMkzyaZctJMRyVtAoLQEPoepvEAOaHYR7FpqfR8nFgtTktBv4mfmlQM6BOL5Xr6ZeGmaS61TSdxo/vuMFUF5IiSnIRjW0x+XHVyeN3o+VQMfLpqvoZVZiZI0BAEQeRRJFnYJYYuQTguo+4kzKBxamAQNSzdIdhcX56CApAsFTdNQ0mb8gGJycJdjGSJtbLcW7m4OLCgsnTntWXMzo10PKlvPq+blpLqCOgSf82kn6ZteiovSVn8Dsjuj/Z7LCzVRONMryzJxtKScR9xwnDk4Iib/nlxvXSTP3PCMRAlHANR0jGv3xloLomGBA1BEERZoicR6pOE1c32xFwaXYIw0jiSQIEgSgxODZB1ZNRk4czSbkAWNp7w6ARAWOId9SiazkkTh6NrMTg2jGUSiHWujbi8uyO6MPw6NAnF0Xt+3n0puHp+MP4xBYxJm/gN+tAuB+ffh+JLN7sudvfG9l0fr4J7I8ZlumXbbo6LeM70dPG8uPzYXKjZzLImSNAQBEHYcHRnrJvs6WKFYXbKSpmuUkWNiG6Df1n8RGKECwxpJRU/h/SxCUkMT3BrkDo+aV/0icOA3rGJHoWgTkXx8/xiUsEiC5u0HF8ezsuIwqescxOJNKGMyV0qaCpk3ZROLC700y15TpCr42N1gkL94xrEy0v22PNhdHHkRzdELk0HwrJxwcnRukPk0BAEQdSH53egfeyBS13GUreFk7MnTaYeL+8w9aQmCQOKUyMkCgMGR0ZzjufF8I34QrDUkeEJtoj/Zx7H4ue1icNAxrEBAJ+LByHPBkCyUZ/OkdHn0zCpDHdt5DI8jt25STfqQ6FHMHBXR3RwVDfEnjOTfSRD9D2VGK6ui8tGf4W+F8jFUY+7uDj8c/PIoSEIgugDiubSmPapyYgdYdWT8mgEUdTo0Dk1yTlNXo1K4sAgXQllKsvLW1dEAYljw+Dm2gDipnxpgGTTPik4tGVEdycv5ybjzGjKaDfy41iWhZchdXAA80+Tl5XdF/2S8xLfDbk4trwZ3UMzgWiXagBgPsvm49BOwQRBEC2DCxODY2MVO0IdbWKv4NRkk3k1bgzMeTX8HCDn1hjdGqmtuL5B2HiA8EgFfZ4NkN2sT51Ssq+Ekvsk5+Xw64rjKM4N4J53w90buQyPkTo/1fJvGHQrqKLX7hv9ZWPq2y2UgyM4OWVcHP6ezdOUE0EQRO14HcH+rmEL07w8mmTaSZNLo60bl9Pl0CQxjTkvae5MIojiOtrpKWZ2a8RN/gDN9E8cVxUFgD7PRj4hYHBBhA9EKKuPoyYd6zohbdZncGbSzfrSvX14GeOGfkK/U9FmdnBc3BYAUh6ObqM/Xkb8rtsPx1TWSciI3zV74wDy5n/RRxEfFzYAZIM05UQQBNE8OjFie5p2XdNPoqjhbYpuTSxqUsci+i4KDWdRw/TnbW4NIN/3XYVN1Ef9dJT0xOyQl03FQ0dwORDKIkMKpGzQp3zAcSx5RZV4TvcIhsT9EYSLdC1M3tBPvGa5DM8j4v2PRYGw940qMlQhAujyZbxMGZODw1+77ocj1nH+3lHqxC6OdgPAOXJoCIIg6kNICM4k+NaBdVdhTVKxqb6DaNIlCgPyFJSrqJHjxe8NwsbeplAmZzoKkMUNn5YSsYkbl2mpvKXg4iMYojJCXo/QD9P0FG9fV0a6dq7B1CkqILPBn/i6ozk2nzlWbqpKd67O6apM0vE8OTQEQRC1Ik039YIST/bOiBKYp6JEdE4NoJ+CMgofTdKwziECUtHAp6ui2KqDEcWOCgqXiuLTUq4Jxbpy+qkr2aFJ2+bt8oMaYRqX4Q6OrpzLFBWgf1p4kc35xA6Znkllq8+nwHSUSToGAKbbXbsmSNAQBEFohIU2F6Zono3qtHBhIubScOJHIiS5NKa60IsaF6cGSG+kZdwa/vgEvsw7iss/GyFplt+spbydOBbjDku0SV9SLn2ZCKbk+VGQE4r5dYib9wHpqimdcxP1KxUWpqRiU7noeHxMcNjUpeG65GHej0HJfUqXiKdx5GXigD7RGLC7J+JrU8KxXM992bg5ttvUlTdHDg1BEETvqCFh2AlbgrCGok5NVCd/CgrQuzVSHAfHJiqX5vXw91H8aJM+AMmjFZLjgsMj+imiq+Ar03Z8KXgUJOvciBv56Zd6w1gOgHZZuJhfwy8sekI4j6ZxkOT5uGwcTl6CdMlfSb0zk79s3OboqO91jpJYpilI0BAEsejw4hwa5nmpWBG+M/WYPkiDPYxRl3HzpuO2yzg1qmgBsk4MoF8JFTUu5IIo+TVRvaSTSTndku/0sQpR0KSsxbkBAM/nIojH1js3Uf/i68rsdwOpL9K1SI6M4LDkluUv0mvhjsqAlIxsdnAASJv8Rcfljf542UEulpTHNYjtRufdnZbomG8s5+Lk6I6JTk6HcmgIgiDqpZFkYG1D5R5smZl6cqkDs1OjroDSltE4MbrYuvwaAEbHBtDk2UB2YqSyBucGQv9V5wZIVx0lK6USVyQWU4aN/HSPYUg6Waqs+KnxssKHacvBKVw2mQfLj2XAdVNAm5PjEmPA9xCQQ0MQBNEgLo5MjLMQUoVI3solZQm3S2zdlFB2KikWB8qybsCcVwNkE4bzygFC7okuxwapaxSVzbofXCgUdW7UnJtO4l6k01O6jfwAOe8G4nVpcm9MD9EUryEv/yYqm8ZIzkv6wNXFScuKj3PguThR3KgtVxcnb+VTekz/GIfotXkJOYbIoSEIgqifIs5JzVNM2k32OKqosYghF1EDZPeqEVHzagBILgygTxrOtiGUFXJs0vrx5WmEFoR+GeuIgki3eR/vVIxur5sMeQ6HEFS/WZ++bNxJQ/ui0IIQW1Q9mjKi8LJs+CeW5TsUiPviBCFkJ0vY/C86n93cT9wfZyA+pnvkApA6OeLKKl53kB5OSRAEUR+m3JnonP54YcrUUwSLlBxsWPUE6AUMR5/Qq5vyyRcruqRh3gZHFEGSW6HLs4HZtYnqyH2Wzmn2eQHKi5uOsopI9yiGqC3ZveECJ33cgiZXRykv7pOTJiCL01oQyotPrVbKKBv+8baAdPpN/bxkkZNevy982OoGgDye+B2wbwKYHpdXVrHZ5hya2qXS9u3bccYZZ2D58uU45phjcPbZZ2Pv3r1SmcOHD2PLli046qijsGzZMpxzzjmYnJysuysEQbSEfhk3nJKBm4AZ/7sPz3JOV4/fRD0gIzg8z0t3+RXb4ALE85KbIK/ve2J9e1nYysNLbuT8uOel5X0v7R//8uN++kqdTD3hX8fzkuMdXy7P+znge+jEX4MdP7mWQd9Hx/OSr8GOB9+PzLLBjnDcF+tEXx0Pcfnoa7DjS+V5HbU8rzPY8ZM6vIzvIXk9KJTxfQ8DnfQrjZm2xcumX1FbUjxe1hfOi1/C+aFO9LV0sIOhAR9DAz6WDnWk70MDPo4Y6mB4wJe+jhDOD3Wa+9uqPfLOnTuxZcsW3HPPPbjjjjswNzeH1772tTh48GBS5pJLLsG3vvUt3Hzzzdi5cyeefPJJvOUtb6m7KwRBtISejRt5Aibj3timJWomLCZkxJ7p8i61x5DeBMRLE/9nnytUlLJFhE22XbmfqgBT+5v2QakX/zP1w/PkvnJx0/G9RKjw6xIFDhc3vi8f7wh1Oh6SL1Hg+L6+vFpHLC+KIlGoDaqx4vIDHUsZLsA6viDm9OUT8dXx0PEjYRiVzQq/oTje0EAal7/mIqbjexge8DEQH2sKjzHF46uZ3/zmNzjmmGOwc+dOvPrVr8bU1BSe+9zn4itf+Qr+7M/+DADw85//HC960Yuwa9cuvOIVr8iNOT09jdHRUZyPNRiqX5MRBOHALELcgMcxNTWFkZGRWmM3MW4A6djxzI/uTPssiBnjdJMqaPhxMc/FNGVliaeNKdbzlZh5cSGvchKnFHTHxeFflEhyKocwXWCKbSjvWidqX6mnnlfem/qe7Y9yTmjH1h/xrbp6R7zGQJ0mEzqTOSfVE+tY4hnqiPXEOur1SudCfTm5fnaaSSxvLpvtsy7x+PDB/fi/r39ZI+NG4zk0U1NTAICVK1cCAPbs2YO5uTls3LgxKXPiiSdi7dq1xoFpZmYGMzMzyfvp6emGe00QRC+pY9wAio0dlXJnGt6vRptLI1J2abiX3QAvOi4uvU6TR3muTnQ8m1+jls+rAwj14iTitG/K+SQfJe17dN49qTjqT1zPsJkfr8ffMsjLwvk1RvXknBkg1bjqEvFsvbQ9U/Kw/KgG3ht+DplHO6hl+BUnsdRkJ10ZyTKDprzBpXTcCLC1G+uFYYiLL74YZ555Jk4++WQAwMTEBIaGhrBixQqp7NjYGCYmJrRxtm/fjquuuqrJrhIE0SfUNW4AlrHDNRHY5qRollbXkoNT4hlPIuKNWLfyCXBbbaQmDEfls0nDaZy0D+pSb9t0mHgvTh6tIJ735AOZ5GAhuriBHwCIj16QN/KLTopLwqNrEj4sfl1iDaHzDOnycADwJTcjXSIOyPd6AAiFG75p+XdUT/6wXDb9G4SndX8GBdESBfAyLs2AkKwckZaRl4VD2dyPZcqKbYll5xt8llOj8zVbtmzBgw8+iK997WuV4mzbtg1TU1PJ1+OPP15TDwmC6DfqGjeAnLGjgOiw5s40mUAszF9Yk4MBY2KxnFvihumKdLk1vA0590WuY8qzUfvH66riSM25cc274dei5t245N6YrivRtcp18PwR8ZrVPJwkrp/qYTHPRawbnUu/onpe4rKY8nHUemJOjtoX8fp0OTm+75nLiDlASf6RnKytS6JuMCe4OYfmoosuwm233Ya77roLxx13XHJ8fHwcs7Oz2Ldvn/S/rcnJSYyPj2tjDQ8PY3h4uKmuEgTRJ9Q5bgBuY0ehqSbLudyHWdYpfERnxvDaONWDfKcGSEWA+L9/k1sD2B0bsZ6urm4WIrNXjupW5Dg34qMXgKx7I16Xzr3h18HPA3YHR9zcLyrL201dDPUzEF0ccbM/QHZxALMjE50T6ymfS0EnJ6ojHFfEvO1xDqozA2Q3Axxuk0PDGMNFF12EW265BXfeeSfWrVsnnT/ttNMwODiIHTt2JMf27t2Lxx57DBs2bKi7OwRBtICujxsue87YVjY1OCjXiUk02JwaT3e9yTkxnlwuz7Ep4to4xYidG91ScHOM/FVT1vrCP/G878n1PS+9Jl5dXEklfgbpSid15ZLZycnW1Tsy6soq0SlxXV01qDgvJidHXGFlapOvsGqK2h2aLVu24Ctf+Qq++c1vYvny5cn89ujoKJYuXYrR0VFccMEF2Lp1K1auXImRkRG8733vw4YNG5xXKhAEsbDoxbhhzXfRiRnLyiZdXeMxXV5OGRxcGhUXpwbIJgsDpoTb1K3hMaGJy2MXcW14HFvOTRJHqVkk7waw594AOgdH3tgPAHylTfXxDLyvQNbFifogPwtJ3sk3OpYkFwuPbYj65yXn058lr8vPQalreYyDYSNAXi/po+jkMHkzQLG8uBngQIP/Gahd0Fx33XUAgNe85jXS8RtuuAHveMc7AACf/vSn4fs+zjnnHMzMzGDTpk34/Oc/X3dXCIJoCd0eN5yWVovkHNNON9WFy7OdVAxTT0BW1AAwrEIyTEGBn5dXNgFZYaPGjsqk9aP4cgzXODyWqglLCRxhyi0pY9m1GLAnGScxlHZVMeZBjsGfRZW0YRE5gF7o6EROVDfug/S4AyT1gFSsuAok3Y7HQCp0RJHD4w10lA+yRhrfh6YJaB8agug9Te5D0xR87PjdT+6W++yyqgnQujO5e8RYXmsdIPW10q5Te5r34kCf3ZtFxrbnC2Df9yWqn72t5LWhi+MayzWeuteNuU21TLZQ/meg6Y/Svkuf1SK6J1q77oujPa+8N+11o9a11VPzeMR6B/bvx//Z8Pvt3IeGIAii78jbnM4mZvJ2FXYsU8uuw7apJvW5ULC4JbyKcF68J7m4NdF5Xt/stpicFjFOcgnKtBSPp/vkyiQWA1n3BshPMAb001Rim9knh6eF1GRjQJ9wLLzNTFdFdXhfYtckVPetka8vm3icujHJ+RJTT4B70vJgm3JoCIIgWoNNzIgYpnycppq6+Vyokhvs6VBFDyDn1gDIPLlbFTZRnOxGe0B2GkxtyxYvKisXVqfWdHHVHJ7oGoSbdBxB3276Wp2Wi8raxZ7Upi6WsOGfrowujjolJybc2jYBTC9KtWNUcaOb9ON1ZXGTiZ30XZmOIkFDEARRI55faZopKltwqimvP01gcWmAfKeGl3FxawDzTTwvP4a3qXVZNHkyUbsat8WQQeHi3gCajf0S10WOq0sS1i0TB+wuDo8VlVMKweLkKNejbgDImOzkRPXk93nLyG2bAUbnZbUnfva2DQHVftUJCRqCIBYvRZwZl6kmx7YKUfOqEJ2TkVdGFTVA1q1xpYjDwtuOyqvtR99d3RuggivEp4osj2YQY4pxbS5OFFOOJ8a0OTnR9chujs2JUj8D1c3JiBt1KkrotH6qSu/mSI9oAIxOTh2QoCEIYnFiW5oNVHNmcs4Z29S9r4rDNJRWsCBfABR1a6KyPF6+awOhD5nl24a8m6gf5umPTFnD/dXJwQEKuzhRP8SYEa5OTlRWLuiSk8PLqU4OkM3LER/pUHxDQFm0qKvFKIeGIAiiTvKWZhcVMy7xkxjNDehRA/kCxpRvkidqjOU0bo2aS5KWjbvp4KzwPsDQD46Ly2Jqx5QlYoqvcz8Aey6OWj7PyYnKMs3+Ofo+6MSep4g68WGcajwxlvrbmdkIL+cJHLa8HCCb5F0nJGgIgliU5G6aJx5HA86MC3VNNxkeYllF1AB6twaQ3YY8YROV53HNeTF1uTe6lVO8HdNPp4iLA+hXUwH6FVVaJwfIbP4HaFZWAVA3ATTH1LhDXPgZVlgJh5we7QBkRaO6V86A4O7UDQkagiAWHdYpH82xOpwZp/I59RvdwC/GVdTwskAxxwZwc23SNrJTU2K/OCZ3Re2fyxSY2p56xiSkeFtGIaVLZAYzTJvp0QkddVoHgFbomOKqux53PM2eOdnwpTYFpBwagiCIujFNMSmU3cgu151pMndGN+3k6NIAZlGDIuWV/BqpfPzd5tpEddV2iosb3r+0nnubuj1w1LbUNgu7RQVEjm56KSqfPaibsgKye8QAbiIn82gHaASTUkQncmjKiSAIok6q5svULWZ0dOkBmEVETV55wCxsgKy4MeWIpHXl9zaxEbVtFhyAeWl4VFffpti26WZcZroKME9ZaZOPgdh1cZy20iQgR7H101Zqf0zLyV2mrMRypimrJiBBQxDE4sQ1X0alCTHTzc33ClBU1NjqAPlLvU3OTVo/fW2bnjLtR5PnMnG012xpu2nnKC/5WC0v1nFNQI5iC2UN/SiTgCxOwzWZE0+ChiCIxYc42tqETBWXBiXFTJFdiWsSQmUESvkbtf5mKtXX9CPPvYli8fbNTgpgdnAAu4sTxbDflE1LxtU+qKRuhwbDz4An5JrcHEAWPfrHMaDwcvIorhxTjisKPLlMgwYNCRqCIBYxZcWMA04rmhzjFk4GrtnxsbkuVevacm2kOPF326phW3Jx1Bezk5LEEF7X7eS49MHkIpVxcwD7poBqnbrdHDGmbmPAuiFBQxDE4kN49EGlXBnNMa2QcXVXms6bsexRY3NpgJypJB7eUpdjm45SqdO9ieKJfTLfWOtwcnT9UmnKzYnqKnV65OaoTk6nwV9xEjQEQSxaCjkfdU0xmY4XfQBmA3k3VUQNrw+HGICb41PUvQHcHJwopiVeQScHyHdzoljm/uj6ZFpl5dIH19VW3d4csElI0BAEsehgnp8KhTz3pIyQcYnLcV0ynhfH5VwNuEw/FRE2HJdpKRGTyHFxcKKY+rbyRIUU17DjcCZmEstcJi83x7bKivfF1gdj25b8HNeVVjY3R41Ny7YJgiCaoOJybKCimLHQjU30dOS5NIC7y+IibNSYLnEBt+TiJLbmmMtKqjS2Ia5l6bgUU1PXliMjxzP3S+xbmURom9BqaoNASgomCIKoEyGHJnmvnre9Rw1CpugUky1WXecL4posnJdoq4srUrfAAaqLnKgNTdwcYZHENLTlInRsOx+rfatzv546RA4t2yYIgmiCtggZWzzX8wVwcWk4RVdAFRU3vA2VXHfIcOcs6uQk7WnbMJcvMnUFuCUiA47JyA0uLS+6rNy06qoJSNAQBLE46SMxk0uXnZeiFEn0FSkyJWVqs2i7RZ2cpD3lfd4KpiJTV0B+AnASV4xnjCXGye9bHRsFujydvGlI0BAEsfgwJQQ3lSPTlCvjWqZIuQpUFTYiRULkJdta23a447ouH8+0nWkrv05eTowU30GMueSs2MRZxzMkB1v6YFtW3mlQ4JCgIQhicdJjR2ahiRmRKhvxcaq4N2pfOGX7ZHselbVt5X2eqxO1lb7Oa6oXy8vreuxDE5CgIQhi8WFJCO57EVOkXNGyNVKHkADcckpccXIranB0gHpcHdfpmrwl3UnsnKXdnDIP1ATc3JwmZ6BI0BAEsThZyI5M2fINUYdjY6JuF6BMArKOInvnSO1rjhXN13FdZl4mT6eqm0P70BAEQdSK+AynPhcxRcqVLd8FyizFLorLrbJqArKJMkvLdZRxdorm6rjm6bg4KkXdHFq2TRAEUTPOQsZ0fAELmW7kO3RD4Ohw3f+lKFUSk0XqXG5edV8dl40Di27Y1yQkaAiCWHQ4PXOpLdNKZesY6JKuyFDXVE9ZmnJ3ALd9Y/KwuTtFHgORtKltQxdbiemwcWCvRA4JGoIgFi9NPm/JFKtKubLlHeiVkLHhevPrtbujUrQ7Vae08qayik5jFUlMdpm+EqeuKCmYIAiiTtRHH/BjOpp4REHRcmXLO9KPYqYIec9B6jZNTGtVcbCKJiiXfSxEkWdeNQEJGoIgFi/dFjF9IGDaLl6KUMf0Rp2iqGh3XB8S6kJ2NVKxBGWXxGQXN8d12XsZSNAQBLE4qWtqqQVCZjGJmLrppfvjsimeK2X2BSqyoaD4G2tzc2iVE0EQRJ2IgqEXT70uW9YCiZbu0gv3py6Hp0xuUhFHx/Yb3eSGAiRoCIJYvPRSzJCQWfQ0vbKrqsNT1NUp+4iIumh896VPfOIT8DwPF198cXLs8OHD2LJlC4466igsW7YM55xzDiYnJ5vuCkEQLaHxccP3MmKGeX7yJcETiHWJxC7ndWUKihlm+SIWFr5X/MsVz/GrbL+ktjzP+NUUjQqa++67D//0T/+El770pdLxSy65BN/61rdw8803Y+fOnXjyySfxlre8pcmuEATREro9bmhFDCfPqXFxa0o4MSRa6sf1Zl70Rt8P1CF2RMpeex1tV6ExQXPgwAFs3rwZX/ziF/Gc5zwnOT41NYUvfelL+NSnPoU/+ZM/wWmnnYYbbrgBP/jBD3DPPfc01R2CIFpAN8cNo5BxdWNMFHRhyHUpRy/ESB2iqNtCqRvuTtG2m6IxQbNlyxa84Q1vwMaNG6Xje/bswdzcnHT8xBNPxNq1a7Fr1y5trJmZGUxPT0tfBEEsPOocNwDz2GEVMjpqFDEkXorTJrekDL0UQnUInn5xtBpJCv7a176G+++/H/fdd1/m3MTEBIaGhrBixQrp+NjYGCYmJrTxtm/fjquuuqqJrhIE0SfUPW4AjmNH2QTgAlNJTQuXKomkvZgaKEKfd6+n2D6bun7nKm3oV1MfXKld0Dz++ON4//vfjzvuuANLliypJea2bduwdevW5P309DTWrFmD8eEBLIkHlY7wyXWUpKM6zunOq8NZXnldmSLlbOVd6nH8fh/BFMICo3WQUzSwZN6b6prq6Mrryqrl1D0a1Dpqedt58ZytnksdfjyvLD9W5yKGJsYNwDx2ALC7MSYKTCNVpVu73Oa106vhol2jVP9R9PMr8utW5dlUTf5caxc0e/bswdNPP40/+IM/SI4FQYC77roLn/vc5/Cd73wHs7Oz2Ldvn/S/rcnJSYyPj2tjDg8PY3h4OHP8tPEjsWxwMHnvCXdzX3jtKXd5v5MOSp7yk7GV1Z9X6muWgap1dHFN5XRt5JXP648JUzvdJsxTJRpYaNrKSSiTE9fUrqleGGTbNJVV+6drS6yrxlbjstCtrNiOKb4YS1dGFJSiqDkUBvjC7zKXUYomxg3APHY0JWaqaJBebdOfB+9XN4VNf4xEiwv1M6/zMQ3d+t2uXdCcddZZ+MlPfiIdO//883HiiSfi0ksvxZo1azA4OIgdO3bgnHPOAQDs3bsXjz32GDZs2FCorVde9WcYOWIJPL8jnxDfKzd0W9nMzb9jiWuMp9t91KFewfpJHLWPBeo6td1POIiWbJ0gtwgLcsqYYlj6w3R1tMc0okgtp75X+psRc0L5bKwwv5whnvg5sSDE9LMzwHs+mel/Gbo5bmTosojpV+GSh9jvlpm8zcJKjEt10tDzvVx/xC6/zuLvS6uetr18+XKcfPLJ0rEjjzwSRx11VHL8ggsuwNatW7Fy5UqMjIzgfe97HzZs2IBXvOIVhdoaev7JGB5ZLh8sImbU8pAFAtNN7bg80E45VmhJaIn/OWr76Vg3w0IUNTkDjgfAc5k/McUpeNzTHVePOZRR+5wRZq7CxlbWJICCAMMHD2X7WJJujhsSFR5nsFiEjI5euDZ9Qa/Fi468PjUkeJLwYlcabSmfnuwU/OlPfxq+7+Occ87BzMwMNm3ahM9//vOF48yc8CocHhnJDBTqDoWhdE4uG2puZOoR3UDkEkcXyzVeUtbyK5J3D3YZQOvYzbGOP3HnP7kiO8oX2MDJZWDOC+db/k+jq2tqU3dY97Ra9VBmYyuHOOJb9aMVPz8xNn851+XVhnWNGwDMK5JyBn/Xv5aFJF5sLFhh04/CpSxFr6WCAOr1r4HHerE/cUWmp6cxOjqKPY88jiOXjUjnxIGEaYafrPjJxlcPBZrRSSdgdAmhOkPBlGRqEkW21I+8hFlbEmxeu0Upkfoi0VQKT9FH19uSrpOYOSO46VpsfdG1qzPMtOV0ieVqfpimTUnQZASRXtDwegf2T+O0F67B1NQURkbkv8N+hY8dk089me2zzQV1jF+3kKkjXDdvMnUJm57dGBeSkKmbmpye6elpjI2PNzJutPpZTnt/ewhHHO5kBhH1Jq676efVicoYBIZDPFNMe1ztYavgyBMsur6WKdNE3TKoN+luxnIpnyeGrILGMF6Y6uiFjS5uvgDKrOBT3R8/W/7QgfqmnHpKRSFT9U+g6b8gW/y6hUPI6hE1DF0WNSRk8rF9Rg1Pa7nSakHz0OQBLDmQvp9XRhbdzdb9WPaHZ7p5N30cyF6baz1XwdEmUaOjLqHThMjJKzdgOZcXX3feVMelbEexhLLn0/czBw+g1fRIyPT+ryVF7EtdAqIuUdMVSMjUQ5+InVYLmt/sP4zhILoEF6GiK2MSCr0UL02cK1ImKdvAbGSRPWV6sV+Oy3RTpk4Nosa1jO18FSGjO6YrI4qv2UPPGvvS91QQM2WETD+JGBO8j3X81dUhahp3aUjMdIcufs6tFjT/85tDGFzqOQkXwJTjYto3xJKMazlnu2Hb0pVsMXPjOoywLqlSRcSG3H6paj2nrv84FBVeRZKV1X2SirRtqqtrXxdHV188Nn/4oLVvbaIJR6YNIkaH2u+yomLBJgw3TS8G1G5OGTV4fa0WNHPzIdh86JQzA+hv/E2Ikypx8+q6tO0iTIr8TrkIpqLUlYisUiQBuOzflXqjLzrl5vkFXCpmv54wsAskk6hRBUwYaMrGq7RNAiicb6mSLcFiETM6up7Pshjp9f8K+2TKqCqtFjQzs/MI/HnpmO5mbhIApht1VcHh0nbRNqN28847tuXYp6pCpgkhlEfdw4JWEOTv1VctvoU8wWaLZxuXTE6PSSx5vof5mXntubZQtyvT5G+7Sz+adEKqTEdVcWoWrJjqtYApQpG+9lj8tFrQqJSdMmkSz/OcRA2/odiugf+umH6/1JuZSVCoN0WTwNHdHIuIlKI366Lx66BMH3vVdtHl5yosNI83Yci0ooYxphU1LGQ9Eazdoh8cmaJ9UMs38au9YAVGN2mTmCmKem1dFjitFjTDQwMYGE4vwbhMumT+icuAXVRE1bHtT5EbSZH+lblBdXMbo34UrCJ1JjHXmWfDyeuf1d3RbezH2jt8mH6TeunI1P3r3ZTAKevWlHVqSES1GJdd0WukvSMSgMEBH4MDqQI0JgN7lpVBDvkMthspb72UGCg7glkez6T21fYopzJipOr/yquIkiKPpWobZcSQq5BxEUdlxA4baM/cet3UpT26qdHrTtIloVGChezO9AGtFjTjo8MYOmJJ5rhtzxag3uXNZfZgaXrfljri9+N19aqtJqi6b05T++W4lu34HuaerTGZqMe4/jrV8VvX61/dOveJKePWlBFWJJ4IF1otaI4eWYLhI5bk3tx0m+TpyxXYo6XPb/h5lO1LlWvIE5pN08vPv84djgH7Znx19sNWftYfKtWHfqMbYqaP/vQboZWCw/PJMVlgtFrQjI0MY+mRWYdGpMjmcN0WKf0kcETq6lc3BEy/foZlaJvoOTzc/pvBYhUz/bCbb9E+NCKaSNQsKFotaI4bWYIjltkFDafKoFJ1x9x+SGYt0gWXQabqJTWxCzHQ3P42Vai6OqkKZXY+tiH+bhwaaveUk8vvcNnfpj74k8+lblFTRnAsKlFDwqlxWi1onrNkEEcuHcwcr/rUZ05TQqSpm3m/0bS4qOvn3Baaehq5iTwhNhRk//YIoij94BaRU7MwaLWgWT0yhOXLh2uN2Yb/WS0WurkknNBjWyG1f2Cuiz2plyb/zmkMaZYqm/wRC5tWC5qlHR9LCy4d7ccpiYWM73kVPvP2DFm9/K3q1ac0323LqMsshpGiL9wRgqiJVguaFZ1ZjHRme92NenFckdUqyg6Y5R+2VLJBogiD/gL721uE1ClmWq+Lmp52ommtxmm1oPFmDsA73Po/IzsL7A/AW2DX0xSsBaLMm93f6y4QBEEktFrQdPY/jQ4OVQvSJzdYr4VTYSzo8iqXsA9X1bRo+2KvU29fB/YfrDXeQsH3Fl8eTZX/VpZxiRr5b2yf3AuI8rRa0IT7fotwvqKgyQRt9qbZdRGgo9vCYCFOozWF30NnpqA4mz9Y899en+FhYefRtDV3pqXdJrpAqwVNsO83COaW5hes6wZesxhh/XCjr1HcsH50UBYIXlNOUIW4waFna+xId2n6Zs7j96tT0y9ipl/60TUoj6ZR2i1ofvskgkPpxnpl3A8WlPvlqkOMhCXbroui1170mst+tgsZr1OfA+NVcHPK9MNX6sw9O1O6/bZQ1aXpx+mnfhERfTPV1G1I1DRGqwXN7P5DmJ03i5gyoqPwTb7iTbvpm35YUXgV6R8JGDfqEjVl4/gFhZCpnbnD7RY0rmJjIYmaJsRMmZCLVswQjdJqQfPs5DMYWCI/IM/F9XAVOk3fzJsQAEVEXBGHqNT19cOUWgGqOB619aGsSClYz+Va8/pyYKb9y7a7KWpEeiFw6hYz3RIyXYOck9bTakEzPzOLec1xl5uv6w3a9aZcdvqoLlFTt0hrejqqTfRC6BQVNkGBOq7XY4vnd3yEcwsjZ6pboqZMm3W1VTfdFjP9rIOI/qHVgmZ26iBmhvT/S7TdkPNu1i4352LuRvGRKyxQJ+96XGO5i6I+8c+7iFfjrrhVBZLv2BcXgZMXy3bds/2wYq8mXJN4xU+j6l+B6QZfVeg06YKUDd0aMdMtl0bcZ2qxuUIN7rHVakETzs4j1Py6227MeUIk72btLA5KOC95sV0Eh4vYcLmGciKsXX+YRadpbBQTPObPyUWshMIjlKztCg6KSUTxErZ2jTk0czp/lKhK2emppqdzeiFmFgWLZaqrC5uFtlrQsDDU3uRNN1bTTTpXSNTggOSJkapCKr9+PWJIKt/yaaZwLqhlOsnreKkycMAmpALNz8AqWoTyNlHCVwCaYgWhWfT4BgG2EJ26Isut63RrbPRSEFRtumrfe3LpvRAY6s2+bQKnT3Y2b7Wg4RQRMCZhYBMtTQsWW3x7vWoiqVgC8cK7eQHI7C3kOp0jwsceV3EUWhwauS9RvLyfIxcptp8Rvy41lihw1N8Hfj2ho2hqE3lXUXQfGR5vofyV1PFTbrUz02vXpF+npPpEuJhotaDpLBlCZ2gQfGswnSgxCRXTzdwmEsqIkqT9QXMdXzlnExpiHzqQf7mKuzjZTdVM16/20S1+96kz1wUosXrIoX0XUeASJ09AmdoxTSGZy2eP+x0fQ7NtvmO5iZDFJmwWvZAR6bWoEfuRBz3IF0DLBc3A0iUYHI7utKoI0N2YXcSNeItvUiCxgGnkBBcl2TNlhJGtX2pfOKpIMtHvjk0dTkJRceTi0JTJVcmra+unSZCZ+qrrg/aY72NgoD3PsbLhsnqprLDh9OtfS93aY8E9vZvf8PtB2NhYYMKkLK0WNMMrlmFoMN9l0N3UjcLEUcQUETBFRVDZFVpVkqGj2PUMu02JnSanO4qKF1fnxiZy8gSM6XwRMQIUEzXOgqbjY3YB7EPDcXVWyi637ifnpom/on7Y46ZR+sWtaTueT6ucTCw77rlYPpzaEi5iwlXcuB7T7cRbVRSZHuFgnQ7LzeGpb2+eIrjErPNxAC6Uac+lTv4UkE3c6N2Oqk4KoN8Z2KV+5r0Sh7X50QeGm1ORaShOEYHjcqOuKnq6KQYWzPSSC/2a19JP9NgparWg6SwfxcAR8bOchAcjah+SqN7wNWVUIeHqrLi6MkUcmTIujctjDpraWK8fKSuUXOu5PELAFsvowFR0VHTCyaWuVlSpD68U4gwdOqzt50KgiKNS9yZ5bdEIi0rMqLRlKqob9NF0VyOC5oknnsCll16Kb3/72zh06BBe+MIX4oYbbsDpp58OAGCM4corr8QXv/hF7Nu3D2eeeSauu+46nHDCCYXaGf69UzG87MjkfUbI5IiYouUBjXviIp50bRWoa6xvi8Nx2Pys7cuvbRRelm1wSiQcnlBtfDq2rT+aOto4uhi6uuq15MTKtGURM57fweyBg9l4FejWuJEg3owMg3KRqSiRfnl2U510S8C0SieZbuZtFzp9JFKKULug+d///V+ceeaZ+OM//mN8+9vfxnOf+1w8/PDDeM5znpOUufrqq3HNNdfgy1/+MtatW4fLL78cmzZtwkMPPYQlS5ZYosuwI1eCHXmEclBZeqr+YgnvPU35bP3syOQianLFkms9W31LnCRekd1cbcKoLTiIDR2mKZ9CsW35MkaB4y589OImX8gwT7lFqINVznsmvo9fMwAsdFj65kg3xw0tLLQO4kVzYIomEfc7i9qNKUNb9pXpsnBhaDaPzGNMc8euwGWXXYbvf//7+M///E/tecYYVq9ejQ984AP44Ac/CACYmprC2NgYbrzxRpx77rm5bUxPT2N0dBS/fPxJjIyMJMd9ZeBWx3FfOiefVP9gdX+/Yhnt33eOODIdy4guwCxgbH8YDn80OoFmpV/2YqhA5oZepU3beYugYbp6plgOZXU/RfXmyWznlN+DUDqnxk0PiKf2T0/jBWtWY2pqSvo7LEM3xg0gHTsmn/w1RkZXmAs6/O5VHTj7Vez0WryQdmovLr/S09PTGB8fr2XcUKndofn3f/93bNq0CW9961uxc+dOHHvssXjve9+Ld73rXQCARx99FBMTE9i4cWNSZ3R0FOvXr8euXbu0A9PMzAxmZtIExOnpaQDA04fmcXgg3X7dg1mk2MRNdD4tkBE3mbp24ZTGSE+krzpCmWxF07036ZOD8JLrOT73p0WjSFkJHjpWzCtlvBGF5r7p2jaLEvlMVFV2z0JtGXMfXQWMWI8pbUjnGHDgYH2PPmhi3ADMY0d0ERZXJt0t0djnqjsF64RDr0ROr0UM0U76TZPXLmj++7//G9dddx22bt2Kv/mbv8F9992Hv/7rv8bQ0BDOO+88TExMAADGxsakemNjY8k5le3bt+Oqq67KHL/jkd/iyOXp0tGO8lfZkUSKck4YpzLnctwbsZ28urr6vmH0cKmbVz6vjWwMp2J9Q5kV4aHjXSLIETymMKZ6pnbVw7r6qgAKNLHy4ogx1Bxv6ZxULv81f3/44IFMn8rSxLgBmMeOhLw8Goc8G6C+fWdIWESfHX0MvacJsRKyZkV77YImDEOcfvrp+PjHPw4AeNnLXoYHH3wQ119/Pc4777xSMbdt24atW7cm76enp7FmzRr8v/t+jcEjliXHJZdFGBk8ZZQQ36s3flEkZARSze9Nx4qWBYABh5HQVt+VMjF0N+M6KBp3Pqe8LV7Rc6byLmULv1eFjHCeKWXF91I5pq9jisUYw/zh+pKCmxg3APPYoSXPlXFwbTht2ViPWJw0/fvYK6exdkGzatUqnHTSSdKxF73oRfjXf/1XAMD4+DgAYHJyEqtWrUrKTE5O4tRTT9XGHB4exvDwcOb4o//1C3SGBUEjJEj6wmvP8Np2Tl0dYxNIumOZfB5tWoTGkXGInRx3mCdydWpc2qsT9UZbFlf3BchOu2TOW2KZ2jHVUVOPtFNOFrFhaldckaYmkNvei69Dw3H5tdBOkC3DwgDhXH3LtpsYNwDz2AEWmqecXIWNrYwCCZxi8M+HnJpydPP3q59ywWoXNGeeeSb27t0rHfvFL36B5z3veQCAdevWYXx8HDt27EgGounpaezevRvvec97CrX1zCMPwOsM1dJvgiCKwYL6dgru5rghYRMnLsJFVa4lBY4U0inC4kD3WSxkkdOPP/s6BAszvK6b2gXNJZdcgle+8pX4+Mc/jj//8z/Hvffeiy984Qv4whe+ACByFS6++GJ89KMfxQknnJAsv1y9ejXOPvvsurtDEEQL6Itxo2KScKFyFqomGy90ynwmvRBBbfzZ1eW29Oraaxc0Z5xxBm655RZs27YNH/nIR7Bu3Tp85jOfwebNm5MyH/7wh3Hw4EFceOGF2LdvH171qlfh9ttvr76XBEEQraTb44bHwmS7BGlJfZ7jotvGIC+ZOK+shSI34jbeQLvFYv5smpgSKhuy6aTg2veh6QZ8L4mBl2ymKSeC6BEsmMX8T25qZD+JpuBjx9O//h+pz9p9gjguIqSoI9OFDc1aN7ATtdCUYKgSVuzT9PQ01qxuyT40BEEQfY8y6qubWxZybVzL2Mq71itAmWkWEkH9RzeSbhfKJpEkaAiCWJzwlVy6x0zopqM4LnkyJVZCVapXEzoR1Cf3qgVNNwVBHU0V7a+0LUSDk0IkaAiCWNyIjxlRxI2TsEkK17sSyjlfp2FoyXk5euVa1NVsmf73OoOFBA1BEIsP0z40BtdGnJIy5tu4uitlBU7VujVR9EGdC5VeTrP0UrQkfSggXkLD67ohQUMQxOLFNH1UdjoqL27Vsqa6ZetXwMPCFzULQbRwyl5LGdelV480JkFDEMTiQ3U6TMJAfeq9IHCsicSmdppybuqov8hYSGIF6J7bkrTnHNv+vk5I0BAEsTgxOSO2DfbCUOvaAH3m3NRRfwHR61U4/SZggOIipojr0qtUGhI0BEEsOjxxxNW5Mza3w+LaRLFrzLfJ64sLPV451TQLUawA3RcsQP2iRfsMO1rlRBAEUS8eY2DqA1773bXJ68sigqaMZPpBwAB6EdMtSNAQBLEIiYZy0amRxE2bXJsyq6RaIojavvRZpBeCBeidaDGVaNXDKQmCIFqB4nRoHRtNudzjQP/n2vS5sOmFkOmXVUUi3Vhh1A0Rk8Zo9mdLgoYgiMWLcmP3lEE7ETgmR8TmlFg27Iva6gNhU4E670tt2ylXpN+niqI2HOPWIFqiONX7UgYSNARBLD7UjfUMYoALHO10lOlJ3DpB0c19bYrQ43ycNjynSGQhTRsB9bkudfWnKiRoCIJYvKhCwSJsCiUQ644D9Qgb1/yaBpOM+/Vhhv3kvixE8RLFKdcf3n6TScMkaAiCWHzkOTSaqaTcBGKTsNGdqyJsXAVLH66GqkvI9FPSbjeES9SOY9wuCJe8/tj6QEnBBEEQTaDe9HViQSMMCjk2NnKShyu7NQ1Q9oZUebqmWvUM/Z770ib3Ja8P3Zp1IkFDEMTiQ3RPbEu063JsmnRr+lD0cCpN2dTXjb5+jtFicF7ENmmVE0EQRN24OCqOgsDo2BRZ7m1xa6x0UbQUuRf1g5jpVyGzGNwXU3s05UQQBFEjns6h8fzSbk0Us+CKqAKippJTU5PgaVLMVLnJLYRnGrVVtJjatLo8DUoaEjQEQSxKMjkqunyaOvNrXFdDlXVq+oRuiZlurkDqZ/el11NILm01KWJESNAQBLH4YPzRB4rz4bKM26FMZbfGkFdjdWoadGnqyM0oEqtsbGObBVRGvzowVfd7qXXaqKBwkZ4FSzk0BEEQNSPc5EsLmzrdmj5bYs3ppZjpVg5M3SKmGwImry+mPnTDedGV57EpKZggCKJO+KiaefSBRthUnJaqJGqKTj/1QBg53XhrjifFbngfmH4RML2eOioiXkyxGWOlf14ukKAhCGJxIooFm7DJc2sc3BvjFFRJUZO7R00RKsTJvQnXFEeK2QcrkPIETFvES9Hk3aLiJRuTVjkRBEE0gyoWquShOExBFY5poVZRY6DM/+5d6rrGkOI1KGS6IWKiGOX6UGf+i62tpkSMS7w6IEFDEMTiQ3z0gZqA65pb45pXI5Rxcmp0cZta+WQRRGXFTD25Ic0k8UaxHWL2oQPTdO5L3cJFFzNklENDEATRDKKYyJmCMi7xLuPMlKFPlnP3i5ghIVNsGqlMAq9crpyIMcVrAhI0BEEsOjzG0mRdUbwUdWtKJg9nEoVLiiDnaaeanqZdZvfXukRMndNHQPVE3rqnj3qRvGuOW27qSI3HNH0JKCmYIAiifiRhUfRRBeq5oiui8uizh0828b/sfhQyVVwY87RNfTkw/ebAaGMpfSGHhiAIoimExxdoRU1TTo1AJp+m2wJG01Zdzoz9pm+/u7kImIXmwvQ6B6bs1JGLcHERQHVBgoYgiMWJJFIMTo2aV1PVqemXp2MXaKNfxExd+8EA5V2YfsuBqTKNVJeI0ZbJ1EkJGlQ0JGgIglh8cIfGJmqA1K2p6tSobbsKCrVsmcRgx7aK3GaKiJl+EDH9IGCacmF6PX2k65NNwLiKzjKQoCEIYnHCxYIgXrTLqgHrCihtTNtr5b12J+Euo7vFFHFmiiSXJnVMfcm53/XbfjBtETC9cF/UzytgjJKCCYIgakXj0OTu3GtwR5xXGrk6M01PO9X8kMqiYqasI1N2h1w5RvG263Bi2ixibAKGYxMyqoBhtl+AitT+VxMEAS6//HKsW7cOS5cuxQte8AL8/d//vfThM8ZwxRVXYNWqVVi6dCk2btyIhx9+uO6uEATREnoyboiiRjnGl3VnzofZslF5/XHX0duz3cnrvAM4JALrNj9jruUY0z6vJxS+5PLylxyfSV+6/uj6JfZN/TK1K4bXtau2xyztmGKHYJkvXVl9TCZ9BYxJn2kIIFDiBGE2TsAYxH8BY/L5MPoS+yJe83zIEAhfc0GIuSBMPqu5MMRcGCZOzFzAEIbRn81cEL0PmjNo6hc0n/zkJ3Hdddfhc5/7HH72s5/hk5/8JK6++mp89rOfTcpcffXVuOaaa3D99ddj9+7dOPLII7Fp0yYcPny47u4QBNECejZuWESNtpzr8aJlmiLHjXG5txRxZXQUnVrSCRixL7am83ai1QknW7t5gsklNhcveWVtAjGNZRaFpjiigDGWUWKo180FTFpf/qzEqSQuYLj2V6eZWpVD84Mf/ABvetOb8IY3vAEAcPzxx+OrX/0q7r33XgDRD+gzn/kM/vZv/xZvetObAAD//M//jLGxMdx6660499xz6+4SQRB9TrfHjYyjwnNplOknKafGtKRbiGl8Srfalq1MATJTXRXj6ZyZvDJAdvqjjIjRljfEMfUjr52y7blOI9U5hVQmibdoDoxa2iUHRjof6s9l66Wv5xpc5VS7Q/PKV74SO3bswC9+8QsAwH/913/h7rvvxutf/3oAwKOPPoqJiQls3LgxqTM6Oor169dj165d2pgzMzOYnp6WvgiCWDg0MW4A9rHDy3NOXJ0al6mnXlBQ7JQRM7rpJRP6G7vejbE5MTYXxubAlGnP1Ykp68LopuiquDD2ttIYTTkw2XqpmAlDhrDhHfZqd2guu+wyTE9P48QTT0Sn00EQBPjYxz6GzZs3AwAmJiYAAGNjY1K9sbGx5JzK9u3bcdVVV9XdVYIg+oQmxg3AMnYkuTKxq6KKD091XzQrkVz3qFHPu7g0ZdybAuXV24rLfUYnZjJl1HYKODJF3BFbbFP8Mu0Y++/gxDTlwgBZJ6ZIEm+RBF6TA5Otp/Q5NMecC5sT+rU7NN/4xjdw00034Stf+Qruv/9+fPnLX8Y//uM/4stf/nLpmNu2bcPU1FTy9fjjj9fYY4Igek0T4wbgNnZYnZo8l0YzOOc6P72goNgRb0Gm3A4Rk6ugUjVPhce1xS6af1MlH0ZN/NXFc3FhnOIouTCmRGTT9YoujPpZZfJccnJg0npZByYMWVJHdW6ir+znWhe1OzQf+tCHcNlllyVz2i95yUvwq1/9Ctu3b8d5552H8fFxAMDk5CRWrVqV1JucnMSpp56qjTk8PIzh4eG6u0oQRJ/QxLgB5Iwd0v4zglOj7E0j5tNUekxBHcuxXTfVs7RTxp1J6pZwGKI23ByZIm5M2WXcVZwYl3yYMs7VQnJhTHV4+SannWp3aA4dOgRf+aPrdDoI409t3bp1GB8fx44dO5Lz09PT2L17NzZs2FB3dwiCaAFdHzc0LkrirFgclsLLqwu4NdbYRbDkzuSJGZszkydm9Dkjbo5M3rJqNV6RZdwuS7fTa5KXVRvLKfFsLkxouJ5MDOWfbTm4es3iUuoglJedi8uoA8akHJhoGbVwTqrHEgcmYLIDMxcIS7PDUFsnWrKtK9+coKndoXnjG9+Ij33sY1i7di1e/OIX44EHHsCnPvUpvPOd7wQAeJ6Hiy++GB/96EdxwgknYN26dbj88suxevVqnH322XV3hyCIFtCTcUO3uimvrA7NhnvOm+1VQIpfQ1u224yLmJHOl3Rkmsy5McVvcmVSnhNT9LECNifGtiJJnRl1cVSieuVcmGx5fdt1U7ug+exnP4vLL78c733ve/H0009j9erV+Ku/+itcccUVSZkPf/jDOHjwIC688ELs27cPr3rVq3D77bdjyZIldXeHIIgW0PVxI/lvbqhMKxWYetLtIpy327DtmIkqYsXgzuQ5M9I5xXWQz8nvXYSHi4ipKmBs98x+FTDdFi/ROV7HEq8m8cLLzze4s57HXNfc9RHT09MYHR3FwEs2w+sM9bo7BLEoYcEs5n9yE6ampjAyMtLr7jjBx45nHtiBkZHl0UF+0xdv/uox5bu04omf89UyGgcl55g2rljHt8S21YNZtDQlZso6MlXybYoKGV2dtgoZwJwP4yJKytQpImT4+UMH9uOCP3xRI+MGPcuJIIjFiTrlVGDqyeWBkpWmncrUc0wEdhEzZYVMGRFT+/SUo3Axx+2NeCmyqV2ZKSTbUmpx1ZJ0XFMnT7iYyvA25htctk2ChiCIRYf0nKa6HxhZcjWTViBp3JnCcYXXpvwSW/KvFMtBjJjiutSv4sTULWSimOZYVfJh+s2FKSpkpOM5QkZqJ2QZ4VYnJGgIgiDycmlcMDyNu1F0fXPIm6nqzNiESBMipu5k3qhsc06MWt9VwFTNhYnqsUz5bDtyWbWNqi4MoF5jWq5Vq5wIgiDaQCa5t6yoqWN/mTx8Mc/GLmKK4OLMFJliqipmygiZKiImimdvswkh0+vppCJ5MEUdGGssln1ERJ2QoCEIYtHBwgCA4ZEG5krmjfbqxJYLU2Cpts41Md1KTM6MyZUpIkSqipiyAsYk0LolYFw3tzMJGBcXxlaniICp6sLkC530/FyDq5xI0BAEQRRJDO4HTMJG03fdzd5lmslFzNQlZPJEjLaMg4hxfep3L6eTqiToZtvIli+zEsnahqWsTsCIj1dQY9UNCRqCIBYlLAjgdTqGk5Z9abrh0gClH05pEhy620hdYqbstFRRN6asiHFxdZpYnWRK6K2S32Iqr9Ypkw/jOo2U58KoIkaMMztPq5wIgiDqI55yAvJzaRqhSFzd3jMOcXRiJs+Z6YWQKSpiiibz6mJE/SsnYAC3VUlFn5HU5DSSWN7urDi4OYqA0Qk4HkeMlwoacmgIgiBqx+rSFArUxamqgsKmiDOTV98oSizTS9ZpKYuY6YWQUeO4Cpkmknqb2tiubDJvckwRMjoXxiZo5mmVE0EQRHPYpo4afS6TuvOwusuv6s5YdhrWiQjtMUdnpqiQcXZxhJI2N6buZdW6Mmoc8XSdSb1ugoRlyorl63JhgGwejOsUkli2iHgRy8wFNOVEEARRL2EA+Io708akYAVbEnCeM6NL2KwiZqQ4Jd2YbgsZwM2JAczTSsXEiV34dGtVks2FEcuVFTJqmSYgQUMQxKKDCTk0fNpJcmnKPlCyyOZ6ju6MUwzNKX7MxZnRiZMiQsZ1WskkYmxuTBEBk7cEXOwzp4wTU+2ZR9nyrsm8ZfaE6ZV4kcuGybHZ+fRvr25I0BAEsXjRuTR9hna6yYBuqilThsd1uNmr5XTTUabyJkemrBuzmIWMWLaKCyOWLZMLI35meUImED44acqJVjkRBEF0CdGJaWIKqkA841O/hdcZJ0Z97+DMiLf2tJ54rICDU9CRcXVjigiYPPESxSgmYMQ6dQqYqKyuH/kCpo5kXp3ron6fdygjujC277RsmyAIomZYGMCL3ZnaVjvZpolchIzrdJNBzNiwTTMlZSxiJk/0RG0wTf30tdu+N8LxkiImT8AAbvkwpt1669zkrg4Xpui+MHVMJZkcGNv3+ZDRKieCIIhaUZem6OhCgnAmf6YEJmcGSAVEGWemjCvTtJBxTeRV+5+UMTgxmXM9SOq1iROgmIgpujdM2XwYFwGj1qdVTgRBEE3hkEcjLd0uKnQ8PztlZFl+bVyqbVmmrcNVzFRxZcoImbpETJkdekXKihKxfF2rklySeuvKgxFfu7owal1XAaP7Tjk0BEEQLSNv7xqnRybkiJm8vJk6xIxOXOTlyfSrkHHZsTeqV4+QEY/bhExVJ6ZIPgxQXMgUdWJ032mnYIIgiAYR82iAgk/fNpH3RGyb0LE95iCmKTHjJHYcHRndtFIREeMiYFz3hBHrpOfFeuo5jchg2bKuAsaWD6NL6i3yoMcmc2GqiBdbLHJoCIIgGqZSYnDVXBuhft5UUxGKihkbVcSM1Cdkb/QubkyVVUnpebkvVR850ISQkcsp72sQMvKxfCemipDRxVIFZJ2QoCEIgiiCSVj4GlFiqCclA9tWNjlMNRVxZmxCxih2LEKmiiOjEzFFBIzr9FFUR+/CmOpVWV5ddpO7Mhvc1S1eXGK6JANLZRWhN0cb6xEEQdRI2NygaiVvOsrhnDrVZMNlIzzxvEnMqG1HZbJRbWLGJmQAvZipssFdVEcvTGz16lxi3ZQT020hU2p6SREyTPneBCRoCIJYnBR5TIENl5yZvOkiMXdGM9WUERzC+yrOjEnIRPGYUoeXkdvTlrE4MjoRU8SNqbJDr1pHrFdldVLdSb3l81fcxAt/XSSZN/c7Y0bxEoYs+b2ZnyOHhiAIou+wJhAbhIxUx/PticAFH0KZnpMFC1AgnyZHyERl1JhCOwZHpi4hU1XEmJOANcc0LoxcR76pu0wp8WNNJPYWSeo1xSskboTPySZixGMBJQUTBEH0jrwl2E5lXaeblPOi8MiKkNQtsQmWMmKmiJBxcWTKTCkVy2/JllXLZ+to2uyBE6M7Zp/6qX9ZtbmtrIjROTHJMaY5JpwLaWM9giCI/kJyWtSpK4N4ybgzyXFhmsky1SS1bxAzRrFiO+c4vWQSMpJDYxAyNhFT7iGO+QLGJF6kOBoBY2zHIGKKPDOpjumkKnkweX1xdWFEASM6MPw8P5ceiz8Xdc6vRkjQEARBFKXo/jImd8Z3d20Y7HksuqXXqjOjO5ctq2/D5sqoMfLETBU3Jq+cXBba42od+1RRtlwbhEwRNyZTR5PQmxEtBYRMUo4xBCRoCIIgGsTh8Qcu+8AwVbjY3Bld7oxQRxIwYhs1OzNVXZmiIsaWF1NGwBRJ5hXLGPuiuDC6vhTd7E4URU3kw7gKGNs0Ev+s8nJhXFwYFrJ0elMRQ5QUTBAE0Y8IwsS5vOl4jmAKWTlnRidmikwxiTf2smJGfz3uYqauZyap8aU2HJyYMrv2mpJxXYSM+t0tv6aAoCnhxIhCJj2GpD7/bPJiNQEJGoIgCBOqyHBZgq2W8Xy7O6OZjmKANgkYUMUGk8rz41Edpj+e48oUdWQAWciYHBkXceJWRmjXMQ9GjJ3tsyaeImDKPDPJ5p5Er8NSSb2uIqaoCwM4JPRaxItYT7e6ib+en6OkYIIgiObIm27SkREtxfJqTKuhTP9/ZYxpH/TIpDKyyIFSXt0oT0R3m6lreinPjXHPn0H2mIMwEfuaXG8XhIz+e31OTJ35MPxckXwY0/SULreGKZ9pE5CgIQiC0GFZZm3cf8ZUR1zFpCYCa57VxN0Z1UGJXpudGeNxyxSTLldGFDI68eQiZEwixiWHpoiAyZs+yiubxG8wqbeIE1M2FybPiXEVL2ldSOdcppF4m6J4UUVPMEs5NARBEI2jEyqZh0Wq5ExLWWOqx5HN96jqzOjEjC1XRrsUO/5expExTSvx81F9vZBxeWaSbVl1JoZUFvrjLLvEWTdlVPfqpFLJvPG5Ki6MKamXfy4uScJMqa8TPyz+PML5OTRF4X2/77rrLrzxjW/E6tWr4Xkebr31Vuk8YwxXXHEFVq1ahaVLl2Ljxo14+OGHpTLPPPMMNm/ejJGREaxYsQIXXHABDhw4UOlCCILoX9owbkhP2raIF93+M5lcGF1ZnTvDvwt7zgBCDo3GnlcTfVWRE7L0uLpRHo8ZIs2X4edY/E+sz5gsZsLYeQnirzCMxEzyPjkPzAXRzU53Tjw/F4RCmajtNH70NR9E5+Z08eKb+pymzFwYImTRubmAIQgjIROVjb7mwqj92SCMvuYjR2V2Pn0dhAwz8yHm4+8z8Tn5K1C+QimG+H5G+crGcvwKwujzm4++wvgrmA8RBNFXGH8F8yHmZ4OoXBBifi6IyswzhPEXr5PUnU9jB3Gd+blAjjUfLcWOvuIy8blgPsD87CyC2cMI52cRzD6LYPaw/m+rBgoLmoMHD+KUU07Btddeqz1/9dVX45prrsH111+P3bt348gjj8SmTZtw+HB6EZs3b8ZPf/pT3HHHHbjttttw11134cILLyx/FQRB9DVtHTesOwTbno6tHlM30RO/YhIhgWwScCo8WFa0xDfmVATpxUz0mmVcGS5mgKyQYUhdgLqEDBcpooiZC1kiROaCUCtiUnESxl9ZEWMSMKJ40QkYUXSI30XRoTs/Ox8gCMP4O7OKjzwBY6ufnAtSEcOFjCo6AkHA8K9EiAQh5udSETM/l9aZnwsQCkKF1wkVkZLWi76L9eZn5xHMBwjn5xDMHkYw+yzC+VmE87OYn30W87PPIghmc/7qyuMx3X8BXCt7Hm655RacffbZAKI/ltWrV+MDH/gAPvjBDwIApqamMDY2hhtvvBHnnnsufvazn+Gkk07Cfffdh9NPPx0AcPvtt+NP//RP8etf/xqrV6/ObXd6ehqjo6MYeMlmeJ2hst0nCKICLJjF/E9uwtTUFEZGRpzr9WrcANKx43d3/1vUZ9+H53cAvwOv04kcFXEvGD+elRcESFLGN5dJ63fSc76v3RGYH0unfGQnJfqMzM6MbjWTupLJtrcMd2X4cdGR4fGB4nkyrvkxebkxpv1hXB41IJZT82r0K4/SKSBdmV7mxZRdWm1K6BVjOeXXhNkpqLRMCBYGYPFT7PnrUHkPAMHMQfzmmx8uPG64UGsOzaOPPoqJiQls3LgxOTY6Oor169dj165dOPfcc7Fr1y6sWLEiGZQAYOPGjfB9H7t378ab3/zmTNyZmRnMzMwk76enp+vsNkEQPaSpcQOoOHao4kOXS6N7ZEFMMt1kSgTWJAEnr2MxI4oWfg7QJwAnZWMxY3Jl0vZkIcNjiUJGfUyBbdWSeK5pEVNmNZLptSpexNdl82FsZcvkw/DvJuFRdEWSKoRM4kXXPs+FcREwSdkgSI4FMwfRFLUKmomJCQDA2NiYdHxsbCw5NzExgWOOOUbuxMAAVq5cmZRR2b59O6666qrMcRY0l1xEEIQd/vdXweQF0Ny4AZjHjumDh6Kl2qJD43OHxhPcGIvrEufc6KeQfNnt8T1j2USQxDV1gobpXBjVseGvNYKGnyvqzAQsvcEBgoARBI2094wiXGTHBslr8ZzOcWGMmcUMZDEjt6sXC2p5XXKvKr50Ykb6fBwcGbE/aTmzGFKFIZB1ZGzJvelrpGWEn6HT8mrlZwzVxcm4MWHyOmRB9lwQysJnPvoPRtVxQ0crVjlt27YNW7duTd4/8cQTOOmkkxA89I0e9oogCADYv38/RkdHe90NLaaxY92m/9PDXhEE0cS4UaugGR8fBwBMTk5i1apVyfHJyUmceuqpSZmnn35aqjc/P49nnnkmqa8yPDyM4eHh5P2yZcvw0EMP4aSTTsLjjz9e+zxcPzA9PY01a9bQ9bWUhXx9/Noee+wxeJ7nnL9ioqlxA6CxY6Fd30K+NmDxXN9DDz1UedzQUaugWbduHcbHx7Fjx45kIJqensbu3bvxnve8BwCwYcMG7Nu3D3v27MFpp50GALjzzjsRhiHWr1/v1I7v+zj22GMBACMjIwvyB8+h62s3C/n6RkdHa7m2bo0bAI0dC4WFfG3Awr++Y489Fn6RZ6A5UljQHDhwAI888kjy/tFHH8WPfvQjrFy5EmvXrsXFF1+Mj370ozjhhBOwbt06XH755Vi9enWyouFFL3oRXve61+Fd73oXrr/+eszNzeGiiy7Cueee24hiIwii99C4QRBE47CCfPe732VItyhIvs477zzGGGNhGLLLL7+cjY2NseHhYXbWWWexvXv3SjF+97vfsbe//e1s2bJlbGRkhJ1//vls//79hfoxNTXFALCpqamil9AK6PrazUK+vjLX1i/jRtn+t4mFfH0L+doYo+urSmFB0y8cPnyYXXnllezw4cO97koj0PW1m4V8fW2/trb3P4+FfH0L+doYo+urSqWN9QiCIAiCIPqB+rNyCIIgCIIgugwJGoIgCIIgWg8JGoIgCIIgWg8JGoIgCIIgWg8JGoIgCIIgWk9rBc21116L448/HkuWLMH69etx77339rpLhdm+fTvOOOMMLF++HMcccwzOPvts7N27Vyrzmte8Bp7nSV/vfve7e9TjYvzd3/1dpu8nnnhicv7w4cPYsmULjjrqKCxbtgznnHMOJicne9jjYhx//PGZ6/M8D1u2bAHQvp/dXXfdhTe+8Y1YvXo1PM/DrbfeKp1njOGKK67AqlWrsHTpUmzcuBEPP/ywVOaZZ57B5s2bMTIyghUrVuCCCy7AgQMHungVdhbCuAHQ2EFjR//QT+NGKwXN17/+dWzduhVXXnkl7r//fpxyyinYtGlT5lkv/c7OnTuxZcsW3HPPPbjjjjswNzeH1772tTh4UH68+rve9S489dRTydfVV1/dox4X58UvfrHU97vvvjs5d8kll+Bb3/oWbr75ZuzcuRNPPvkk3vKWt/Swt8W47777pGu74447AABvfetbkzJt+tkdPHgQp5xyCq699lrt+auvvhrXXHMNrr/+euzevRtHHnkkNm3ahMOHDydlNm/ejJ/+9Ke44447cNttt+Guu+7ChRde2K1LsLJQxg2Axg4aO/qHvho3GtndpmFe/vKXsy1btiTvgyBgq1evZtu3b+9hr6rz9NNPMwBs586dybE/+qM/Yu9///t716kKXHnlleyUU07Rntu3bx8bHBxkN998c3LsZz/7GQPAdu3a1aUe1sv73/9+9oIXvICFYcgYa/fPDgC75ZZbkvdhGLLx8XH2D//wD8mxffv2seHhYfbVr36VMcbYQw89xACw++67Lynz7W9/m3mex5544omu9d3EQh03GKOxg8aO/qDX40brHJrZ2Vns2bMHGzduTI75vo+NGzdi165dPexZdaampgAAK1eulI7fdNNNOProo3HyySdj27ZtOHToUC+6V4qHH34Yq1evxvOf/3xs3rwZjz32GABgz549mJubk36OJ554ItauXdvKn+Ps7Cz+5V/+Be985zvheV5yvM0/O5FHH30UExMT0s9rdHQU69evT35eu3btwooVK3D66acnZTZu3Ajf97F79+6u91lkIY8bAI0dNHb0J90eN2p92nY3+O1vf4sgCDA2NiYdHxsbw89//vMe9ao6YRji4osvxplnnomTTz45Of4Xf/EXeN7znofVq1fjxz/+MS699FLs3bsX//Zv/9bD3rqxfv163Hjjjfj93/99PPXUU7jqqqvwh3/4h3jwwQcxMTGBoaEhrFixQqozNjaGiYmJ3nS4Arfeeiv27duHd7zjHcmxNv/sVPjPRPd3x89NTEzgmGOOkc4PDAxg5cqVPf+ZLtRxA6Cxg0NjR//R7XGjdYJmobJlyxY8+OCD0jwxAGke8SUveQlWrVqFs846C7/85S/xghe8oNvdLMTrX//65PVLX/pSrF+/Hs973vPwjW98A0uXLu1hz+rnS1/6El7/+tdLT35u88+OaA80drQbGjvqo3VTTkcffTQ6nU4mo31ychLj4+M96lU1LrroItx222347ne/i+OOO85adv369QCARx55pBtdq5UVK1bg937v9/DII49gfHwcs7Oz2Ldvn1SmjT/HX/3qV/iP//gP/OVf/qW1XJt/dvxnYvu7Gx8fzyTYzs/P45lnnun5z3QhjhsAjR0ibfxZLvSxo9vjRusEzdDQEE477TTs2LEjORaGIXbs2IENGzb0sGfFYYzhoosuwi233II777wT69aty63zox/9CACwatWqhntXPwcOHMAvf/lLrFq1CqeddhoGBweln+PevXvx2GOPte7neMMNN+CYY47BG97wBmu5Nv/s1q1bh/HxcennNT09jd27dyc/rw0bNmDfvn3Ys2dPUubOO+9EGIbJgNwrFtK4AdDYQWNHO+j6uFElo7lXfO1rX2PDw8PsxhtvZA899BC78MIL2YoVK9jExESvu1aI97znPWx0dJR973vfY0899VTydejQIcYYY4888gj7yEc+wn74wx+yRx99lH3zm99kz3/+89mrX/3qHvfcjQ984APse9/7Hnv00UfZ97//fbZx40Z29NFHs6effpoxxti73/1utnbtWnbnnXeyH/7wh2zDhg1sw4YNPe51MYIgYGvXrmWXXnqpdLyNP7v9+/ezBx54gD3wwAMMAPvUpz7FHnjgAfarX/2KMcbYJz7xCbZixQr2zW9+k/34xz9mb3rTm9i6devYs88+m8R43etex172spex3bt3s7vvvpudcMIJ7O1vf3uvLklioYwbjNHYQWNH/9BP40YrBQ1jjH32s59la9euZUNDQ+zlL385u+eee3rdpcIA0H7dcMMNjDHGHnvsMfbqV7+arVy5kg0PD7MXvvCF7EMf+hCbmprqbccdedvb3sZWrVrFhoaG2LHHHsve9ra3sUceeSQ5/+yzz7L3vve97DnPeQ474ogj2Jvf/Gb21FNP9bDHxfnOd77DALC9e/dKx9v4s/vud7+r/X0877zzGGPREszLL7+cjY2NseHhYXbWWWdlrvt3v/sde/vb386WLVvGRkZG2Pnnn8/279/fg6vRsxDGDcZo7KCxo3/op3HDY4yxYp4OQRAEQRBEf9G6HBqCIAiCIAgVEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbQeEjQEQRAEQbSe/w/s5VmwTYdILgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "grad_mat = np.loadtxt(folder_name+'s2_activation_in_1x2e+1x4e_lmax_4_8_grads.csv',delimiter = ',')\n",
    "grad_mat = grad_mat.reshape(grad_mat.shape[0],-1,2)\n",
    "grad_mat1 = grad_mat[:,:,0]\n",
    "grad_mat2 = grad_mat[:,:,1]\n",
    "# print(grad_mat)\n",
    "vmax = grad_mat1.max()\n",
    "vmax = 1\n",
    "fig, axarr = plt.subplots(1,2)\n",
    "# fig, axarr = plt.subplots(1,3)\n",
    "axarr[0].imshow(grad_mat1,cmap='RdBu', vmax = vmax, vmin=-vmax)\n",
    "axarr[1].imshow(grad_mat2,cmap='RdBu', vmax = vmax, vmin=-vmax)\n",
    "# vmax = 10\n",
    "# axarr[2].imshow(np.sum(grad_mat**2, axis=2),cmap='RdBu', vmax = vmax, vmin=-vmax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x726d7ab17850>"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "grad_mat = np.loadtxt(folder_name+'s2_activation_in_1x0e+1x2e_lmax_2_8_grads.csv',delimiter = ',')\n",
    "grad_mat = grad_mat.reshape(grad_mat.shape[0],-1,2)\n",
    "grad_mat1 = grad_mat[:,:,0]\n",
    "grad_mat2 = grad_mat[:,:,1]\n",
    "# print(grad_mat)\n",
    "vmax = grad_mat1.max()\n",
    "vmax = 0.1\n",
    "fig, axarr = plt.subplots(1,2)\n",
    "# fig, axarr = plt.subplots(1,3)\n",
    "axarr[0].imshow(grad_mat1,cmap='RdBu', vmax = vmax, vmin=-vmax)\n",
    "axarr[1].imshow(grad_mat2,cmap='RdBu', vmax = vmax, vmin=-vmax)\n",
    "# vmax = 10\n",
    "# axarr[2].imshow(np.sum(grad_mat**2, axis=2),cmap='RdBu', vmax = vmax, vmin=-vmax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 377,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7949d3839120>"
      ]
     },
     "execution_count": 377,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjQAAAERCAYAAABsAj0bAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABmRklEQVR4nO3deXxc9Xno/885Z87s0mgfSZZkyRu2MRiwjTEEQoIDIQkhCdlJS5bb3KaQG0LbJPRXktKblpT2trlJadIllyQtZA8QaEJCzBaCMV4wYLzvtqx9mdFolrP+/jijsQRmsS3paOTnnde8Yo1GM8/RmK+feb7P9/tVXNd1EUIIIYQoY6rfAQghhBBCnC5JaIQQQghR9iShEUIIIUTZk4RGCCGEEGVPEhohhBBClD1JaIQQQghR9iShEUIIIUTZk4RGCCGEEGVPEhohhBBClD1JaIQQQghR9nxNaO666y7a29sJh8OsXr2aZ5991s9whBBlQMYNIcSJ+JbQ/OhHP+KWW27hK1/5Clu2bGH58uVcddVV9Pb2+hWSEGKGk3FDCPFqFL8Op1y9ejWrVq3in//5nwFwHIfW1lY++9nP8qUvfek1f9ZxHI4dO0ZFRQWKokxHuEKIl3Fdl5GREZqbm1HV6flsdDrjxtjjZewQwj9TOW4EJvXZ3iDDMNi8eTO33npr6T5VVVm7di3r169/xeMLhQKFQqH0dWdnJ0uXLp2WWIUQr+3IkSO0tLRM+euc7LgBMnYIMVNNxbjhS0LT39+Pbdskk8kJ9yeTSXbu3PmKx99xxx3cfvvtr7hfW/pBFE2fsjiFEK/OtU3s7T+moqJiWl7vZMcNkLFjNqlZcD6NC9q56Zql1MeCABiWwzcf3cveLXvp37nB5wjFGzGV44YvCc3JuvXWW7nllltKX6fTaVpbW1E0HUUL+hiZEGImT93I2DF7hBONRBMJEpWVVEa99850HCoSCcKJRnk/y8xUjBu+JDR1dXVomkZPT8+E+3t6emhsbHzF40OhEKFQaLrCE0LMQCc7boCMHbNJrLqCSEWIqK4RCni9F6qjUBMPEq+OoAZ0HMv0OUrhJ19WOQWDQVasWMG6detK9zmOw7p161izZo0fIQkhZjgZN85cWjBMrDJMdSxIKKASHrtpKlVRnUg8SKy+ze8whc98m3K65ZZbuOGGG1i5ciUXXnghX//61xkdHeUTn/iEXyEJIWY4GTfOTJHqRkKRAImojq6p6NrYZ3GHRDRIOBoklKhjpGufr3EKf/mW0HzoQx+ir6+PL3/5y3R3d3Peeefx8MMPv6LhTwghxsi4ceZRVJXKOYuoq4nSUBkmqqsUZ5xQUKmNB6mvjtCXbGRgt4rrOP4GLHzja1PwTTfdxE033eRnCEKIMiPjxpklVFlPMBomHg5QEQ6gqyoKXkOporiEAxrxcIBwLEgwXkMh3e9zxMIvcpaTEEKIGatm3nJqG+PMrYvRUBEiFFDQVdBVCGoKdVGduXUxqupj1C64gGC82u+QhU8koRFCCDEjBePVhGMRQhGdinCAcMCrzmiqd1MBXVOpCAeIR3TvsRU1foctfFIW+9AIIYQ489Qvvoj61krmNVXQWBGiNhokqCkEVG/KSVMUqiM6jRUhFjbGGRrOAcukOfgMJRUaIYQQM064KkksEaaqMkxDZZh4KEBU19BUUBXvpigQ1VXiwQC18RCVlWGiiRChyjq/wxc+kAqNEEKIGSVS20zt/POpb0mwuLmCjrooddEgiVAAXT1eoXFdiOoadVGdOYkwi5u97fSHFq0i3blbKjVnGElohBBCzCg1Hcupm1PBwqYKOuriNMRC1ER0QsXpJq24a76rQFhTSIR1GuIh5tXHsR2XvjkJAsGlktCcYSShEUIIMWOEKuuom5MgmaxgXkOchniQuqiXzIQCXjKjjavQBDUVB4easE4mFsSoi7EnGUdRoStejZEZ8vmKxHSRhEYIIcSMULPgAqrntLJ0YS1LmitZ0hCnLREhqqtUBFU0VSGoqRTzGRwXIrpCQFVRowFUNUJU1xhZUMuhqjDDfZcyfGQ/w4e2+XthYlpIQiOEEGJGqGiYQ6Iuyty6GI0V3jRTVFe9ysy4qaYxquKtdHJUr1JTEQxgRlyaE2FsxyVRG8Uy5kpCc4aQhEYIIYTvEq1LOPeCZhY2VnBJezXNFWGqwhrxoFpajqsoSqk6M2aspyaoKUR1hXjQO7iyLREmlTXYk4wz0rWE1JEd035NYnrJsm0hhBC+ClclqWiax9y6KC3VERIhvdQvc/wYSnBd9zWfR1MVdFUhqmtUR3RaaqLMrYsST7ajqPLP3WwnFRohhBC+WnTp5bS0JrhqcQMNsRCVIY2gpmA5MFSwAW9qSVPwdgseV6UpWC6m4yU6ruvtTZMIqcT0IBe3VbOoLsbRwRyRinez97H7fbg6MV0koRFCCOGbSG0zDU0VLG6upKkiTExXCWpe8pKzXQzbRVNBU0BXFWzXRSseTum4XjJj2C6u6+LgTT2FAyqaCjURHV1TWNgYZzid52hVkvxwj78XLKaMJDRCCCF8UdE0n46VK3nvijk0xIKoCliOS7pgU7AcTMfBtF1CAZWK0qZ6Ks642aOC5ZCzXAzbIWva6KpKNKihFvtqEqEAF7XX0FAZJjN8GS/98if+XbCYUpLQCCGE8MWcc87j7LPquKCpklDAW45tOi5dmQKZgkVxJol4UMNxXRJhHduF0jcAw3FJFyyypk2qYKEpx/to2hIhggGV+TVREuEAzy+qY+Do5XS/8Lgv1yumliQ0Qgghpl3d4tWcvbSB5W1V6JqKabv0jhbImg6d6TyZglU6VbsmoqOqCqqiUBlSUZWxKSevhyZjWKTyFv1Zs/T84YBXxonqGqGASlNFmFXzajjS3YKZX8nA7k2+XLeYOpLQCCGEmFaR2maWXnI2H1zRQnVEJ6BC1nB4oXuE3nSe3nSBTN4iHg4QDWq01ERLuwMnbb30PK4LGcNiKGfRM1rgUP8otuOSM2yCAZWBrEFlOMCa1mrqIhqrW6rgYngwFOD3ktDMOpLQCCGEmFb1Cy9gYTJOXdSbQuoeMejPGuzvzTCQMegfKeBYDjlDJx4OEAlqNFSEKFgOtgtaccbJcSFveb0zw1mTgYyBYTmksibBYoUmHtZpTUQIqGEAFtXGOHduFTsWXMDg3i1+/QrEFJCERgghxLRZ+vb389aLWnnzgjqaK0LsH8rxm129dA3n2blngELexMzbOK5LrDJEJB7EsBwS0SCaomA6bmnZtutCqmDRm/GqMwe6RjALFrmMAcCxrgDBUICcYbEwWcH5TZVc1FJBQzzIof6V7J07l93r7vPxtyEmkyQ0Qgghpk3dnErOaqwgqmsUbIehnMmh/iy9Qzkyw3kKOQPHMnAdm4BehaapZAoWOcPGdBxc10tkwKvQWLZL1rDJ5C2MvIlRsMkWExrLtDF0i0P9WTRVYV5NFMuBcEDj7JYEwyMFdvv4uxCTSxIaIYQQU66iaT5t51/AH795HiuaKnipd5T7Xuph4/5Btr/QTW54iKGD27CNHACKqlFoWkC+vgVFVeiqjlARDpCzbDRVA8B2IFUw6R7O0T2QZbBnlEJmlJGufTiOjapqqIEg2cxiDleFGcgYDC1NkggF+NDyZla2VtG57xqObnoE28j7+esRk0ASGiGEEFOuYdEy5rZX05YIUxFUydsO246m6O4ZId19lHyqDyMzNOFnCplBApEYhVyYnGGTNWwcx0tkFAVcij00ho1ZsDCyeQqZIfKpPhzLq9IoqoYeq8SxGjnUk2FXXYylyQoqQyrtVRGSbQny6VX0bPudD78VMZkkoRFCCDGltGCYD79zMec2VXI4lWf/YI4fbjzC9he6GTq051UPjsz2HcExDULxavpHCtTGg+Rth1BxZz3TcRjOmnSn8mRSeUa69pEb6sbKj457FpOB3ZsYCugUMheRzRTY2VpFRPee410XtrK7rYr/koSm7ElCI4QQYspowTDta67irfNraYoHWXdgkK2Hh9m/d4DeXc+R7Tvymj9fSPeRT/dj5Kq9Sozt4BSbaBwHcoaNkbfIj5rkU30vS2aOcyyT/t0bUVQN14F9C2qpCussS1YwrybKr5deTN/2pyf9+sX0kYRGCCHElFm89hrmtlfTnzXJmja/2dbD/v2DHH1+8+smMwCu41BI9ZMfbSeVNTEdF9P2EhrTccjkTfJZg3x6GDObfs3nso083S88TmFkOQ9WhWmrj3HNuU1EdY25yzqwjbws5S5jktAIIYSYEnq0kj94+yJqIjpdIwWGsgYvbu2ie9uGkzokMjvQST57LumciWl7ZzwBmLbLcNYkP2qSG3rjzzd04Hl2hcIMtbdy5dIkddEgay+Ywwt1MX4pCU3ZkoRGCCHElKhbtIr6WBCAF48Oc6g/S/+eF076xGvbyGMUbCzDxnRcigUaTMfBsBxvefZo6qSec3DvFlzHZvPhVrJNlTRWhqld2sDTc5cxfGjbST2XmBnU13+IEEIIcXKWveuDXPrWs2hNRFAVhd9tOMLGX/2eTM/BU3q+fDpNPmtQsBwKlk3BsjFtl8FRg9xI4aSTJMfymoUf/M1evv/EfhbXxbj+nCTv+tDlaMHwKcUo/CUJjRBCiEm3YF4NLTVRhnImR4ZzDHYee9XVTG+EZeRwLBfH9So03s3FcdzS3jWnYvjIXga6RujPGhRsl4bKMPWLLzrl5xP+kSknIYQQk2rF+z/K7Vcv5sWeEb7x2z107R+if+eG03rOQqqffLaZvOVg2l4PTcFyyI8a5FP9p/y8qSM7SB3ZwTeScQ5d1EZFOMDHP3oh3w8EObblN6cVs5heUqERQggxadSAzqL2aqrDGrqm0n8sTf/+U6/MjLGMHJbhLdl2XI7fbOe0KjRjeo+m2XJwCMtxWZqsoGFuzWk/p5hektAIIYSYFGpA5+I/+Bi18SC/3DPANx/dy65Hfk668/RPTDJGBinkjFKFZmy1UyFnURgZPO3nP/jUL3ji4S28cHiY2qjOiiUNVDTNP+3nFdNHEhohhBCTYt6l7+T9q1qJBAM8urOXwzv6Ju25bSOPbeSwHRfT8ao0tuNiWw5WPjMpr9G/cwN9Qzmiusbi5ko6Vq4kGK+elOcWU08SGiGEEJOidX4tDfEgO4+l+f2TBzj8zEOT+vxmPoNhedNOpuN4m+wVLBzLnLTX2PnUFr737GEO9Y/y/rfM4/x3v2vSnltMrUlPaO644w5WrVpFRUUFDQ0NvOc972HXrl0THpPP57nxxhupra0lHo9z3XXX0dNzckvuhBCzh4wb5W/+m6/lLUsbaIqHONY9QuemX036a5ij6eLxB+7xW8Ge1NcYPrSNRx8/wNHBHO87O8lnr1w0qc8vps6kJzRPPPEEN954I8888wyPPPIIpmly5ZVXMjp6/HyNz3/+8zz44IP85Cc/4YknnuDYsWO8733vm+xQhBBlQsaN8tZ20btYek4jvek8v93bz6Ft+6bkdazilJPtejfHdbGtyU1oAI5tfYzdu/s5MJRjKG9Sv/TiSX8NMfkmfdn2ww8/POHr7373uzQ0NLB582Yuu+wyUqkU3/nOd7j33nt561vfCsDdd9/NkiVLeOaZZ7joIln/L8SZRsaN8vbnH7+AC+dU8f89uJ0dWzpPe4n2qzFHU+QMq3SWk2E7GNmT2yH4jbDyo2x/+Kfcf0EzkaDGZVcu5+DSdjb/9N5Jfy0xeaa8hyaV8v6y1dR4S+A2b96MaZqsXbu29JjFixfT1tbG+vXrT/gchUKBdDo94SaEmL0mY9wAGTumQyAcQ1UUMoZFb9cIfTufmbLXciwD23GLS7dd78+WMWWvt+3gEIf6s8ytizG/rWrKXkdMjilNaBzH4eabb+aSSy5h2bJlAHR3dxMMBqmqqprw2GQySXd39wmf54477iCRSJRura2tUxm2EMJHkzVugIwdU23epdey8rrr2NaZ4t7NR3nhwR9hZIam7PVsI49hOV5lxnbIGjZWbvT1f/AUbbj3P9n89AFWz63mkxfNJbns0il7LXH6pjShufHGG9m2bRs//OEPT+t5br31VlKpVOl25MjrHzkvhChPkzVugIwdU615QQ0L5lTSNZxnZ+f0VL9sxy3dgCmt0AClPXSiukZdWyN6tHJKX0+cuik7+uCmm27ioYce4sknn6SlpaV0f2NjI4ZhMDw8POHTVk9PD42NjSd8rlAoRCgUmqpQxTTQgmH0aIJwoh5VD6KHYyiqVvq+mc/gmCaFzCDGyCBWfuo+dYmZazLHDZCxYyrp0Uo+dWkHWdPmb/51PV1bfzstr5s1bAzLO/rAsBzM3OTsQfNqMj0H+dufvshZ82s4d2kDixddz8++/q0pfU1xaiY9oXFdl89+9rPcd999PP7443R0dEz4/ooVK9B1nXXr1nHdddcBsGvXLg4fPsyaNWsmOxzhA0VVCcZrqGpbQiieIF4VJloZIhTRScSCBAMq8XCAgKqUfmYkb2FYDqmcSXakgJGzSA/lMLJ5ho/soJDqwzbyPl6VmEoybpSftlVvYWl9nMOpHP27N+I6zrS8ru24WMXqjGHZU16hATj8wg5s+yyuvayDBXUx7g+GZTyagSY9obnxxhu59957eeCBB6ioqCjNbycSCSKRCIlEgk996lPccsst1NTUUFlZyWc/+1nWrFkjKxXKVCAco7LlLBoXzCNaGWLZvBri4QDxsI42LmkBSmXilxv/GfvlP5PJL8OwHJ4/MER6KEf/4V4G9m7BzEqD52wh40Z5WfH+jxJLhPnuxsNs2TswpX0zL2dYTmkcsR130nYJfi1DB54n3bmLpYs+yYK6GK0XXsnBp34x5a8rTs6kJzTf+pZXirv88ssn3H/33Xfz8Y9/HIB/+qd/QlVVrrvuOgqFAldddRX/8i//MtmhiCkUqW2mqnUJzQuSLJlXw6LGCs5vrqQuGmRORZCACjnL+yQ1YjgM5kwyBYtUwcK0HbKmt9vnmKiuoWsK8WCA6ohOVFepjejoqkJEV1CA7lGL3ozBzv5Rth4+h709GQ6+1Et2sIvBvVv8+2WI0ybjRvlQAzqff9cSnj+W5r5H9nD0uVdfZTYVDMuZMOU0mbsEvxbbyHO0z5sK71hcTyFzBV1b103La4s3ZkqmnF5POBzmrrvu4q677prslxdTrHLOIuLJdtqWNNKWjFMbD5KIBgE4OJyjM11g36DXG9M7apApWBwdzNKbLpDKmoxmCjiOt7unO65ao4c0tIBKMKJTHQuSiOrMrYtREQ6QjIcIBVQyBYuC7ZC3bBqrIsTDAVpro/Slm9jf1MrIQB9925/25fciTo+MG+WjZsEFFGyH/b0ZDq5/ZNr73byGYKf05+m0Z/Mefp4IEw8HWPmmBTwoCc2MMmVNwWL2CIRjLLr8aqqTcT68po3GeIjFdTEqgipHRwz2DGQ5Mpxj3fZe+kcK9HemMXIWw11HMEYGyQ11n9J8c7S+FT0cJzFnPuGYTk1jBTWJMGe3JFicjNMYD3FWbRTbdTkwlGcwb3L/1vPYd3iY/ZtfYujA81Pw2xDizFW/9GLmn7+AkYLN3gNDvjTvG/bxCk3Bmp6+nTF925/msYFjfOhT7+bmy+bRN/SHPHPP96c1BvHqJKERr6lq7jJq2uYzf0EtTVVhdFXFdFy6MgYpXeX57hG2HBpif+8oxw4NkRsx6N/3POZo6rR7XLJ93hLbka69BOM1jLQvY7C2ksFUnsFMgXkNcXRNRVNgxLCwbJe5dTE0VcEsLEYLhadsx1IhzkQd584jEtHZsH+A7n2dvsTgjKvKTHeFBrxVTzs702QMm0hEn/bXF69OEhrxCoFwjObz3sKyC5q5bsUc4sEAdVGdEcNm45FhuodzvLh/kPRgjt79Bxjav3VKVzg4lkl+uIeurT10Fe97Bogn20kuXk6sMszC+TU0VIa4sL2GKxbUkV/RQtY8h02HL+W/n9hP/6HDDOzeNGUxCjHbrXj/R/n2H67ga7/dw8//7UcU0v2+xOG8rIfGD1se+g0/nF9DMKBy1tvex65Hfu5LHGIiSWjEK8y54K20LKxl1bwaWhMRNAVURaFgefPmh/tG6dw7wEjXvtKmU37I9BzEtgyitc0EgiqD1VGWNldiu0Eqgho1YZ1MMs7OhXWEo0GG9j8/bQ2EQsw2zY0VxHSVwYzhWzIDXoXGj8rMeLmBY7xwOIWmKrR21NAzdxnDh7b5GpOQhEaMs+xdH2ROS4J3n9/M/OoonSN5ntg/wP7eDNv3DDAymOPg+l/OqKQgN3CM3MCxUvVl29MXU9vSRFNbFSvn1dCUCPPpSztI5y0eXVLP/r5RNt7/MLmBYz5HLkT5mLPyalI5k39Zf4gn7/2Zr7E4tlPqnfGrQgPwxHe/z7Kr38c/fXwF9zVX8M9/JQmN3yShEYSrktTMW84VF7ZwdlMlyxsrqY5o9GcN9nSPsPfQEAc2bSHTc2BGJTMn0rf9adJH6zALlxAMqFQsqqO9KozjQiig0jtaYLj3Uo7tOSj9NUK8AZVzFjF/eRO25bBhV/+07jlzIn730JTisEyymQJzE2EunlfLP/sWiRgjCc0ZLtG6hHd86K00VUXoqIviuPCLHT30pfM8vbWLQ5s3M9K1z+8wT0oh3c++Jx6g8/kkLy1ayZaLWmmoDLG0OYGuKXz0bQsYubSdn/y6md3r7vM7XCFmtBVXX8qHLmzlH36wlb2P3e93ODjjVjn5PfW097H7+eZb5pHJWyy64r0c2bpBqr8+koTmDHbW297HorPqufnN8wmoCnsHswzlTH679Ridewfp3PSradvOfCrkh3s4+ux/k0+vpmZOM4krFjC/Lsbb5tdREVKpCAf4aW2UPeu3kDqyw+9whZiRPrK6ldUtVQx1HvU7FGBiD42fU05jHlq3j+pknEtXt7KzJcHvv/ddv0M6Y0lCc4Zqf9O7efdb5tNQGeLgcI6MYfHrl3o42jfKzt9tmlX/wPfv3MDAbpVfhq6jOhknu7KF9qoINRGd9148lwd1jS0PdPteShdipkkuu5QNBwY5NJSbMasEXed4ZcZ+AxsyTrV9TzxA47mXs/aCOQQDKr/3O6AzmCQ0Z5jqjuUsWnMun7h8Pu8+q5buUYsfbD3GS0dTPPObTQwffHHG98mcCtdxeOmXPyEQjjEyeA0LOqr5g9VtvHNRLataqviPZJztu/vZ9tCP/Q5ViBnhTZ/4BAuScdZvOcbA0R6/wymx7eNnOTk+TzmN6X7hcdpvupzqOQl+vGjljEn+zjSS0Jxh5px9Fhctrieqa/RlbfYMZFm/p5/+zvQZcR6SlR+lc9cBbNvhuZYELZVhsqbNspYEmbzFvtpmmQMXAmitjRIPB+g9eGRGNdC746ac3BmS0AA8tbefJc2VVM9pITfUU9oYVEwfSWjOEG0XvYuWhbV87spFrGiqYHPXCF9bt4cd+wZ44cGfzcqqzKvp37nBux2+nHUrOnjzkgbee3YjF7ZU0VT1fnYcSfH0f37P7zCF8E2ktpmLF9TSnS7MqGQGwC5urKepCvYM6KEZ87Pv/Jw5517IRataaHrbQv7+L/7e75DOOKrfAYjp0dhexfKOaqqLW3X3Zw32HB6m99DgGZXMjNe/eyPdB4fY0z1C3rJRVYXFzZUsm1tFonWJ3+EJ4ZvquctI5y06B7N+h/IKYweZ+r3C6eVyA8cYOHiAaFCjvTbqdzhnJKnQzHJzVl5N07wa/vSdS5hfE2X9kSHue+EYj64/fMZv123lR9n72P307JzPsaHLOKupgmvOaWJxXYyRD72VfUdX8OwP/8vvMIWYVtfd/BkGMwb/776XOPrczGtxdR0X0/YqM449cyo0AEMHnmdn1wpWzq1mzsqr6dz0K79DOqNIhWaWaz87yUVLG1hYG6U6rNGdLrBxZx9d22VXyzEjXfs4umeAHUdShDWVumiQixfU8qZljdQvvdjv8ISYVm9bmmReQ4yenc/7esTBq5kpjcCvJjtSwHRcapsqCVcl/Q7njCIVmlmqcs4i2s4/j/+1diHxoMb6I8MMjBr86Fe7OLzxCVmi/DIHn/oFPTua+YeIzsLGOBe21/Cmjhr2rz2XF+vr2ffEA36HKMSUq5yzCNNxeOnQMJmeg36Hc0KO5eJYDsoM66EZs+nH95DLfICq+hjv/Pj7+NnXv+V3SGcMqdDMUksvv4irL57L6jkVLKyNsOXQEL945jAH1z8iycyryA0cY/umwzz9fDdRXWN+TZRrljdx5Zs7aH/Tu/0OT4gp17R0Gabtkh6Yeb0zYxz3+AondwbsQ3Mie578LTUVIf7o4nYaz73c73DOGFKhmYXmv/larr+0nURIZ2vPKL2ZAr/f1EnPnr1Y+VG/w5vRjm35DenOdn4wt4rLzqonHtS4ZF4th/qzDB1aMqs2HBRivOXXfhhFhXse28eO38zc/jrXcUvTTjN1+snIDHHg4BCDF5okkjV0+x3QGUIqNLPM2e/4AJ9879l8YGkDy5JxfvpcJ//2yB52/uZnDB143u/wykKm5yBP/eY5vvvwbkzHZdWcSj5x8Vyu+sBbOOtt7/M7PCEmXdXcZXzlg+cSr4qw+af3zugjT8YqM67r4s7cMOl8aRe9GYO65kqi9a1+h3NGkIRmFmk67wrOXdpAVUSnZ9RiZ/8o2/cN0LV/0O/Qyk7/zg0c23OQ9fsG2D2QJWc6rJpXQ/v8Wr9DE2LSxepbMR2X4b6ZX8F1HNdLaoq3mWrowPOs296DbTm0nrfK73DOCDLlNEs0nns5n/7YKt6/rJE9A1m+t/koT+/oZesDPz1j95k5Xf07N/BLy2Rv5zKuWdXC+89OsryxktHCJ+jaPyiNwmLWaGyvpmukwMGNz/odyutyHef4lNMM7aEZ88h/3c9Zb34LX/rIefzfeJCt9/3Q75BmNanQzAJVc5eR7GikoSKEokCqYPHC4WH6j6UlmTlNQ/u30nc0Vdx8z0VT4Ly5VTTNq/E7NCEmRaJ1CYqqsKs7PWNXNo3nOvaMr86MyQ/3MJrOkwgFqKyRzfammlRoyly4KslHbljL5QvryRgWjx0Y5EcbjvD8w08y0rXP7/DKnus47HviAYa7VpI1vDOfPrGqjdHlc/iz3Mc4vP0o3S887neYQpyS5LJL+fAHV/HI04e59+5f+x3OG+I6dml1kzMDl22/3P7f/Te9HzmPxkTY71BmPanQlLFwVZLmcy5i5dxq5tdEMW2XXd0j9HemJZmZZAO7N7Fr3yD7ezNUhFSScZ0LF9fTtrTF79CEOGVzzmrhvJYqCjmzbFbwuY7tdwgnxbFMBrIGmqpQNXeZ3+HMalKhKWNv/8P3sri5EttxebFnhHs3HObgS70cfuYhv0OblZ5/4Icc23MxiahOR12ctWc1cPWSJF+2Psr2xx6XU7pF2amvj2PaDoc3PuZ3KG+Y69gzftn2y939wHbiVWHOXXshR3fPZ//vpP9uKkiFpgzp0UrmXXotH1zZwlsX1OG4cGQ4R+feAY5uKo+ycbnq2/40j23s5PGdvcyvjnBhc5wPXNbB0rdcjqLKf06ivDRVhXFcMLNpv0N5wxzHxnXwbjO8KXjM4Y1PMNyX5apzGlm5ao7f4cxaUqEpQyve+x7aknFyps2RVI6fbjpKb9eIrLqZJtsfeYieBRfw/cYKzm9JUB8L8sm3LcR1P8SWn/3A7/CEeF1qQKftoqvZfnCIHYeH/Q7npIw1BXt/Lo+ExsgM0b1tA5UfO48lzZV+hzNrSUJTRoLxapa+7Sr+v2uWYLtwJJXjQH+Wbc/spWfbk36Hd8aw8qP0bPsdP36oit/Pr+EL71jMRXMqqIsG+b/RG9izeQ9925/2O0whXtXK93+Ipe3VPPr4AXp3bvQ7nJPiOjaO66Iqit+hnJT8cA/xYIDqOp1wVZL8cI/fIc06ktCUkYWXraW9tYoRw2YoZ7Juey9Hu0dklY1Pjm56hELmIn7dUU1U18gYFhedVY9l2pLQiBltUVsVc+tipDr3le0/rI7rlk0PzZhnDw7SUBkm0bKobH/vM5kkNGUgUtvMVde/mz+5bB79WYMDg1me2TvA4z/7raxm8pFt5Ol+4XHuGTjG+gsv4O2r2/jDFXO4bH4t/9n4GfbsG+SFB3/kd5hCvMK15zahKUrZrGwaz3WcsptyGvPgw3tItiWYu2wuyY5mGR8mmXQxznDBeDWt561mXkMcgKGcyZaDQxw+kpJkZoZId+6mc9dhnjs4RPeIQda0mdcQp2lOJXpU5svFzKIGdHKmQ++o4Xcop8S1y2vZ9nipIztJDWSprorQ0prwO5xZRyo0M1j90ov50z9+Cxe3VvNi7wi/2NbF757rYtuv7sc28n6HJ8bp2/40v97+NAf2vJf6lgR/cEk7C+tjLG7+Hxzqz/Lf/3FvWa0kEbNTPNlO7fxz+P76Q/R2jfgdzimZ2BTsczAnaaRrH/lUH//zuv/FBU2V/PJf/I5odpEKzQzVfMGVzF3WwdkNcRordBzX5aWjaXoP9UkyM4MdfWETfUdTmI5DOKBxdlMll51VT9uqtxAIx/wOT5zh6haeS7wqTH9fhr4j/X6Hc8rK5SynEzGzaaK6Rl00SKiyzu9wZpUpT2i+9rWvoSgKN998c+m+fD7PjTfeSG1tLfF4nOuuu46eHmmQAqjuWM5Zb3sfn//khdz49rN4cv8gf/2bPXztPzby2H98h66t6/wOUbyGbN8Rdq+7j9u//mv++vubeWxXH70jBT753rO54x8+z+Irr/M7xLIg48bU+MA7zuLsxfUc3LKtbMeSsZ2Cy60heLyn9vSzbzBLzbzlfocyq0xpQrNx40b+9V//lXPPPXfC/Z///Od58MEH+clPfsITTzzBsWPHeN/73jeVoZQFLRjmTe+8iPe/bSFXzKtleWMFO4+leXZzJ52bfuV3eOIk9O/cwP7f/TcHukZIZQ0uaq3i/Usb+NS7l7D4yusIxqv9DnHGknFj6qyZW828hjjDh7b5HcppcV3Xu5VpUnOoJ0N/1iCaiPsdyqwyZT00mUyG66+/nn//93/nq1/9aun+VCrFd77zHe69917e+ta3AnD33XezZMkSnnnmGS666KKpCmlGO+tt76O6Ic68hhiprMHXfruH7lSeZ350H0ZmyO/wxClwLJNn7vk+2+cs4vm3ruGSJQ0Yls1lF7ZQk3w3uza8xMDuTX6HOaPIuDF11IDubS+QN/0O5bSU21lOJ3JoRy+PJeNEKkI0nXdF2VbLZpopq9DceOONvPOd72Tt2rUT7t+8eTOmaU64f/HixbS1tbF+/foTPlehUCCdTk+4zRaJ1iVcd/Nn+Pc/uZgvvGMxHXVxMnmL3/zsSZ78zv+TZGYWSHfu5un//B73/PR5DvVnufacJv7s7Wdx5xev4Zav/pkcWDfOZI4bMLvHjpNVv/giQgGV4Wz5JzSu45Zu5ahr6295cWcf0XiQ+ee3+R3OrDElFZof/vCHbNmyhY0bX7kDZXd3N8FgkKqqqgn3J5NJuru7T/h8d9xxB7fffvtUhOqrxnMvp21pC5GgxobOYV46muK5HX30Huor+5KweKVjW37D7zIrSWVNauJBWmoiZPIW81edy8iChexed5/fIfpqsscNmL1jx6nQo5Xs6h9ld5kddTAbOZbJcO8oidoo57QmeMrvgGaJSU9ojhw5wuc+9zkeeeQRwuHwpDznrbfeyi233FL6Op1O09raOinP7YcLP/wxzplXw5VLkrQlwtyz5Sh3P7STw89tItNz0O/wxBQa2L2Jx4rTTGe/4wM0NFfyV+8/h7pokEevWcLzh4dZ99CzZ9xU1FSMGzD7xo5TlVx2KbFEiPu2dLJ303a/wzkt5Xja9ol0v/A451/4Md6xNMl/Jttl7J8Ekz7ltHnzZnp7e7ngggsIBAIEAgGeeOIJvvGNbxAIBEgmkxiGwfDw8ISf6+npobGx8YTPGQqFqKysnHArR1owTN3i1VRXRQgGVA6ncmzpSrN+Ww/7n/md/IU+w+zf8Ht2bz3G7w8O8Xz3CMNZk2hQIzmvnXiy3e/wptVUjBswe8aO05VI1hHQNQYGs2S6D/gdjsA7Ey4YUKmLBonUNvsdzqww6RWaK664ghdffHHCfZ/4xCdYvHgxX/ziF2ltbUXXddatW8d113lLWHft2sXhw4dZs2bNZIczI7Rd9C7az27gi1cuImPY/GDjETbv7uee7/ySdOduv8MTPskNHKNz4BhfK65gm7PyaupbE6y5oJkvfehT7BsYZd1LPXQfHGLvY/f7G+wUk3Fjal28qoXtB4c48ML+WdGX5zouiqrgOmW2s97LRIIabYkgrUvmyvlvk2DSE5qKigqWLZvY5BiLxaitrS3d/6lPfYpbbrmFmpoaKisr+exnP8uaNWtm5UqFmgUXsOjcRi5ZVEdTRYjejEH3QJbeo2lJZsQE3S88hutcxvDcairDAdprolx5TiPPJ8L07182q/uqZNyYWvMa4uzuTJMbOOZ3KJOmXBuCx7MdF01RCEeDfocyK/hy9ME//dM/oaoq1113HYVCgauuuop/+ZfZswd0PNnO8rdfzqVLGtjTPcKR7hF+8tu93PUfjzF8cBtWftTvEMUMZBt5jm35DT/bAj/DO8ercdklhGM6i990AcG1F6IpCrbrsukXj5DtO+J3yNNqto8bU6VyziIumVvN73f3z4ppbWcWLNses/vgEMcyZln3As0k05LQPP744xO+DofD3HXXXdx1113T8fLTavVH/4ALFtTy3nObmZsIcd+OXvbsG6Rr1x6GDjzvd3iijBiZIY5u+jU1Cy7gwhWrWNJcyaVza6iJBvivhXU89NRB9q1/alZ96h7vTBo3plJF03yS8SCRoOZ3KJPGdUCZBQf3jKYL9Jf5MvqZRA6nPE2KqhJPdtC09FwCusbIYI4nnj3Krx7dj5k3ZYdfcVocy6R/5wb+a+cGwPu0XdW6CMdxcR2H6rnLqJ67DCObIn1096zojxCTK1EXI6yp5IzZU9mA8juY8kRGBrN0pvO4rouiqmXfE+Q3SWhOUc2CC7jgrRfwhSsXUbBshnIWB4eyfOen2+jbs/WMmw4Q0yPdubvUe1U5ZxFt55/Hx65cSHNFmHMb41gOfPXXu9i9u5/tD//U52jFTBCvChPUFAxr9v1jWe67BmcHjnEs7R02HE92MNK1z+eIypskNKcgnmxHC4Y5uKefv0znyQzn6d67n/TRXdIfI6ZNunM32zp386WHIFyVZO6qS9A0lcFj/eRT/fKJT5RkDJuR4j+cYuYws6nSzs3Bimro8jmgMicJzeuo7ljO9Te8lbl1MZKxEKoC33psHwdf6pn1S2lF+cgP97DrkZ9PuC9a30rLuStZenaSj6xqxbQdekcNDg2M8sMfb6Rv5zM4lszfz3aO49KVMRjukw9bM00+1UfXcA6AWE0jAz7HU+4koXkNgXAMRdPYtGeAF46ksAwbo2Dx/EMPYmbP3DNhRHnI9h1h97ojHNxQzf4DV6IGFDRNpZC3GO07IsnMGSRr2ljm7KvWKWp5Nzq7jo1dXOEU0Mv7WmYCSWiASG0z7/iDa7lkYR0bDwxyoGuEY/sGOfLsLxncu4Vn9m7xO0QhTpmRGeKFB3/0mo+J1DbTvGwV1ck4V61sIZU1+OW6/Qwc3E3qyI5pilRMld5Rg9zw7GgYV8s8iRnPNvJk8haKohCMyD/Hp+uM/w0ml11KbUuSVfNqaE2E2aIq5DIGQ4d2SP+BOGPkBo6RG8mRqIvSWhWhsTLES2fVUVkXYUeqj0K63+8QxWkwbRfbMvwOY1LNhmXb46mq4ncIZe+MSGgq5yyi+exzGDjaRfro7gmDc8+239GzDb70sI8BCjEDHNvyG45tgT/+md+RiMkSCMcAyFsOdmF2NAWrgSCKCoqqoAXKu1qjBnSCAVWSmUkyqxOas9/xAea2V/MXVy2irTLEA7v6+MHvF7Lvuf30bPud3+EJIcSUUgNBVFXBdJyyX+I8RlE1lFmSACiqhla8Ftkt+PTN6oTmpV/+hJeAX8ru6EKIM5Dr2Ciqgq6qaKGw3+FMCi0UQVUVFFVBDZT3vFMoUU9tPEjnQBazYPkdTtkr64Rm6y/u5D9fGuapbd28+Mijs3YLeCGEOB26ppT9iqAxakBH1bxERtPKu1Kjh+PEwzqKqmAWZkcFzU9lndCc9+4voGhySmk5CoRjqIHj751s2S/E5LPyGRRFIaprhOI1foczKfRwHC2goqgKrlve0zSR6iRNiTCqqpBLD/odTtkr64RGlJ9ofSuR6iT17XMJBDVcx8V1XPoOHyPTc1CqbEJMItdxUFWF6ohOpCLkdziTIhiNooc0VFVBVcq7QlNZX01jRYigpsrYNwkkoRHTKpyoJ1bTSE0yTigUwHZdHMclP1qPbeTlP2ohJpmiKlQENUIR3e9QJkU4phOK6GiaiqWX9zRNtDJEXTSIpirkU31+h1P2JKER00YLhqme00ptUwXvv6iNRNj762faLj/VNQ4HVaxcpnT4ohDi9GkBlaZ4kNqmCr9DmRTJtirmVEcIBVQsx2X/4tX0F0+jLzeLOmporwoRDKhyDuAkkIRGTJtYfRvxqgjVVREaK0IkQsWExnGZWxdlaDDLSH2rJDRCTCLHcQloCvFQ+Q/38WQ7jYkwTVURggEVw3KI1yUZKNODWCvCATRldp6E7ofy/xsuZrxE6xKSixbT2F7Ney6Yw5zKMOc3xQkXVyo4rktUb+GCudWsn1fD1pZahrpH6Nz0K58jF6L85UYKqCg0VZX3su26xauZc1YH7z63iYZ4CF1VMB2XPd0jwLs4+NQv/A7xpERqm4mHA2QMh65OORtwMkhCI6ZUMF5Nbfsi6lsSnD+3ink1UZriIRIhDV1VUAAXaIp7K54KlkNfukBAV8n0LCHTcwDbmB07nArhh7HlwJFgeS/bTiQbSdRFmVMZpiaioypguy7zGmIcqY8SrW8l23fE7zDfsFh9K8GAhum45LOz61gKv0hCI6bMnJVXU9UQ5+zF9Vw0v5b2qggLaiKENRXtZasTEiGNoOZ96orqGvv6R3kiFCA9uJSDzz5FfrjHp6sQorx17trHtr7zyOQt6pdeTN/2p/0O6aSFq5LUtyRY3FRBRSiAroKiKCguzK2N0TonwdDC8zhUJglN5ZxFtJ09j8FMgScPDnJ4c/m9JzORJDRi0kXrW6lIttN6Vj0dTRW8aWEdi+ti1EWD1IS9rb7Hdi4f20UiElAIBTQUJYiuKdRGdQzL5uhgDrNwEem+vrIciIXw2/DBbewZeDtZw6a2pYmB3TqOZfod1kmpaltCWzJOS02UgErpuABQqIsGvSpNMkZPVbIsPvzUzVvCgrnVjOQtNh4YLIuYy0F57xstZhxFVWk463zq25s4e24Vy1oSNMVD3j4YuoKuKq+ozoD3aUtTFIKqQiIUIBkLsShZwbKWBMm2Kprmt5JoXeLDFQlR3mwjz5M7+8jkLebOqyG57DK/QzopwXg10USCqqh+wsbmgKYQD+tE4yFiDa0+RHjy5i2p581n1ZPKmrywvdfvcGYNqdCISVPdsZxYfQsdi+uZUxNhVXsNjRUh2hJhEiGNcEAhWNyq3H7ZBp+aAqoCEd3LsQOqzuK6GE3xEAXL4ehgFjiXgWQ7vdt/j5mVJjoh3qiXnu+meUEN71/VSiZn0rXV74jeuMqWRVTWRaivDBMPanidd8dFdY3aWJDaRJhEcg5WbpTUkR0+Rfv6gvFqPriqhdUtVdzz1EH2Pf2k3yHNGlKhEZNCUVVi9S1U1kRorArTUBmmMhygIug1/46vzLzaobKO6/2F1DXv8fFggHgoQG08SFNVhGhliHh1hFh92/RdmBCzwMDB3Rg5kzmVIRaW2X40wWiCgK4RCqjHT6YeN4Z4H4YUIkENPayhxyp9ivSNqW5fhuPCiGEx2JOR6aZJJBUacdrCVUmq25fRPK+a6qoIy9uqqInotFSEqQxrRHWVoKagKa+ezIzdrSgKQRWcAFQEVXRNp70qQk1EJ5M32V8RQtMWo+pBUoe3ywooId6A1JEdDPct5txkHGjkwUUrGdi9ye+wXle0vpV4dYxoRchLWNRXfgZXFYVwQKUqqhOrDJGvaaDfh1jfiMVXXkdTWxVZ02Z7b4Z9Tz3id0izilRoxGkLJ+oJxWOEY0ESUZ1YUPMOwwt4q5k0BRTFS1Zez1ivn6p4jX9a8WC9iK6RiHrPH47phCvriFQ3TvGVCTF7jAykyVkOjguJ5ByC8Wq/Q3pdejhOQNcIFldGqq8yhIyNFwFdI6CraMGZuedOQ2uCeQ0xBkYN9vSNytT5JJMKjTgtFU3zqWmbT3UyxsJknPrKMLXRIIlQgHBAJRRQSonJ+MHo1VIbl2Ii40JAVQgHIFHcTXNOcWOwTN7CKNiogbPJDXVLlUaIN6Br6zr+df05BAMqq1e3UN/6Ljbc+59+h/WaItVJwjGdeDiArimo4waRsWqvpnhjTCQYIFg8hDNW38Zo3+EZMzYoqsrci9/FX1x1FqqqcPuD2zm0Q85ummxSoRGnJVhRXTosLh4OUBEOENZUwgEVTQWVV/9UdSKlxZjFJmFFAV1V0TWFkKZSEQ4QDwcIFys1wYqaKbkuIWaj5w8McXQwx6LGCpa0VfkdzmtSAzqBcAxVUwkGvH+qXr5C0nW9rEZVFIIBFV1TCegqgUicQDg+7TG/mpoFF9DQUklTRYjaiM5w3yj9ZTDlV24koRGnLFyVJFbTSLQyRFVFiKpokMpwoDTdpOIlJHB84Hk9Lsc/eSl4CVFAVQgFVKK6RizoNQlHK0LEKsPE6luJ1pfHUk0h/Lbpvl/w/PNdLE1WcPXZjcx/87Xo0ZnZRBuubiQUCRAMBYgGNdRXmbIeq9qEAirxcIBQZGZNSVc0zefKd6/mTcsaWX9kmB8+f4yXfvkTaQaeApLQiFOiBnTCifoJ1Zl4OEBIU4urlFSUl00zjW8IVpVX3sYby38UBTTVq9KEAl7lJx729qMIRQKE4jWE4lKlEeKNMDJDDBw8QEMsyIKaKB1n1dO64i1+h/UKakAnGE2ghwIEgtoJp63HG5t2CgZUNE1FD4dmxGonNaAzd8UK3rmskcXJOM8fHeZ3L0kiM1Wkh0acEj2aIBCJEdA1tIBKNKiVBpXxn6Qc17vZLmi42MUpqJfvQzPGdlwcvAMrXbzE5uWJUDCgEglqBHQNPawTiMSm9FqFmE2GDjzPd565lGUtCVYvqGVxcwX/eXDJjNq7JRivQY9VEgh6DcHBgDphwcDLjTUFBwMqgaCGHtIIRhNowbBvfTThqiQL3vRmli6qQ1UVukcKPPK7gxzbttmXeM4EktCIUxKMJdDDcfRQgIiuFeevlQnLKl3XxXWVYlLiAgoKLrZ74tKgA6XH2sVExuF4NjOWMAXGDVwBXUUPx1FUFddxpvy6hZgNHvnl8+xeNpcvXbOUeTURXjp6MVt+zYxJasKJeoLRBMGQRiSovWoPjVJcRQleQhMKqER0jVBEx7FcItWNviwc0KOVLH/HlXzoknbixQ97+3sz7H3s/mmN40wjCY04JYqqFW/jz1XxTr91xm7Fr20XFFfBxUUp5ifuCebDx6oyjutVamzXxXa8JMd0HOwT9OGoqlKKRRIaId6Ynm2/w3FsdlzURiigMrcuyuAFy9kx1I2RGfI7PLRQmEAwgKp5m+lpqjphnDnhzxQ/6AQDqrd8O6gSCMfRo4lpTWgq5yyibt4SFrYkqI7o9GQKbDgwyLNbu6YthjOVJDTilKiBIGpAn7CM0na8pMS0XUzVxRo3V+S4xVVLUJySOvGc01h1xnXBsr0/G7bjPafjPff451VUBUVV0YKRsjtwTwg/9W1/mp/9bi7DK1pY1VHD1Wc38v+aKvj9fY+Q6TnoW1zBeDXhyvpSQ/D4Cs348UYdt1GnqnrV4bHp6FAkgOu4RKqTKKpGId035R94wlVJEi2LePOV57BqXg1zKsMkY0Ge2N3H/T94jOFD26b09YU0BYvT5ExIWtxSZcV0HGxnLMnheLWFsarNq9044Z8d18UpVW282/jXdh3bh6sXorx17etl0/5BRgpWqVLTsGg58WS7L/GoAR0tFEELaKiaijruuIPxvXnjizXj7/eqOUrxZxW0YNjr9ZuGJdwNi1dR397EvIY4NRGdnGlzcDjH9oNDksxMkylJaDo7O/nYxz5GbW0tkUiEc845h02bjq+5d12XL3/5yzQ1NRGJRFi7di179uyZilDEFHEsA8cycSwXw3LIGjY50yZrOmQMm6xpM2rY5C2HnOVQsFzytkPO9G55y33FLWcef2zOcijY3n2Zgs1I8Tmzpk3OsMgZNlbx5limJDSzgIwb069r6zoe+4/vcN8zh+keKXBBWzVf+IPzef8nrqF+6cWEKuumNZ5YfRvR2mZvN/CYTri4BUSo1ENzfCuI8TRFQdcUggGNaFAjGA4QjgaJVgSJVtUSq28jXJWc9HjDVUnmXXotKz94PZ/92Hn86fuWsaIlQWUowM82d/K/797Msz/8r0l/XXFik57QDA0Ncckll6DrOr/61a/Yvn07/+f//B+qq49vs33nnXfyjW98g29/+9ts2LCBWCzGVVddRT4/M3Z1FG+c47oYtoPteImN6TiYpSki7+vxFRrb5WVVGO9mOcWKjHP8sROex3Ywi5UZw3IwLMdrOna86owkNOVNxg1/DXSN0JX2fo/tVRHOba2iaX4r9YtXT2scWjBCIBjxVk8WVzeNVV1e3hB8wp8f66PRVLSxXhpdJRCJoUfik3okQjzZTt2ilTTNq2ZxezXzq6PMqQyjKQo50+FYV5rubRsm7fXE65v0Hpq/+7u/o7W1lbvvvrt0X0dHR+nPruvy9a9/nb/8y7/k2muvBeD73/8+yWSS+++/nw9/+MOTHZKYAmY+490KcYy8xWDGYCBTwHJcorpGwfaaeL3jDxzCmoqqUtxL4sQDkzM2vVRMarKmjem4pPMWpuMwnDMZzpoMZAwyOZNCzqSQMzCyKemfKXMybvhr72P388+dK1mwcgl/+OZ5xIMan3vPUvpGDe5NxhnoStO56VdT9vqBcAw9liBSnSQYjRKMBLwVlMHjq5xedbl2cX8avbjKKVjcYA8gHw8S0DVsO4kejqMFI+SGurHymVNqFE60LiGcqKO+vYnG5krOb6/migV12K7LUM6kcyTPD9cfpv9Yml2P/Px0fy3iJE16heYXv/gFK1eu5AMf+AANDQ2cf/75/Pu//3vp+wcOHKC7u5u1a9eW7kskEqxevZr169ef8DkLhQLpdHrCTfjLMQ1sI49tOVimN92UM2wyeZOC5ZC3nHH/PzZd5H2dNW0Kxe+P3bKmXfqZsamlscflx37eGDfdZNpYpoNt5LAL8gm93E3FuAEydpyMgd2b6Nw7SO9IAV1TWdmc4C0dtVxyfhPzlzcxZ+XVRGqbp+S1gxXeBpl6OIIe0oqrlLRiheb4P1OqopR2IB/7XDT2Qen4Kift+F5VxT1pvE04Y4QT3g7CkepGtGAY5QSnd4+nqCqBcIyqucuoW7yapiVLmXNWC+csrueqcxu5fH4tZzdEmVcdoWA7dA7nObSjjwPrH5uS35N4bZNeodm/fz/f+ta3uOWWW/iLv/gLNm7cyP/6X/+LYDDIDTfcQHd3NwDJ5MT5zGQyWfrey91xxx3cfvvtkx2qOA1mNoU5miI/apKPmaiqQm+6QMFyiAS9rcod1yWkqYQDGgHNKxnrYw1+L/u4Ndbg6zUUew2/WdPGcWE4b5IzbPrSeYazJkOjhve6owaFkSEKmcFpv34xuaZi3AAZO07W0Wf/m7tVhcb2Kv7g8nkkQjqXLqjjknm1/LY+xs4j9fQeTtG3dxvZgc7TXg6tBcMEK2qKlZkEkYogesg7viBWPPJgbArp5WPGeGpxQ8+xZdsV4QCaqpCJBiloFrbtFKefqgiEY9hGnmBFDa5tY+UzE6as1UDQm/qKxIhU1qCHNKrqY4RjQc7vqKapKkJzZZiGWBDTcXnmaJojqTz3PLaPge4MR5/979P6nYhTN+kJjeM4rFy5kr/9278F4Pzzz2fbtm18+9vf5oYbbjil57z11lu55ZZbSl+n02laW+X8Hj85lokxmqKQGSIXCaAqCkMRA8NyvM2tghq24xIJaoQDDvpYQqO9csVC6TmLK5ic4r4z+WKvzEDGwLBsetMFMnmL3EiBfNZLagqZQYwRSWjK3VSMGyBjx6k4/MxD9Gyvo7rqvZzfXs0fnt9MVVhjTmWY/QuzPHdkmI2tlWSG8/TsP4w5mibdueuklkWPJTLBaAI9Vkm0qp6ArhGOBgnoKpFxy7VDARVV8caPV26sd3yzvbHvR4vTVACJqE6u2FBshexitUbHtsKYiTiuA7bt4DouavFxoeJ0VygcoLIqQiKqc3ZLgtpYkOWNFdRG9eJrwc7+LA+80MXuw8O88MuHMLNSAfTTpCc0TU1NLF26dMJ9S5Ys4Wc/+xkAjY3egWE9PT00NTWVHtPT08N55513wucMhUKEQqHJDlWcJiMziDEyRCFejRYwCI4GcCyHgXEDyli1Zqy5L6ippWRGG1ftHdvDZmxZ9tjKKcNyGMwUyBo2g6MGRt6ikLeKycwQ5mjKt63NxeSZinEDZOw4VYV0Py88s5/urnpaqyPMr46SNW0iusZZjRXEwzpHB7NsjwTIj5pEqpMY2TT5VF/xv8nchL62sb2iFFVDjyXQAkH0WIJgtJJAOEY4pntHmRSnm8b3znhNwd7zqKrinRGHN4aM7SSuFc+D0zUFw/ZWOwFEiudA2Y6LUTwuxdAtXMfFMnUA3GJ1OBD0zp8LRXSiEZ2aeJB5DXGqojod1dHSSqt03mYwb5LOW6w/MMCmrV30HTwkycwMMOkJzSWXXMKuXbsm3Ld7927mzp0LeI1+jY2NrFu3rjQQpdNpNmzYwGc+85nJDkdMIddxGO07jBoIYht1KKqCHgrgOC6BoEYmb5XKv6WEZmz55ct2/vT2ljm+Wsp2XEbyFoblkMqaGKbNaDqPkbPIDOcZHewmN9Qjg8gsIePGzNO1dR1dW+H/DF5LQ1uC69a0cU5DBYtqY1QuUEkXHDYtqGM4b7Jxfz2prMnQYJZ81sQsWBRyXuLgOC6u45T6VbSAiqIq3uqjYq9MKBxAC6iEY0EiukYiqhMNasTDOpGghq6q6OrxYw7GU4sLDXRNRVdVwgGoCAewHC+psR2XinCAgnV8fBlvbBVVVVQnGFBpqAxTGwtSHdHpqIoQ0VWqQt5z7RvKcziV47HdfWzd3U/n7mN0v/D4VL4N4iRMekLz+c9/nosvvpi//du/5YMf/CDPPvss//Zv/8a//du/Ad7ZGzfffDNf/epXWbhwIR0dHdx22200Nzfznve8Z7LDEVPMyo9iZlOouk4hF8N1XIyQhmM7pIoVGdtxSwlNaNwyzPHGNsuzxiU0mWJCk80a2JaDkbMo5EyMbAZzNI05mvLpqsVkk3Fj5jr24jMYhZVsTMYJB1RMx0FXI9iOS21UJxRQWdaSYCRvsT8cYHDUKK5A9PapskyvP2WsT26sF0Ytnowd0FX0kJfQxEOB0jRTMKASOMEp2xP+zPHpprHvaap3gK3muESCAezi6wYDaunPYzRVKVZxVKqiXvJUF/WSmYriwZgAWdPBduFwKs/BwSwvHRqm++AQfTufmfxfuDhlk57QrFq1ivvuu49bb72Vv/7rv6ajo4Ovf/3rXH/99aXHfOELX2B0dJRPf/rTDA8P86Y3vYmHH36YcHjy9ggQ0yfTc5B8qg+7kCcQiVHINRDQvU9bAV1jSPcOklQUBS1w/FPaeN6nOO9m205p9ZRjueSzBpbhkE2lMLJpckPd5AaO+XGpYorIuDFz5Yd7OPrsf/PAzjqePfdiWhbWcuU5jcxJhFnWUIGuKaxsrsRxoWukwGDeZCBr0J8xvKnijLdYIGfYEyqwY8YaeTVVKTXzJqLB0vLrUMBbWDD+8NuxVhrX9ZIS7+gDhXBAK31Ysh1KvXwQwnbc0ocpr5LjHagbDwbQVcVLYkIBKoIqFUGVnOUylLfpHTXZ3puhczjHo1s6GejOcPiZX8lWETOQ4ronOPFvhkun0yQSCQLnXI+iBf0ORxRF61vRw3Gitc1owXBpXnzsVGy1uCU5jB0qefyj1vHStJfQOJaLUbBwbIdCzsIyLHLDPZijqUlZXSFOn2sbWC/eQyqVorKy0u9w3hAZO05PtL6VlnNXsuL8ZpY0V3J5Ry2xoEY8qKIpCsMFm1TeJJW3SBUssqbNwKhBwXJIZQ1sxyVneNsxAKUkY6xyO9bzEg/rBFSFREQnqmvEgxqJcIBESKexQi9VZFwXUgWbgZxJ1rTJFCzM4gpJANOe+M+blxR5SU1E19BVhURYJ6ypxEMaQU0hrqvEgxqpgs3hVIH+rMGju/s4OpjjhS3HGD6yd8acSl6OpnLckMMpxaTJ9h0BoDAySCAUIVhRgxrQ0cNxbylkQEMtrlhQXrb9g1tsCnYdF9tycCwTM5/BsQyMkSEsI0ch1SefioTwUbbvCLvXHaF37zLWt85j43lNNFWFWd1RQ2UoQF00SCKs0xALEgmo5G2H4bxFwXLoz3p7VI0Y3teG7ZT6WcYqNmMVlGDAS5CixaMPxvpjjq+S9OJx8Ko1erFCEwqoqI77itVQY9tGhAIqYU31kqSQl9CMJWM5y9uNvD9ns28oT2e6wLOHBjnUn+Wl57sZGeijb/vT0/a7FidPEhox6fLDPWjBMLZlEAhGsHKjaKEwiqqhBYIoqoaiahN+ZmwfCNsyvHOiTNPbzdMyMEYGS2dHCSH8N3xoG7mhbsLRN9NTEyEe1mmpjlARDJAIQzzoNdIWbK+Z17BddNVLcCJ5tXiem7cTuOO6J6ykqMVtHsZ6aEq9N7yyM1gbv6xbnXg/4CVFqpcgeUmSQlT37qsIaqgKGLaL4br0jxocTuXYP5Bl66FhRgZz9O/fQabnwNT9QsWkkIRGTAnbyE/oc/F25dTQghEAVH1iud+1vfOYnLGExjJOal8LIcT0KqT72fmbnxGpbSY1cBEV1RGWL6hlXkOcBbUx2qsiBFSFoKagKNBYoeO6MBrVi5Uabwdw0/Z2CB87881x3dLWDrpaXL2kqaU/A6WUpnT0geolQSFXxXFddHdsKbeX5HjVGK9vJqJ7y74Vxeuz6cta2K7L0eL00o7eDC8dTXGsN8ORnV1keg4y0rXPp9+yOBmS0IhpMdbzYuVHfY5ECDGZcgPH2P/73xKrbyOXWcLO+hhntyY4pyVBQyzEgpookYBCdUgjoCqMGA552yGqaxOOOxnbTBMoJTe6enyHcU1RUJh42vbYH73HqNjjCr+aQmmaKqKrBFXv/6O6t9pprCLTN2qSKpjs7B/l6GCWFw6n6DmaYqh7iK6t66bt9yhOnyQ0QgghTouZTTN8aBsAmTkdmAWLrGEzty6GqkAirKMoXrUGvGmjcACCmoZRXG1k2i66apeOPxmjKaAXD7c90bm2arESo6ouunt8GbeqQiSgoSgQCahepYji1JLtkjG8BOpwKsdQ3uSloykO9WfpOjxM38FDpA5L42+5kYRGCCHEpBg+tI3hQ9tIdS5juG8hu+tjpLIGDZVhsk2VJEIBkjGdiK4S0bx9ZgqWS1BTsF2XqKVh2l6iMT6pCRebglXleAIzRlPw9qtRNTTFQVUUAqo3pRTWvCbjeFAlpKkUbIec6TJqFhOZnMXmI0P0pgts3zNAaiBL767nSgscRHmRhEYIIcSkSh3ZTqiiGoD9NVFyhk1DPETBcqgIBfDWJ6mlKSQvoQHLcVFQsV1vpVKpp0b1VkB5/3slRQFcr5Kj4G2up6AQ0I4fiGu7XmUmV5ziGspZDOZMjg7m6BspMDKYY6T3mCQzZUwSGiGEEJPKdRx6tv2Owf2VGIXLOVwVZiRv0VQVJmNY1EaDtFSGqQiqhDSFREgrJTGW4xJQvf+3iqugdE0t7QKsKsqEqSdNVdAcQAEX7zkCxfOf4rq3v41hu2RNh1TBpjNdYCBrsrUzRddwjl17B8gM5zm29XcYmSHffmfi9ElCI4QQYkqY2TSjg/1AHd0pb2FAS00UVfGWS4e0IAHVW5btFlcmoSpoqstYy6/leH9SJ67IRlW85mFFGX8cgpfsaGqxj0ZRUPH2uTEdl5zpkDFsUgWT3nSevnSBbKpAbnhIkplZQBIaIYQQU6Zv+9MMhWO4zlsZqApjWA4tNREKzQnylkNd1NvCQS+uQgJK+8KYDmiON32kjU07jUtgvCRHQVNclHFLvUMBpZjwuNguZEyHUcPhcCrP3oFRDvWPsvPgEJnhPN07t8g00ywhCY0QQogpZeVHyfR34TqN9A7l0FSFhsow8aCGrnlnJ7mat6R6bG+ZgOpVYFylWIXh+Cqn8X00XkVGGffn43vQ2K6L7VBc1WSRypsMZAx60wWyYzdJZmYNSWiEEEJMuYHdmxitSqKHLiKfNUrHHBRsh6juHUcQ1LxEJlCsxniVmuPPMf7kbVVRcFwXTQG32FejKcePT3BdyJkuhu0du9CbKXBoKMfOY2l6ejMMHO1hVJKZWUUSGiGEENMiP9zDcFcnrjOHo9EgVVEdgNpokETIJR5UCboK4YC3pNtxHexxG4arylg/zdiZTl6Coyju8WSmWOGxXC+ZydsuQzmTobxJ93COgeEcI0M50l37JuxmLsqfJDRCCCGmTfrobgAiFUEOxYIEAyqNFSEcx6UmomNroGsuiuslMIFiJ7DL8UbfCbsFj6vMjC3RNmwHy4G87ZIp2AzlTLrTBY4O5rzl2QNpSWZmIUlohBBCTBszm2Zo//MEown0kHdWQUNluNQgHAtqRALHD5tUNC+ZcYoJzvjzJx2K/TKat1RbVxVMx6VgeXvODOVMUnmLrnSeQ/2j9PePMtQ9xPAR2QV4NpKERgghxLRyLJPcUA+5+gSpaIGBTIFgQGXEsFBVMBwVzTk+jeS6AO4rNtVT8fpnHPf4rsKuC2ZxmXbW9A7AHM4apLIm+axJITNEIdU3jVcrposkNEIIIabd8KFtBCIxXKeZPYkwOcOmPhakYDnEg17lJl48VNJ2QSnmLNrLDnTSipvpAaVDJ3Oml8z0Z036swb7e0fp6s0w1J1i+OCLOJY5rdcqpof6+g8RQgghJp8xMkQhZ5EpWAxnTfKWdxK35YBle3vIwPFN9U70D5aiKKU9aGx3bO8ZF9P2kpqcYZPJWxg5i0JmUJKZWUwqNEIIIXyR7vQahCtqIhh5iyMNcQqWQ01Ypy4WJKA53mnbqtcjA14/zZjxtRrDpXhW0/HemWOpPN3DOQb7RhnuG5UTtGc5qdAIIYTwTWFkkPyogZE3SWUNMgWLvO2Qt2xsp1h1gdJJ2wrHb2PGjk6wi9WZsUpPJm8ykrcwCxaFTAorP+rPRYppIRUaIYQQvimk+0n19OI69RwdzGE7Lq1VETQForpWWoo9tqme9rLOYNsF0/EagfOWt8IpVbAYypl0Dec5NpQj1T/KSM/B6b84Ma0koRFCCOGr/FAPgWCEwRFvtVPGsIjqGgXLwQyoaI5XfQHlFQmNU6zMjJ3OnbNsMgWLkYLFYMYgN1Ign+4jP9Tty7WJ6SMJjRBCCF9lBzpRA0FymQb6AipDWZOQppKN6kR1DU31VjChguYeP/5gLJkZO03bsF2yxRO1BzIGI5kCuYxBduCYNAOfASShEUII4SvbyDPad5j04FkAdA3niAQ1UnmLeDCApqpYGri46KqCU+wMdvESnbFVUWPVmYFRg750ntF0gcxwXnYFPkNIU7AQQgjfWflRb2l1zmIkb5HJe83BpuNgOV6zr+MWT+Dm+GonF69KYzpQeFkzsJEzMbIZH69KTCep0AghhJgRRnqO4DgtdA7miAY1GipCJEIBdFXF1L0UxnVdnOIaJ7e434xhe1NOqfzxZuCeVJ503xAZaQY+Y0iFRgghxIxgZr2l1YZpkzVsCpbjNQY73qnbTnEJt+u6uMXjDsbOeTJtxzvywHbJGTZmwcLMZzBzUqE5U0iFRgghxIwwVk0ZGUzSqWu01ESpjuiEAioVwQCqMtYcfHypk+14G+qNGDapvElfpsBAKk9mOM9o7xEK6X6frkZMN0lohBBCzBhmLoNl2himTc6wSpUXFxfbmfjYsc30XFxM26FgO+QMG6NgYZk2Zjblz0UIX0hCI4QQYsYopPtJD+bQQwF60wVaasb2pHFRAt5BlaVlTngVm4LlnduUzlsMZgpk0wUyQzlsI+/fhYhpJz00QgghZhQzm6aQM8kUVzsViqudXFzccYc5eSucwHS8XpuRvLdCqpAzMaQ6c8aRhEYIIcSMkhvqIZcxGBo1GM4aZE2vQdhyvNO0x5Ztj22sV7AcsqZNKmswmDHIjxoUUtI7c6aRhEYIIcSMkhvqJp8eJj9qkMqapPMWWdMmb9mlRMZxiz00DuQth6zpMJw1yWYNcsM95OSogzOOJDRCCCFmFDObpjAyhFHcZC9r2Ji2tyR7LJFxXa9aYxWPPchbNpniydpWLoOZTft9GWKaTXpCY9s2t912Gx0dHUQiEebPn8///t//u7RnAHh7CHz5y1+mqamJSCTC2rVr2bNnz2SHIoQoEzJuiJfLDnQyms7TN1IgNW7ayXbdcTdK003DWZOhUYPsiEF2oNPv8IUPJj2h+bu/+zu+9a1v8c///M/s2LGDv/u7v+POO+/km9/8Zukxd955J9/4xjf49re/zYYNG4jFYlx11VXk89KRLsSZSMYN8XJWPoNlOtiWtxTbLB5/ML4pGIonbdsuhuVgGTaWaWPlR/0JWvhq0pdtP/3001x77bW8853vBKC9vZ0f/OAHPPvss4D3KevrX/86f/mXf8m1114LwPe//32SyST3338/H/7whyc7JCHEDCfjhng5xzIZHexlNB1jIBEma9pkTdtrBC7uR+PgNQSPGN5y7VzGIJvK+hu48M2kV2guvvhi1q1bx+7duwF4/vnneeqpp7j66qsBOHDgAN3d3axdu7b0M4lEgtWrV7N+/foTPmehUCCdTk+4CSFmj6kYN0DGjnJnF/JYpoNhOeP6ZyaWaEzHwSmudLJMG9vI+RSt8NukV2i+9KUvkU6nWbx4MZqmYds2f/M3f8P1118PQHe313meTCYn/FwymSx97+XuuOMObr/99skOVQgxQ0zFuAEydpS77EAnuZF2UqMG6bxJIhzALi7VBm+lU95yihvqGeRGDHJDPT5HLfwy6RWaH//4x9xzzz3ce++9bNmyhe9973v8wz/8A9/73vdO+TlvvfVWUqlU6XbkyJFJjFgI4bepGDdAxo5yZ+UzmAXvoMmC5WDazvhNgr3Tth2vfyZnekceGKOyod6ZatIrNH/+53/Ol770pdKc9jnnnMOhQ4e44447uOGGG2hsbASgp6eHpqam0s/19PRw3nnnnfA5Q6EQoVBoskMVQswQUzFugIwd5c428hQyKQq5OJm8ScEOTTjTyQEs22Ukb2HkLQqZIYzMoK8xC/9MeoUmm82iqhOfVtM0HMf7G9jR0UFjYyPr1q0rfT+dTrNhwwbWrFkz2eEIIcqAjBvi1RRGhijkTHKGTd5ysB0vkXHw9qLJW94hlkbexBgZwrFMv0MWPpn0Cs0111zD3/zN39DW1sbZZ5/Nc889xz/+4z/yyU9+EgBFUbj55pv56le/ysKFC+no6OC2226jubmZ97znPZMdjhCiDMi4IV6NkU1hFrzN9XKGt1PwWF+w44LpuMUTtm3MfMbXWIW/Jj2h+eY3v8ltt93Gn/zJn9Db20tzczP/83/+T7785S+XHvOFL3yB0dFRPv3pTzM8PMyb3vQmHn74YcLh8GSHI4QoAzJuiFdTSPWVjkDwdgx20FUNOH6O03DWxMiZ5OW4gzOa4r58DVwZSKfTJBIJAudcj6IF/Q5HiDOSaxtYL95DKpWisrLS73DeEBk7ylPjuZez/OKFnN2S4H3nNBIPFhMaBx7Z18+TO/vY+WIP+3/3gM+RitczleOGnOUkhBBiRsun+snkTDJ5E9P2moJtxztxeyRvkc6Z5Edl/5kznSQ0QgghZjTbyGFb3gZ7zrhJBdtxsR0X13FlQz0x+T00QgghxGTKp/ow8iYjeQvT9k7YBm+X4EzeJD9qUBgZ8jlK4TdJaIQQQsxotpHDMrwKje26pSqN4+DdZztYssLpjCcJjRBCiBnNsUyMgkUmb5VO3QZvlVPWsDELtuwQLCShEUIIMfOZBQvDtHEcl+J+i6U9aMyChZmVhOZMJwmNEEKIGc8s2N5p2q6LWcxonOI5TkbBxh3LcsQZS1Y5CSGEmPGMbMarxDhu8cTtsaZgCyOb9zs8MQNIhUYIIcSMZ1sGtuUWp5zGemi8PhrHMnyOTswEUqERQggx4xnFQyoLtoPpFG+2490nS7YFUqERQghRBhzLwHW9jfTscQf2uI5UaIRHEhohhBAzXmFkkELO66Exba8B2HRcjIKFISucBDLlJIQQogzYRg7nZUcfOI6LY7nYBTn2QEiFRgghRBmwjby30sl2MUtHH3gVGtmDRoAkNEIIIcqEZeQwbKe0ysm0HSxT9qARHklohBBClAW7kMd2jldoHBcsU5IZ4ZGERgghRFkwsynv7KZSU7CDmTd9jkrMFNIULIQQoizYloE9rjpjO8iSbVEiFRohhBBlwRxNYVgOhQkVmozPUYmZQio0QgghyoJjGdjjGoBtx8WxZMpJeKRCI4QQoiw4lknOsDFtF9v1Tto2R2XJtvBIhUYIIUTZ8I4+cI//WXpoRJFUaIQQQpSNrGFjWN60U8FysHLSQyM8ktAIIYQoG7bjlhIaw3KwDTn2QHgkoRFCCFE2DMvBKi7dNiwb28j7HJGYKSShEUIIUTYMy5lQoRFijCQ0QgghyoZhOaXN9cb+XwiQhEYIIUQZyZs2OcMCvKZgIcbIsm0hhBBlwx1XlZEKjRhPKjRCCCHKhmXa5AwboPT/QoAkNEIIIcqI67ilVU5SoRHjSUIjhBCibFimLaucxAlJQiOEEKJsOI5bqsxIQiPGO+mm4CeffJJrrrmG5uZmFEXh/vvvn/B913X58pe/TFNTE5FIhLVr17Jnz54JjxkcHOT666+nsrKSqqoqPvWpT5HJyPbVQsxWMm6IyeJYbmkvmrEznYSAU0hoRkdHWb58OXfdddcJv3/nnXfyjW98g29/+9ts2LCBWCzGVVddRT5/fDfH66+/npdeeolHHnmEhx56iCeffJJPf/rTp34VQogZTcYNMVnGppwMy8GSpmAxjuK6p57iKorCfffdx3ve8x7A+5TV3NzMn/7pn/Jnf/ZnAKRSKZLJJN/97nf58Ic/zI4dO1i6dCkbN25k5cqVADz88MO84x3v4OjRozQ3N7/u66bTaRKJBIFzrkfRgqcavhDiNLi2gfXiPaRSKSorK9/wz/k1boCMHbPB4iuvo6W9GoDMqMEz93zf54jEyTjVceONmNR9aA4cOEB3dzdr164t3ZdIJFi9ejXr168HYP369VRVVZUGJYC1a9eiqiobNmw44fMWCgXS6fSEmxBidpiqcQNk7JiNLNMmX7xZplRoxHGT2hTc3d0NQDKZnHB/Mpksfa+7u5uGhoaJQQQC1NTUlB7zcnfccQe33377K+53bXMywhZCnIKx//5Oo8gLTN24ATJ2zEZWbhQr71XXrLyBaxs+RyROxmSNGydSFqucbr31Vm655ZbS152dnSxduhR7+499jEoIATAyMkIikfA7jBOSsWP22fPiPex5/YeJGW4qxo1JTWgaGxsB6OnpoampqXR/T08P5513Xukxvb29E37OsiwGBwdLP/9yoVCIUChU+joej7N9+3aWLl3KkSNHJn0ebiZIp9O0trbK9ZWp2Xx9Y9d2+PBhFEV5w/0rr2aqxg2QsWO2Xd9svjY4c65v+/btpz1unMikJjQdHR00Njaybt260kCUTqfZsGEDn/nMZwBYs2YNw8PDbN68mRUrVgDw6KOP4jgOq1evfkOvo6oqc+bMAaCysnJWvvFj5PrK22y+vkQiMSnXNl3jBsjYMVvM5muD2X99c+bMQVUn/yjJk05oMpkMe/fuLX194MABtm7dSk1NDW1tbdx888189atfZeHChXR0dHDbbbfR3NxcWtGwZMkS3v72t/NHf/RHfPvb38Y0TW666SY+/OEPT0nGJoTwn4wbQogp556kxx57zAVecbvhhhtc13Vdx3Hc2267zU0mk24oFHKvuOIKd9euXROeY2BgwP3IRz7ixuNxt7Ky0v3EJz7hjoyMnFQcqVTKBdxUKnWyl1AW5PrK22y+vlO5tpkybpxq/OVkNl/fbL4215XrO10nndDMFPl83v3KV77i5vN5v0OZEnJ95W02X1+5X1u5x/96ZvP1zeZrc125vtN1WhvrCSGEEELMBJPflSOEEEIIMc0koRFCCCFE2ZOERgghhBBlTxIaIYQQQpQ9SWiEEEIIUfbKNqG56667aG9vJxwOs3r1ap599lm/Qzppd9xxB6tWraKiooKGhgbe8573sGvXrgmPufzyy1EUZcLtj//4j32K+OT81V/91StiX7x4cen7+XyeG2+8kdraWuLxONdddx09PT0+Rnxy2tvbX3F9iqJw4403AuX33j355JNcc801NDc3oygK999//4Tvu67Ll7/8ZZqamohEIqxdu5Y9eyaeqjM4OMj1119PZWUlVVVVfOpTnyKTyUzjVby22TBugIwdMnbMHDNp3CjLhOZHP/oRt9xyC1/5ylfYsmULy5cv56qrrnrFWS8z3RNPPMGNN97IM888wyOPPIJpmlx55ZWMjo5OeNwf/dEf0dXVVbrdeeedPkV88s4+++wJsT/11FOl733+85/nwQcf5Cc/+QlPPPEEx44d433ve5+P0Z6cjRs3Tri2Rx55BIAPfOADpceU03s3OjrK8uXLueuuu074/TvvvJNvfOMbfPvb32bDhg3EYjGuuuoq8vl86THXX389L730Eo888ggPPfQQTz75JJ/+9Ken6xJe02wZN0DGDhk7Zo4ZNW5Mye42U+zCCy90b7zxxtLXtm27zc3N7h133OFjVKevt7fXBdwnnniidN+b3/xm93Of+5x/QZ2Gr3zlK+7y5ctP+L3h4WFX13X3Jz/5Sem+HTt2uIC7fv36aYpwcn3uc59z58+f7zqO47pueb93gHvfffeVvnYcx21sbHT//u//vnTf8PCwGwqF3B/84Aeu67ru9u3bXcDduHFj6TG/+tWvXEVR3M7OzmmL/dXM1nHDdWXskLFjZvB73Ci7Co1hGGzevJm1a9eW7lNVlbVr17J+/XofIzt9qVQKgJqamgn333PPPdTV1bFs2TJuvfVWstmsH+Gdkj179tDc3My8efO4/vrrOXz4MACbN2/GNM0J7+PixYtpa2sry/fRMAz+67/+i09+8pMoilK6v5zfu/EOHDhAd3f3hPcrkUiwevXq0vu1fv16qqqqWLlyZekxa9euRVVVNmzYMO0xjzebxw2QsUPGjplpuseNST1tezr09/dj2zbJZHLC/clkkp07d/oU1elzHIebb76ZSy65hGXLlpXu/+hHP8rcuXNpbm7mhRde4Itf/CK7du3i5z//uY/RvjGrV6/mu9/9LmeddRZdXV3cfvvtXHrppWzbto3u7m6CwSBVVVUTfiaZTNLd3e1PwKfh/vvvZ3h4mI9//OOl+8r5vXu5sffkRP/djX2vu7ubhoaGCd8PBALU1NT4/p7O1nEDZOwYI2PHzDPd40bZJTSz1Y033si2bdsmzBMDE+YRzznnHJqamrjiiivYt28f8+fPn+4wT8rVV19d+vO5557L6tWrmTt3Lj/+8Y+JRCI+Rjb5vvOd73D11VdPOPm5nN87UT5k7ChvMnZMnrKbcqqrq0PTtFd0tPf09NDY2OhTVKfnpptu4qGHHuKxxx6jpaXlNR+7evVqAPbu3TsdoU2qqqoqFi1axN69e2lsbMQwDIaHhyc8phzfx0OHDvHb3/6W//E//sdrPq6c37ux9+S1/rtrbGx8RYOtZVkMDg76/p7OxnEDZOwYrxzfy9k+dkz3uFF2CU0wGGTFihWsW7eudJ/jOKxbt441a9b4GNnJc12Xm266ifvuu49HH32Ujo6O1/2ZrVu3AtDU1DTF0U2+TCbDvn37aGpqYsWKFei6PuF93LVrF4cPHy679/Huu++moaGBd77zna/5uHJ+7zo6OmhsbJzwfqXTaTZs2FB6v9asWcPw8DCbN28uPebRRx/FcZzSgOyX2TRugIwdMnaUh2kfN06no9kvP/zhD91QKOR+97vfdbdv3+5++tOfdquqqtzu7m6/Qzspn/nMZ9xEIuE+/vjjbldXV+mWzWZd13XdvXv3un/913/tbtq0yT1w4ID7wAMPuPPmzXMvu+wynyN/Y/70T//Uffzxx90DBw64v//97921a9e6dXV1bm9vr+u6rvvHf/zHbltbm/voo4+6mzZtctesWeOuWbPG56hPjm3bbltbm/vFL35xwv3l+N6NjIy4zz33nPvcc8+5gPuP//iP7nPPPeceOnTIdV3X/drXvuZWVVW5DzzwgPvCCy+41157rdvR0eHmcrnSc7z97W93zz//fHfDhg3uU0895S5cuND9yEc+4tclTTBbxg3XlbFDxo6ZYyaNG2WZ0Liu637zm99029ra3GAw6F544YXuM88843dIJw044e3uu+92Xdd1Dx8+7F522WVuTU2NGwqF3AULFrh//ud/7qZSKX8Df4M+9KEPuU1NTW4wGHTnzJnjfuhDH3L37t1b+n4ul3P/5E/+xK2urnaj0aj73ve+1+3q6vIx4pP361//2gXcXbt2Tbi/HN+7xx577IR/H2+44QbXdb0lmLfddpubTCbdUCjkXnHFFa+47oGBAfcjH/mIG4/H3crKSvcTn/iEOzIy4sPVnNhsGDdcV8YOGTtmjpk0biiu67onV9MRQgghhJhZyq6HRgghhBDi5SShEUIIIUTZk4RGCCGEEGVPEhohhBBClD1JaIQQQghR9iShEUIIIUTZk4RGCCGEEGVPEhohhBBClD1JaIQQQghR9iShEUIIIUTZk4RGCCGEEGXv/wdkQREzAkJA6AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "grad_mat = np.loadtxt(folder_name+'s2_activation_in_1x0e+1x2e_lmax_2_5_grads.csv',delimiter = ',')\n",
    "grad_mat = grad_mat.reshape(grad_mat.shape[0],-1,2)\n",
    "grad_mat1 = grad_mat[:,:,0]\n",
    "grad_mat2 = grad_mat[:,:,1]\n",
    "# print(grad_mat)\n",
    "vmax = grad_mat1.max()\n",
    "vmax = 1.5\n",
    "fig, axarr = plt.subplots(1,2)\n",
    "# fig, axarr = plt.subplots(1,3)\n",
    "axarr[0].imshow(np.abs(grad_mat1),cmap='RdBu', vmax = vmax, vmin=-vmax)\n",
    "axarr[1].imshow(np.abs(grad_mat2),cmap='RdBu', vmax = vmax, vmin=-vmax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "loss_mat = np.loadtxt(folder_name+'s2_activation_in_1x2e+1x4e_lmax_4_1.csv',delimiter = ',')\n",
    "print(loss_mat)\n",
    "vmax = loss_mat.max()\n",
    "vmax = 10\n",
    "plt.imshow(loss_mat,cmap='RdBu', vmax = vmax, vmin=-vmax)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(3.4387e-10, grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "teacher = S2NetDot(irreps_in, l_max = lmax)\n",
    "student = S2NetDot(irreps_in, l_max = lmax)\n",
    "\n",
    "# list(student.parameters())[0].data = list(teacher.parameters())[0]\n",
    "list(student.parameters())[0].data[0] = -list(teacher.parameters())[0][0]\n",
    "list(student.parameters())[0].data[1] = list(teacher.parameters())[0][1]\n",
    "\n",
    "y1 = teacher(data)\n",
    "y2 = student(data)\n",
    "loss = torch.sum((y1-y2)**2)/N_train\n",
    "loss\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/jit/_check.py:178: UserWarning: The TorchScript type system doesn't support instance-level annotations on empty non-base types in `__init__`. Instead, either 1) use a type annotation in the class body, or 2) wrap the type in `torch.jit.Attribute`.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[Parameter containing:\n",
       " tensor([-0.6014, -1.0122], requires_grad=True)]"
      ]
     },
     "execution_count": 102,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "irreps_in = e3nn.o3.Irreps('1x4e+1x6e')\n",
    "torch.manual_seed(10)\n",
    "teacher = S2NetDot(irreps_in, l_max = 6)\n",
    "list(teacher.parameters())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "e3nn",
   "language": "python",
   "name": "e3nn"
  },
  "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
