{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ddced768",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import imageio"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "12a8d92c",
   "metadata": {},
   "outputs": [],
   "source": [
    "raw_path = '../md17'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "bfa711dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "molecule_files = {1:'H', 6: 'C', 8:'O', 7:'N'}\n",
    "def read_mol(mol_name):\n",
    "    npz_file = np.load(os.path.join(raw_path, molecule_files[mol_name]))\n",
    "    z = npz_file['z']\n",
    "    x_all = npz_file['R']\n",
    "    x = x_all[:, z > 1]\n",
    "    return z, x_all, x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "85033049",
   "metadata": {},
   "outputs": [],
   "source": [
    "from xyz2mol import *\n",
    "def get_mol(z, x):\n",
    "    mols = xyz2mol(z.tolist(), x.tolist(),\n",
    "                charge=0,\n",
    "                use_graph=True,\n",
    "                allow_charged_fragments=True,\n",
    "                embed_chiral=True,\n",
    "                use_huckel=False)\n",
    "    return mols[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0be69c3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def plot(x_gt, x_pred, path):\n",
    "    fig = plt.figure()\n",
    "    ax = fig.gca(projection='3d')\n",
    "    lw = 1.2\n",
    "\n",
    "    for p1, p2 in x_gt:\n",
    "        pos_gt = list(zip(p1, p2))\n",
    "        ax.plot(pos_gt[0], pos_gt[1], pos_gt[2], color='r', ls='-', linewidth=lw)\n",
    "    \n",
    "    for p1, p2 in x_pred:\n",
    "        pos_pred = list(zip(p1, p2))\n",
    "        ax.plot(pos_pred[0], pos_pred[1], pos_pred[2], color='b', ls='-', linewidth=lw)\n",
    "    \n",
    "    plt.savefig(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "0e878749",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_bonds(mol):\n",
    "    pos_pair = []\n",
    "    for bond in mol.GetBonds():\n",
    "        atom1_idx = bond.GetBeginAtomIdx()\n",
    "        atom2_idx = bond.GetEndAtomIdx()\n",
    "        atom1_symbol = mol.GetAtomWithIdx(atom1_idx).GetSymbol()\n",
    "        atom2_symbol = mol.GetAtomWithIdx(atom2_idx).GetSymbol()\n",
    "        # if atom1_symbol == 'H' or atom2_symbol == 'H':\n",
    "        #     continue\n",
    "        atom1_pos = list(mol.GetConformer().GetAtomPosition(atom1_idx))\n",
    "        atom2_pos = list(mol.GetConformer().GetAtomPosition(atom2_idx))\n",
    "        pos_pair.append((atom1_pos, atom2_pos))\n",
    "    return pos_pair"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7adab314",
   "metadata": {},
   "outputs": [],
   "source": [
    "molecule_files = dict(\n",
    "    Aspirin=\"aspirin_dft.npz\",\n",
    "    Benzene=\"benzene_dft.npz\",\n",
    "    Ethanol=\"ethanol_dft.npz\",\n",
    "    Malonaldehyde=\"malonaldehyde_dft.npz\",\n",
    "    Naphthalene=\"naphthalene_dft.npz\",\n",
    "    Salicylic=\"salicylic_dft.npz\",\n",
    "    Toluene=\"toluene_dft.npz\",\n",
    "    Uracil=\"uracil_dft.npz\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "0505f6ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[6 6 7 6 7 6 8 8 1 1 1 1]\n"
     ]
    }
   ],
   "source": [
    "tar_mol = 'Uracil'\n",
    "z, x_all, x = read_mol(tar_mol)\n",
    "print(z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "f87b6ee0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[127947, 127957, 127967, 127977, 127987, 127997, 128007, 128017, 128027, 128037]\n"
     ]
    }
   ],
   "source": [
    "now_index = 128047\n",
    "past_index = [now_index - i*10  for i in range(10, 0, -1)]\n",
    "print(past_index)\n",
    "x_now = x_all[now_index]\n",
    "mol_gt = get_mol(z, x_now)\n",
    "pair_gt = get_bonds(mol_gt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "56d5029f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8, 3)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "estag_pred = np.array([[ 1.5626e+00,  1.3470e-01, -4.2686e-01],\n",
    "        [ 1.3546e+00, -1.1379e+00, -2.4442e-01],\n",
    "        [ 8.7156e-02, -1.5669e+00,  1.6798e-01],\n",
    "        [-1.0801e+00, -6.2163e-01,  6.3953e-02],\n",
    "        [-6.6833e-01,  6.4951e-01,  3.0130e-01],\n",
    "        [ 5.6741e-01,  1.1699e+00,  2.1489e-03],\n",
    "        [-2.2218e+00, -1.0695e+00,  1.6782e-01],\n",
    "        [ 7.1248e-01,  2.3828e+00, -8.3180e-02]])\n",
    "print(estag_pred.shape)\n",
    "x_now[z>1] = estag_pred\n",
    "mol_estag = get_mol(z, x_now)\n",
    "pair_estag = get_bonds(mol_estag)\n",
    "plot(pair_gt, pair_estag, f'../hh/3d_{tar_mol}_estag.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "773238bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8, 3)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPkAAADuCAYAAAD7nKGzAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABhjklEQVR4nO2dd3hUZdrGf2cmk94rJfSShJAQAkFEEESwIogi4iq4imBfXPu3llV3UXd11d1VV9ey6qqrNFFAUbGxrqKUkISQQAgllSSTnkwm0873RzzHyWR6SXPu6/KSJDPnvDPn3Od53qfcjyCKIn744cfghaKvF+CHH374Fn6S++HHIIef5H74McjhJ7kffgxy+Enuhx+DHH6S++HHIEeAg7/782t++OF7CL48uN+S++HHIIef5H74McjhJ7kffgxy+Enuhx+DHH6S++HHIIef5H74McjhJ7kffgxy+Enuhx+DHH6S++HHIIef5H74McjhJ7kffgxy+Enuhx+DHH6S++HHIIef5H74McjhJ7kffgxyOOon98MHMJlMaDQalEolAQEBKJVKFAr/89YP30BwoLvuF43wIkRRxGAwYDAY0Ov1mEwm+W8KhQKVSuUn/S8TPhWN8JO8l2AymWRiC4KAXq+X/yaKovyf9HNAQAAqlUq29oLg0/vAj76Fn+QDGaIoYjQaZVJLZDUnubX3mJMewGAwEBQUREhICEql0k/6wQWfXkz/ntyHMHfPBUGQiSkR2BZRzV8rvb6yspKwsDDi4+MBUCqV3dx7P+n9sAU/yX0ES/fcExIKgoBCoUAQBJRKJaIoYjKZ6OjokI/rJ70ftuAnuZdh7p5L5PQ2pIeGdGw/6f2wBz/JvQhRFKmrq0OlUhESEuKQWPZcdlfgDOkDAgLk//yk/2XBT3IvwWQyodPpqKmpITo6mtDQUJuvlUjpythoV15vjfTm3gUgR+8DAgLkrYAfgxN+knsIy+Baf8xv2yK9wWCgpKSECRMm+Ek/iOEnuQcQRRGdTtctuCYIQrciF2/BVcvv6FgSiVtbW1EoFDLppb+bu/d+0g9s+EnuJqSqNehOGm+SsbdgLWVn+fn8pB+48JPcRdjKfUsYiCS3hDXS6/X6HqSXKvL8pO/f8JPcBTiT+/YVyfvy4SHl5yVYI71l3b2f9P0HfpI7AcvSVHvBNYVCMeAtuSNYI71Op6OzsxPo+g5MJhNhYWFy3b2f9H0HP8kdQLJaRqPRqZvVV4E3aS39EdZIf+DAAbKzs+XvTKVSye69n/S9Cz/J7UCv16PRaAgMDHT6xvRldH2gQPquAgIC5AeTTqdDp9MBXZbeck/vh+/gJ7kVSMG1xsZGysrKyMjIcPq9zuydTSYT5eXlBAYGEhsbi0ql8nTJ/Q7Sd2BeZmv+ez/pew9+klvAPPct7S1dgSOSd3R0kJ+fT3R0NHq9nsrKSkwmE1FRUcTGxhIVFUVAQM/LMhii9mCd9NJ3bk56v4CG9+AnuRmk4JpUU+5OEM0eGWtraykpKWHSpEmEh4fLUXqDwUBzczMNDQ2cOHECQRCIiYkhJiaGqKioAXmTO7u9sJauE0WRzs7OboE8P+ndh5/k2C5N9ZYlN5lMHD16lPb2dnJycggMDOwmGhEQEEBcXBxxcXFAlyvb1NQkPxQCAwNRKBSEhYV5ramlv8IR6dva2lAqlcTExPhVc5zEL57k9nLf7lhyyweD5J4nJiaSkpLi1A0ZGBhI+c5Gdm9u4rcfnoFWq+XEiRM0NDSgVqsJDQ2VLX1oaOigvsktr0lLSwsKhYKQkBD5gedvq7WPXyzJrckyWate88SSm7vnMTExLh2nsxPWfzWHXxeVE5OWRFRUFBEREQwfPhyNRkNjYyPHjx9Ho9EQEREhkz44ONil8ww0iKKIUqnstqc3mUxotVr5NX7Sd8cvkuTO5r7ddddNJhPFxcXd3HNXMfP6iQz/vzo+eqiAazcldTt+WFgYYWFhJCcnI4oira2tNDY2UlxcjE6nIyoqSib9YIvcSwFRCdbcez/pu+MXR3Kp71ty9exdcHfcdZ1OR3V1NaNGjXLaPbd6bqXAigWneeezEVyr09kM6AmCQGRkJJGRkYwaNQqTyURzczONjY1UVFQ4FbkfSLAkuSVskf6XrJozsK+4C3BHlslVd722tpZjx44RHR3N2LFjPVkuAMsfHsMTH8dx4h8bCF6e5dR7FAqFbMUBh5F7X8CXqT5XA49+1ZxfCMlFUaShoYGWlhaGDh3qUnrHGZhMJkpKSmhrayM1NRW1Wu3JcmWMmxTImcNO8P6LrVy73D3yWEbu9Xo9jY2Ncrygo6ODU6dOERMTQ0RERL+/wR1Zckewp5pTW1tLeHg4UVFRg0pAY9AnHE0mk5x+aWpq8voF6+joYO/evahUKrKzswkKCvKqJVuxNpi3qxcQmFfgleOpVCo50j9jxgyCg4MJDAykoqKCH3/8kYKCAioqKmhvb3f7c/gyzecpyS0hET4gIIC2tjaMRiNGo5GOjg5aW1tpaWmhra2Nzs5OjEbjgCxIGrSW3DL3LUkZexN1dXUcPXqUtLQ0YmNjAe9Xpi29Ppx7Hwui8K+5jH451WvHlaBQKBg6dChDhw5FFEWvRO59SXJfHttoNMrW2/x8A101Z1CS3FruW6lUeq1xRHLPW1tbe0TPnd3HO3tjREfDorPq2fTteO5Vq2HkSHeX7dSavBG5H0iW3NGxB4NqzqAiub3ctyAIGI1Gj88hFbckJCQwbdo0t5VhXLkRrrw9iuu/vYKH//MQZGe7vGZ34W7kfqCS3Gg0Ojy2s6o5x44dY9y4cYSHh/tkra5g0JDckSyTN8QcrLnnlnCW5K6s5dxzjQSHCuz+j5bLHtdDH+W+nY3cR0RE+GwNvn6AmPfFOwNbqjmPPPIITz75JCkpKd5epssYFCR3RpbJncIW8+NL7vn06dMJCgqy+VpfdIupVHDJUi3v/Odylm/bhuGyy7x6fHdhK3JfV1dHS0sLBw8elB8K3orc97UldwSJ9BqNpl9YcRjg0XXJend2diKKot39kFKpdMtdN5lM7N27l4CAAKZNm2aX4OA7+aelyzv4wnQOtX/b7PVjewtS5H7s2LHExMSQmprq9ci9r/fkrlpyW2hvb+83JB+wltxVWSZ3LHldXR0ajYZp06bJ1soRXLHkrriekybpGT+qjfcOpHFbfj6mzEyn3tcXkD5XcHCw1yP3viS5N7cCGo3G7hSd3sSAJLkrpakSXCG5yWTi2LFjtLS0EBYW5lJzie/kn2DRZW289c9buOOlh9C9+ILXz+EtWCOLtch9W1sbDQ0NPSL30dHRNuv9B0qrrclk6jclxAPKXZesd15eHgaDwaV0hbOv02q17Nu3D6VSybRp07rplDl7Hl8VTFx0URPFmpEc2lAC9fU+OYc34AwRBUEgIiKCUaNGkZWVxfTp00lKSqKtrY1Dhw6xb98+SkpKqK+vl3PUzh67r9Hf1tg/HjVOwFyWSaPR+MRaStHz1NRU2T2XLLOzezVnSV5TU4NOpyM+Pt7hPl86bny8nvnzjby1eyXPLF6M5n//c2pNvQ13bnKFQkF0dDTR0dHAz5H7xsbGbpF7g8HQ70hkDf1pjQOC5JbFB+4G0WxBcs+bm5t7RM9dDaQ5IrnJZKKoqAidTkdYWBiHDx/GYDDI+ebo6Gi7bt6v5ldw365lPFVwB6q33kK/apXTa+steOMGtxW5r6ysZN++fQQGBno9ct9fSOlt9GuS28p9e5IOs4RWqyU/P5+4uDimT5/usXCEPZJ3dHSQl5fH0KFDGTZsGEajkdGjR2M0GuV888mTJ+V8dGxsLBERET8HmgwGlm1ayQ18w6qZRfznt2mISiWGq69267P7alvhCysmRe5PnTpFTk4OWq1WLsppbW31WC3Hm56hTqdzyjvrLfRbktvLfXvLkqvVao4cOdLNPbeEqw8UWySXziWpxEiNEND1eWJjY+UCG51OR2NjI1VVVbS2thIcHExQUBBDXnuNL0rHIAoCm/aO5eLVO7nm9vPRKpUYVqxw4xvwDXrDVfV25N6b6bO2trZ+E1mHfkhyZ0YSeWrJTSYTpaWlNDU1eb24xfLmFkWR0tJSGhsbHZ5LQmBgIElJSSQlJSGKIh0dHah37UL1ylZWB5dw880VJCcHsvr359C0/Atuu+VctAEBGJYtc3qdvkRv70e9Ebn3Zmqura2t3+TIoZ+R3NnctyeWvKOjg4KCAmJjY62655bw5IGi0+koKCggPDycadOmuXUTCYJAqELB+EceZVnSFsYnB3PvvQLNzTXodHXctX42FXN38sTaCzEplZiWLnX62L4iY18HnaTIvRS9N5lMtLS00NDQYLPm3mg0DspCGOhHJHdVlskd4hkMBvbv309aWprTxS3unqulpYWCggLGjx9PUlKS4zfYQdBjj/GfxgvZ1T6D77Z3EBsbRWxsFHfeCRkZ7axceQ7N07/ghevnc6S8HPHSS4mNjSUsLKxPyNbXJLeEM5H78PBwDAaDVyy6RqMhLCzMCyv3Dvqc5LY0z+3BVUsuiiLHjh1Dp9Nx5plnunQB3Ml763Q6CgsLycrK8vhiK//7X2pf/JB1IcdYt66K8eOju/194UL46KMOli2bTef0A7zy6AxOx8ZyMitLtijSfr+3gkG+IrkUn/EU1iL3VVVVNDY2eiVy39bW5ie5BPPct7OVa+CaddVqtRQUFBATE0NkZKTL6qWunMtoNFJUVITRaGTGjBmeu3/NzQTdeBPXj/iMjBFGli2rA6J7vGzGDBM7d2q49NJ0lqce5N1104l9918YzjtP3ptaS9W58p27goG2DVCpVERFRdHZ2cnEiRO7Re7b2toICQlxKXLv35P/BKPRyPHjx0lMTCQoKMili+esJbeMnu/fv9/rs80kaDQa8vPzGTZsGM3NzV7Z3wXfdx//NN3Ajy0T2fleNfacnEmTTHz6qYYlSyawaFQ+H1w9nYD3XiViwQJ5b2qZqhMEAa1WS3NzM5GRkV4jkC8teW8IRngaue9PHWjQByQ3d88bGxvdGgigUCi6jRmydo5jx471iJ67s7925j1SpVx6ejrR0dFUVFS4dA5rCNi2jVMbD3BPwFv85dlOhg0z4kgfcswYkc8+03DppSNZkJTHx1fNIGTjyxjnzQN6puo6Ojo4ePAgVVVVHDlyhJCQEGJjY2WL5S58acl92WZq7cHsTuS+vb3dZXddEIQLgL8CSuBVURSftPj71cB9P/3YBtwsimKeM8fuVZJb5r7dlWRSKpXdxPPN0dnZKU8NtYyeu0tyW5Zcepg0Nze7PUTBGoTaWgJuv4Nrh+1j3mQTV11loLnZOY9iyBCRjz/WcMUVQ5nbmctny88kevPzGOfM6fFalUpFYGAgaWlpssVqaGjg2LFjaLVaIiMjZdK7ss3p73tyW8d2VqbbXuT+yy+/ZM+ePUyaNMlpt10QBCXwArAQqAD2CoLwkSiKh81edgKYK4pioyAIFwL/BM5w5rP1CsltyTIplcpuzQfOwhZZ6+vrKS4uJiUlhfj4eKffZw+2Kt50Oh35+flERUVZlYFyG6JI8O2380zEwxxpS+bHv2lw9dCxsfDhhxquvjqO2bl7+fzysxm69RmMs2b1eK25PJZksUaMGNHt5i0vL0cURbkKz9Gk1YHorrsrGGEZuR87dixlZWWUlpayYMECHnnkES644AJHh5kBHBNF8TiAIAjvAUsAmeSiKH5n9vo9QLKza/Q5ye3lvqX8pKuw3JObF5xMmzbNpvvvTn7d2oOhubmZQ4cOMWHCBBITE11eP9iuk1b9+98Uf13Hw8ZbeO31ThISRLuvt4XwcNiwoYMbbohkzq7v+XTpAsZ9uB7jzJlOvd9a2slcrz0wMFB2/S1TdQOR5N6qeJO+s+XLl3PhhRc6+7bhQLnZzxXYt9KrgU+cPbhPSe4o9+1uUYs58ey555Zwp9fbPPAmiiIVFRVUVFQwdepUr5cuCidOoLjvQVbFH+HSWUYWL+7u5biaygsKgjfe0LLuN8HM3fg1Oy69hMyPfodpxgyX1xYQEEBCQgIJCQlAV9ZCCuBZpuoGWnQdvNv/7cae3NqHsnqxBUE4hy6Sz3b24D4hubMjiRQKhUeW3JF7bu187gbejEYjhw93eU/OpMdcviGNRoJvuolHhz5PjSaeD59qd2mdtqBUwt+f7yQ6OpCFL33MB4uXM2vHbzFNm+YRaYKDgxk2bBjDhg3rFow6fPiwrIoSHBwszxH3BnztrvdhxVsFMMLs52SgyvJFgiBkAq8CF4qi6LSggNdJ7kru2113XRAEmpub6ejosOueW8KdAQsKhQKtVsuPP/5IcnIyycnJTgkiuArV88+z/3AYT7b/io0bO/jJS+52THe7xgQB/vBHHTExKhb9cRPvXnw9F+xUQnq6W8frefzuwaiysjJ5Yo3UVSdZeU/aQntbc91dtLe3u6pYuxeYIAjCGKASWAH8yvwFgiCMBLYAK0VRPOrKwb1KcldlmZRKJTqdzqVzdHZ2cvjwYUwmE9OnT3fpwrjjObS2tnL69Gmys7OdHhAoEdLp4p5DhzA99hTXJpRx7TI9557rvV75n9cEd92tJzpaZMVdb/DS+etYtnO518/Tda6uMtGhQ4cCXUFKKfostYVKpA8JCXH6uL6MrntDqVWCq5ZcFEWDIAi3AZ/SlUJ7XRTFQkEQbvrp7y8BDwNxwIs/fQcGURSnO3N8r5FcsuBgvXPMGlzdk0vu+dixY6moqHD5orjirouiSElJCQ0NDYwYMcKlCaDS3t+p9XV2Erx2LXeNew9dZwR//KNtN90b/d+rbzAQFSVy45rnaLrgEea+MA6mTvX4uOawfMAFBgYyZMgQhgwZ0i1Vd/ToUTo7O51O1fkyT97XSq2iKH4MfGzxu5fM/n0DcIM76/EayaW9tys3orMkl6LnDQ0Nsu5aWVmZy2t0luQ6nY68vDx5BLFGo3HpPK641oGPP87umlSeb7iATz7pwFa8xpsWbNkVRiIjO1m54iHW3fx3HkgvRkzz3pw1e16MJ6m6/phCs4aOjg6XPBRfw6vuuqv7RmdILkXPo6KiZPdcCuxZoqICfve7AP74R4PVkWHOuOtNTU0UFhYyceJEEhISqK2t9XoprMlk4siRIxi/+YYJf32da+MquO02HTNnet9Nt4Xzzjex8QMNv7rsJprmbeTP3yggdaJXju3SVsUiVafX62lqapJTdUFBQTLpvUlES3jTkgNePZan6NMGFUckl9xziXASbN1ARiPU1wtMnRrIgw8aue02Y7eJQvbKYUVRpLy8nKqqqm7pMXcCXvbeI3kJ8UFBTHj2Wa4f/xGBRgXnn/8/8vOD5L2qtfSct+WaZs4y8dw/irn/tstoOvsLXvxGQUDaeI+P60nUXqVSdUvVdXR0yKm65uZmAgMDUalUXu+q85aXIIqiz2S13EW/JLkoihw/fpz6+nqXouejRsH27Xo2blRw770BvP22gr//3cCsWV1fui133Wg0UlhYiEKhICcnp9tT2N0qOWsXWiqimThxIkMefpgdxgv4z4k5fPmlhilTcnqUlUodYzExMT7LO09I1fLJtwJL587h6rPzeePrE4Skj/H4uN5ab0hICMOHD2f48OFUVFTIs+alrrro6Gi5q84T6+nNFBr0L1FIr7vrrsAayTs7OykoKCAyMtLl6DmAcLqaq19YwYW/u4WHD61g4UIVK1eaWL/eYJWw7e3t5OfnM2LECJKTe1YKequppaqqilOnTpGVlUXEN9/Q9O+PWRtZxn336Zgypeu1oaGhhIaGkpycLE8QbWho4NSpU7KFaG1tJTw83Ks30YQUgU9/UHHpmSksm1vJf74qIzLD/RHJviyGCQ0NZejQobIAZlNTEw0NDRw/frxbA46rqTpvWvL+hn5lyRsaGigqKurhnruEwEBM8+cT94e7eUG4h1UrH+bWfTeQmRnI734Xzvz5jfJLa2pqKC0tZfLkyURGRlo9nKfuurT/1mq15OTkENDYSMDNN3NLyi6Sg5Xceaf1oJ7lBNGmpiaOHTtGWVmZ3PgQGxtLXFycVxpjho9SsvNAGMtmxLJono7Nn1eSkD3crWP1VsWbUqnsJv7gSarOWyTv7OzsV0E36Cckd9c9t4q4OIy//z3G++5DsXEjM154gR+K7uQfU/7BAw+t5O23x/LPf4oEBh6lra2NnJwcu2kbT9x1af8dGxtLamoqAhBw++28F3ED20rT+e9/23G2klKlUhESEkJ6erpcYVZfX8+hQ4cwmUxON4+Yw5I0cUMC+DA3jqunVXDBglC2fnKaEWcMcemzWzuut+CIiI5SdVJLqKtdda6gvym1Qh+761I+ef/+/URERLjsntu9mYKDMa1ciemaaxC+/55bXnyRyw8+zB3HX+bMMy5g1aok/vz0RFQqx0KO7ljy1tZWjh8/3s0rUbz9NjWf5nNb4Eb+8Ac9EyeasF627Pj4UoXZ6NGjezSPBAcH2w3g2UNknIqNecNYnV3C+ReMZus2NRNnOy4ZNkd/aFCxlqqTdN3Ky7t6QSTCu1ID4Qj9TRUG+tiSNzQ0oNFoSElJcdk9lyysw2CJICDOmoVh1iz0+/bx+N/+xuqPX+X2fz9N9pYgnnlGz6JrrLvqXW93vamlo6OD0tJSpk6d+nOjQlkZyt/eyQ1j8shIUHDzzXoMBufJYG/bYNk8Yi+A50wTRnBUEG/mjef27INcsGgaWzY1krXA+aGP/bFBxXL7I01kkR6MHR0dlJeXyw9Gd8/T30QcoY9ILrnnarWa0NBQt/bfkqvvTERUFEXKysqo1OkIWreOeS9PYv/bm3jmjzquvuF6zvv9If7yNxh58eQe73XFkptMJo4ePYpWqyUjI+Pni20yoVqzhldHPsq3ZaPY94EOhcJ3EVh7ATypjjwuLg6lUmlzDQHhwbyQO4UHc77i4mXn8/5bzcxebPthaI7+YMkdQZrIIrUK79mzB4VC0U3iSXowupKqc0cVxtfwamWBMxdWp9Nx4MABDAYDOTk5bl80Z/fKBoOB/Px82trayMzM7DpfSAiBa1Zy/8nrOfDGfrR6BVmXp/LcxFcwvrsRzHLpzlpynU7H/v37UalUxMfHd/tcyhde4OTBZu46+RueesrAqFG9l2KRLNi4ceOYPn06kydPJjg4mLKyMvLy8mhpaeH06dNWewgUYSGs3zubO0dsYOnKeD5+z7nKv4FAcnOIoohSqWT48OFkZGQwY8YMkpOT0Wq1FBYWsnfvXnnCqqNiql+8u97Y2Mjhw4d7RM/duSmcqZZra2ujoKCAkSNHMnz4cLRabXfCCgLjVkznoyth80v13PPgSv59QxUv3rOSWbdNwbh6NYroaIcklzTWpc9VVFQkW3+hqAjhgYe4btxJzh4jcu217g1q8KQLzRzmwSmNRkNxcTFardZmAE8IC+WuPRcRNesfrLzxVp5vbeKqNfYDowON5JbHFQSByMhIIiMjrabqAgICus2qM/+s/W2wAvSi/NOJEyeoq6sjOzu7W4pBIqurDfuOLPnp06c5fvx4t/SYrfcIAiy7OY7zroZHHxzD/Fc3s/KvH/Lnx88gevl8QufNg5wcq+cxz39Lbpps/XU6Aq6/nmcnvUxheSL7P9G5LOXkawQGBjJ69GiHAbwb/nclMXMeZ+3dv6O5tZWb7rTfSOKQ5EYjitJSFAUFiEOGYDzrLIdr9dXDw1G5rGWqrrOzs9uwxbCwMFnI0R2SOyHiKPz094sADfBrURQPOHt8n0fXzUcFWXPP3SW5LUsu7Ys1Gk2P9JijB0NkJPzlbwLXXGfg9tuWkHr0Yp449DKr370J4V//wnjrrZgWLwaVSj5PR0dHV/7bbP2S1VU+8QTFlZE80LyS1183MMT1bFQ3+LrQwlEAL/PVuby7+h6uefRPNLVoue/3CqsPrR5kbGxEeegQQsEh2nJLqclXU32sg2p9PJWRaZRPmkTE2YE8+KD9tmNfWnJXqt2CgoK6pera29tpbGzk9ddf55VXXiE5OZmJEydy7rnn2qy/kPDTPexIxPFCYMJP/50B/AMnRRzBx5Zccs/taaF5QwJKQmdnJ3l5ecTFxTF16tQeDx1n9/FTp4p8s1vPa68puPeh23h+wgreHPcGWbfeCvfei+6GG8ibPp3IsWNJSUnpcR5BEFAdOIDpz8+yamw1i+eauPxyz0bj9kWZpLUAXsAbl7P56jVc9dyLlJW38MQzEBkZjlYrUF0pUrO/mkOfVvFNTQ215QaqawKo7oimUphIlXAOGlOXFxcZqmfISBiaLDBkiMjwSMf3gK9I7knji9Q7Hx4ezu23345er0er1bJ//35iYmKY95Mcti38+OOP4EDE8aef3xK7nvJ7BEGIFgRhqCiK1c6s0WfyT7bcc0u4S3LL90kPFEdjiJ21hkolrF1rYvFiHTfcYGTGf+7m9ptu454h/yTilWc548knMa1YgfHWWxEzM7ufp6ODmHXrWJ+9kaqKKLb91TVhjP4I8xTUmP+t57Nz1zJ347/YsFlBiEJLs6FLCSWIQIYpghga2cawJAND5gSSkRZJUnoMQ4eLDBnSxpAhIq4Jp3TBl3t9b9Wtd3Z2Mm3aNJY5OWG2srISHIs4WhN6HA70DckdueeW8NSSi6LIqVOnqKmp8bxazgqGDIHf/a6Iu+6K5ZZbAnin/Uaefvo6lsd+S8A/XkR1xhmIs2d3ufKLFkFAAEOffZYD+gzW517Mpk0Gfppl4BG8FXgzh9ukiY4m/fMnuG70v9goXsFbc18jNjWSoJQINKOjaFYIJCUlkZiYaFaB55knA70XePMErko/2bimlr90WujRGrwu/7Rv3z7Gjx/vtFSxJ5ZcKhsNDAz0KB3nCKIoMnRoEW+8oWXXrqmsWRPBe+eezzPPnMvoP5eifPllAtauhagoTFOmELLjC1Yln2bVKhMXXOD5zd0vERvLqnNO8urX0Zzx3s2Yp5Jzc3OJjIz0SgWeOXzprntTFcaVPPlPTVGORBydEnq0Ba9+Y0qlkpkzZ7qkRe4uyfV6PaWlpSQmJjJp0iSfEVyn06HRaFCpVMyYMYUHHhA5cECHwdDVt/7Ulol0/PHP6I4fx3D33Sg++YSHxUfpbOzkT7ef9No6+lProoTUMyMxiQJHj/b87uPj40lJSWHGjBmMH9/Vo37s2DF+/PFHjhw5Ql1dncuDNQZCas7V6HpOV9ZmgiAIYwRBCKRLxPEji5d9BKwSujATaHZ2Pw4+cNddVUR1h+TV1dVUVVUxdOhQhg0b5uoSnUZLSwuHDh0iMDCQcePGyb8fNw4+/FDPBx8ouPvuAN59V8Hf/hbBnBtv5KsJv+bZReHsHLqWuJw3u/btd92FmJbm8Xr6jbv+E4IzxzFWcYrCwiFkZPzssVge11oAr76+vkcFnqMWWl9pvHlTcUaqlnMWP2VlHIk4fkxX+uwYXSm061xZU5/PJ3eF5OZtm+PGjXNrxJKzqK6u5sSJE0yZMoW8vJ5z5QQBLrvMxIIFOv7wByUXXKBiyRITP/4YyKprGxnzu/vRn7oK5dNPo8rOxnTxxV1kP/NMoKtQ59SpU3Iwy1vC/r0JU0oKGaaDHN53Dqz42d219/CwrCHv7OykoaGhWwttXFwcsbGxXpst5/BzeFnE0dWyVidEHEXgVnfX5PU7yxc6b9A1sSMvL4/ExERSU1Opra2ls7PTrTXauwlNJhMlJSVoNBpmzJjhkHyRkfDUU0auvtrE+eeraG4W2Lo1koKCEDIzx5A6fy4pF55g0q7nGXPuQoSZM2hYs4b85GRGjRlDS0uLbNGkggvLsUPgm8CbpxBHj2ay8mN+PHAW8HMGxRUPISgoqNuY4NbWVhoaGqxW4PkK3nTX29raXNVc9zn63Hw4o70uiUmYp8fcnb5iTxNdGmIYHR1NVlaWS65sVpbIyZM6Pv9coKFBTWlpIDU1gWzZoqC4eDxNTX8lOOhZxheVM2n1j6TEHmH8pQLjV05n4sRxiGInGk2XlplGoyEyMpK4uDifWnmPHxpKJZOH1/OvY91TpO5uAyzLSS0r8LRaLRUVFR4H8CxhNBq95jVotVqvZ3g8Rb8guS2yiqLIyZMnqa2t7ZEec3fssZR6s3xyt7a2UlBQ4FJmwBIhIbB4sUhFRQfz5rUyenTET58DqquNfPZZGWVlobTUXMCPX1fz79eDOPlqFCASGhJG9ekuqybJFEv7VqVSSXR0tCyw4c3gk6fHmpRmpPLTCBobW4kx60b1xhotK/B++OEHAEpKSmQRCFdaaG3Bm5bc3liwvkK/JbnBYKCgoIDg4GC75bCuwlrVm7T/zszMtBoZdXkiikXRjU7XSXn5QebPH8rIkUkAiOJIdI2N6F97lvTfX01TRwQvnvsxt355UQ+Z4s7OTurq6ujo6GDv3r29YuWdxdjp0QR9pqOoSMmsWb6VlFYoFPKoKk8CeJbwVuCtPyq1go/25K7AGlklqzpmzBh51I4l3JFlsnyfKIocPXqU9vZ2u/tvqeHE2eCM+f5ZUmi1WokXFkbuzLXUCyG8zkqu3/cG2TvVnHlB9weNVCtdW1tLVlZWDysvBaqs7eV9DcWkiUxSFlNYONHnJO92Xi8G8Lytud7f0p39zpJXVVVx8uRJm1bV1vuchURy8/23tTp3y/e48oSWSC55CPbGHL//vorzkwu4anwNeYXvcd3KC/lvISRY2TFIKSRLK19fX+/WXt4brr8xNZUMQy6HD3gm4+wIjr5/VwJ4llbbm0qt/Y3g0I9IbjKZKC4uprOz06motieWvLW1ldLSUqf33+5IQKnVagICAux+Fr0etmwJ4MXOv6J/bBUPTM7ihxlHWXPRcDb/EIu5cbF18wQFBckjhK3t5aWIvSeSRvYgjhnDZOUGPjhowJe3kysEchTAs6zA81bFW0dHR78TcYR+4q7rdDr27t1LYmIiaWlpTh3DXUuu1Wo5evQoU6dOdboyyZUHisFg4OTJkwBkZ2fb/SxffBGAXmPgkuCdGC76MwFBQfzrTzuYdfd4nrqnmfufcS1tZMvKHz9+nI6ODt/s5QMCmDS8kfXHQxFF3/XLe2IlzQN4oijKU1mkAJ4kChEcHOzR99IflVqhH1jy5uZmWlpamDZtGrEudHK4asml/bdWqyU9Pd2l0kNn3fWOjg4OHjxITExMl6qKg5vy/fdVLI35koDFizH+VPydtPZi3vr471zy6j2ccV4b51zQdYncyZM7svJhYWEYDAaP3cz0dBPNnwRRUaFnxAjfBJ685VILgtCjAu/AgQO0t7eTm5srD2hwJ4DXH1VhoA9JLrWjqtVqQkJCXCI4uEZy8/13QkKC61NZnHDXpVbX9PR0jEYjarXa7utbWuDjHUq2dT6FfuWj3f521r9/zQOTX+CGVdfz34MCw4Z5ThxrVr6iooKWlhb27t3rUTpqSFYiMZ+3UFgYwIgRvgm++ao5RaFQoFQqGTt2LCqVyqMAXn8UcQQvN6iAc+66Xq8nNzcXnU7n1igkZ88DXZH6ffv2MXLkSMaPH+9Wft3RA6WiooIjR44wbdo0oqOjHT4URFFk61aBaFUbczLq6UxLk+MSAEREcOfGLLI6f+D6JR3YmNHoEYKCgoiPjycuLo7p06eTmJhIS0sLubm55ObmUlZWRnt7u1PegzgpjQxFIYcP+26Sp8lk8llQyzyFJgXw0tPTmTFjBiNGjJA18Pbt20dpaSmNjY1Wr29/JXmvW3IpPTZ27FiGeKqH5ACSzpt5pN6bAwylWvrOzs5ugxLtudaiKGIymXjvP4H8SvE+plVXd+uNl4ophOlTee2eV5n51GT+cJ+OR/+i8kkOVjqflI4aN25cj718VFSUvJe3FqAypaaSodtD4cFMK2fwDnzVnAK2vQRXA3ieKLUKghALvA+MBk4Cy0VRbLR4zQjgLWAIXQ36/xRF8a+Ojt2rJK+srOTUqVMO02Oewjz/7arOmzVYe49erycvL4+YmJiuEUhmVsYWySWCV1aKfLNbydOKVxBXbCEwMFA+vmTRTSYTYfdcyzufPcrC157ljHO0JHr5mWjroWG5l5eKTk6ePGk1Ym8aO5bJitd5Ps93vfO+ctclOOMl2Avg7d+/n08++YTY2Fh3yX4/8IUoik8KgnD/Tz/fZ/EaA3CXKIoHBEGIAPYLgvC5hR5cz3W7uhJHsPZlmUwmioqK0Ov1TqXHPIGj/Le7JDcnRHt7O3l5eYwbN46kpKQer7dGclEU5bLUzZtVpEZUkrFgFPqfYhHSDSz9XyJ61ru38Pj0P3Dz6vv5+ytBGI3GXi2dtCw60Wq1sjSxuZVPT27kaFkoer1z2uyuwpfuujuwDOClpKRQWVnJ3r17Offcc/ntb3/LihUrXDnkEmDeT/9+E/gaC5L/1ENe/dO/WwVBKKJLBqp3SW6Jjo4O8vPzSUpKYtSoUTYvlDcKCaStgC3ygfvuuvQetVrNkSNHyMzMtNltZPlQEEVRbotVKBS8/66Cq9v/iXHVSpvnVCgUXUQeNYq1/0zhvys/56lHZnPuuSaCguhGdncJ7853HhwcbNXKD0tuQl+mZPfuGsLCvF9j70t33RsIDg5myJAhXHHFFdxyyy3ubK2SJCEIURSrBUGwW8AhCMJoYCrwg6MD+5TkEiEmTZokWwJrcFeWWSKfQqGwuv+2dy5XIHW8Sc0y06dPtzs6x9ySS+63IAgIgkBxscDBAhVbhnyG6Zx7HJ67ra2NQ0OH8PxVW5i7YSqPPhDH038zyV6B0WiU/y2NPeoLKx94dhajDpymtDSE1FSdHLG3t5d3Bb52172B9vZ2uZnG2gNuwYIFnD59usfvCwsLl7hyHkEQwoHNwB2iKLY4er3P+smPHz9OQ0ODQ0KAZwMWjEYjx44do7W11eEYYuk9ejfC1adOnSIkJMSpbID08LEkOMD77wcwOyKX5GvnoXdw49fX11NSUtI1V+3vWby/52bmvPk2s+aZWLbsZ7deIrv5vt5TK+8qTKmpTKaAqqo5ZGeHkp2dLVv5EydOoFKp5FSUO9V3vhyR5C04Gna4a9cuW3/6UBCEGklmWRCEoUCttRcKgqCii+DviKK4xZl1ef1bMxqN8qyzadOmOTUszt3qNUEQyM3NRRAEsrOznZo57aq7rtPpqK6uJjg4mPT0dKdvNL1ej16v70ZwUYT33zZxTetLGK65xu77KyoqOH78ONnZ2V03TnAwGRvu5RnF3dy6VsHRo4L8eZRKJYGBgQQHBxMYGChbTaPRKK+jW4rOBzClppKp3Uth3s8ZgpiYGMaPH09OTg6pqanyQMG9e/dy5MgR1Gq109d9IOi7eTgH7SPg2p/+fS3woeULhK4v4DWgSBTFZ5w9sNctuUKhYMKECQ4nR5jDHZK3trbS0tJCSkoKI0aMcPwGs/U5e7O3traSn58vR5OduclEUUSlUhEcHMy+ffsIDw8nPj6e+Ph49u0Louq0ksvOrEQcO9bm+yWBhOzs7G5urpiWxg1Pj+Pbuz/kmuWL+Po7EcsqSnPrbc3KGwwG2a33JnFM48YxWfgb7xyy7qoGBwczfPhwhg8f3m0vb27l4+LiCAkJsRm87Q/TU+zBw4q3J4ENgiCsBsqAKwAEQRhG1+iki4CzgJVAgSAIB3963+9+ko+yCZ+461FRUS5LQLmi1ybtv6Ojo+3u9a3BWZLX1NRQWlpKVlYWdXV1Tr1HIpQgCEyaNAlRFGlra6Ouro6DBw/yt+fGcYEyn6CrL7RKMKPRyKFDhwgLCyMjI8PqzW68YTUvfno9Z341nTvvGMZL/7T9vUmkkG5i8y2EyWRCr9fL/zZ/vVsICiJ9ZDNlp0LQaBw3F1lG7Ovr67vNU7fcyw8UzXV3SS6KYj1wrpXfV9El4ogoit9iXYPdLvq8dh2cV3mRrJy0/y4uLvZ69ZoUT2hsbJT3+PX19Q4fWub7b+mmEQSBiIgIIiIiSE4ey3+/VvKS4l2K02+gdc8eucw2JiYGg8FAXl4eycnJ9hVoBYGgl59mw7Rrmfn+TmbNVrJqlXNekLmVb25u5tSpU0ycOLGb4oxUc+/OjT8hIxBVuYETJ8KYPdv59zlj5b2pqGoOb2quu6rU2lvwCcl9Ieao1+vJz88nMjJS7u5yN1Jui+RGo5GCggKCgoLIzs7uRlZb75EKXCwDbJb4/HMlRq2BC38VhnLGDEwmE01NTajVarlxZvjw4c7V8MfFMfHNe3hx0U3cvO4Vpk41kZHh/PctBfQyMzMJCwuT3Xrpc0gW39XgnTJtPClfl3HihPuFTrasfHV1tTxnTKqx9wY5vW3J/WWtNhAQEGDXXbeV//ZW9Rp03UwHDx6U5YUs32MtIu8swQHee0PP5cYNqK7/FaafjhkbG4vJZKKhoYHMzEw0Gg2FhYUYDAbi4uKIj48nKirK+h517lyuvusrdr+wgWuuWsZ/v9PjTBikurqaiooKsrOz5YYLe269lKKTXmfPyptSU8kw5XPixAzHC3ESkpWX9s7BwcE0NDT02Mu72+LpTUveH5VaoZ+Q3B5Z7eW/vWXJm5qaKCwstJnPd1TB5ojgzc3w8WdBbB+xG9P0K+Xfl5eXU1NT041wI0eOxGAwUF9fT2VlJUVFRURERMjNJOYZBP0DD/C3Lxcx6+hMbrt1BG++ZbufWxLFbGpq6hHQs/Yd2Qve2bLyprQ0MjUfsqFkrs1juwuTyYRKpZJrxQG5rFTay0dHR7ts5b1pyXU6Xa9pxbsCn7nrrsBa4M1y/20tPeYNS15VVcWpU6fsTl+1fI8rBAf48EMlcdRz1toUTD89MI4ePYper++2LZAQEBBAUlISSUlJiKJIS0sLarWasrIyFAoF8fHxJCQkEBoaivLNl9h4xuXk7Piel18O4KabenpEoihSXFyMKIpMmTLFpZvalpWXvgPpuimVyq4adqGQJ0tDEEW9VwUkrFW8hYSEdNvLNzU1WY3Y27Py3tzr90elVugnljwgIKDboARr+29r8MSSS0TTaDTk5OTYLcQxJ7m1AJsjbHhFw1XGtzH9agUGg4FDhw4RERHBxIkTHT4gpGxFVFSU3CGmVqs5duwYHR0dREdHM+qJ63j1rutZef+/yckxMW3azw8kKc4QGRnJmDFjPE6Z2bXyKhVpyY00lwdTVaVj+HDvsdyRxZW2P/asfFxcHNHR0d2svLdSaP1VqRX6CcnNyepKK6pU8eYKFAoFBoOBAwcOEBkZ6dQQBcldt1bB5ghVVQJfH4jiqbNPoY2KIv/AAUaMGGFThdYRgoKCulmvxsZGTp11FnPmbWP1D//mqhVXsfu/WoYMCZSnvg4bNozhw4e7dT57sLTyOp2OyBEQWaPh0CGBxES9/DpPrZyrbrUtK3/8+HECAwNl9RdvR+37UxONhH5BcomsztafS1AqlS6XqGq1WlpaWpg8ebLTRBMEwS2CA2x4x0S6ooix1+dwIDeX1NRUl3P7tqBQ/DxaSXzrLf4y82x+aDuLa66J4bHH9qDXdzJmzBifDoWUoNPpOHjwIFlTMplcdIIjR8Zz/vn02Mu7S3hPCnesWXkpL9/a2kpISAhhYWE9rLwr6M+19T5ZlTt78oaGBiorK8nJyXG6oMBVd72+vp6CggJCQkKcJrgoigQHB9PY2MiBAwcoKytDo3G+nXLDax1cFbyFg0OHMGXKFK8R3BJCZCTCv19jc/MFFOWH8/77Ixg5ciQtLS3s2bOHwsJCamtrfTIksqOjgwMHDjBu3DhCpk8nw3CQw4eVVsttJY9IKrc1L8axB2+SKCQkhOTkZDIzM0lOTiYyMpKGhgYOHDhAXl4eFRUVLl1j6MqR90cRR+gHllyv13PkyBFEUXSobmoJVwJvZWVlVFdXM23aNA4cOODUe6QbMigoiBkzZsj7YUkNJjY2loSEBKta3gCHDwvklcfz0uJa0s44w6naek9gmjaNqLuv4PW/rmT5G+9zxRWdzJ7dtW9ubm5GrVZz4sQJWfwgPj7e4xuzra2NgoICJk2aRFRUVFcarfUdXim4stvrLPfy5vl4cGzlfdmgEhkZKUtzm1t5e3t5S7S1tfXLHDn0Mcnb2trIz88nOTkZtVrtlekrlpD03A0GA9OnT3faHZN6wM1vuuDgYDmPbjQaaWhooLq6muLiYiIiIkhISCAuLo6AgABEUeTlJyuYSxUZD12L4GOCQ5fyTtV557Ho+0f57fH/cO21K/j+ey2JiYIs4jh+/Hi0Wm2Ph1V8fDzR0dEuEampqYni4mK5qAZAnDiRDAooPqLAYABr8UxrwTtLwlum6HwlGmH58JCsvHSNpeo7aS9v3klnjv6q1Ap9mEKTasMzMjIICgqipqbG5fM4suRS4Ck+Pp7Ro0c73WDiTIGLUqnsJgXU0tJCXV2dLJGk1er45NOpPDRmM8KkdS5/NlcgleK2tbWRPX06htdeY/2MWeyJOIvrrkvmo486uw1qsPawqqmp4ciRI4SFhckNNfZyvmq1Wq7t7zbFMzSU9JEtdJYpKC0VSEmxH3E2D96pVKoeKTqJ+L7qoLMXeJPkmS338pJeu7mV94Tkzui7mb1WCewDKkVRXOTM8XvdkouiyLFjx2hpaZHz3+YX0xXYs+SSl+DKlFJXKtjMYZ7mSk5O5uDBg5w8PpS6tnCmrGqnpKREduu9bY0kaS2lUklmZmZXJmDoUEwvv8B/rjqb7JYSnnhCxYMPWg9QWj6s2tvbqaurIy8vD4C4uDgSEhK6aZBLVXNTp061+iCImjyc5MYmCgtDSElxPfthaeVbW1tpb2+XA63e7JV3JYVmy8p/8cUXvPTSS4SHh3P8+HHG2ugwtANn9N0krAOKAKfbPHuV5FL+OyIiotv+252iFnvvq62t5dixYy4JRrpLcHO0tLRQWFhIWloa7/5Zx8WKnUz6v5toMBi6Va+Zu/WeQJr8GhMT00Nay3jRRSSu3sXbH63moqfeYuZMIwsW2P+OBUEgPDyc8PBwxowZg06nkwUc29raiIrqmujS0dHB1KlTba5fTE1l8t5jFBZO4bLL3NdhVyi6RloVFRWRmZkpjzTypiKOuyk0cys/YcIEOjs72bJlC7/5zW9YtGgRN910kyuHc6jvBiAIQjJwMbAeuNPZg/eauy5ZVmv5b3etm6UllwY21NfXM336dKdLDF2tYLOG2tpaTpw4wZQpU1AqQ9nypYmXzzpOQOxCEoHExMQebr1KpZIDYLaq7Wyhs7OTvLw8uzl3/fr1nPvfs3kwfhOrVy/ju++0DB/ufMFGYGCgPETQaDRSVFREc3MzSqWS/Px8m2s3paaSoT9AYWGWS5/JEs3NzRw+fLjbnt9Rr7xk4Z0lrreKYSIiIjj77LN5+OGH3Xm7s/puzwH3Ai4VyPeKJTfff3uzgN+yEq2wsJCAgACmTZvm9EW2FFl0FaIoUlZWhlqtltVptr2rwaQPYOE9k7u91tytHz9+PB0dHdTV1clKtpJrHBkZafdB097eTkFBARMnTrTftRYSQuebb/Lg7LP534QzWbVqKDt3duJqDFCqDlQqlcyaNQtBEOjo6ECtVstrl4J3UVFRKNLSyGj+J5sPrXbtRGZobGzkyJEjZGVlWX0Aeq2pxktR+/b2druZClv6buvXr3fq+IIgLAJqRVHcLwjCPFfW5lOSW9t/exOSJddqteTl5TF06FBGjhzp8H1ScQvgkXtuMnUNVzCZTEydOlW+Wd7/ewPLInIJnG8/LhISEsLIkSO7NaWUl5fT2tpKZGSk7NabW5qmpiaKioqYPHmyUw9McdIkjH96grcfmMPU8KP8/vcqHn/c+QIik8kkC1mMHTtW/p5CQkIYMWIEI0aMwGg0yu2gxcXFRCqVZIp5nDipoL0dXM0sSSmsHkE9O3CmqcYa4b1V8eZI+smOvhuAM/puZwGLBUG4CAgGIgVBeFsURfs6YvjQXbe1//YmpBbQ/fv3k5qaSlxcnNPrk9I07hJc2g9HR0d3i9w3NcHHBaPYvup/uNKhYdmU0tzcTF1dndxskZCQgCAIVFZWMnXqVKdvfgDDDTcQu2sX7x27iXNffJVZs0wsWuR4r2wwGMjPzyc+Pt7uw1OpVJKYmChvSVpbWwkb1oqi2sSWLUeYPTuQhIQEwsLCHH7X0me2FdRzBuZW3trQCukBL/3dG+56e3u726XK/Kzv9iQ29N1EUfw/4P8AfrLkdztDcPARyY1GI/v27WPMmDFOj0KShBlcearW1NSg0WiYPXu200UdUqCmrKyMpKQkt4pBJC350aNH99B3//DvVSSKgZz5fy5Io1hAEH7Oa0NXNVVJSQkNDQ2EhIRQWVlJfHy8Q7fe7IDoXniBs2bOZP1Z21m7dhH/+5+WMWNs78+l9GNycrJLN68gdI0WCsqYyMRONTpdCkFBVZSWlqLRaIiJiSE+Pt5qO+jp06cpLy9n6tSpXvP6pPvJshDHaDSi0+nk0cXS2t216hqNxtf6bm7DJyRXKpUOO7usvcdZ10naBrS2thIWFuYSwY1GI2lpadTV1VFcXCzvhRMTE4mIiHBIGikYlJaWJpPQHBveMrJi9HcIIxY7tSZn1lxZWYkgCMydO1fOa0tufVRUFAkJCcTGxtq3SPHx6F57jbsuWcx/Z1RwzTUJfPGFFmsOgbT9GTduHPHx8W6t25SaSsahoxQXz2T16p+HMTQ1NVFXV8exY8cIDg6Wc/L19fWcPn3abtTeG5DcekEQKCgoYMyYMQQEBNgtxHEGnqjCOKPvZvH7r+mKwDsFn32bKpVrA/okkjt6gktucmhoKFOnTuX777936vjmATbLvbBarebUqVO0tbXJumuxsbE9LrIUQbcVDKos7eSbqgk8/XiJk5/aPkwmE4cPHyYwMFAWdlQoFLJbL+mh1dXVUVpaSlBQkBzxtubOm+bOxfjbO3jj7XlMUxVw//0qnnuu+/5cCuqlpqZafYg5vfa0NDI697GrcJb8O8tGkfb2dtRqNfv370en05GcnCyn6nzZzSXp6Q0fPlz2UmwV4jibovNQjtmn6PPadQnOlKh2dHRw8OBBRo0a5VJnlb0OsoCAAIYMGcKQIUNkSyNNrQwLC5ODX1VVVTQ0NNjVd9+0/jgZyiDSbjrL6bXZgjP7YUs9NI1GQ11dHYWFhRiNRjlab+6h6B98kKhvvuG94HuY+9YznHmmiSuv7PreJS8lIyPD4xtWTEsjo+EZ/lpou9ovLCyM2tpawsPDSUtLo7GxsUc9QWxsrFcDtgaDgYMHD3YjuAR3FXHgF1jWCt4Xc2xsbOTw4cOkp6c7bWFcLXAxtzSSnHJtbS1HjhxBoVDIlt/WTffejmhW5ORDkMsVT92g1WrJz89n1KhRNme6WUNoaCijRo1i1KhR6PV66uvru3ko8fHxxMbGovvXv5hx5pk8vfgSbr/9HLKytMTHqykpKbHppbgKU0oKmaY81GoFNTVg+TFEUaS0tBStVktGRkY3D8VcDefUqVMolUrZrXdn+ooEieDJyclOaRWAbUUcSyvfX5VaYYBY8oqKCioqKpg2bZpVN9Rar7GnFWyCIBAcHExzc7McYDPPC1vmtAu/qKWgbQyb7mty6TyWaGtr49ChQ6SkpHjUlqpSqXp4KJJbHxwczNiHH+aWBy/m23kVrFgRwXPPneDMM7O9p1EWEcGI4UbC6/UUFipISuoun3X06FGMRiPp6ek9ro0tNRxp6IR58M7ZfbMrBLcGR1b++PHj/bafvF+TXMpD63Q6cnJyrAaWpIKYbpNGvFDBZi2CLuWFLXPa0dHRvPPHZs4Oq2P4eekun0uCVAAyefJkr7p+1vbCddHRCJ99xrPFcznD+D2vvz6dOXO8K18kpKWQXlRNYeEQ5s/vIoMoinKtfVpamlPXxpoaTl1dHSUlJYSEhMhW3tZILoPBQG5uLiNHjnTJM7IFcysviiLPPPMMiYmJbgcpfQ2fuuuuwJLker2evLw8YmJiSE1NdajzJpHc0wo2+HlvKvVIW8I8p20ymWhQN7B5/xBumvs1eXkG+YK7spesqanh1KlTLhWAuAspI3HqsccYc/nlvJ+9nvnb1/PII0e46qoOm4FHV2FKS2PysSMUFnbFT6RAYnBwMOPGjXPr4dtNDUcU5ThEQUEBJpOpRxxCr9dz8OBBrxHcHKIo8sILL3DgwAF27drlc70Ad9EvLblU525vzrgEWyKL7u7bampqOHnypNN7U4VCwZGNp6kzZvLrv84lIEFFXV0dubm5KBQKucPLXprv1KlT1NfXk52d7dP0kQTJXTYolYjvvMPM887jhZsu59YXpnPeebUoFFWUlJQQGhoqR+vdceNNaWlkbviRNwvnYzKZuglKegOCIBAWFkZYWBijR4+W4xBlZWW0trYSHh5OS0sLY8aM8QnBX3nlFXbv3s3mzZv7LcEBBAfBMbf9N4PB4FL7aFlZGYIgEBISwpEjR8jMzHQqkHHw4EEmTJhAcHCwRwSXdMkbGxvJzMx0iWyNJ5s5sOEE596b1e33kjhDbW2t1X28uTTzpEmTemVPJ1nToKAgxo8fjyAIBDz9NKq//53r55fy3/3hfPutloiIn9tO1Wo1gCwF7UzlGoDihx/4fsEfuThoFzt3fkdSUrxLwyk9gU6nY//+/YSGhqLValGpVN2Cd55AFEXeeOMNtm3bxtatW73heflU/dFnJDfX5HYGFRUVsgZZVlaW05ZDikKHhITIRQ6uQurJVigUpKSk+IRs0j6+rq5Ork3XaDRERkY6Jc3sDRiNRvLz84mJiWH06NHmfyBo0SI6CGHCkY9pbRN4441OFiwwIV0GnU6HWq2mrq5OrlyT5rjZ/L6amugYnkE89Xz++SlmzUrw+WeErq1ebm4uo0ePlrUEtFqt/MDyRA0H4O2332bDhg189NFH3tJ1G/wkN5lM7Nu3D4PBwMyZM13qIDt69CgtLS0MGTKEhIQEl90mqcZeykf3Btk6OzvJzc0lICAAvV7vsVvsDKQYx7Bhw6zWGAhVVQTPnMnzs95i3fYLCQqCkBC49FIjy5YZmDPHJKvLmAe/Ghsbba5fr9cTPH48o/QnefYfASxZ4n5vuSuf05LglpCqBtVqNU1NTU6r4QBs2LCBN954gx07dnhT021wk1zqiw4LCyMgIICUlBSnjm8eQZeCL3V1dbLSSWJiokM3SqPRyKWNzqrHeAqpZFQ6p7kaS11dndP7eE/OaQvK7dsJvOYa7lh6nF2HhnH//Xq2bFHyySdKYmJELrvMyPLlRqZPN8m9N+brl9x6SQXn6NGjzPz971lc+TpnXDWS3/3O+0qx5pAIPmbMGBISnPMapHoItVrdbVsSHx/fTQ0H4IMPPuDll19mx44d3s6JD0ySm0wmh5roLS0tFBQUyC5yTU0NaWlpDo9tL8AmuWW1tbUYjUbi4+NJTEzssY+UWjbT09OJdGZSoBfQ2trKoUOHbNa9Q9dDTyJ8Z2enXFfvdDOKBTQaDfn5+U7n3VW//S1t//mEiUIJDz5sYM3NAi0tsH27ko0bA/jiCwUjR4osW2bkiisMpKd3v0V0Oh3V1dUcP34clUpF1htvsP6HKziVcQnvvqtzef3OQtJ9d4Xgto4jbava29uJiori2LFj6PV6/vGPf7Bjxw5fyGoPTpJLQhJTpkwhLCyM5uZmysvLmTx5ss33uFrgotfr5cBXR0cHsbGxJCYm0tHRQXl5OZmZmT5PV0loaGjg6NGjZGRkOO3mWe7jnW5G+QnSQ8XZ3nMAGhsJGTmSf5pW8wCPUzR1BdEzJ2LKycGUk0NdxBi2fqhi40Yl336rZNIkE8uXG1i2zMiYMSIdHR3k5eWRkpJCZGQkuhdeYPOzDfwh8Pds3Fggu/XejEZ7i+CWkLYl69at45tvviE7O5trr72Wa65xqsPTFQwukkvljE1NTUyZMkW+2G1tbTLprS7Ewwo2Sdjg+PHjaDQaOc/tjXywI1RXV1NeXs6UKVNsFmw4gnkzitRyam8fLz1UJG00VyAcO4bq7HOYpsxlTkoNzw19EsXevSjKyxHj4zFNm4YxJ4ey0bPZeGomG7eHk5urZNo0PWeccYI1a6KYOLHroaL4/nsKL/gdM0x7KC2tpa2ty603H9zoyd5WIvjYsWN9Uozy5Zdf8thjj7Fjxw7a2to4duwYCxcu9PZpBg/JpeF7wcHBpKSkdCNqR0cHRUVFZGdn91yEFyrYpNRRQEAAEyZMoKWlhdraWhoaGggLCyMxMbHHaGBPYT4uOCMjw2s5cMt9sCAI8rYkNDS0W7ecuw8Vxa5d7LnsORayiz0/dJKWJsLp0yj37esi/N69KA4cQGhtxTRhAofGXsCrTRews+psSivDmDOny8IvOVtNbMZ4whUadu/WMnVq1y0llarW1dWh1WrdinbrdDpyc3M9aom1h927d/Pggw+yfft2t0phXcDAJLkoiuh0P+/BtFqtXDucnJzc4/WSSEFOTk6P43hKcCmCnpCQ0KOjy7wRpb6+noCAABITE0lISHCbINJxjxw5Ivev+9JbMN/Ht7W1AZCWlkZcXJxH2YKA557j6t9PoilnPls/D+gpdGM0Ihw5Qufu3bR/+SVJJ0+iOFxEnmo678bdxoa2i6nWRHGB4jP2BM/j7gcV3HZbzwi7ZbQ7PDxc7v6z9dCVCD5+/HinFYFcwXfffcc999zD9u3bfTIs0gIDn+RNTU0UFhYyadIkm0ELo9HI3r17mTlzZrffSdVsnih2SNVzzuzXJHHF2tpaRFGUI92uuJRGo5FDhw4RHh7eTRfN1zh58iQNDQ0MGzaM+vp6WlpaXN7Hd4MoUrX8XiZ/8gzvvNHOhct6xi+kevspU6Z0VQi2t6PIzUWxdy/s3c8P/zPxvnoBL3IzoGDm2NPMv0DBOUsjmZ4j9hCVlOSj6urqqK+vlzvQzLMNvib43r17WbduHR999JFTmoFewMAmeWVlJWVlZQ7LREVR5Pvvv2fWrFle0UCHrhuwuLjY7Qi6VABSW1uLVquVbzZ7kW5fjwu2Bkkpp7Ozs1vlnCiKcvdZQ0MDwcHBcl290/l4jYbH07fwftvF7C2PIjD454etJLg4ZcoUuwFMxY4d1B+soHC/nh/3BbCrPpvvmEVwgIGz02qZf0kQ8y6PJiVF7OEtSFWDUrYhKiqKhoYGUlJSfOKi5+bmcsstt7B161avld86gYFL8oKCAjQajdP70e+++44zzzzTKwSXgl3eiqBLgbva2lpaW1utVnxJkeXx48f3WkeSVK0XEBBgt3JOqieora3tls92xkvRFJeTlRPBXYuLufGdLk+rtrZWrvF3tYBHqKqiY9f3fLe5ji/3RrGrOYcCMhke0sA5WXXMXxrBvGXRPXrQNRoNBw4cICwsDK1W69VBFQAFBQWsWbOGzZs3M2HCBI+P5wIGJsmNRiMnTpwgOTnZaaL+73//Y+bMmR7XoB8/fpyWlhavBrvMYa4g09jYSEREBOHh4VRVVZGenm61c80XkLYFkZGRTs96kyAFvmpra+V8vL1RTvmbjjHu7KGEJYbJgotZWVleCVQKFRXUbt/HNx+08OXBeHa1zaSSZCZHl3FuTjPzrohh+oVhHD2aK2vNmwtLqNVqeVJrQkKCW6IXhw8f5vrrr2fDhg2kpqZ6/JlcxMAkOXS5rs6qw4iiyHfffSdL+7rTTy1F0FUqVa/Vg4uiSHl5OSdOnJBncUuBO1+VqMLPOmVJSUlWA5muQPJS6urqaGlpsan5Dl2TU0+fPs2UKVN81zF3qoxjG/P5cpuWLwqH8k3HGWgJ5oyEYyyY3cG8XyWSfX5ctyGOUhFUXV0dOp3O4UPLHEeOHOHaa6/l3XfftVun4UMMfpJLPeBSq6D5HjgpKalHeaGtc+Xn55OUlNRrnU7w07jgqiqmTJlCYGBgtxJVQRDkEltvSCpJkHLDrspDOQNJ811KLwYHB8sW8vTp09TX15OZmekVrXJnoNVqObT9U9r3Cuz5RsUXR0awR5dNhKKdc0aUcM7ZeuZdO4yxMxPk/bzlQ8ueW19aWsrVV1/NW2+9RVZWVq98JisYvCS3F2CTqr1qampob2+XyzutPZklhdHe3AtL24LW1lYyMjKs3vRSaktqNZVy2c48tGxB2vdPmDDBJ5FlS0gPrfLycoxGI6NGjZLLhH0NKe3arSRXFGk9VMb/3jjBV18KfHF8HEWGiYwKqODcsce5ZJmS8x6YKh/DfP5cfX29PKhCmpC6YsUKXnvtNaZPn+7zz2MHA5fker3e5rRSVyLoUh61traWlpYWoqOjSUxMJCYmhqamJo4ePUp6enqvCemZTCaKi4sRBMGuao05JOnn2tpa2tvbiY2NJSEhwaXij7a2NgoKCmwq1vgC5oKL48ePly2kVMBi68HrKSSCO5SGFkWqvi/j67eq+Gq3iiHxev6w+0ybL5dmuK1du5aioiIuvvhibr75ZmbMmOHV9buIwUdyT1Jk5kGv2tpaTCYTEydOJCkpqVdcSKkn23I8kiswmUzyQ6u5udnuHliC1FBjPuHT1zAXXLTUY3NlH+8qnCa4m6iuruaKK67g8ccfp729nfz8fB599FGvn8cFDC6Se6OCTbIura2tjBo1CrVaTUNDA6GhoXIe2BdBIXdHB9mD+dyz+vp6uSbdvDderVbLdf291VBjLrjoKIhp+RmCgoLk6+Bq1aC0HfEVwWtqarj88st5+umnmT9/vtePX15ezqpVqzh9+jQKhYK1a9eybp1t7fmfMHBJbikB5Q2RRaPRKMsXTZgwQb75zMtT1Wo1gYGBXo1yS/t+X+6FLXvLlUolQUFBtLe3ezQA0FWYTCYKCwsJDQ11q2LP/DMA3erq7R3L1wRXq9VcdtllrF+/nvPPP9/rx4cuL6G6uprs7GxaW1uZNm0aW7duZdKkSfbeNvBJ7q0KNsmSDh061GHayFKIQSK8O5ZQUm91qWXTCygtLaWmpobAwEBMJpPN3nhvQhJcjIqK6i4R5SYsqwbNYxGWDUp5eXmkpaX5JN7Q0NDA5ZdfzkMPPcSiRfZHSnsTS5Ys4bbbbnPUuTawSW4wGLxCcE8i6FqtltraWurq6jCZTHJay5kWTKmjKzMz06tpMHuQtiMajYbJkyfLI5qt9cZ7M+hlNBrJy8sjISHBJ2lIKYBaV1fXLRYRGhoqi2n4guBNTU1cfvnl3HvvvSxdutTrx7eFkydPcvbZZ8sFS3YwsEmu0+k8JrjUG+2NoQM6nU5Oa+l0OrtprfLycmpqarr1vfsaoihSXFwMYDNyb5ltiIqKIjEx0aPeeKm4ZujQoS7NmXMX0j6+urqaqqoqIiMjGTp0qMfdf5ZoaWlh2bJl/OY3v2H58uVeO64jtLW1MXfuXB544AEuu+wyRy8fuCRfu3YtcXFxLF261G3JYanYJDMz06sXH35Oa9XU1NDR0dFthLEkLpGent5rhR8mk4lDhw4RFhbm9F5YakLxpDdeGkAwYsQIX/dNd4PUIThp0iSUSqXcHy+Kosvyz9bQ1tbG8uXLWbNmDVdffbWXV28ber2eRYsWcf7553PnnXc685aBS/KmpiY++ugjtmzZwqlTp1iwYAFLly4lMzPTIeGlzirJZfU10aSUUE1NDWq1muDgYCZOnOjSvC1P4MwUU0ewDD6qVCqHvfG+kk5yBI1GQ15entUOQXP5Z2lrIpWoOnstNBoNV155Jddccw3XXXedLz6CVYiiyLXXXktsbCzPPfecs28buCQ3R0tLCzt27GDLli0cOXKEc889l0svvZRp06b1uHBGo5HCwkJCQkLkAQC9AYlosbGxREREUFtbS1NTE5GRkbJ19AXhfZGag65glhSLsNYbL6m4+qov2xbsEdwSlvt4ZzrPtFotV111FZdffjlr1qzptfsH4Ntvv2XOnDnypFaAxx9/nIsuusje2wYHyc2h0Wj45JNP2Lx5M/n5+cybN49LL72UM844g5qaGk6cOMGoUaM8brxwBbbGBUt7x5qaGhoaGggPD5cJ741cvEQ0X0kYSZBiEVK1mtSXbU/IwxeQik/cyVRIJaqSik9QUJD84JI8lc7OTq655houvPBCbr311l4luAcYfCQ3h1ar5fPPP2fjxo1899136HQ67rvvPlauXNkrc8HA+XHBkmqJ5A6bd5y5E5iTbnh7Es2+QEtLC3l5eYSHh8ujgB1OQ/ECPCG4NZjr7avVar7++muOHj3KwoULufPOOwcKwWGwk1zCnj17uPnmm7npppvYu3cv33//PTNnzmTJkiWcffbZPisEkdRjMjIyXI7ct7e3y+6wUqmU22SdCRBKuXd3zusJJJlm6byW01C8LcQgwdsEt0RdXR0333wzFRUVKBQKbr31VtasWeP18/gIvwySq9VqTCaTPOHDYDDwzTffsHHjRr799luys7NZsmQJ8+fP91qUXRoX7A31GEttOInw1nLr9fX1lJSU/KyL1ktobm6mqKjIpva7eceWWq2Wy1M9rRqUCO6rB5rRaOTGG28kJSWFhx9+WO7+682WYw/xyyC5PRiNRr799ls2b97MV199RXp6OpdeeikLFixwe5RQWVkZarXa5QmmzsC8xdRgMHTLxZvPIe+tMlWwIrjoBLzRGy91zvmS4LfffjvDhg1j/fr1PnPRr7/+erZv305iYiKHDh3y9uH9JDeHyWTihx9+YNOmTXz++edMmDCBpUuXct555zl1E4miSElJCTqdrlfGBZtXqrW0tAAwefLkHmWdvoQkuOiJDrs7vfG+JrjJZOKOO+4gOjqaP//5zz69lrt37yY8PJxVq1b5Sd6bMJlM5ObmsnHjRnbu3MmoUaNYvHgxF110kdXySKnYpLdTc6IocuLECVpaWkhKSkKtVtPW1iaXpvqS8J4ILtqCM73xvUHwe++9F6VSyV//+tdeqWU4efIkixYt8pO8ryAReOPGjXz88cckJSWxZMkSLr74YmJjY2ltbeXo0aMkJib26l5N6sk2GAzdhixY9pR7ozTVEt4WXLQGa73x4eHhVFZWynPufHHOhx56iI6ODl588cVeITj4Sd6vIPVCb9q0ie3btxMcHExVVRV/+9vfmDdvXq+tQxKWDAoKsus5WJamRkREyLl4dyv9ekVw0QKiKFJdXc3Ro0cJDAwkLCysR2+8N87x2GOPUVtby6uvvtprJcfgJ3m/RX5+PldeeSXnnHMOBw8eJDg4mEsuuYQlS5aQlJTkMzdZUpCJiYlxqWXTsuAjJCREFmBwlihlZWW9LrgIP6fnpCGLlr3xzs6NtwVRFHnyySc5efIkb7zxRq9+NvCTvN/i4MGDhISEkJKSgiiKnDp1is2bN/PBBx8gCAKXXHIJl156KcOHD/ca4aWGj+HDh3vU0SWJSEjFN9KctsTERJv7a2nvb15W2RswJ7g1F93ZufG2IIoizz77LAUFBbzzzju95p2Yw0/yAQZRFKmqqpIJ39nZyaJFi1iyZInb2m3wc5nq2LFjvd7wIdWi19bWIgiCnMMOCQnpJrjYG1kDc7S0tFBYWMiUKVOcSmmaZxw0Go1dJV7oulYvvPAC33//PRs2bOi1tl9zXHXVVXz99deo1WqSkpJ49NFHWb16tbcO7ye5ryGKIrW1tWzZsoUtW7bQ3NzMxRdfzJIlS7pJTDmC1DrpqDzWG+js7JQJL0lsBQcHk5GR0avlnK4S3BKOeuNFUeSVV17hiy++YNOmTV5vN+4n8JO8t6FWq9m6dSubN2+mrq6OCy+8kCVLlvRQLDWHdLP3tkSUKIoUFhai0+kQBIHOzk6XhlJ4Ak8JbgmTydRtsMN7772HIAiUlpayY8eOXhOx7AP4Sd6XaGxslHviy8rKWLhwIUuXLu2255WUa6SAU2/BmuCiK0MpPIFUIuur0lxRFHnqqaf44IMPCAoKIj4+nq1bt/ZqlWAvwk/y/oKWlha2b9/Oli1bKCkp4dxzzyU6Oprm5mYefPDBXnUlnRFctDeUwpM9u68JDvD+++/z5ptvsmPHDsLCwqiqqvK6LNXOnTtZt24dRqORG264gfvvv9+rx3cBfpL3R2g0Gu655x62bt1KYmIis2fPZsmSJZxxxhm9omLjquCitUms7uTie4PgW7Zs4Z///Cc7duzw2dbHaDQyceJEPv/8c5KTk8nJyeE///mPI+lkX8GnJO/9PMQggV6vR6PRUFJSgkKh4LPPPuPNN99k3bp1zJkzh0svvZRZs2Z5PdXjruCiQqEgNja229jf2tpajh8/7vRQiqamJoqLi31K8O3bt/OPf/zDpwQH+PHHHxk/fjxjx44FYMWKFXz44Yd9RXKfok8s+T333MO2bdsIDAxk3Lhx/Otf/+pV0QRfQqfTyZHgPXv2cOaZZ8o98Z6mfqT8+8iRI702zdTZoRS9QfBPP/2UP/3pT+zYscPnclSbNm1i586dvPrqqwD8+9//5ocffuD555/36XltwKeWvPeSqWZYuHAhhw4dIj8/n4kTJ/LEE0/0xTJ8gsDAQC688EJee+01Dh48yIoVK9ixYwdnnXUWN998Mzt37qSzs9Pl4+p0OnJzcxk9erRXxxULgkBERATjxo3jjDPOICUlBb1eT15eHvv376esrIza2lqKi4vJysryGcG//PJLnnjiCbZt29YrenPWjNsAUpJxCX1C8vPOO092C2fOnElFRUVfLMPnUKlULFiwgJdeeom8vDyuu+46vvrqK+bMmcPq1avZtm0bHR0dDo+j1WrJzc1l3LhxPldUDQ0NZfTo0eTk5JCenk5HRweHDh1CEAROnz6NRqPx+jl3797NI488wkcffdRrirHJycmUl5fLP1dUVPSK3nxfoM8Db5dccoksnftLgdFoZM+ePWzevJldu3YxceJEli5dysKFC3u0Zfp6Ppg9SEITWVlZKBQKp4dSuILvvvuOe++9l+3bt/cqyQwGAxMnTuSLL75g+PDh5OTk8O6775Kent5razDDwIyuL1iwgNOnT/f4/fr161myZIn873379rFly5ZB6yo5gslk4sCBA3JP/JgxY+Se+JMnT3L69GlmzpzpULrY25By/1lZWT2KUMz7yc3LUiMjI126jj/++CN33HEH27Zt6xOppo8//pg77rgDo9HI9ddfzwMPPNDra/gJA5PkjvDmm2/y0ksv8cUXX/RqAUl/hpT73rhxI5s3b6a5uZlbbrmF6667rldlkyWCT5061WHuXxpKUVtbS2trKzExMbIQhr1c/IEDB7j11lvZunUrY8aM8fZHGGgYfCTfuXMnd955J998802vTu0YKCgqKuJXv/oV69evZ+/evezYsYOYmBgW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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "egnn_pred = np.array([[ 1.6001,  0.1901, -0.4319],\n",
    "        [ 1.3362, -1.1318, -0.2270],\n",
    "        [ 0.0701, -1.5887,  0.1785],\n",
    "        [-1.0937, -0.6551,  0.0325],\n",
    "        [-0.6718,  0.6429,  0.2888],\n",
    "        [ 0.5767,  1.1703,  0.0048],\n",
    "        [-2.2425, -1.1062,  0.1948],\n",
    "        [ 0.7488,  2.4150, -0.0914]])\n",
    "print(egnn_pred.shape)\n",
    "x_now[z>1] = egnn_pred\n",
    "mol_egnn = get_mol(z, x_now)\n",
    "pair_egnn = get_bonds(mol_egnn)\n",
    "plot(pair_gt, pair_egnn, f'../hh/3d_{tar_mol}_egnn.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9004c61",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.6.13 ('protein')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.13"
  },
  "vscode": {
   "interpreter": {
    "hash": "0efb669c6e3cfb88bb9dab8f7ee3cbda7c9159c050b184dbe0517885df69196f"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
