{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3f80e3a6",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 53
    },
    "id": "3f80e3a6",
    "outputId": "688d4a21-c2c8-4090-8785-ba9fec49eaef"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\273441208.py:10: DeprecationWarning: Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "  from IPython.core.display import display, HTML\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>.container { width:90% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# !pip install deeprobust\n",
    "# !conda install pytorch torchvision torchaudio -c pytorch\n",
    "import torch\n",
    "# print(torch.__version__)\n",
    "# !pip install torch-scatter torch-sparse -f https://data.pyg.org/whl/torch-{torch.__version__}.html\n",
    "# !pip install torch-geometric\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:90% !important; }</style>\"))\n",
    "\n",
    "from networkx.generators.random_graphs import erdos_renyi_graph\n",
    "from networkx.generators.random_graphs import barabasi_albert_graph\n",
    "from networkx.generators.community import stochastic_block_model\n",
    "from networkx.generators.random_graphs import watts_strogatz_graph\n",
    "from networkx.generators.community import random_partition_graph\n",
    "\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import FactorAnalysis\n",
    "\n",
    "import random\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c287cb5c",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 71
    },
    "id": "c287cb5c",
    "outputId": "54552bfd-7681-4b66-bce2-74e2c38e399f"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\anaconda3\\envs\\nimesh\\lib\\site-packages\\torch_geometric\\typing.py:56: UserWarning: An issue occurred while importing 'torch-scatter'. Disabling its usage. Stacktrace: [WinError 127] The specified procedure could not be found\n",
      "  warnings.warn(f\"An issue occurred while importing 'torch-scatter'. \"\n",
      "C:\\Users\\Sandeep\\anaconda3\\envs\\nimesh\\lib\\site-packages\\torch_geometric\\typing.py:93: UserWarning: An issue occurred while importing 'torch-sparse'. Disabling its usage. Stacktrace: [WinError 127] The specified procedure could not be found\n",
      "  warnings.warn(f\"An issue occurred while importing 'torch-sparse'. \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\4057615484.py:25: DeprecationWarning: Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "  from IPython.core.display import display, HTML\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>.container { width:90% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import collections\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "from torch import Tensor\n",
    "import torch_geometric\n",
    "from torch_geometric.utils import to_networkx\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import networkx as nx\n",
    "from networkx.algorithms import community\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "data_dir = \"./data\"\n",
    "os.makedirs(data_dir, exist_ok=True)\n",
    "\n",
    "import numpy\n",
    "import torch\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "%matplotlib inline\n",
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:90% !important; }</style>\"))\n",
    "\n",
    "\n",
    "from random import sample\n",
    "from networkx.generators.random_graphs import erdos_renyi_graph\n",
    "from networkx.generators.random_graphs import barabasi_albert_graph\n",
    "from networkx.generators.community import stochastic_block_model\n",
    "from networkx.generators.random_graphs import watts_strogatz_graph\n",
    "from networkx.generators.community import random_partition_graph\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import FactorAnalysis\n",
    "import random\n",
    "\n",
    "from scipy.sparse import csr_matrix\n",
    "from scipy.sparse import csgraph\n",
    "from scipy.sparse.linalg import inv\n",
    "\n",
    "import os\n",
    "os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3669a0f9",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "3669a0f9",
    "outputId": "213cddc0-551b-4948-a025-9704edf67d7e"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite\\\\Cora'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset = os.path.join(os.getcwd(),'Cora')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "067c3d06",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "067c3d06",
    "outputId": "9c7402f2-2cfc-46ea-e604-13ef4b07d6ff"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dataset: Cora\n",
      "num_nodes: 2708\n",
      "num_edges: 10556\n",
      "num_classes: 7\n",
      "num_features: 1433\n"
     ]
    }
   ],
   "source": [
    "import os.path as osp\n",
    "import torch\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import torch_geometric.transforms as T\n",
    "\n",
    "def get_planetoid_dataset(name, normalize_features=False, transform=None, split=\"public\"):\n",
    "    path = osp.join(osp.dirname(osp.realpath(os.getcwd())), '..', 'data', name)\n",
    "    if split == 'complete':\n",
    "        dataset = Planetoid(path, name)\n",
    "        dataset[0].train_mask.fill_(False)\n",
    "        dataset[0].train_mask[:dataset[0].num_nodes - 1000] = 1\n",
    "        dataset[0].val_mask.fill_(False)\n",
    "        dataset[0].val_mask[dataset[0].num_nodes - 1000:dataset[0].num_nodes - 500] = 1\n",
    "        dataset[0].test_mask.fill_(False)\n",
    "        dataset[0].test_mask[dataset[0].num_nodes - 500:] = 1\n",
    "    else:\n",
    "        dataset = Planetoid(path, name, split=split)\n",
    "    if transform is not None and normalize_features:\n",
    "        dataset.transform = T.Compose([T.NormalizeFeatures(), transform])\n",
    "    elif normalize_features:\n",
    "        dataset.transform = T.NormalizeFeatures()\n",
    "    elif transform is not None:\n",
    "        dataset.transform = transform\n",
    "    return dataset\n",
    "\n",
    "\n",
    "if __name__ == '__main__':\n",
    "#     lst_names = ['Cora', 'CiteSeer', 'PubMed']\n",
    "    lst_names = ['Cora']\n",
    "    for name in lst_names:\n",
    "        dataset = get_planetoid_dataset(name)\n",
    "        print(f\"dataset: {name}\")\n",
    "        print(f\"num_nodes: {dataset[0]['x'].shape[0]}\")\n",
    "        print(f\"num_edges: {dataset[0]['edge_index'].shape[1]}\")\n",
    "        print(f\"num_classes: {dataset.num_classes}\")\n",
    "        print(f\"num_features: {dataset.num_node_features}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7f8577f3",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "7f8577f3",
    "outputId": "de9c336b-dbd9-40ca-e1fa-58107ade7ce8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data(x=[2708, 1433], edge_index=[2, 10556], y=[2708], train_mask=[2708], val_mask=[2708], test_mask=[2708])\n",
      "torch.Size([2708, 1433]) torch.Size([2708, 2708])\n",
      "torch.Size([2708, 1433]) torch.Size([2708, 2708])\n"
     ]
    }
   ],
   "source": [
    "from torch_geometric.datasets import Planetoid\n",
    "from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "# # dataset = NELL(root='/nell')\n",
    "\n",
    "# dataset= Planetoid(root=dataset, name='Cora')\n",
    "k_ = dataset.num_classes\n",
    "print(dataset[0])\n",
    "adj = to_dense_adj(dataset[0].edge_index)\n",
    "adj = adj[0]\n",
    "labels = dataset[0].y\n",
    "labels = labels.numpy()\n",
    "\n",
    "X = dataset[0].x\n",
    "X = X.to_dense()\n",
    "N = X.shape[0]\n",
    "NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "A = adj[:nn,:nn]\n",
    "AT= torch.transpose(A,0,1)\n",
    "labels = labels[:nn]\n",
    "print(X.shape,adj.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "475846d5",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "475846d5",
    "outputId": "c6102e64-ae54-46d6-8f9b-48ba85a81564"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2708, 1433])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7aec8d70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2708,)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a0757b15",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "a0757b15",
    "outputId": "d35c00b4-f747-4b97-c075-b98efcdb77eb"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([2708, 2708])\n"
     ]
    }
   ],
   "source": [
    "def get_laplacian(adj):\n",
    "    b=torch.ones(adj.shape[0])\n",
    "    return torch.diag(adj@b)-adj\n",
    "\n",
    "theta = get_laplacian(adj)\n",
    "print(theta.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "36a2d1ca",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "36a2d1ca",
    "outputId": "47e7d15b-491d-49ad-9dff-fcdb283b16a7"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'torch.FloatTensor'"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(theta@A).type()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cad0c60b",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "cad0c60b",
    "outputId": "4de3ae5a-7f39-4649-bae9-c437127dc115"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "theta.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "114a42e0",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "114a42e0",
    "outputId": "62b0a402-9d33-44be-8e7f-20de623be138"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7 2708\n"
     ]
    }
   ],
   "source": [
    "\n",
    "features = torch.Tensor(X)\n",
    "NO_OF_NODES = X.shape[0]\n",
    "print(NO_OF_CLASSES,NO_OF_NODES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2ba32732",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "2ba32732",
    "outputId": "4d8096c2-cca6-41e5-f7f9-ebd3e815a404"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b33c30e2",
   "metadata": {
    "id": "b33c30e2"
   },
   "outputs": [],
   "source": [
    "def convertScipyToTensor(coo):\n",
    "  try:\n",
    "    coo = coo.tocoo()\n",
    "  except:\n",
    "    coo = coo\n",
    "  values = coo.data\n",
    "  indices = np.vstack((coo.row, coo.col))\n",
    "\n",
    "  i = torch.LongTensor(indices)\n",
    "  v = torch.FloatTensor(values)\n",
    "  shape = coo.shape\n",
    "\n",
    "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b7f9d72b",
   "metadata": {
    "id": "b7f9d72b"
   },
   "outputs": [],
   "source": [
    "from scipy.sparse import random\n",
    "from scipy.sparse.linalg import norm\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "p = X.shape[0]\n",
    "k = int(p*0.3)\n",
    "n = X.shape[1]\n",
    "lr = 1e-5\n",
    "thresh = 1e-10\n",
    "\n",
    "from scipy.sparse import random\n",
    "from scipy.stats import rv_continuous\n",
    "class CustomDistribution(rv_continuous):\n",
    "    def _rvs(self,  size=None, random_state=None):\n",
    "        return random_state.standard_normal(size)\n",
    "temp = CustomDistribution(seed=1)\n",
    "temp2 = temp()  # get a frozen version of the distribution\n",
    "C = random(p, k, density=0.25, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "eecc9adb",
   "metadata": {
    "id": "eecc9adb"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.nn import GCNConv\n",
    "\n",
    "\n",
    "class Net(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Net, self).__init__()\n",
    "        self.conv1 = GCNConv(X.shape[1], 64)\n",
    "        self.conv2 = GCNConv(64, NO_OF_CLASSES)\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.conv1.reset_parameters()\n",
    "        self.conv2.reset_parameters()\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "        x = self.conv1(x, edge_index)\n",
    "        x = F.relu(x)\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return F.log_softmax(x, dim=1)\n",
    "    \n",
    "    \n",
    "####### NO output layer is written\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1c5a519a",
   "metadata": {
    "id": "1c5a519a"
   },
   "outputs": [],
   "source": [
    "def get_accu(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # Lc=C_0_new.T@L@C_0_new\n",
    "        en_mat = Lc\n",
    "        print(\"L:\", Lc.shape)\n",
    "        entropy(en_mat)\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        model=Net().to(device)\n",
    "        lr=0.01\n",
    "        decay=0.0001\n",
    "        features_= features.cpu().detach().numpy()\n",
    "        try:\n",
    "          X=np.array(features_.todense())\n",
    "        except:\n",
    "          X = np.array(features_)\n",
    "        #print(\"X:\",X.shape)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=decay)\n",
    "        # criterion=torch.nn.CrossEntropyLoss()\n",
    "        x=sample(range(0, int(k)), k)\n",
    "      \n",
    "        from datetime import datetime\n",
    "        Xt=P@X\n",
    "        # Xt=X_t_0\n",
    "        def train():\n",
    "            model.train()\n",
    "            optimizer.zero_grad()\n",
    "            out = model(torch.Tensor(Xt).to(device),edge_index_coarsen2)\n",
    "            loss = F.nll_loss(out[x], labels_coarse[x])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            return loss\n",
    "        now1 = datetime.now()\n",
    "        losses=[]\n",
    "        for epoch in range(100):\n",
    "            loss=train()\n",
    "            losses.append(loss)\n",
    "            if(epoch%100==0):\n",
    "                print(f'Epoch: {epoch:03d},loss: {loss:.4f}')\n",
    "        now2 = datetime.now()        \n",
    "        pred=model(torch.Tensor(Xt).to(device),edge_index_coarsen2).argmax(dim=1)        \n",
    "        def train_accuracy():\n",
    "            model.eval()\n",
    "            correct = (pred[x] == labels_coarse[x]).sum()\n",
    "            acc = int(correct) /len(x)\n",
    "            return acc\n",
    "    \n",
    "        t+=[(now2-now1).total_seconds()]\n",
    "\n",
    "        zz=sample(range(0, int(NO_OF_NODES)), NO_OF_NODES)\n",
    "        adj_ = adj.cpu().detach().numpy()\n",
    "        Wc=sparse.csr_matrix(adj_)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_coarsen).argmax(dim=1)\n",
    "        pred=np.array(pred)\n",
    "        correct =(pred[zz]==labels[zz]).sum()\n",
    "        acc = int(correct) /NO_OF_NODES\n",
    "        return acc\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "8a4725d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "\n",
    "def entropy(en_mat):\n",
    "  EV, _ = np.linalg.eig(en_mat)\n",
    "  my_list = [x for x in EV.tolist() if x]\n",
    "  leng = len(my_list)\n",
    "  Sum = np.sum(np.real(my_list))\n",
    "  entropy = 0\n",
    "\n",
    "  for i in range(leng):\n",
    "      ratio = np.real(my_list[i]) / Sum\n",
    "      if ratio > 0:\n",
    "        entropy += -(ratio * math.log2(ratio))\n",
    "  print(\"Entropy..................\", entropy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "1f724733",
   "metadata": {
    "id": "1f724733"
   },
   "outputs": [],
   "source": [
    "def experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A):\n",
    "      p = X.shape[0]\n",
    "      k = int(p*0.3)\n",
    "      n = X.shape[1]\n",
    "      ones = csr_matrix(np.ones((k,k)))\n",
    "      ones = convertScipyToTensor(ones)  \n",
    "      ones = ones.to_dense()\n",
    "      \n",
    "      try:\n",
    "        C = convertScipyToTensor(C)\n",
    "        C = C.to_dense()\n",
    "      except:\n",
    "        C=C\n",
    "      try:\n",
    "        theta = convertScipyToTensor(theta)\n",
    "      except:\n",
    "        theta = theta\n",
    "      try:\n",
    "        X = convertScipyToTensor(X)\n",
    "        X = X.to_dense()\n",
    "      except:\n",
    "        X = X\n",
    "      if(torch.cuda.is_available()):\n",
    "        print(\"GPU is available\")\n",
    "        C = C  \n",
    "        theta = theta  \n",
    "        X = X  \n",
    "        ones = ones  \n",
    "      \n",
    "        \n",
    "      def bracket_term2fun(C,CT,theta):\n",
    "          # U  = update_V(C,theta).double()\n",
    "          U = torch.stack(update_V(C, theta)).double()\n",
    "          UT= torch.transpose(U,0,1)\n",
    "          Lw = (CT @theta @C).double()\n",
    "          lb= 1e-5\n",
    "          ub = 1e+4\n",
    "          beta = 0.5 \n",
    "          lambda_ =  laplacian_lambda_update(lb, ub, beta, U, Lw, k_,C)   \n",
    "          lambda_matrix =  torch.diag(lambda_,0)  \n",
    "          # print(lambda_matrix)\n",
    "          # print(f'Shape of U is: {U.shape}')\n",
    "          # print(f'Shape of lambda: {}')\n",
    "          # print(f'Shape of lambda_matrix is: {lambda_matrix.shape}')\n",
    "          return UT@lambda_matrix@U\n",
    "        \n",
    "      def update_V(C,theta):\n",
    "            \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        product = CT @ A @ C               \n",
    "        matrix = torch.tensor(product)         \n",
    "        eigenvalues, eigenvectors = torch.linalg.eig(product)\n",
    "\n",
    "        # select non-zero eigenvalues and eigenvectors\n",
    "        non_zero_eigenvalues = []\n",
    "        non_zero_eigenvectors = []\n",
    "          \n",
    "        # for i in range(matrix.shape[0]):\n",
    "        #     if matrix[i, i] != 0:\n",
    "        #         non_zero_eigenvalues.append(eigenvalues[i])\n",
    "        #         non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        # U = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        # return U    \n",
    "\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if eigenvalues[i] != 0:\n",
    "                non_zero_eigenvalues.append(eigenvalues[i])\n",
    "                non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        return V \n",
    " \n",
    "\n",
    "      def update_C(C):\n",
    "          CT = torch.transpose(C,0,1)\n",
    "          C.size()\n",
    "          t1 = alpha_param*(C@ones)  \n",
    "          bracket_term1 = (CT@theta@C)\n",
    "          bracket_term3 = (CT@A@C)\n",
    "          bracket_term2 = bracket_term2fun(C,CT,theta) \n",
    "          bracket_term = bracket_term3 - bracket_term2             # bracket term (CT*A*C - U*lambda*UT)\n",
    "          t22 = -2*(theta@C)                                      # Check for multiplication of gamma\n",
    "#           print(t22.type())\n",
    "          t3 = bracket_term1\n",
    "          t7 = bracket_term2\n",
    "          t6 = (CT@A@C)  \n",
    "          t5 = 2* beta_param*(A@C)\n",
    "          t5 = t5.float()\n",
    "          t4 = (1.0/k)\n",
    "          t44 = t4*((torch.ones(k,k)).double())  \n",
    "#           print(t3.device)\n",
    "#           print(t44.device)\n",
    "          t8 = (t3 + t44)  \n",
    "          t9 = torch.pinverse(t8)                  \n",
    "          t9 = t9.float()\n",
    "#           print(t9.type())\n",
    "#           print(t9)x\n",
    "          t10 = (t22@t9)  \n",
    "          t11 = (t6 - t7)  \n",
    "          t11 = t11.float()\n",
    "          t12 = (t5@t11)\n",
    "          t13 = (t1 + t10 +t12)  \n",
    "        \n",
    "          #t2 = beta_param*(theta@C@bracket_term.float())\n",
    "          grad_fc= t13\n",
    "          C_new=C-gamma_param*grad_fc\n",
    "          C_new[C_new<thresh] = thresh\n",
    "          for i in range(len(C_new)):\n",
    "              C_new[i] = C_new[i]/torch.linalg.norm(C_new[i],1)\n",
    "          return C_new        \n",
    "            \n",
    "\n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "\n",
    "      #We set c1 = 10−5 and c2 = 10^4 We observed that the experimental performances of the algorithms \n",
    "       #are not sensitive to different values of c1 and c2 as long as they are reasonably small and large,respectively\n",
    "      # K is the number of smallest eigenvalues of the Laplacian matrix that are being ignored while updating the eigenvalues.\n",
    "      def laplacian_lambda_update(lb, ub, beta, U, Lw, k, C):\n",
    "        q = Lw.size(1) - k\n",
    "        # print(f'q is: {q}')\n",
    "        U = U\n",
    "        UT= torch.transpose(U,0,1)\n",
    "        UT = UT.type(torch.float64)\n",
    "        UT = UT\n",
    "        \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        CT = CT.type(torch.float64)\n",
    "        CT = CT\n",
    "        \n",
    "        AC=(A@C).double()\n",
    "        AC = AC\n",
    "        \n",
    "        Af=(CT@AC).double()\n",
    "        Af = Af  \n",
    "        Af.device\n",
    "        U.device\n",
    "        dd = U@Af@UT\n",
    "          \n",
    "        # cc = UT@A@U\n",
    "        \n",
    "        product = dd\n",
    "        matrix = torch.tensor(product)     \n",
    "\n",
    "        non_zero_diag_elements = []\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if matrix[i, i] != 0:\n",
    "                non_zero_diag_elements.append(matrix[i, i])\n",
    "            if len(non_zero_diag_elements) == len(matrix):\n",
    "                break\n",
    "\n",
    "        k = len(non_zero_diag_elements)\n",
    "        e = non_zero_diag_elements\n",
    "        d = torch.diag(torch.tensor(non_zero_diag_elements))\n",
    "#-----------------------------------------------------------------------------------------------------------------------------------------------\n",
    "\n",
    "       # Trial-2                 -########################################\n",
    "\n",
    "        e_bar = torch.tensor([])\n",
    "        if(k%2 == 0):\n",
    "            for i in range(k//2):\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)\n",
    "            \n",
    "        if(k%2 != 0):\n",
    "            for i in range((k+1)//2) :\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)       \n",
    "                \n",
    "        lambda_,indices = torch.sort(e_bar, dim=- 1, descending=True)\n",
    "        eps = 1\n",
    "        qq = lambda_.size(0)-1\n",
    "        condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "\n",
    "#                                   (lambda_[1:(q)] - lambda_[0:(q-1)]) >= -eps])\n",
    "        \n",
    "          \n",
    "        if condition.all():\n",
    "            # while(lambda_.size(0) != 135):\n",
    "            #     lambda_ = torch.cat((lambda_, torch.tensor(0).unsqueeze(0)), dim=0)\n",
    "            for i in range(k//2):\n",
    "                lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)\n",
    "            # print(f'Shape of updated lambda1_ is: {lambda_.shape}')\n",
    "            # hm= sns.heatmap(data =lambda_)\n",
    "            # plt.show()\n",
    "            # print(lambda_)\n",
    "            return lambda_\n",
    "        else:\n",
    "            greater_ub = lambda_ > ub\n",
    "            lesser_lb = lambda_ < lb\n",
    "            lambda_[greater_ub] = ub\n",
    "            lambda_[lesser_lb] = lb\n",
    "            condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "        for i in range(k//2):\n",
    "            lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)            \n",
    "            \n",
    "\n",
    "        print(f'Shape of updated lambda2_ is: {lambda_.shape}')\n",
    "        if condition.all():\n",
    "            return lambda_\n",
    "        else:\n",
    "#           print(lambda_)\n",
    "            raise ValueError(\"eigenvalues are not in increasing order, consider increasing the value of beta\")\n",
    "\n",
    "      for i in tqdm(range(10)): #update C only 21\n",
    "         C = update_C(C)\n",
    "            \n",
    "      return C\n",
    "          "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "556afd48",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "556afd48",
    "outputId": "7f0b9b03-7a98-4a01-ac78-fc754863ff46"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\2387417581.py:13: UserWarning: torch.sparse.SparseTensor(indices, values, shape, *, device=) is deprecated.  Please use torch.sparse_coo_tensor(indices, values, shape, dtype=, device=). (Triggered internally at C:\\cb\\pytorch_1000000000000\\work\\torch\\csrc\\utils\\tensor_new.cpp:607.)\n",
      "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/10 [00:00<?, ?it/s]C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\2793157037.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\2793157037.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\2793157037.py:33: UserWarning: Casting complex values to real discards the imaginary part (Triggered internally at C:\\cb\\pytorch_1000000000000\\work\\aten\\src\\ATen\\native\\Copy.cpp:299.)\n",
      "  U = torch.stack(update_V(C, theta)).double()\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_40692\\2793157037.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:44<00:00,  4.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.667900161804725\n",
      "Epoch: 000,loss: 1.9431\n",
      "Accuracy = 0.8515509601181684 1 0.01 10\n",
      "Average accuracy = 85.15509601181684 +/- 0.0\n",
      "Params =  1 0.01 10\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "import time   \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [1]:                                                        #\n",
    "  for beta_param in [0.01]:\n",
    "      for gamma_param in [10]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(1):\n",
    "            avg_accuracy_all=[]\n",
    "            X=X\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              A = A\n",
    "              theta = theta\n",
    "              a = time.time()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              b = time.time()\n",
    "              C_0 = C_0\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              L=L\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              c = time.time()\n",
    "              acc = get_accu(C_test,L_test,X_t_test)\n",
    "              d = time.time()\n",
    "              # print(\"Time taken:\", b-a+d-c) 10 0.001 0.01\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "FN7Cp3UQoMKv",
   "metadata": {
    "id": "FN7Cp3UQoMKv"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvgAAAK9CAYAAABRtxg8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABSSUlEQVR4nO3deXQUVf7+8acTSAICIkISiGyyukHYBRdcolERh3FQxIVFx0FkUTIqxIXFLSIjRgHBZRQXGFAUFEEEUVAUF1BGxDGAgDhIAqggBE0g3b8//NFfe9KpNEUuteT9OodzpOx03RR17n3qU/dWBUKhUEgAAAAAfCHO6QYAAAAAqDgEfAAAAMBHCPgAAACAjxDwAQAAAB8h4AMAAAA+QsAHAAAAfISADwAAAPgIAR8AAADwEQI+AAAA4CMEfAC+c/DgQd1xxx1q2LCh4uLi1KtXL6ebVK5zzjlH55xzjq2fHTBggJo0aVKh7flf06dPVyAQ0JYtWyw/N3bsWAUCAVv7aNKkiS699FJbP1uWQCCgsWPHVuh3AoDbEfABFzkUolatWhX1/59zzjk69dRTjbZh4cKFng9Ezz77rCZMmKDevXvr+eef14gRI5xuEgAAR00VpxsAwF0WLlyoKVOmeDrkv/vuu0pLS9Ojjz7qdFNitnjxYts/+/TTTysYDFZgawAAXkYFH4Dv7NixQ7Vr166w7wsGg/rtt98q7Pv+aP/+/ZKkhIQEJSQk2PqOqlWrKjExsSKbBQDwMAI+4AMvvfSSOnTooGrVqqlOnTq66qqr9P3330d85oMPPtAVV1yhRo0aKTExUQ0bNtSIESP066+/hj8zYMAATZkyRdLvc5cP/ZGkLVu2KBAI6B//+IemTJmiE088UdWrV9eFF16o77//XqFQSPfdd59OOOEEVatWTX/605/0008/RbTh9ddfV48ePdSgQQMlJiaqWbNmuu+++1RSUhLxuUNTkVavXq1u3bqpWrVqatq0qaZNm2Z5HA618b333tO6devC7V+2bJkkqbCwUH//+9/VsGFDJSYmqlWrVvrHP/6hUCgU8T2BQEBDhw7VjBkzdMoppygxMVGLFi2y3PcTTzwR/myDBg00ZMgQ7d69u8zf6+yzz1b16tV15513hv/f/87B/+6773TZZZfpmGOOUXJyskaMGKG333474neSSs/B/+O/1VNPPaVmzZopMTFRnTp10meffRaxjy+//FIDBgzQiSeeqKSkJKWmpur666/Xjz/+aPn7Ho7nnntO5513npKTk5WYmKiTTz5ZU6dOLfPzixcvVnp6upKSknTyySfrtddeK/WZ3bt369Zbbw3/WzZv3lzjx48v907G3r17deutt6pJkyZKTExUcnKyLrjgAn3++edH/HsCgFswRQdwoT179mjXrl2lth84cKDUtgceeED33HOPrrzySv31r3/Vzp07NWnSJJ199tn64osvwpXsV155Rfv379fgwYN1/PHH69NPP9WkSZP03//+V6+88ookadCgQfrhhx+0ZMkSvfjii1HbNmPGDBUXF2vYsGH66aef9PDDD+vKK6/Ueeedp2XLlmnkyJHauHGjJk2apNtuu03PPvts+GenT5+uGjVqKCsrSzVq1NC7776r0aNH65dfftGECRMi9vPzzz/rkksu0ZVXXqm+ffvq5Zdf1uDBg5WQkKDrr78+atvq1aunF198UQ888ID27dunnJwcSdJJJ52kUCikyy67TO+9955uuOEGpaen6+2339btt9+ubdu2lZrO8+677+rll1/W0KFDVbduXctFrGPHjtW4ceOUkZGhwYMHKy8vT1OnTtVnn32mDz/8UFWrVg1/9scff9TFF1+sq666Stdee61SUlKifmdhYaHOO+88bd++XbfccotSU1M1c+ZMvffee2W243/NnDlTe/fu1aBBgxQIBPTwww/r8ssv16ZNm8JtWrJkiTZt2qSBAwcqNTVV69at01NPPaV169bp448/tr1g9o+mTp2qU045RZdddpmqVKmi+fPn6+abb1YwGNSQIUMiPrthwwb16dNHN910k/r376/nnntOV1xxhRYtWqQLLrhA0u93Pbp3765t27Zp0KBBatSokT766CNlZ2dr+/btys3NLbMtN910k+bMmaOhQ4fq5JNP1o8//qgVK1boP//5j9q3b3/EvysAuEIIgGs899xzIUmWf0455ZTw57ds2RKKj48PPfDAAxHfs3bt2lCVKlUitu/fv7/U/nJyckKBQCD03XffhbcNGTIkFK1r2Lx5c0hSqF69eqHdu3eHt2dnZ4ckhdq2bRs6cOBAeHvfvn1DCQkJod9++82yDYMGDQpVr1494nPdu3cPSQo98sgj4W1FRUWh9PT0UHJycqi4uLj0wfuD7t27RxynUCgUmjdvXkhS6P7774/Y3rt371AgEAht3LgxvE1SKC4uLrRu3TrL/YRCodCOHTtCCQkJoQsvvDBUUlIS3j558uSQpNCzzz5b6veaNm1a1DZ37949/PdHHnkkJCk0b9688LZff/011Lp165Ck0HvvvRfe3r9//1Djxo3Dfz/0b3X88ceHfvrpp/D2119/PSQpNH/+/PC2aP8m//rXv0KSQu+//35426Fzc/PmzZbHY8yYMaXOn2j7yMzMDJ144okR2xo3bhySFHr11VfD2/bs2ROqX79+qF27duFt9913X+iYY44JrV+/PuLnR40aFYqPjw9t3bo1vE1SaMyYMeG/H3vssaEhQ4ZY/g4A4HVM0QFcaMqUKVqyZEmpP23atIn43GuvvaZgMKgrr7xSu3btCv9JTU1VixYtIqq91apVC/93YWGhdu3apW7duikUCumLL76IuW1XXHGFjj322PDfu3TpIkm69tprVaVKlYjtxcXF2rZtW9Q27N27V7t27dJZZ52l/fv365tvvonYT5UqVTRo0KDw3xMSEjRo0CDt2LFDq1evjrm9hyxcuFDx8fEaPnx4xPa///3vCoVCeuuttyK2d+/eXSeffHK53/vOO++ouLhYt956q+Li/q9LvfHGG1WrVi0tWLAg4vOJiYkaOHBgud+7aNEipaWl6bLLLgtvS0pK0o033ljuzx7Sp08fHXfcceG/n3XWWZKkTZs2hbf98d/kt99+065du3T66adLUoVNW/njPg7dnerevbs2bdqkPXv2RHy2QYMG+vOf/xz+e61atdSvXz998cUXys/Pl/T73aizzjpLxx13XMR5n5GRoZKSEr3//vtltqV27dr65JNP9MMPP1TI7wYAbsQUHcCFOnfurI4dO5bafijQHLJhwwaFQiG1aNEi6vf8cWrI1q1bNXr0aL3xxhv6+eefIz73vyHLSqNGjSL+fijsN2zYMOr2P+5r3bp1uvvuu/Xuu+/ql19+sWxDgwYNdMwxx0Rsa9mypaTf55gfCqGx+u6779SgQQPVrFkzYvtJJ50U/v9/1LRp05i/V5JatWoVsT0hIUEnnnhiqe9NS0uLaTHtd999p2bNmpWaItO8efOY2iWV/rc6FPb/+G/y008/ady4cZo1a5Z27NgR8fnDOS+sfPjhhxozZoxWrlwZXlT8x3388YKxefPmpX7nP/67p6amasOGDfryyy9Vr169qPv739/jjx5++GH1799fDRs2VIcOHXTJJZeoX79+OvHEE+3+egDgOgR8wMOCwaACgYDeeustxcfHl/r/NWrUkCSVlJToggsu0E8//aSRI0eqdevWOuaYY7Rt2zYNGDDgsB6xGG0/VttD/38B6+7du9W9e3fVqlVL9957r5o1a6akpCR9/vnnGjlypOse8/jHqrMXvjea8v5NJOnKK6/URx99pNtvv13p6emqUaOGgsGgLrroogr5N/n22291/vnnq3Xr1po4caIaNmyohIQELVy4UI8++qitfQSDQV1wwQW64447ov7/QxcE0Vx55ZU666yzNHfuXC1evFgTJkzQ+PHj9dprr+niiy8+7LYAgBsR8AEPa9asmUKhkJo2bWoZatauXav169fr+eefV79+/cLblyxZUuqzFbGoMpply5bpxx9/1Guvvaazzz47vH3z5s1RP//DDz+osLAwooq/fv16SbL11tbGjRvrnXfe0d69eyOq+IemBjVu3Piwv/OPP5eXlxdRBS4uLtbmzZuVkZFh+3u//vprhUKhiH+TjRs32vq+aH7++WctXbpU48aN0+jRo8PbN2zYUGH7mD9/voqKivTGG29E3FEoa7Hwxo0bS/3O//vv3qxZM+3bt8/2sa1fv75uvvlm3XzzzdqxY4fat2+vBx54gIAPwDeYgw942OWXX674+HiNGzeu1KMeQ6FQ+FGHhyq5f/xMKBTSY489Vuo7DwXq/33E45GK1obi4mI98cQTUT9/8OBBPfnkkxGfffLJJ1WvXj116NDhsPd/ySWXqKSkRJMnT47Y/uijjyoQCNgOdxkZGUpISNDjjz8e8bv985//1J49e9SjRw9b35uZmalt27bpjTfeCG/77bff9PTTT9v6vmii/ZtIsnwKTUXsY8+ePXruueeifv6HH37Q3Llzw3//5Zdf9MILLyg9PV2pqamSfq/Cr1y5Um+//Xapn9+9e7cOHjwY9btLSkpKTTtKTk5WgwYNVFRUdHi/GAC4GBV8wMOaNWum+++/X9nZ2dqyZYt69eqlmjVravPmzZo7d67+9re/6bbbblPr1q3VrFkz3Xbbbdq2bZtq1aqlV199tdRcfEnh8Dx8+HBlZmYqPj5eV1111RG3tVu3bjruuOPUv39/DR8+XIFAQC+++GKpcHlIgwYNNH78eG3ZskUtW7bU7NmztWbNGj311FMRawti1bNnT5177rm66667tGXLFrVt21aLFy/W66+/rltvvVXNmjWz9XvVq1dP2dnZGjdunC666CJddtllysvL0xNPPKFOnTrp2muvtfW9gwYN0uTJk9W3b1/dcsstql+/vmbMmKGkpCRJFXOnpVatWjr77LP18MMP68CBA0pLS9PixYvLvKtix4UXXqiEhAT17NlTgwYN0r59+/T0008rOTlZ27dvL/X5li1b6oYbbtBnn32mlJQUPfvssyooKIi4ILj99tv1xhtv6NJLL9WAAQPUoUMHFRYWau3atZozZ462bNmiunXrlvruvXv36oQTTlDv3r3Vtm1b1ahRQ++8844+++wzPfLIIxX2OwOA0wj4gMeNGjVKLVu21KOPPqpx48ZJ+n3B64UXXhh+AkvVqlU1f/58DR8+XDk5OUpKStKf//xnDR06VG3bto34vssvv1zDhg3TrFmz9NJLLykUClVIwD/++OP15ptv6u9//7vuvvtuHXfccbr22mt1/vnnKzMzs9TnjzvuOD3//PMaNmyYnn76aaWkpGjy5MmH9RSZP4qLi9Mbb7yh0aNHa/bs2XruuefUpEkTTZgwQX//+9+P6HcbO3as6tWrp8mTJ2vEiBGqU6eO/va3v+nBBx+0dTEiKfyegGHDhumxxx5TjRo11K9fP3Xr1k1/+ctfwkH/SM2cOVPDhg3TlClTFAqFdOGFF+qtt95SgwYNKuT7W7VqpTlz5ujuu+/WbbfdptTUVA0ePFj16tWL+j6DFi1aaNKkSbr99tuVl5enpk2bavbs2RHnSPXq1bV8+XI9+OCDeuWVV/TCCy+oVq1aatmypcaNGxexaPePqlevrptvvlmLFy8OP4GqefPmeuKJJzR48OAK+X0BwA0CobLKZwDgkHPOOUe7du3SV1995XRTXCc3N1cjRozQf//7X6WlpTndHACACzEHHwBc6tdff434+2+//aYnn3xSLVq0INwDAMrEFB0AcKnLL79cjRo1Unp6uvbs2aOXXnpJ33zzjWbMmOF00wAALkbABwCXyszM1DPPPKMZM2aopKREJ598smbNmqU+ffo43TQAgIsxBx8AAAAw4P3339eECRO0evVqbd++XXPnzlWvXr0sf2bZsmXKysrSunXr1LBhQ919990aMGDAYe2XOfgAAACAAYWFhWrbtq2mTJkS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FStWON0kX/n55591xhlnqGrVqnrrrbf09ddf65FHHtFxxx3ndNPgYzwm00KXLl3UqVMnTZ48WdLvbx5r2LChhg0bplGjRjncOv8JBAKaO3euevXq5XRTfGvnzp1KTk7W8uXLdfbZZzvdHF+qU6eOJkyYoBtuuMHppvjGvn371L59ez3xxBO6//77lZ6ertzcXKeb5Qtjx47VvHnztGbNGqeb4lujRo3Shx9+qA8++MDppqASoYJfhuLiYq1evVoZGRnhbXFxccrIyNDKlSsdbBlg3549eyT9HkJRsUpKSjRr1iwVFhYe1uvEUb4hQ4aoR48eEf0xKs6GDRvUoEEDnXjiibrmmmu0detWp5vkK2+88YY6duyoK664QsnJyWrXrp2efvppp5sFnyPgl2HXrl0qKSkJv2XskJSUFOXn5zvUKsC+YDCoW2+9VWecccZhvQ0P1tauXasaNWooMTFRN910k+bOnauTTz7Z6Wb5xqxZs/T555+HX+GOitWlSxdNnz5dixYt0tSpU7V582adddZZ2rt3r9NN841NmzZp6tSpatGihd5++20NHjxYw4cP1/PPP+900+BjVZxuAICjY8iQIfrqq6+YX1vBWrVqpTVr1mjPnj2aM2eO+vfvr+XLlxPyK8D333+vW265RUuWLFFSUpLTzfGliy++OPzfbdq0UZcuXdS4cWO9/PLLTDOrIMFgUB07dtSDDz4oSWrXrp2++uorTZs2Tf3793e4dfArKvhlqFu3ruLj41VQUBCxvaCgQKmpqQ61CrBn6NChevPNN/Xee+/phBNOcLo5vpKQkKDmzZurQ4cOysnJUdu2bfXYY4853SxfWL16tXbs2KH27durSpUqqlKlipYvX67HH39cVapUUUlJidNN9J3atWurZcuW2rhxo9NN8Y369euXuuA/6aSTmAoFowj4ZUhISFCHDh20dOnS8LZgMKilS5cyvxaeEQqFNHToUM2dO1fvvvuumjZt6nSTfC8YDKqoqMjpZvjC+eefr7Vr12rNmjXhPx07dtQ111yjNWvWKD4+3ukm+s6+ffv07bffqn79+k43xTfOOOOMUo8nXr9+vRo3buxQi1AZMEXHQlZWlvr376+OHTuqc+fOys3NVWFhoQYOHOh003xj3759EZWizZs3a82aNapTp44aNWrkYMv8YciQIZo5c6Zef/111axZM7x+5Nhjj1W1atUcbp33ZWdn6+KLL1ajRo20d+9ezZw5U8uWLdPbb7/tdNN8oWbNmqXWixxzzDE6/vjjWUdSQW677Tb17NlTjRs31g8//KAxY8YoPj5effv2dbppvjFixAh169ZNDz74oK688kp9+umneuqpp/TUU0853TT4GAHfQp8+fbRz506NHj1a+fn5Sk9P16JFi0otvIV9q1at0rnnnhv+e1ZWliSpf//+mj59ukOt8o+pU6dKks4555yI7c8995wGDBhw9BvkMzt27FC/fv20fft2HXvssWrTpo3efvttXXDBBU43DYjJf//7X/Xt21c//vij6tWrpzPPPFMff/yx6tWr53TTfKNTp06aO3eusrOzde+996pp06bKzc3VNddc43TT4GM8Bx8AAADwEebgAwAAAD5CwAcAAAB8hIAPAAAA+AgBHwAAAPARAj4AAADgIwR8AAAAwEcI+AAAAICPEPABAAAAHyHgA8Bhmj59umrXrn3E3xMIBDRv3rwj/h4AAP6IgA+gUhowYIB69erldDMAAKhwBHwAAADARwj4APA/Jk6cqNNOO03HHHOMGjZsqJtvvln79u0r9bl58+apRYsWSkpKUmZmpr7//vuI///666+rffv2SkpK0oknnqhx48bp4MGDUfdZXFysoUOHqn79+kpKSlLjxo2Vk5Nj5PcDAPgbAR8A/kdcXJwef/xxrVu3Ts8//7zeffdd3XHHHRGf2b9/vx544AG98MIL+vDDD7V7925dddVV4f//wQcfqF+/frrlllv09ddf68knn9T06dP1wAMPRN3n448/rjfeeEMvv/yy8vLyNGPGDDVp0sTkrwkA8KlAKBQKOd0IADjaBgwYoN27d8e0yHXOnDm66aabtGvXLkm/L7IdOHCgPv74Y3Xp0kWS9M033+ikk07SJ598os6dOysjI0Pnn3++srOzw9/z0ksv6Y477tAPP/wg6fdFtnPnzlWvXr00fPhwrVu3Tu+8844CgUDF/8IAgEqDCj4A/I933nlH559/vtLS0lSzZk1dd911+vHHH7V///7wZ6pUqaJOnTqF/966dWvVrl1b//nPfyRJ//73v3XvvfeqRo0a4T833nijtm/fHvE9hwwYMEBr1qxRq1atNHz4cC1evNj8LwoA8CUCPgD8wZYtW3TppZeqTZs2evXVV7V69WpNmTJF0u/z5GO1b98+jRs3TmvWrAn/Wbt2rTZs2KCkpKRSn2/fvr02b96s++67T7/++quuvPJK9e7du8J+LwBA5VHF6QYAgJusXr1awWBQjzzyiOLifq+BvPzyy6U+d/DgQa1atUqdO3eWJOXl5Wn37t066aSTJP0e2PPy8tS8efOY912rVi316dNHffr0Ue/evXXRRRfpp59+Up06dSrgNwMAVBYEfACV1p49e7RmzZqIbXXr1tWBAwc0adIk9ezZUx9++KGmTZtW6merVq2qYcOG6fHHH1eVKlU0dOhQnX766eHAP3r0aF166aVq1KiRevfurbi4OP373//WV199pfvvv7/U902cOFH169dXu3btFBcXp1deeUWpqakV8kItAEDlwhQdAJXWsmXL1K5du4g/L774oiZOnKjx48fr1FNP1YwZM6I+rrJ69eoaOXKkrr76ap1xxhmqUaOGZs+eHf7/mZmZevPNN7V48WJ16tRJp59+uh599FE1btw4altq1qyphx9+WB07dlSnTp20ZcsWLVy4MHwXAQCAWPEUHQAAAMBHKA0BAAAAPkLABwAAAHyEgA8AAAD4CAEfAAAA8BECPgAAAOAjBHwAAADARwj4AAAAgI8Q8AEAAAAfIeADAAAAPkLABwAAAHyEgA8AAAD4yP8DTLH5szDuQxEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvQAAAK9CAYAAABLi/iyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABgiElEQVR4nO3deXiU5fn28WuyTYYEgmAgrBEQRBFE2RQQUKiIiqVCEasV3Ep9QSpoVayKuKVqVVwoSvtWUPG1ioJLFRQRFCooKC4gCAgq+5qEbJNM5nn/4Ed+eSSByZCba557vp/j4DhkmMx9Mg6TM8/ci89xHEcAAAAAeFKCdgAAAAAA0aPQAwAAAB5GoQcAAAA8jEIPAAAAeBiFHgAAAPAwCj0AAADgYRR6AAAAwMMo9AAAAICHUegBAAAAD6PQAzgmoVBIbrvtNmnRooUkJCTIkCFDjI7Xr18/6devX42/bvPmzeLz+eRvf/tbrWVZtGiR+Hw+WbRoUa09ZiTmzZsnnTt3ltTUVPH5fJKbm3tcx8f/0noNAEBlFHrErRkzZojP55MVK1ZU+ef9+vWT008/3WiGd999V+69916jY5j2r3/9Sx599FEZNmyYzJw5U8aPH68dyWp79+6V4cOHSyAQkKlTp8qLL74oaWlp8tBDD8ncuXO14wEAFCRpBwDi2bvvvitTp071dKlfuHChNGvWTJ544gntKHHh888/lwMHDsj9998vAwYMqLj9oYcekmHDhhn/hARuffr0keLiYklJSdGOAiCOcYUewDHZtWuX1K9fv9YeLxwOS0lJSa09nm127dolIlKrz3l1SkpKJBwOGx/nWBUVFamNnZCQIKmpqZKQwLdTAHp4BwJq6KWXXpIuXbpIIBCQBg0ayIgRI+Tnn3923eeTTz6R3/72t9KyZUvx+/3SokULGT9+vBQXF1fcZ9SoUTJ16lQREfH5fBW/RNzzvadOnSqtW7eWOnXqyAUXXCA///yzOI4j999/vzRv3lwCgYD8+te/ln379rkyvPnmm3LxxRdL06ZNxe/3S5s2beT++++X8vJy1/0OTS1auXKl9OzZUwKBgLRq1UqeffbZIz4PhzJ+9NFHsnr16or8h+YSFxYWyi233CItWrQQv98vp5xyivztb38Tx3Fcj+Pz+WTs2LEya9Ys6dChg/j9fpk3b17E/z9KS0vlnnvukS5dukhGRoakpaXJueeeKx999FG1X/PEE09Idna2BAIB6du3r3z77beH3Wft2rUybNgwadCggaSmpkrXrl3lrbfeOmqe9evXy9ChQyUrK0tSU1OlefPmMmLECMnLyzvi10XymunXr5+MHDlSRES6desmPp9PRo0aJT6fTwoLC2XmzJkV/x9GjRpV8XVbt26Va6+9Vho3bix+v186dOgg//rXv1zjH5oL/sorr8hdd90lzZo1kzp16kh+fn61mcPhsDz55JPSsWNHSU1NlczMTLnwwgtd09hCoZDcf//90qZNG/H7/XLSSSfJnXfeKcFg0PVY0bxe+/TpI3Xq1JE777xTRERWrFghAwcOlBNPPLHidXzttdcelnnKlCnSoUMHSU1NlcaNG8vo0aNl//79rvuddNJJcskll8iSJUuke/fukpqaKq1bt5YXXnihyuet8hz6QxnXrFkj5513ntSpU0eaNWsmjzzyyGHP4Y8//iiXXnqppKWlSaNGjWT8+PEyf/585uUDqBGm3CDu5eXlyZ49ew67vays7LDbHnzwQbn77rtl+PDhcv3118vu3bvl6aeflj59+siXX35ZcdX0tddek6KiIrnxxhulYcOG8tlnn8nTTz8tW7Zskddee01EREaPHi3btm2TDz74QF588cUqs82aNUtKS0vlpptukn379skjjzwiw4cPl/PPP18WLVokt99+u2zYsEGefvppufXWW10lbcaMGZKeni4TJkyQ9PR0Wbhwodxzzz2Sn58vjz76qGuc/fv3y0UXXSTDhw+XK664Ql599VW58cYbJSUl5bBCdEhmZqa8+OKL8uCDD0pBQYHk5OSIiMipp54qjuPIpZdeKh999JFcd9110rlzZ5k/f778+c9/lq1btx42PWfhwoXy6quvytixY+XEE0+Uk046qer/WVXIz8+Xf/7zn3LFFVfIDTfcIAcOHJD/+3//rwwcOFA+++wz6dy5s+v+L7zwghw4cEDGjBkjJSUl8uSTT8r5558v33zzjTRu3FhERFavXi29evWSZs2ayR133CFpaWny6quvypAhQ+T111+X3/zmN1VmKS0tlYEDB0owGJSbbrpJsrKyZOvWrfLOO+9Ibm6uZGRkVPv3iOQ185e//EVOOeUUmT59utx3333SqlUradOmjQwYMECuv/566d69u/zhD38QEZE2bdqIiMjOnTvl7LPPrvjBKTMzU9577z257rrrJD8/X26++WZXjvvvv19SUlLk1ltvlWAweMSpJNddd53MmDFDBg0aJNdff72EQiH55JNPZNmyZdK1a1cREbn++utl5syZMmzYMLnllltk+fLlkpOTI999953MmTOn4rFq8nrdu3evDBo0SEaMGCFXXXWVNG7cWHbt2iUXXHCBZGZmyh133CH169eXzZs3yxtvvOH62tGjR8uMGTPkmmuukXHjxsmmTZvkmWeekS+//FKWLl0qycnJFffdsGGDDBs2TK677joZOXKk/Otf/5JRo0ZJly5dpEOHDtU+LyIH/01deOGFctlll8nw4cNl9uzZcvvtt0vHjh1l0KBBInLwh97zzz9ftm/fLn/6058kKytLXn755SP+MAoAVXKAOPX88887InLEXx06dKi4/+bNm53ExETnwQcfdD3ON9984yQlJbluLyoqOmy8nJwcx+fzOT/++GPFbWPGjHGq+me4adMmR0SczMxMJzc3t+L2iRMnOiLinHHGGU5ZWVnF7VdccYWTkpLilJSUHDHD6NGjnTp16rju17dvX0dEnMcee6zitmAw6HTu3Nlp1KiRU1paeviTV0nfvn1dz5PjOM7cuXMdEXEeeOAB1+3Dhg1zfD6fs2HDhorbRMRJSEhwVq9efcRxKo/Xt2/fit+HQiEnGAy67rN//36ncePGzrXXXltx26HnNBAIOFu2bKm4ffny5Y6IOOPHj6+4rX///k7Hjh1dz1M4HHZ69uzptG3btuK2jz76yBER56OPPnIcx3G+/PJLR0Sc1157LaK/S2WRvmYOvW4///xz133T0tKckSNHHvYY1113ndOkSRNnz549rttHjBjhZGRkVIx76O/SunXrKrP80sKFCx0RccaNG3fYn4XDYcdxHGfVqlWOiDjXX3+9689vvfVWR0SchQsXVtxW09frs88+67rvnDlzqnxeKvvkk08cEXFmzZrlun3evHmH3Z6dne2IiPPxxx9X3LZr1y7H7/c7t9xyS8Vtv3wNVM74wgsvVNwWDAadrKwsZ+jQoRW3PfbYY46IOHPnzq24rbi42Gnfvv1hjwkAR8KUG8S9qVOnygcffHDYr06dOrnu98Ybb0g4HJbhw4fLnj17Kn5lZWVJ27ZtXVfVAoFAxX8XFhbKnj17pGfPnuI4jnz55ZcRZ/vtb3/ruqrbo0cPERG56qqrJCkpyXV7aWmpbN26tcoMBw4ckD179si5554rRUVFsnbtWtc4SUlJMnr06Irfp6SkyOjRo2XXrl2ycuXKiPMe8u6770piYqKMGzfOdfstt9wijuPIe++957q9b9++ctppp9V4HBGRxMTEiqvI4XBY9u3bJ6FQSLp27SpffPHFYfcfMmSINGvWrOL33bt3lx49esi7774rIiL79u2ThQsXyvDhwyuetz179sjevXtl4MCBsn79etfzXNmh/1fz58+v8bzu2nrNVOY4jrz++usyePBgcRzH9bodOHCg5OXlHfYcjRw50pWlOq+//rr4fD6ZNGnSYX92aOrYoed0woQJrj+/5ZZbRETkP//5T8VtNXm9+v1+ueaaa1y3Hfp07J133qny0zWRg5+CZGRkyK9+9SvXc9GlSxdJT08/7Mr4aaedJueee27F7zMzM+WUU06RH374ocrHryw9PV2uuuqqit+npKRI9+7dXV87b948adasmVx66aUVt6WmpsoNN9xw1McHgMqYcoO4171794rpAZWdcMIJrqk469evF8dxpG3btlU+TuWP6n/66Se555575K233jpsbu7R5lJX1rJlS9fvDxXGFi1aVHl75bFWr14td911lyxcuPCwedC/zNC0aVNJS0tz3dauXTsROThX/uyzz444s8jBecFNmzaVunXrum4/9dRTK/68slatWtXo8X9p5syZ8thjj8natWtdZa6qx63q/1+7du3k1VdfFZGD0ywcx5G7775b7r777irH27Vrl+uHgsrjTZgwQR5//HGZNWuWnHvuuXLppZfKVVdddcTpNiK195qpbPfu3ZKbmyvTp0+X6dOnV/t3+eXfIRIbN26Upk2bSoMGDaq9z48//igJCQly8sknu27PysqS+vXru14HNXm9NmvW7LCpQH379pWhQ4fK5MmT5YknnpB+/frJkCFD5He/+534/X4ROfhvOC8vTxo1alRl3l8+F7/89ydy8H3hl/9/qtK8efOKH2wqf+3XX39d8fsff/xR2rRpc9j9fvl8AcDRUOiBCIXDYfH5fPLee+9JYmLiYX+enp4uIiLl5eXyq1/9Svbt2ye33367tG/fXtLS0mTr1q0yatSoGu0aUtU4R7rd+Z8Fp7m5udK3b1+pV6+e3HfffdKmTRtJTU2VL774Qm6//faY27kkkivC1XnppZdk1KhRMmTIEPnzn/8sjRo1ksTERMnJyZGNGzfW+PEOPTe33nqrDBw4sMr7HKlwPfbYYzJq1Ch588035f3335dx48ZJTk6OLFu2TJo3b17l19Tma6aqv8tVV11VsZj2l375SdSx/L+ozi8L6y/V9PVaVUafzyezZ8+WZcuWydtvvy3z58+Xa6+9Vh577DFZtmyZpKenSzgclkaNGsmsWbOqzJGZmen6/dH+nR3JsXwtANQUhR6IUJs2bcRxHGnVqlXF1euqfPPNN/L999/LzJkz5eqrr664/YMPPjjsvkcrOtFatGiR7N27V9544w3p06dPxe2bNm2q8v7btm2TwsJC11X677//XkSkRgtUD8nOzpYFCxbIgQMHXFfpD02dyM7OrvFjVmf27NnSunVreeONN1zPZ1VTQUQOXqX9pe+//77i79m6dWsROfiJS+V93muiY8eO0rFjR7nrrrvkv//9r/Tq1UueffZZeeCBB6q8f01eM9Wp6rWUmZkpdevWlfLy8qj/LtVp06aNzJ8/X/bt21ftVfrs7GwJh8Oyfv36ik9nRA4u1M3Nza14HdT09XokZ599tpx99tny4IMPyssvvyxXXnmlvPLKK3L99ddLmzZtZMGCBdKrVy8jP7jUVHZ2tqxZs0Ycx3H9/9uwYYNiKgBexBx6IEKXXXaZJCYmyuTJkw+7yuY4juzdu1dE/vfKXOX7OI4jTz755GGPeahA5+bm1mrWqjKUlpbK3//+9yrvHwqF5LnnnnPd97nnnpPMzEzp0qVLjce/6KKLpLy8XJ555hnX7U888YT4fL6KXT5qQ1V/1+XLl8unn35a5f3nzp3rmgP/2WefyfLlyysyNWrUSPr16yfPPfecbN++/bCv3717d7VZ8vPzJRQKuW7r2LGjJCQkHLZN49H+DtW9ZqqTlpZ22OsoMTFRhg4dKq+//nqVW3Me6e9yNEOHDhXHcWTy5MmH/dmhv8dFF10kIiJTpkxx/fnjjz8uIiIXX3xxRc7KXydy5NdrVfbv33/Yv8tDOxwdeu6HDx8u5eXlcv/99x/29aFQqNb/HR7NwIEDZevWra7tUEtKSuQf//jHcc0BwPu4Qg9EqE2bNvLAAw/IxIkTZfPmzTJkyBCpW7eubNq0SebMmSN/+MMf5NZbb5X27dtLmzZt5NZbb5WtW7dKvXr15PXXX69y3u2hsjxu3DgZOHCgJCYmyogRI445a8+ePeWEE06QkSNHyrhx48Tn88mLL75Y7cf9TZs2lYcfflg2b94s7dq1k3//+9+yatUqmT59umttQKQGDx4s5513nvzlL3+RzZs3yxlnnCHvv/++vPnmm3LzzTdXbKlYGy655BJ544035De/+Y1cfPHFsmnTJnn22WfltNNOk4KCgsPuf/LJJ0vv3r3lxhtvlGAwKFOmTJGGDRvKbbfdVnGfqVOnSu/evaVjx45yww03SOvWrWXnzp3y6aefypYtW+Srr76qMsvChQtl7Nix8tvf/lbatWsnoVBIXnzxxYpiXZ2avGaq06VLF1mwYIE8/vjj0rRpU2nVqpX06NFD/vrXv8pHH30kPXr0kBtuuEFOO+002bdvn3zxxReyYMGCw84viNR5550nv//97+Wpp56S9evXy4UXXijhcFg++eQTOe+882Ts2LFyxhlnyMiRI2X69OkV02o+++wzmTlzpgwZMkTOO+88Ean567UqM2fOlL///e/ym9/8Rtq0aSMHDhyQf/zjH1KvXr2KHyz69u0ro0ePlpycHFm1apVccMEFkpycLOvXr5fXXntNnnzySRk2bFhUz0c0Ro8eLc8884xcccUV8qc//UmaNGkis2bNktTUVBEx9wkeAAsdr+10gFhT3fZ/h1S1HaPjOM7rr7/u9O7d20lLS3PS0tKc9u3bO2PGjHHWrVtXcZ81a9Y4AwYMcNLT050TTzzRueGGG5yvvvrKERHn+eefr7hfKBRybrrpJiczM9Px+XwVW1ge2mLx0UcfdY19aIu8X26LWNXfZenSpc7ZZ5/tBAIBp2nTps5tt93mzJ8/v8ot9jp06OCsWLHCOeecc5zU1FQnOzvbeeaZZyJ6Hqt7ng4cOOCMHz/eadq0qZOcnOy0bdvWefTRRyu2NDxERJwxY8ZENNah8SpvWxkOh52HHnrIyc7Odvx+v3PmmWc677zzjjNy5EgnOzu74n6Vn9PHHnvMadGiheP3+51zzz3X+eqrrw4bZ+PGjc7VV1/tZGVlOcnJyU6zZs2cSy65xJk9e3bFfX65ZeEPP/zgXHvttU6bNm2c1NRUp0GDBs55553nLFiw4Kh/r0hfM9W9bteuXev06dPHCQQCjoi4trDcuXOnM2bMGKdFixZOcnKyk5WV5fTv39+ZPn36YX+Xmmy5GQqFnEcffdRp3769k5KS4mRmZjqDBg1yVq5cWXGfsrIyZ/LkyU6rVq2c5ORkp0WLFs7EiRNdW1E6Ts1fr7/0xRdfOFdccYXTsmVLx+/3O40aNXIuueQSZ8WKFYfdd/r06U6XLl2cQCDg1K1b1+nYsaNz2223Odu2bau4T3Z2tnPxxRcf9rW/fP1Vt21lVRl/+Zp0nIOvmYsvvtgJBAJOZmamc8sttzivv/66IyLOsmXLDnsMAKiKz3FYoQPEs379+smePXuqnJIB4PibMmWKjB8/XrZs2VLlbkoA8EvMoQcAQElxcbHr9yUlJfLcc89J27ZtKfMAIsYcegAAlFx22WXSsmVL6dy5s+Tl5clLL70ka9eurXZrTQCoCoUeAAAlAwcOlH/+858ya9YsKS8vl9NOO01eeeUVufzyy7WjAfAQ5tADAAAAHsYcegAAAMDDKPQAAACAh1HoAQAAAA9TWxTbe/BiraEBADCuTv162hGsV5Sbrx3Bekve7qsdoUr/ST5FbeyLy9apjV0ddrkBAMAAyiaA44VCDyAmJSQlakewnhNmkzOTnHBYOwJgLV+yTztCTKHQA4hJ4VC5dgTgmCQmJ2tHsF55WZl2BCAmUOgBADCAsgngeKHQAwBgQHIgVTuC9cqKS7QjQElCElNuKqPQAwBgQChYqh0BQJyg0AMAYACLYgFzfMkcpVQZhR5ATPKnBbQjWC9YWKwdAQBQCyj0AGISZRMAUB3m0LvxeQUAAADgYWpX6Fn9bxYr/wEAAOKDWqE/sVkjraHjQsH+A9oRrFe/UX3tCFZr3KKBdgTrbdu8RzuC1cqC7ENvWtGBQu0IUMJJsW5qhX77hp+0hgZqRcH+PO0IVvv5u03aEQAA8AS1Qt+yQxutoeMCV4bMa3VKlnYEq7U6iV1uTPv6m1ztCFY7kFukHcF6+3fu044AJSyKdVMr9D+t3qg1NFAr+JTJrJVsW2kcOwkBgB3YthJATKJsmpfkT9GOYDVOigVwvFDoASBOUTjhdYnJydoRoIRFsW4UegAADOC0Y/P4JA84SK3Qd+jVUWvouLB7GwuFTGvc4kTtCFbrclZ97QjW+/xz3idMyt9XoB3BegV5bFsZr1gU66ZW6Fcv/UZraKBW7Nq0VTuC1dZ8ykfpppWXsRsWgKM5VTsAIsCUGwAxibIJAKiOL5Er9JUlaAcAAAAAED0KPQAAAOBhTLkBopQcSNWOYLWy4hLtCACAGJXAlBsXCj0QJQonAACIBWqFPiEpUWvouBAOlWtHAAAAMMKXwBX6ytQKPYUTAAAAOHYsigUAAAA8jDn0AAAA8BRfItekK6PQA1HypwW0I1gtWFisHQEAAE+g0ANRonACAKCDbSvd+LwCAAAAMCAnJ0e6desmdevWlUaNGsmQIUNk3bp1rvv069dPfD6f69cf//jHGo3DFXoAMSk1PU07gvVKCgq1IwBAVLyybeXixYtlzJgx0q1bNwmFQnLnnXfKBRdcIGvWrJG0tP/9PnfDDTfIfffdV/H7OnXq1GgcCj2AmETZNC/Jn6IdwWqhYKl2BADK5s2b5/r9jBkzpFGjRrJy5Urp06dPxe116tSRrKysqMdRK/QXXdVba+i4sGHtXu0I1mt+Un3tCFa7sHtQO4L1PvqqZleAUDPbtxVoR7DegVzWMuH4CwaDEgy6v0f5/X7x+/1H/dq8vDwREWnQoIHr9lmzZslLL70kWVlZMnjwYLn77rtrdJXe5ziOE/G9a1HvwYs1hgUAAJZIDqRqR7DeR6/20I5Qpc97n6029n8GXCiTJ0923TZp0iS59957j/h14XBYLr30UsnNzZUlS5ZU3D59+nTJzs6Wpk2bytdffy233367dO/eXd54442IM1HoAcSkOvXraUewXlFuvnYEADFuydt9tSNUSbPQd/pwcVRX6G+88UZ57733ZMmSJdK8efNq77dw4ULp37+/bNiwQdq0aRNRJubQA4hJlE0AQHV8ittWRjq9prKxY8fKO++8Ix9//PERy7yISI8eBz8VodADxwG7sJjFolgAgNc5jiM33XSTzJkzRxYtWiStWrU66tesWrVKRESaNGkS8TgUeiBKFE4AAHAkY8aMkZdfflnefPNNqVu3ruzYsUNERDIyMiQQCMjGjRvl5ZdflosuukgaNmwoX3/9tYwfP1769OkjnTp1ingcCj0AAAA8xZfgjbNRp02bJiIHD4+q7Pnnn5dRo0ZJSkqKLFiwQKZMmSKFhYXSokULGTp0qNx11101GodCDwAAABhwtL1nWrRoIYsXH/tGMWqFnh0szGJBIQAAsJVXToo9XtQKfRkn6BnFCZDmJSUna0ewWt2GGdoRrHdgb552BKuVl5drR7BeOMRzDIhoFvriEq2hgVrBse5msegYAFCdBMVtK2MRc+gtlcjVY+PKy8q0I1jNKwuevMwJh7UjAABqgVqh73xeZ62h40LuXq5umpbdpqF2BKsN7V2gHcF6b/y3rnYEq/38wz7tCNYrKQoe/U5AHFAr9Ks+WqU1NFArNn+9XjuC1RbP0U4AABDJ1g5QJRbFuqkVej5ON4uP0gEAAOKDWqGncAIAACAaXBh2Uyv0w27oozV0XFj/PdvRmXZuT7ZVNKlfg1XaEaz3+qYztSNYbftOdsIyjXUKwEFqhX72Pz7WGhqoFV8d+8FuOIJntAPEBV7EAI4mSzsAIsC2lZbiJF7zOI0XAAAdLIp1o9BbirIJAAAQHyj0AAAA8BROinVTK/ScZGpWuLxcO4L1EhITtSNYLSmF6w2mhUpD2hGs5jjs5maaE3a0IwAxQe07ZnlZmdbQQK0oZ+tVo3iPAABUhzn0bmziCQAAAHgYhR4AAADwMCapAgAAwFM4KdZNrdCnpqdpDR0XylkUa1yyP0U7gtXSMtK1I1ivMK9AOwJwTEqLS7QjADFBrdCXFBRqDQ3UijK+kRjFN2rzQsFS7QgAEBUWxbox5QZATKJsAgAQGbVC37HPGVpDx4V9O/O0I1gvs2l97QhWu+T8gHYE6837hB+aTNq9jfdh04oLi7UjADFBrdB/8/FXWkMDtWL7Rg6WMmnVR6wDAQB9J2sHqBJTbtzUCv3Fv++tNXRc2LmTqxam9TiLhd0mndF4u3YE632xvYl2BKvlHtBOYL9VX+7VjgDEBLVC/58Xl2gNDdSKFe9rJwCO1XrtAMAxSUxO1o4QB07UDlAlrtC7sSgWAAB4kuOEtSMAMYFCDwCAAUmcVWEcu2EBB6kVet7ozOJNDgB08T4MmMNJsW5qhd4JO1pDAwAAANZQK/TlZWVaQwO1gk+ZzOLqJgCgOgmJLIqtjDn0QJQonPC6QL107QhWK84v0I4AIE5Q6AEgTlE4AXgV21a6UegBIE6lpnM4mkklBYXaEQDECbVCzzcSs0pLSrQjWM/nY4W9ScmsUTAuxFomozj0yLxwebl2BCAmqBV6rlzA+/hGYhIL5wEA1WHbSjeeDQAAAMDDmEMPICaxA4t5LIoF4FUsinVTK/T+tIDW0HEhWFisHQE4JpRNAAAio1boKZwAAADAsWPKDQAAADyFKTduLIoFAAAAPEztCj3bDZnFT67mOWFHO4LVeA2bx2vYLCcc1o4AWIse6aZW6JM4NMaosmIOloK3OXQhAAAiolboQ8FSraEBAADgYXyK66ZW6PkoEgBgs4SkRO0I1guHOLEbEFEs9LzRmcXcWPO4OmBWQiLvEaaFyylDJiUmJ2tHsB7f64CD1Ao9P1XD65L8qdoRrMY6EHgd3+cAc1gU66ZW6JMDlCGTKEPmsQ7ELK5umscVengd03eBg9QKPYUTXsc3ErMcpjQZx2sYgGf5+B5RGSfFAohJTFcAACAyTLmxFGXIPH9aQDuC1ZL9TLkxLVjIJ6UmlTOlybjysjLtCEBMYMoNEKWiXL6RAACggZ3m3JhyAyAm8QmIecHCYu0IAIBaQKEHEJMom/A6dmoyjyk38YttK90o9AAAGEDZBHC8UOgBAADgKcyhd+PzCgAAAMDDKPQAAACAhzHlBgAAeBILI+MX/+/dKPQAYlKSP0U7gvVCwVLtCMAxccJh7QhATKDQA4hJlE0AQHVYFOtGobdUanqadgTrlRQUakcAAADQK/TJgVStoeMCZRMAACA+qBX6suISraEBAADgYUy5cWPKDQDEqcTkZO0IVuOkWADHC4UeiBJbZpmVEvBrR7BeaXFQOwIARIfvwS4UeiBKbJdmVrCwWDsCAACeQKEHosQ+6WaxbSUAoDo+H3PoK1Mr9L+6vKfW0HFh25YD2hGs1679CdoRrHZ9yw+1I1jv2R/O145gtbw85tCbtvXH/doRgJigVuj372fupknhsKMdwXqlpUy5MenLlF7aEaxXUlKuHcFq+/YUaUewXnk578OAiGKhX//VZq2h4wKL3czbvaWudgSr/bgpUzuC9bZv3qUdwWrlIX5gMq20hO915jXVDlAlNqZwUyv0hblMCTEpXM43EtPKmONtVDmvYeMK9udrR7BamEJvnONwhR4QUSz0LHiD1/HN2qz927h6DACoGgdLubHLDYCYlJqeph3BeiUFhdoRAAC1QK3Qc0KhWZxQCK+jbAIAEBm1Qk/hBAAAQFRYFOvCswEAAAB4mNoV+uRAqtbQcaGsuEQ7AgAAgBEsinVTK/QUTgCAzZL8KdoRrMeOecBB7HIDAIABlE3AHJ+PWeOV8WwAAAAAHkahBwAAADyMKTcAABiQkJSoHcF6nNgdx1gU60KhBwDAAMomgOOFQg8AAABP8XGwlAuFHgAAAwL10rUjWK84v0A7AhATKPQAYlJicrJ2BOuVl5VpR7AaZRPA8aJW6NMaZGgNHRfKS0PaEaznT+O0Y5NObHqidgTr7d2+TzuC1crLeB82rbSEQyrjFSfFuqkV+sJ9eVpDA7WipKBQO4LV8nbu1Y4AAIAnqBX6XoO7aw0dF3L3FWtHsF52Kz5lMunSLru1I1jv3a8aaUew2s6dvA+btm0zP/jHLU6KdVEr9Evf/kxraKBWrF6qncBu776knSAerNMOACDmtdQOgAiwKBYA4lRqepp2BKsxLQ8whzn0bmqFnv1DzXLCYe0I1uM1bBZv1uaVl3PwEQDYQK3QUzjhdbyGzXJ4eo1LSWWnJpPYFBTA8cKUGwCIU0wJAeBZfEruwrMBAAAAeBhX6AHEpDr162lHsF5Rbr52BACIis/HOqvKKPQAYhJlEwCAyFDoAcQkf1pAO4L1goUcfAQANqDQA4hJlE0AQLVYFOvCswEAAAB4GFfoAQAA4CkcPuhGobdUYnKydgTrlZdxbAwAANBHobcUZRMAACA+UOgBAADgLT6WgVZGoQcQk3zsYGBckj9FO4LVyopLtCMAUJaTkyNvvPGGrF27VgKBgPTs2VMefvhhOeWUUyruU1JSIrfccou88sorEgwGZeDAgfL3v/9dGjduHPE4FHoAMckJh7UjWI/CCcCzPLIodvHixTJmzBjp1q2bhEIhufPOO+WCCy6QNWvWSFpamoiIjB8/Xv7zn//Ia6+9JhkZGTJ27Fi57LLLZOnSpRGP43McxzH1lziSW6cVaQwbN/bsPKAdwXqNsuppR7Ba59NTtSNY74tv2OvfpAN5/MBk2s6f9mhHsN7cv7fTjlClgmcnqo2d/secqL929+7d0qhRI1m8eLH06dNH8vLyJDMzU15++WUZNmyYiIisXbtWTj31VPn000/l7LPPjuhx1a7QL3v3c62hgVqxQTuA5f77H+0EAACR2Cz0PsU59MFgUILBoOs2v98vfr//qF+bl5cnIiINGjQQEZGVK1dKWVmZDBgwoOI+7du3l5YtW3qj0CckJWoNHRecsMoHL3GFPXDN8tcJaEewXmlx8Oh3QtTC5eXaEQAYkJOTI5MnT3bdNmnSJLn33nuP+HXhcFhuvvlm6dWrl5x++ukiIrJjxw5JSUmR+vXru+7buHFj2bFjR8SZ1Ap9OMQbHbzNYYq3UfzQbx7b2wJAzU2cOFEmTJjgui2Sq/NjxoyRb7/9VpYsWVLrmVgUCyAmFeWyDgQAUA3FT8kjnV5T2dixY+Wdd96Rjz/+WJo3b15xe1ZWlpSWlkpubq7rKv3OnTslKysr4sen0AOISexyAwDwOsdx5KabbpI5c+bIokWLpFWrVq4/79KliyQnJ8uHH34oQ4cOFRGRdevWyU8//STnnHNOxONQ6IEoBeqla0ewWnF+gXYEAECM8spZJWPGjJGXX35Z3nzzTalbt27FvPiMjAwJBAKSkZEh1113nUyYMEEaNGgg9erVk5tuuknOOeeciBfEiigW+sTkZK2h44LDBG/jQmUh7QhWS2uQoR3BesFCtq00iUWx5rEBBGLdtGnTRESkX79+rtuff/55GTVqlIiIPPHEE5KQkCBDhw51HSxVE2qFnsVY8DoWdpvFoUcAAK+L5Lin1NRUmTp1qkydOjXqcZhyYymOdDcvFCzVjgAAQHzysXV0ZWqF/t4HI58XhJr7djOF3rQ+7fdpR7Ba+qQrtSNYL+GBadoRrPbZ9pO0I1hv7UY+7QdERHxOJJ8FGNB78GKNYQF4BJ8ymcenTACOZsnbfbUjVKloxuSj38mQOqMmqY1dHabcAIhJlE0AACKjVui9st2QV7GHNwAAsBZz6F0Ut63kwwGTuLoJAAAQH9RaNYXTLOYfm8dr2KyEpETtCNZjD2+z+KQUwPHCZXJLUTbhdezzb15yIFU7gtU4SwEwh6nbbhR6S/GN2jy+WcPreA0DgB0o9JbiGzW8jmlj5vFJHgDP8nGFvjIKPYCYVF4W0o4AHBOmBJjHOgXgILVC32NQV62h48KP63ZqR7Deyac31Y5gtTNO82tHsN5nXxZqR7Da/j08v6YVHSjWjgDEBLVC/9Un32kNHRfKy1lQaFrenv3aEaz23Rfp2hGsV1xQpB3BaizsNq+MaWPHwUnaAaqWwD70lakV+pICrlzA28q4MGRUcX6BdgQAADyBOfQAAADwFB+LYl3UCv3A3/XSGjou7NvLLjemtWmdph3BagNP+Uk7gvU++TFbO4LVvl7Np0ym7dmRrx0BiAlqhX7+y0u1hgZqxefaASz3KifFGhcObdaOACDmxegGEMyhd1Er9C1ObaU1dFwoLuAKvWl16tXRjmC1jmc10Y5gvdVfsRuWSQX7uUJvWmlJUDsCEBPUCv3P323SGhqoFZzGa9ZPqzdqRwAAwBNYFAtEidN4AUBXYnKydgRoYVGsC4UeAAB4UnlZmXYEICZQ6AEAAOAtPhbFVsbnFQAAAICHcYUeAAB4kj8toB0BiAlqhT4zO0b3NbUEW3mZV69BPe0IVmvROlM7gvXWf7tFO4LVgkUsnDetLFiqHQFaEphkUplaod/94zatoYFakbdzr3YEq7G1LQAAkWHKDQDEKaYrmBUsLNaOANiLbStdKPQAEKconGYF6qVrR7BecT6n8QIiioW+Tn3mH5tUlJuvHQEA4hplEzAogW0rK1Mr9BROAAAA4Ngx5QaIUkJSonYEq4VD5doRAADwBAo9ECUKJwAASlgU66JW6P/2aGetoePCqh8ztCNY75JW32pHsNpXHYZqR7Bet69maUew2npprx3Bet/8zMJjQETE5ziOozFw78GLNYYF4BGJycnaEaxXXlamHQFAjFvydl/tCFUqeWuq2tipl45RG7s6alfokwOpWkPHhbJiTiiEt1E2AQCIjFqhp3ACAAAAx06t0PNxullc3QQAANZKYFFsZWqFnsIJAAAAHDtOirUUB3cBAABr+TgptjJOigWAOMWFFbP4PgfgeOFgKQCIUxROAJ7FwVIuPBsAAACAh3GFHkBMSvKnaEewXihYqh0BAFALKPQAYlJiUqJ2BOuFgtoJACBKbFvpQqEHosQVZLOChcXaEQAA8AQKPRAlpisAAKCEbStd+LwCAAAA8DC1K/QtO7TRGjou5O9lOzrTsk5qpB3Bak2bs0e6aVs252pHsFqwhBPRTcvdvV87AhAT1Ar9T6s3ag0N1IrcHbu1I1htrXYAAEDsYh96F+bQA4hJaQ0ytCNYr3BfnnYEAEAtoNADiEmUTQBAtVgU60KhB6LkTwtoR7Aa21YCABAZtUJ/cpf2WkPHheKCEu0I1qt7Qpp2BKv16X2idgTrfflNgXYEq+34aZ92BOsV5BVqR4AWDpZyUSv0G1ay5A1A9dYu004AABA5VTsAIsCUGyBKnBRrFgd3AQAQGQo9ECUKJwAAOhwWxbqoFfo+Q87WGjou/PTDXu0I1ut3flPtCFY7rekB7QjWW/R1He0IVvv5J17DphXms3geEFEs9B/PZYIsvG3G1+u1IwAAYFgT7QBV42ApF54NAAAAwMPUrtAnB1K1ho4LZcVsWwkAABAP1Ao9hRMAAABRYcqNC7vcAFFKSErUjmC1cKhcOwIAAJ5AoQeiROGE16Wmc9qxSSUFnGIKmMK2lW5qhf6U7qdpDR0X9u/O045gvRZtGmtHsFrbtunaEay3dm2+dgSrBUtC2hGst3fHfu0IQExQK/TrPlujNTRQK3Zt2qodwWpfLmJKk2l8ygTg6E7WDoAIqBX6hs2ztIaOCyVFHLZhWloGV5BNanpSpnYE6+34kQPoTCo6wJQb00qLg9oRoIVFsS5qhX7vlh1aQwO1onAf05pM2rtll3YE65WXlWlHAADUAhbFAohJyf4U7QjWo9AD8CwWxbpQ6AHEJHYIAQAgMhR6AAAAeEsCc+gro9ADiEk+3qyNc8Jh7QhWS2LamHGhYKl2BCAmUOgBxCTKJryOsgngeGHbSkuFWOxmXJ26nLJpUtOTTtSOYL1tm/doR7BaYV6BdgTrlfFDU9zipFg3tUKfkMjH6Sb5Qjy/ppWXcyiPSX4/HyCalpTM4V0mJSTy/JqWkMRzDIgoFnquXJhVlMuR7vA2TuIFAFSLg6Vc1Ar9PRPbaQ0dF5atDWhHsN4FHZmuYNLJn0zVjmC9Vefcqh3Bap9v4DRp07ZtL9GOAMQEn+M4jsbAfS/7r8awcYMDYwAAwLFa8nZf7QhVKvx0rtrYaecMURu7OmpX6CmcAAAAiIbDlBsXng0AAADAw9hGAgAAAN7CtpUuFHogSsmBVO0IVisrZrEbAACRoNBbKjE5WTuC9SicAADoYA69m1qhr9vwBK2h4wInxZqXlsVJpiY1bMJ7hGl7tu3TjmC1kqJi7QjWKy8NaUcAYoJaoT+wd7/W0ECtKM7ncDST9vy8XTsCAACewJQbADHJl8DHqaY54bB2BACIDotiXSj0AGISZRNel+RP0Y5gvVCwVDsCEBMo9JbiG4l5fCMBcCS8RwAGsSjWhUJvKb6RAAAAxAcKPYCYxNar5pWzGxYAWIFCDyAm+dMC2hGsV5RLoQfgTQ6LYl0o9ABiUlFuvnYEAAA8gUIPRIkryGYFCzmUBwBQDRbFuqgV+oSkRK2h44ITdrQjWK+MhcdGsVOTeeHycu0IVkvmNWwcP/gDB6kV+nCIbyQmUYbMYychs/ih1Dz2+jcrGKJsAqY4whz6yphyYynKJryOsgmvY1qeeVyhBw6i0ANR4lMQs/ihFF5H2QRwvFDogShROAEA0OGwKNaFQg9EiSv0ZpWXhbQjWI9pTQBgBwo9ECWu0AM4EnZzM48NNuIYV+hdKPQAABhA2QRwvPDjDQAAAOBhalfo69SvpzV0XCjKzdeOAAAAYITjYx/6ytQKPYUTAAAAOHbMoQcQk1LT07QjWK+koFA7AgBEhW0r3Sj0AGISZRMAgMhQ6AHEJH9aQDuC9TjJFIBneWQO/ccffyyPPvqorFy5UrZv3y5z5syRIUOGVPz5qFGjZObMma6vGThwoMybN69G41DogSj5Evi4zyTKJgDA6woLC+WMM86Qa6+9Vi677LIq73PhhRfK888/X/F7v99f43Eo9ECUAvXStSNYjYXzAACvGzRokAwaNOiI9/H7/ZKVlXVM41DogShROAEA0KG5KDYYDEowGHTd5vf7o7qyLiKyaNEiadSokZxwwgly/vnnywMPPCANGzas0WMwZwAAAACIUE5OjmRkZLh+5eTkRPVYF154obzwwgvy4YcfysMPPyyLFy+WQYMGSXl5zU6a5go9AAAAPMURvUWxEydOlAkTJrhui/bq/IgRIyr+u2PHjtKpUydp06aNLFq0SPr37x/x41DoASBOcWK3WUzLA+x0LNNrjqZ169Zy4oknyoYNG7xR6JMDqVpDx4Wy4hLtCABiHIUTAGLLli1bZO/evdKkSZMafZ1aoadwAgAAIBpeOSm2oKBANmzYUPH7TZs2yapVq6RBgwbSoEEDmTx5sgwdOlSysrJk48aNctttt8nJJ58sAwcOrNE4TLkBAAAADFixYoWcd955Fb8/NPd+5MiRMm3aNPn6669l5syZkpubK02bNpULLrhA7r///hpP6VEr9En+FK2h40IoWKodwXocLGWWL8EbpwB6mRN2tCNYzQmHtSMA9vLISbH9+vUTx6n+vXb+/Pm1Mo5aoadwwuv4Zm2Ww9NrHGuZzGJqKYDjhSk3ABCnKJwAvMrhKCUXtUKfmJysNXRcKC8r044AAACA40Ct0FM4AQAAgGOnVug50MQs9pcGAAC2cjyyKPZ4USv0FE4AAADg2LEoFgAAAJ7ilYOljheeDQAAAMDDuEIPRInD0czirAoAACKjVujvmNxLa+i4sGg5Zci04eexU5NJpy+boh3Bel92v0U7gtV+2p+mHcF6S5ezHi9eOcKi2Mp8zpHOozWo9+DFGsMCAAAgQkve7qsdoUrb165SG7tJ+85qY1dH7Qr9RVf11ho6Lmz9+YB2BOu1bZehHcFqV7b5TDuC9RYd6KYdwWrfb1a5XhZX1q3epR0BSlgU66ZW6N99aYnW0HGBk3jN+2oxU25Mmq0dIC58oh0AQMxroh0AEVAr9MmBVK2h40JZcYl2BAAAACM4WMpNrdBTOAFAlz8toB3BasHCYu0IAOJEVIX+iy++kOTkZOnYsaOIiLz55pvy/PPPy2mnnSb33nuvpKSwnR8AxDoKJwDYIapCP3r0aLnjjjukY8eO8sMPP8iIESPkN7/5jbz22mtSVFQkU6ZMqeWYAIDaxlkKZnGWAmAO21a6RVXov//+e+ncubOIiLz22mvSp08fefnll2Xp0qUyYsQICj2AY8Z0EPO4Qg8Adoiq0DuOI+FwWEREFixYIJdccomIiLRo0UL27NlTe+kAxC3KJgCgOmxb6RZVoe/atas88MADMmDAAFm8eLFMmzZNREQ2bdokjRs3jugxBl3JPvQmbdq4XzuC9Tqf2VA7gtUGnLJVO4L11u5jOzqT1vygncB+G9bu1Y4AxISoCv2UKVPkyiuvlLlz58pf/vIXOfnkk0VEZPbs2dKzZ8+IHuO9WexDD29bu0w7gd1e0Q4QFzZqBwAQ8xppB0AEoir0nTp1km+++eaw2x999FFJTEw85lAAAABAdVgU6xb1PvS5ubkye/Zs2bhxo/z5z3+WBg0ayJo1a6Rx48bSrFmzo379wN/1inZoRODHH3K1I1ivT+8TtSNYLfvEIu0I1lv6rV87gtV+3JSnHcF6obJy7QhATIiq0H/99dfSv39/qV+/vmzevFluuOEGadCggbzxxhvy008/yQsvvHDUx/j0g++iGRoRChaxoNC0/H0F2hGsVqcuu9yYtnf7j9oRrFZaEtSOYD22Bj0eMrUDVIlFsW5RFfoJEybINddcI4888ojUrVu34vaLLrpIfve730X0GPm790UzNBAztn1PGQIAAPqi+vHm888/l9GjRx92e7NmzWTHjh3HHAoAAABAZKK6Qu/3+yU/P/+w27///nvJzIzNj2YAAABgBxbFukV1hf7SSy+V++67T8rKykRExOfzyU8//SS33367DB06tFYDAgAAAKheVFfoH3vsMRk2bJg0atRIiouLpW/fvrJjxw4555xz5MEHH6ztjAAAA5IDqdoRrFZWXKIdAbAWi2Ldoir0GRkZ8sEHH8iSJUvk66+/loKCAjnrrLNkwIABtZ0PAGAIhRMA7BD1PvQiIr1795bevXvXVhYAwHGUmJysHcFq5f8zLRVA7WMOvVvEhf6pp56K+EHHjRsXVRgAOCQhiVOnTaNwAoAdIi70TzzxhOv3u3fvlqKiIqlfv76IHDw5tk6dOtKoUSMKPYBjFg5xAiQAAJGIeEXBpk2bKn49+OCD0rlzZ/nuu+9k3759sm/fPvnuu+/krLPOkvvvv99kXgAAAMQ5x+dT+xWLfI7jODX9ojZt2sjs2bPlzDPPdN2+cuVKGTZsmGzatOmojzFvFcc1m7RyLdMVTOvfuUA7gtUy/jJMO4L1Eh75l3YEq63Z21Q7gvVWruGTPNMeGJWiHaFKG3/4QW3sNq1bq41dnagWxW7fvl1CodBht5eXl8vOnTsjeowH7v40mqGBmLFwbkA7gtWCpXdpR7DfzXrfEOMDzy8sMKqvdoIqOU5sXinXElWh79+/v4wePVr++c9/yllnnSUiB6/O33jjjWxdibgRLCzWjgAAABBdof/Xv/4lI0eOlK5du0ry/2x7FgqFZODAgfLPf/4zosc49ZzToxkaEdq7Y792BOu1aNNYO4LVBp7LoUemfbyS6Qombf85VzuC9Q7kMvUREIlyDv0h33//vXz33Xfi8/mkffv20q5du4i/tvfgxdEOCyAO+BI4BdA0JxzWjmC1JH9szj22SSjIejzTlrwdm1Nu1m/8UW3stm2y1cauzjEdLNWuXTtp27atiIj4YnTVLwBvomzC6yibAI6XqC+BvfDCC9KxY0cJBAISCASkU6dO8uKLL9ZmNgAAAOAwjvjUfsWiqK7QP/7443L33XfL2LFjpVevXiIismTJEvnjH/8oe/bskfHjx9dqSAAAAABVi6rQP/300zJt2jS5+uqrK2679NJLpUOHDnLvvfdS6AEAAGBMrF4p1xL1PvQ9e/Y87PaePXvK9u3bjzkUAMC85AA7CZlUVlyiHQFAnIiq0J988sny6quvyp133um6/d///nfFIlkAQGyjcAKAHaIq9JMnT5bLL79cPv7444o59EuXLpUPP/xQXn311VoNiOikpqdpR7BeSUGhdgQAAOISU27coir0Q4cOleXLl8vjjz8uc+fOFRGRU089VT777DM588wzazMfokTZBAAAiA9R70PfpUsXmTVrVm1mAQAAAI6KK/RuNSr0CQkJRz1AyufzSSgUOqZQAAAAACJTo0I/Z86cav/s008/laeeekrCnO6IOMEOIWaxYBMAgMjUqND/+te/Puy2devWyR133CFvv/22XHnllXLffffVWjggllE4AQDQ4ThMuaks6jn027Ztk0mTJsnMmTNl4MCBsmrVKjn99NNrMxuAOMZOTeaxeB4A7FDjQp+XlycPPfSQPP3009K5c2f58MMP5dxzzzWRDUAco2wCAKrDoli3GhX6Rx55RB5++GHJysqS//f//l+VU3AAAAAAHD8+x3GcSO+ckJAggUBABgwYIImJidXe74033jjqY/UevDjSYQEABvjTAtoRrBYsLNaOAByzJW/31Y5QpW837FAb+/STs9TGrk6NrtBfffXVR922MlIZjRvWyuOgamXBMu0I1ktJ9WtHsFrDJg20I1gvb0++dgSr+evwA5NpZcFS7QhATKhRoZ8xY0atDVyYe6DWHguHC/EmZ1yRdgDL5e7YrR0BAABPiHqXm2NF4QQAAEA0WBTrlqAdAAAAAED01K7Q+xL4WcIkhxN7AQCApThYyk2t0FM4ARxJoF66dgTrFecXaEcAANQCtUIPAEdC2QRwNHXq19OOAMQECj2AmJSQVP1ZF6gd4VC5dgTgmBTlsvVqvAqzKNaFQg8gJlE2AQCIDIUeQEziFFPzOMkUgFexbaUbhR5ATKJsmpfkT9GOYDXOWwFwvLBtpaUSk/lZzbTyspB2BKslJDKH3jRew2bxfc48dsyLX2xb6ca2lZbiyhC8rpz3CAAAIsJlXCBKTFcwi6vH5nFhBQDsQKEHosSnIAAA6GBRrBuFHgAAeFJicrJ2BCAmUOgBxCS2rTSPnYTgdeVlZdoRoIRFsW5qhX7EjX20ho4L363J045gvS5n1deOYLUR/te1I1jvleBQ7QhWY1aeeevWF2hHAGKCz3EcR2Pg3oMXawwLAPgfCUlsDWoSpx3DBkve7qsdoUor1u1XG7vrKSeojV0dptwAQJyicJrFPvTmsVNT/GJRrBuFHgAAAyibAI4XCj0AAAA8hUWxbmqFno8iARwJB3eZxw4hZjlhlSVqcYVPQYCD1Ap9anodraHjQnE+K//hbWXFJdoRAAAxih/l3NQKPYUTAAAAOHZqhb7Fqa20ho4LBXmF2hGsF0jn4COT2ndqqh3BehvX7taOYLVC3oeNKzrAcwyIKBb6n7/bpDU0UCv0dsCND9u+/1E7AnBMWAdiXojTu+IWi2Ld2OUGAAADkpKTtSNYj0IPHKRW6H9/U2yePGaLPfs4MMa0XqfzjcSk7stztCNYb3PfP2pHsNqKrUwbM+2r1Uy5iVccLOXmcxxHZV+t3oMXawwLAACACC15OzYvwP73uwNqY/c8ta7a2NVRu0J/y929tYaOC0tXBrUjWO+CnsxYM6nPrpe1I1jvRd8o7QhW25fLxnqm7dpVrB0BiAlcoQcAAECVYvUK/dI1etuf9zotXW3s6nCJEYhSanqadgSrlRQwNxYAgEioFfoOvTpqDR0XdvzI/tKmZWVnakew2mkdTtCOYL21a/O0I1it6ACnHZu2bycbCMcrFsW6qRX6NZ+u1hoaqBX7d/BDk0nrViRqR7BeuJzdsExKZNtK48qK+aHJvFO1AyACaoXeCbNYCN7m8BI2KhyibMLbKPSAOWGVFaCxS63Q+xIStIaOC/zAZF5CEleQTfL5eI8wLSmFZVQmlRaz2xiA44Mr9ECUEhIp9CZxAqR55WVl2hEAALWAyzNAlCicZiUHUrUjWI/5xwC8ikWxbhR6IEpMGzOLq8fm8Ro2KzGZb7GmcWEFOIh3GyBKTBszi0XH8DrKJmCO43CFvjIuzwAAAAAeRqEHAAAAPIwpNwAAGMA+9Oax1iZ+OexD70KhB6LEPvRmcbAUvI6yCeB4USv0GY0bag0dF4KFbEdnWqBemnYEq53QqL52BOvt35WrHcFqpSUcLGVaeWlIOwKUhNm20kWt0Oft3Ks1NFArSgoKtSNYbf+2XdoRAADwBBbFAgAAAB6mdoU+UC9da+i4ECrjY0jTUgJ+7QhWC6TV0Y5gPaaEmFVcUKQdwXqstYlf7EPvplbonTDLk03i0CPzklNStCNYzZfAm7Vp5eWUIZOSOCnWuFIKPSAiioWe+cfwutwdu7UjAAAQl7yybeXHH38sjz76qKxcuVK2b98uc+bMkSFDhlT8ueM4MmnSJPnHP/4hubm50qtXL5k2bZq0bdu2RuMwhx4AAAAwoLCwUM444wyZOnVqlX/+yCOPyFNPPSXPPvusLF++XNLS0mTgwIFSUlKz3Qr5PBAAAACe4nhk28pBgwbJoEGDqvwzx3FkypQpctddd8mvf/1rERF54YUXpHHjxjJ37lwZMWJExONwhR4AAACIUDAYlPz8fNevYLDmmwxs2rRJduzYIQMGDKi4LSMjQ3r06CGffvppjR6LQg9EyZeQwC+DvwAAiEU5OTmSkZHh+pWTk1Pjx9mxY4eIiDRu3Nh1e+PGjSv+LFJMuQGixE5CAADo0NwsceLEiTJhwgTXbX6/7lbWFHoAAAAgQn6/v1YKfFZWloiI7Ny5U5o0aVJx+86dO6Vz5841eiw+1wYAAICnOI5P7VdtadWqlWRlZcmHH35YcVt+fr4sX75czjnnnBo9FlfoAQAAAAMKCgpkw4YNFb/ftGmTrFq1Sho0aCAtW7aUm2++WR544AFp27attGrVSu6++25p2rSpa6/6SFDoAQAAAANWrFgh5513XsXvD829HzlypMyYMUNuu+02KSwslD/84Q+Sm5srvXv3lnnz5klqamqNxvE5js5ZW70HL9YYFgAAABFa8nZf7QhVeveLMrWxLzorWW3s6jCHHgAAAPAwptwAAADAU8IeOSn2eOEKPQAAAOBhXKEHAACAp+isAI1dFHoAMSk5ULMV/qi5suIS7QgAgFpAoQcQkyibAABERq3Qn9n/TK2h48LeHfnaEazXuHl97QhW+3W/RO0I1nt/OcuoTPpxwx7tCNYLlYW0I0BJbZ7YagO1Qv/lh19qDQ3Uip9Wayew28oPKfSmhUPl2hEAxLxs7QCIAFNuAMQkyiYAoDphFsW6UOgBxCRfAtNBTHPCYe0IAIBaQKEHEJMomwAAREat0I+d2Edr6LiwaQtlyLQLz9yvHcFqzWf+WTuC9TZdNUU7gtU276+rHcF6H396QDsClLAPvZvPcXSekt6DF2sMCwAAgAgtebuvdoQqzflMb53Vb7rH3qYNTLkBAACApzjCtpWVseoMAAAA8DCu0AMAAE9K8qdoR4AStq10Uyv0CUmxN//IJuzhDa/jPcI8h++IRrFTk3mhYKl2BCAmqBV6CieAI+E9AgCAyKgV+jP7n6k1dFzI21uoHcF6afUC2hGs1r9PPe0I1vtydZl2BKtt/zlPO4L18vcVaEeAEratdFMr9F9++KXW0AA84LvlzI01jekKAI6utXYARIBFsUCU/GlcoTcpWFisHQEAEKO4Qu9GoQeiROEEcCR16jNtzLSi3HztCEBMoNADAGAAC7sBHC8UeiBKqelp2hGsVlLAwm54G69hwJyww0mxlVHogSjxzdosXwIHWZvGPukAYAcKPYCYRNkEAFSHRbFuFHoAMYldhMxjYTcA2IFCDyAmUTYBANXhCr0bhR4A4lRyIFU7gtXKiku0IwCIExR6ADEpyc9JsaZROAHADhR6ADEpFCzVjmA9rtCbxQ9MgDlhpty4UOiBKLFo0yzm0JtH4QQAO1DogShROAEA0OFwsJSLWqGvU7+e1tBxoSg3XzsCAAAAjgO1Qk/hBAAAAI4dU24AIE4lJidrR7BaeVmZdgTAWuxD70ahBxCTAvXStSNYrzi/QDsCAKAWUOgBxCTKJgCgOmxb6UahB6LEwm6zWGcDAEBkKPRAlCicAADoYA69G4UeAAADfAkJ2hGs54TD2hGAmEChBwDAgMRkvsWaFgqWakcAYoLau02SP0Vr6LjgsFrEuISkRO0IVguk19GOYL0iFh4bxfuwebwPxy+m3LipFXp+qobXsce0WWXFJdoRrJeanqYdwWolBYXaEQDECT4PBIA4VcaFFQAexQdgbmqFvvelPbSGjgs//7BXO4L12ndqrB3Ban06UTZNW/KNXzuC1fbsKdaOYL0dP+3TjgDEBLVCv+St5VpDA7Xix283aEew2pJ5GdoRrFe4L087AoCY11I7ACLAlBsAMYmyCQCoDoti3dQKff2sTK2h40JpSVA7gvXYhcWsrGzeI0zbtYWpeSbxPmxeWZDNCQARxUKfu2O31tBxITmQqh3BepwUa9a+bbu0I1iPQ3kAeBVvX25MubEUW/7B61ICLNg0LVjIok0AsAGFHkBMSkxO1o4QByj0ALyJOfRuFHoAMYkpTeb50wLaEazGJyAAjhcKPRAlypBZlCHzeI4BwA4UeiBKYY6pAwBABVNu3Cj0QJRYeAyvS/KnaEewWijIaccAjg8KPQDEKQonAK/iQ3I3tULP/GOzmBsLAAAQH9QKPYUTAAAAOHZqhZ65m2Y5fBZlXEJSonYEqyXzHmFcGVNujAqHyrUjWI/3ifjlqK6K9SmOXTW1Qs/cTXhdeVmZdgSrJSbyA5NpLOyG1/E+DBzEolgAMamkoFA7AgAgRrFtpRuFHgAAeBLTd4GDKPQAABjgS0jQjmA9pu8CB1HoAQAwwAmHtSMA1uKflxuFHgAAA7hCbx4/NAEHUeiBKCUHUrUjWI0dWOB1lE3AHBbFulHogShROAEcCT/0m8f7MHAQhR4AAAMom4A5nJ/pRqEHopSYnKwdwWocGAMAQGTUCj0fRZrFlSHzHIf5sSbxA5N54fJy7QjAMWGdAnCQWqGncMLrwiHKkFk8vwCAqrEo1k2t0J99UTetoePCnp0HtCNYL6tZhnYEq/3qbO0E9lv4uU87gtX27CrUjmC93D18rwNEFAv9snc/1xoaqBUbVmonsNuSt7QT2M+fFtCOYLVgYbF2BKAWZGsHqJKjuio29i6GsCgWiBKHxpjF3FjzKJwAYAcKPRAlCicA6GLxPHAQhR4AAHhSUgo1Jl6xD70b/xIAAIAnMW0MOIhCDwAAAE9h20o3Cj2AmMThc+ZxHggA2IFCDyAmUTYBANUJM4neRa3QJ/lTtIaOC6FgqXYEAAAAHAd6hZ6tpoyi0AMAAMQHtUJfUsCR2ACqxxx685jWBMCrWBTrxhx6ADGJsgmv49Aj88rLyrQjADGBQg8AgAGUTcAcrtC7UeiBKPnTAtoRrMaBMQAAREat0DM/1qxwqFw7AnBMGjbP0o5gvYL9edoRrFbO+7BxDlsXAiKiWOiZHwuv4+N0s7hCDwCoTpg5Ny4J2gEAAAAARI859AAAAPAUJ6ydILZQ6AHEJF8CHyCa5oT5jggANqDQA4hJlE0AQHUc5tC7qBV6rr6ZRRkCAACID2qFnsIJ4Ejq1K+nHcF6Rbn52hEAALWAKTcAYlJxfoF2BABAjOK6sBuFHohSQlKidgSrcTgaAACRodADUaJwmuVPC2hHsB6HdwHwKhbFuqkV+sTkZK2h40K4nLJpWkIiV+hN8vlYOG8a78NmOWyUbZwTptQBIoqF/jejztEaOi5s/OGAdgTrndGRRZsmDWu4SDuC9d4v7qMdwWqbtmonsN+OHUXaEYCYoFboZ//jY62hgVrx5YfaCew2Q3zaEeLAJ9oBAMS6sX21E1SJD2fcmENvqUC9dO0I1mMXFgAAEAso9JaibAIAAFuxfsKNQg8AgAHs1GQeOzUBB1HoAQAwgLIJmMOulW7sCwcAAAAYcO+994rP53P9at++fa2PwxV6AAAAwJAOHTrIggULKn6flFT79ZtCDwAAAE8Je2hRbFJSkmRlZZkdw+ijQ40vgdlUpjlhToEEACDeBINBCQaDrtv8fr/4/f4q779+/Xpp2rSppKamyjnnnCM5OTnSsmXLWs1EobcUZRNexw+l5vE+AcCrHMVVsTk5f5XJkye7bps0aZLce++9h923R48eMmPGDDnllFNk+/btMnnyZDn33HPl22+/lbp169ZaJp+j9Iz0HrxYY1gAAI4LDvgzjzNXzFvydmyeFHv7dL1dpO4bmVCjK/SV5ebmSnZ2tjz++ONy3XXX1VomtSv0Q645V2vouLB1W5F2BOud06WOdgSrXXpgpnYE671RZ5R2BKtt2emdOb5etemHfO0IiEORlveq1K9fX9q1aycbNmyo1UxqhX7u859oDQ3Uis/nayew21PSWjuC9fxpn2tHsBr70MMKf47NK/SOR2cMFhQUyMaNG+X3v/99rT4uc+gBIE5ROAHArFtvvVUGDx4s2dnZsm3bNpk0aZIkJibKFVdcUavjUOgBAIAnJQdStSNASdgjR8Vu2bJFrrjiCtm7d69kZmZK7969ZdmyZZKZmVmr41DoAQCAJ5UVl2hHAI7olVdeOS7jUOgBIE4l+VO0I1gtFCzVjgBYS3PbylhEoQeAOEXhBAA7cHILAAAA4GFcoQeAOMXBR2Zx6BFgTjjMlJvKKPQAEKconABgBwo9AAAAPIU1sW7MoQcAAAA8jEIPAAAAeBhTboAopaanaUewWklBoXYEAECMclgU66JW6H0JfDhgkhMOa0ewHoUTAADEArVCT+EEAABANMKsinXhMjkAAADgYcyhBwAAgKcwh95NrdCzoNAs5ncDAADEB7VCT+EEAADHIiEpUTsCEBOYcgMAcYrdxsxi8wfzwqFy7QhQwpQbNwo9AMQpCicA2IFCDwAAAE/hAr0bhR5ATGI6iHlcoQcAO1DoAcQkyiYAAJGh0AMAAMBTWBTrxmfaAAAAgIdxhR4AAACe4jhcoa+MQg8AADwpyZ+iHQGICRR6AADgSaFgqXYEICZQ6AEAAOApYRbFurAoFgAAAPAwtSv0Tdtlaw0dF4oLirUjWK9hkwbaEazW6mSeX9M2rtujHcFqRfm8D5tWmFegHQFKWBTrplboi/KLtIaOC6UlQe0I1svbk68dwWrbUpO1I1gvf+8B7QhWKytlfrdppSUl2hGAmKBW6HN37NYaGqgVRbkUepN2/7hNOwIAIEZxsJQbc+gBAAAAD6PQAwAAAB7GtpUAEKcSkhK1I1gtHCrXjgBYiyk3bhR6AIhTFE4AsAOFHgAAAJ4SZttKFwq9pfxpAe0I1gsWssc0AADQR6G3FGUTAAAgPlDoAQAA4CksinWj0AOISWkNMrQjWK9wX552BABALaDQA4hJoWCpdgQAQIxyWBTrolboR/6pr9bQcWHd+iLtCNa7oCc/D5vUNeEz7QjW+29ZL+0IVlu5hsJh2rYtB7QjADFBrZHMfHKx1tBArVj2rnYCuwXqpWtHsF5x/lLtCABiXmxegA0zh96FS4wAYhKnmAIAEBkKPYCYxIJNAAAiQ6EHAACAp7BtpRuFHohSnfr1tCNYrSg3XzsCAACeoFbofQkJWkPHBScc1o5gveL8Au0IVmMOvXlc4YLX8b0ufrFtpZtaoecfIbyO17BZDk8vPM6fFtCOYL1gYbF2BCAmMOUGiFKSP0U7gtU4WApeR9kEcLxQ6IEoUTgBANDBp+RuFHoAMYl1NubxDREA7EChBxCTKJsAgOpwUqwbl8AAAAAAD+MKPQAAADyFbSvdKPQAYlJagwztCNYr3JenHQEAUAso9ABiEgd3AQAQGQo9gJgUqJeuHcF6XKEH4FWcdO1GoQcQkyib5rE1qFns1ATgeFEr9JyyaRaHHgE4GgonAK/iCr2bWqGncAKAroSkRO0IVguHyrUjAIgTTLkBgDhF4QQAO6gV+lvu7q01dFz4+ns+SjdtcPd87QhWa/PWfdoRrPflhX/VjmC1b35M1Y5gve07+LQ/XoUdek5laoX+sfuXaA0N1IoP/q2dwHaXaQew3+LPtBMAiHXX9dVOgAgw5QZATKpTv552BOsV5fIpEwBvYlGsG3uWAQAAAB7GFXoAMYmrxwCA6nCF3o1CDyAmceiReexDD6/jTBvgILVCn9YgQ2vouMA+/+bVbVBfO4LV6jWsqx3Benl7+BTEpOKCIu0I1ivjex0gIoqFnmPd4XXBwmLtCFbb8/N27QgAgBjlOEy5qYzPtAEAAAAPYw49gJiUHOBQHtPKiku0IwBAVMKsAXJRK/Tj7jxXa+i4sPFnPooyrcsp5doRrNZnzRPaEay3pMPN2hGs9vlarpmZtuWnA9oRgJig9m7z1EOfaA0N1Ir/aAew3tnaAeLAMu0AAGLdrZwU6wVcPgCilJicrB3BauVlZdoRAAAxin3o3Sj0QJQonGYlJCVqR7BeOMS0MQCwAYUeQEyibAIAquM4LIqtjEIPICb50wLaEazHWQoAYAcKPYCYRNkEAFSHOfRuHCwFAAAAeBhX6AHEpNT0NO0I1ispKNSOAACoBRR6ADGJsgkAqA5TbtzUCn1G44ZaQ8eFwlxOzzMt/YQM7QhWq3tCunYE6+3+eZd2BKulBPzaEaxXlF+gHQGICWqFPm/nXq2hgVqRu2O3dgSrFR/gG7VpLDw2i0+ZAHPCbFvpwpQbADGJsgmvS/KnaEewXihYqh0BiAkUegAADKBsAjheKPQAABjAFXrz+KEpfrEo1o1CDyAm+RI4JsM0J8wcVJMomwCOFwo9ECUKp1m+BJ92hDjAa9gkfmAyj09B4hf/vtzUCn2d+vW0ho4LLCg0LymFn4dN8tcJaEewXrCI9wmTykPl2hGsx7QL4CC1RlKUm681NFArysvKtCNYjR9KAQDV4Yc5Ny4xAkCcYtqYWUwJAHC8UOgBxCTKpnkUTgCwA4UeQExKTObtyTR2YQHgVQ4nxbrwHRNATKJsAgAQGQo9AAAAPCXMolgXCj2AmMT+0ubxKQgA2IFCDyAmUTYBAIgMhR4AAACewi5dbuwLBwAAAHgYV+gBAADgKZwU60ahBxCTEpIStSNYLxwq144AAKgFFHoAMYmyCQBAZCj0AAAA8BROinWj0AMAYABnKZjH9rbAQRR6AAAMoGwC5rAo1o1tKwEAAAAP4wo9AAAAPIWDpdwo9AAQp1LT07QjWK2koFA7AoA4QaEHEJPSGmRoR7Be4b487QgAgFrgcxyHVQVHEQwGJScnRyZOnCh+v187jnV4fs3jOTaP59gsnl/zeI7N4vmFSRT6COTn50tGRobk5eVJvXr1tONYh+fXPJ5j83iOzeL5NY/n2CyeX5jELjcAAACAh1HoAQAAAA+j0AMAAAAeRqGPgN/vl0mTJrGIxRCeX/N4js3jOTaL59c8nmOzeH5hEotiAQAAAA/jCj0AAADgYRR6AAAAwMMo9AAAAICHUegBAAAAD6PQH8XUqVPlpJNOktTUVOnRo4d89tln2pGs8vHHH8vgwYOladOm4vP5ZO7cudqRrJKTkyPdunWTunXrSqNGjWTIkCGybt067VjWmDZtmnTq1Enq1asn9erVk3POOUfee+897VjW+utf/yo+n09uvvlm7SjWuPfee8Xn87l+tW/fXjuWdbZu3SpXXXWVNGzYUAKBgHTs2FFWrFihHQsWodAfwb///W+ZMGGCTJo0Sb744gs544wzZODAgbJr1y7taNYoLCyUM844Q6ZOnaodxUqLFy+WMWPGyLJly+SDDz6QsrIyueCCC6SwsFA7mhWaN28uf/3rX2XlypWyYsUKOf/88+XXv/61rF69WjuadT7//HN57rnnpFOnTtpRrNOhQwfZvn17xa8lS5ZoR7LK/v37pVevXpKcnCzvvfeerFmzRh577DE54YQTtKPBImxbeQQ9evSQbt26yTPPPCMiIuFwWFq0aCE33XST3HHHHcrp7OPz+WTOnDkyZMgQ7SjW2r17tzRq1EgWL14sffr00Y5jpQYNGsijjz4q1113nXYUaxQUFMhZZ50lf//73+WBBx6Qzp07y5QpU7RjWeHee++VuXPnyqpVq7SjWOuOO+6QpUuXyieffKIdBRbjCn01SktLZeXKlTJgwICK2xISEmTAgAHy6aefKiYDopeXlyciB0snald5ebm88sorUlhYKOecc452HKuMGTNGLr74Ytf7MWrP+vXrpWnTptK6dWu58sor5aefftKOZJW33npLunbtKr/97W+lUaNGcuaZZ8o//vEP7ViwDIW+Gnv27JHy8nJp3Lix6/bGjRvLjh07lFIB0QuHw3LzzTdLr1695PTTT9eOY41vvvlG0tPTxe/3yx//+EeZM2eOnHbaadqxrPHKK6/IF198ITk5OdpRrNSjRw+ZMWOGzJs3T6ZNmyabNm2Sc889Vw4cOKAdzRo//PCDTJs2Tdq2bSvz58+XG2+8UcaNGyczZ87UjgaLJGkHAHB8jBkzRr799lvmx9ayU045RVatWiV5eXkye/ZsGTlypCxevJhSXwt+/vln+dOf/iQffPCBpKamasex0qBBgyr+u1OnTtKjRw/Jzs6WV199lWljtSQcDkvXrl3loYceEhGRM888U7799lt59tlnZeTIkcrpYAuu0FfjxBNPlMTERNm5c6fr9p07d0pWVpZSKiA6Y8eOlXfeeUc++ugjad68uXYcq6SkpMjJJ58sXbp0kZycHDnjjDPkySef1I5lhZUrV8quXbvkrLPOkqSkJElKSpLFixfLU089JUlJSVJeXq4d0Tr169eXdu3ayYYNG7SjWKNJkyaH/YB/6qmnMrUJtYpCX42UlBTp0qWLfPjhhxW3hcNh+fDDD5kfC89wHEfGjh0rc+bMkYULF0qrVq20I1kvHA5LMBjUjmGF/v37yzfffCOrVq2q+NW1a1e58sorZdWqVZKYmKgd0ToFBQWyceNGadKkiXYUa/Tq1euw7YK///57yc7OVkoEGzHl5ggmTJggI0eOlK5du0r37t1lypQpUlhYKNdcc412NGsUFBS4rgRt2rRJVq1aJQ0aNJCWLVsqJrPDmDFj5OWXX5Y333xT6tatW7H+IyMjQwKBgHI675s4caIMGjRIWrZsKQcOHJCXX35ZFi1aJPPnz9eOZoW6desett4jLS1NGjZsyDqQWnLrrbfK4MGDJTs7W7Zt2yaTJk2SxMREueKKK7SjWWP8+PHSs2dPeeihh2T48OHy2WefyfTp02X69Ona0WARCv0RXH755bJ792655557ZMeOHdK5c2eZN2/eYQtlEb0VK1bIeeedV/H7CRMmiIjIyJEjZcaMGUqp7DFt2jQREenXr5/r9ueff15GjRp1/ANZZteuXXL11VfL9u3bJSMjQzp16iTz58+XX/3qV9rRgIhs2bJFrrjiCtm7d69kZmZK7969ZdmyZZKZmakdzRrdunWTOXPmyMSJE+W+++6TVq1ayZQpU+TKK6/UjgaLsA89AAAA4GHMoQcAAAA8jEIPAAAAeBiFHgAAAPAwCj0AAADgYRR6AAAAwMMo9AAAAICHUegBAAAAD6PQAwAAAB5GoQeAGpoxY4bUr1//mB/H5/PJ3Llzj/lxAADxjUIPIC6NGjVKhgwZoh0DAIBjRqEHAAAAPIxCDwC/8Pjjj0vHjh0lLS1NWrRoIf/n//wfKSgoOOx+c+fOlbZt20pqaqoMHDhQfv75Z9efv/nmm3LWWWdJamqqtG7dWiZPniyhUKjKMUtLS2Xs2LHSpEkTSU1NlezsbMnJyTHy9wMA2IVCDwC/kJCQIE899ZSsXr1aZs6cKQsXLpTbbrvNdZ+ioiJ58MEH5YUXXpClS5dKbm6ujBgxouLPP/nkE7n66qvlT3/6k6xZs0aee+45mTFjhjz44INVjvnUU0/JW2+9Ja+++qqsW7dOZs2aJSeddJLJvyYAwBI+x3Ec7RAAcLyNGjVKcnNzI1qUOnv2bPnjH/8oe/bsEZGDi2KvueYaWbZsmfTo0UNERNauXSunnnqqLF++XLp37y4DBgyQ/v37y8SJEyse56WXXpLbbrtNtm3bJiIHF8XOmTNHhgwZIuPGjZPVq1fLggULxOfz1f5fGABgLa7QA8AvLFiwQPr37y/NmjWTunXryu9//3vZu3evFBUVVdwnKSlJunXrVvH79u3bS/369eW7774TEZGvvvpK7rvvPklPT6/4dcMNN8j27dtdj3PIqFGjZNWqVXLKKafIuHHj5P333zf/FwUAWIFCDwCVbN68WS655BLp1KmTvP7667Jy5UqZOnWqiByc5x6pgoICmTx5sqxatari1zfffCPr16+X1NTUw+5/1llnyaZNm+T++++X4uJiGT58uAwbNqzW/l4AAHslaQcAgFiycuVKCYfD8thjj0lCwsFrHq+++uph9wuFQrJixQrp3r27iIisW7dOcnNz5dRTTxWRgwV93bp1cvLJJ0c8dr169eTyyy+Xyy+/XIYNGyYXXnih7Nu3Txo0aFALfzMAgK0o9ADiVl5enqxatcp124knnihlZWXy9NNPy+DBg2Xp0qXy7LPPHva1ycnJctNNN8lTTz0lSUlJMnbsWDn77LMrCv4999wjl1xyibRs2VKGDRsmCQkJ8tVXX8m3334rDzzwwGGP9/jjj0uTJk3kzDPPlISEBHnttdckKyurVg6wAgDYjSk3AOLWokWL5Mwzz3T9evHFF+Xxxx+Xhx9+WE4//XSZNWtWldtH1qlTR26//Xb53e9+J7169ZL09HT597//XfHnAwcOlHfeeUfef/996datm5x99tnyxBNPSHZ2dpVZ6tatK4888oh07dpVunXrJps3b5Z333234lMCAACqwy43AAAAgIdx6QcAAADwMAo9AAAA4GEUegAAAMDDKPQAAACAh1HoAQAAAA+j0AMAAAAeRqEHAAAAPIxCDwAAAHgYhR4AAADwMAo9AAAA4GEUegAAAMDD/j/w9Y+jzI+5TwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_nodes = len(labels)\n",
    "num_labels = len(set(labels))\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((num_nodes, num_labels))\n",
    "\n",
    "# Fill in the one-hot encoded values\n",
    "for node_idx, label_idx in enumerate(labels):\n",
    "    Y[node_idx, label_idx] = 1\n",
    "Phi = C_t_0@Y \n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 8))\n",
    "sns.heatmap(Y, cmap=\"coolwarm\", cbar=True, xticklabels=True, yticklabels=False)\n",
    "plt.xlabel(\"Labels\")\n",
    "plt.ylabel(\"Nodes\")\n",
    "plt.title(\"Heatmap for original labels\")\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 8))\n",
    "sns.heatmap(Phi, cmap=\"coolwarm\", cbar=True, xticklabels=True, yticklabels=False)\n",
    "plt.xlabel(\"Labels\")\n",
    "plt.ylabel(\"Nodes\")\n",
    "plt.title(\"Heatmap for labels after coarsening\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "dce60711",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgsAAAGkCAYAAAC//WZoAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABlC0lEQVR4nO3deVxU9foH8M8Mw6YCyg4pbhiguaVGqKUmiuuV8mqaGilp9UNNLVNyzxLLJbVruNRVu2amFqaWGG6oaYaoKZn7VsqSKbusM78/yMmJAWbgDGfmO5/3fZ3XK2fOfM8zF5jzzHd7FBqNRgMiIiKiCijlDoCIiIjMG5MFIiIiqhSTBSIiIqoUkwUiIiKqFJMFIiIiqhSTBSIiIqoUkwUiIiKqFJMFIiIiqhSTBSIiIqoUkwUiIiKqlKzJwsqVK9GkSRM4ODggODgYP/30k5zhEBERkR6yJQtffvklpkyZgjlz5uDkyZNo27YtwsLCkJGRIVdIREREpIdCrkJSwcHB6NSpE/7zn/8AANRqNRo1aoQJEyZg+vTpcoREREREesjSs1BUVITk5GSEhob+HYhSidDQUBw7dkyOkIiIiKgCsiQLd+7cQWlpKby8vHQe9/LyQlpamhwhERERUQVUcgdgiMLCQhQWFuo8Zm9vD3t7e5kiIiIish6yJAvu7u6wsbFBenq6zuPp6enw9vYud35MTAzmzZun85hCWQ9KG2eTxklEBAB17RzkDsGk8ooK5A7B5EqKbpn8GsV3rkrSjq17M0nakZKsExyfeOIJfPTRRwDKJjj6+flh/Pjx5SY46utZaOAWCIVCUWvxEpH1slGKvSVNqVotdwgmVyvJQsYlSdqx9WwhSTtSkm0YYsqUKYiIiEDHjh3xxBNPYNmyZcjLy8Po0aPLnatvyIGJAhHVFmu4mRJVRrZk4fnnn8cff/yB2bNnIy0tDe3atUN8fHy5SY9ERHIT/auJLN3LItKIm1TKNgxRUyq7R+QOgYiILEStDEOk/ipJO7Y+QZK0IyWLWA1BRERk7jQC9yyIPWuHiIiIaow9C0QmJPoseoCT/4i0BP5bsNhkoZmLj9whmFyxuljuEEyuRR2xf46P2rjIHYLJnShKr/okC5dVki93CCZ1pzBL7hDEIPAwhOTJQmxsLGJjY3H9+nUAQKtWrTB79mz07dsXd+/exZw5c/D999/j5s2b8PDwQHh4OObPnw8XF+M+VG/kiP8BZQ3f2H7LuSN3CCa1X+4AiIgkIHmy0LBhQyxcuBAtWrSARqPBhg0bMGjQIJw6dQoajQa3b9/G4sWL0bJlS9y4cQOvvvoqbt++jW3bthl1HWu4kRIR1QZrGC6rFepSuSMwmVpZOunq6opFixYhMjKy3HNbt27FyJEjkZeXB5XK8NyFSyeJiMhQtbF0suj6CUnasWvSUZJ2pGTSOQulpaXYunUr8vLyEBISovecrKwsODs7G5UoEBERUe0xyR367NmzCAkJQUFBAerVq4e4uDi0bNmy3Hl37tzB/PnzMW7cuErb01cbQqPRcMtnIiIyHwIPj5tkGKKoqAg3b95EVlYWtm3bhk8++QSJiYk6CUN2djZ69eoFV1dX7NixA7a2thW2N3fuXFadFJStjdg9SsWlJXKHQESonWGIwis/StKOffMnJWlHSrUyZyE0NBTNmzfH6tWrAQA5OTkICwtDnTp1sGvXLjg4VF7+lVUniUhOok8AtIYJ40wWaqZWvtap1WrtzT47OxthYWGwt7fHjh07qkwUAFadJCJ5WcPNlCQg8O+J5OlydHQ0Dh06hOvXr+Ps2bOIjo7GwYMHMWLECGRnZ6N3797Iy8vDp59+iuzsbKSlpSEtLQ2lpeIuOSEiIiugUUtzGCEmJgadOnWCk5MTPD09ER4ejgsXLuic0717dygUCp3j1VdfNeo6kvcsZGRk4MUXX0RqaipcXFzQpk0b7NmzB7169cLBgwdx/PhxAIC/v7/O665du4YmTZpIHQ4REVHtkGGfhcTERERFRaFTp04oKSnB22+/jd69e+PcuXOoW7eu9ryxY8finXfe0f67Tp06Rl2HJaqJiEh4tTJn4XyiJO3YB3ar9mv/+OMPeHp6IjExEU8//TSAsp6Fdu3aYdmyZdVuV+yp6ERkciqljdwhmFyJwDvzkYQkqg2hb1K/vrl7+mRlldX5cHV11Xn8888/x8aNG+Ht7Y2BAwdi1qxZRvUuWGyyMMSnk9whmNy5wgy5QzC5JnauVZ9kwV4oFr+Q1Nd2eXKHYHK/l2TLHYJJiV4oq9ZINMExJiam3HYBc+bMwdy5c6u4vBqTJk1Cly5d8Nhjj2kff+GFF9C4cWP4+vrizJkzmDZtGi5cuICvv/7a4Jg4DEFERMKrlWGIX/ZJ05B/12r1LLz22mvYvXs3jhw5goYNG1Z43v79+9GzZ09cvnwZzZs3NygkkywevnXrFkaOHAk3Nzc4OjqidevWOHFC/57Zr776KhQKRY3GUshyOajshD6IyIpItBrC3t4ezs7OOkdVicL48eOxa9cuHDhwoNJEAQCCg4MBAJcvXzb4rUk+DHHv3j106dIFPXr0wO7du+Hh4YFLly6hQYMG5c6Ni4vDjz/+CF9fX6OvYw27LFhkl4+RCkqK5A6BiEgaMuyzoNFoMGHCBMTFxeHgwYNo2rRpla85ffo0AMDHx8fg60ieLLz//vto1KgR1q1bp31MX/C3bt3ChAkTsGfPHvTv39/o61jDjZSIiKgyUVFR2LRpE7755hs4OTkhLS0NAODi4gJHR0dcuXIFmzZtQr9+/eDm5oYzZ85g8uTJePrpp9GmTRuDryP5MMSOHTvQsWNHDBkyBJ6enmjfvj3Wrl2rc45arcaoUaMwdepUtGrVSuoQiIiIap1GUyrJYYzY2FhkZWWhe/fu8PHx0R5ffvklAMDOzg579+5F7969ERgYiDfeeAODBw/Gzp07jbqO5D0LV69eRWxsLKZMmYK3334bSUlJmDhxIuzs7BAREQGgrPdBpVJh4sSJUl9eKKLvRw+Iv40uh8uIrIhESyeNumQVaxQaNWqExMSa7/8gebKgVqvRsWNHLFiwAADQvn17pKSkYNWqVYiIiEBycjKWL1+OkydPGlzfwVpLVNvbVFyJUxT56sKqT7JgvJESkQgkTxZ8fHx0SlEDQFBQEL766isAwOHDh5GRkQE/Pz/t86WlpXjjjTewbNkyXL9+vVyb+tacWkOJ6vxisW+kRERCEbinVPJkoUuXLuWKWFy8eBGNGzcGAIwaNQqhoaE6z4eFhWHUqFEYPXq03jajo6MxZcoUnccauAXyWxuZPe5uSGRFZBiGqC2SJwuTJ09G586dsWDBAgwdOhQ//fQT1qxZgzVr1gAA3Nzc4ObmpvMaW1tbeHt7IyAgQG+bLFFNloo3UiIrIvDfu+Qz6Dp16oS4uDh88cUXeOyxxzB//nwsW7YMI0aMkPpSREREVAssdrtne4dGcodgcmqBx78eUAq+4oPDEGKw0I9Jg4n+/gCguBa2ey74aask7Tg8MUSSdqRksYWkRF9yZy1E/zmK/v6I6CEC/72L/bWOiIiIasxiexaIiIjMCldDEBERUaUEHoYwSbKQk5ODWbNmIS4uDhkZGWjfvj2WL1+OTp06ac/59ddfMW3aNCQmJqKkpAQtW7bEV199pbNZU2U6urcwRehm5Y+ibLlDMDlv+/pyh2BSI5TGV1S1NFs0aXKHYHJpRVlyh2BS+SUFcodAZs4kycLLL7+MlJQU/O9//4Ovry82btyI0NBQnDt3Do888giuXLmCrl27IjIyEvPmzYOzszN++eUXODg4GHyNE3cumSJ0qmU3kC53CCZ1HBeqPomIxCBwz4LkSyfv378PJycnfPPNNzqlpzt06IC+ffvi3XffxbBhw2Bra4v//e9/1b6Oyu4RKcIlIrJ61lC0rrDgN5Nf4/6h9ZK04/j0S5K0IyXJexZKSkpQWlparpfA0dERR44cgVqtxrfffou33noLYWFhOHXqFJo2bYro6GiEh4dLHQ4RUY2Jvl+GNeyVQTUjebLg5OSEkJAQzJ8/H0FBQfDy8sIXX3yBY8eOwd/fHxkZGcjNzcXChQvx7rvv4v3330d8fDyee+45HDhwAN26dTPoOtaQCXONPpF54M2UDCLwZ7ZJ5iz873//w5gxY/DII4/AxsYGjz/+OIYPH47k5GTtroSDBg3C5MmTAQDt2rXD0aNHsWrVKr3Jgr4S1SWlpawPQUQkAdF7TmoNl04ap3nz5khMTEReXh6ys7Ph4+OD559/Hs2aNYO7uztUKpXeMtZHjhzR215FJaoVgpeoJiKqDew5kQh7Fqqnbt26qFu3Lu7du4c9e/bggw8+gJ2dHTp16lRpGet/qqhEtejq2hm+OsRS5RVxyRYRkbkzSbKwZ88eaDQaBAQE4PLly5g6dSoCAwMxevRoAMDUqVPx/PPP4+mnn0aPHj0QHx+PnTt34uDBg3rbs9YS1byREhFZEA5DGCcrKwvR0dH4/fff4erqisGDB+O9996Dra0tAODZZ5/FqlWrEBMTg4kTJyIgIABfffUVunbtaopwiGRTx9a+6pMsXH5xYdUnEVkDgYchLLZENfdZICIiQ5XUQonq+99/LEk7jr3/T5J2pMTaEERERFLgMIT5EX/GgnXMy7DQji2D8WcoBvHfIUlC4GEIi00WVDYWG7rBiktL5A6BasgabqREJD6jt0E8dOgQBg4cCF9fXygUCmzfvl37XHFxMaZNm4bWrVujbt268PX1xYsvvojbt2/rtHHx4kUMGjQI7u7ucHZ2RteuXXHgwAGj4iguLRH+IMunUtoIfxDRX9RqaQ4zZPTX87y8PLRt2xZjxozBc889p/Ncfn4+Tp48iVmzZqFt27a4d+8eXn/9dfzrX//CiRMntOcNGDAALVq0wP79++Ho6Ihly5ZhwIABuHLlCry9vWv+rshi2AreQ8Skj8iKCDxnoUarIRQKBeLi4iotAJWUlIQnnngCN27cgJ+fH+7cuQMPDw8cOnQITz31FAAgJycHzs7OSEhIQGhoqEHX5moIsgRKK5izoOZQC1mAWlkNsWupJO04DphS9Um1zORf67KysqBQKFC/fn0AgJubGwICAvDZZ5/h8ccfh729PVavXg1PT0906NDB1OEQ1SreSImsiJkOIUjBpMlCQUEBpk2bhuHDh8PZuayOg0KhwN69exEeHg4nJycolUp4enoiPj4eDRo0MGU4REREpiPwMITJkoXi4mIMHToUGo0GsbGx2sc1Gg2ioqLg6emJw4cPw9HREZ988gkGDhyIpKQk+Pj4lGtLX9VJjUZjFcvSiEh+Nkqj54JblFKBvxHXKoH/fzRJsvAgUbhx4wb279+v7VUAgP3792PXrl24d++e9vGPP/4YCQkJ2LBhA6ZPn16uPVadJDJfDio7uUMwuYKSIrlDIJKV5MnCg0Th0qVLOHDgANzc3HSez8/PBwAo/5GpK5VKqCvIyqy16iSRJeCNlOgvHIb4W25uLi5fvqz997Vr13D69Gm4urrCx8cH//73v3Hy5Ens2rULpaWlSEtLAwC4urrCzs4OISEhaNCgASIiIjB79mw4Ojpi7dq1uHbtGvr376/3mtZaddIaiP5T5PRGIisi8DCE0UsnDx48iB49epR7PCIiAnPnzkXTpk31vu7AgQPo3r07AODEiROYMWMGTpw4geLiYrRq1QqzZ89G3759DY6DSyfJEljDpkUl6lK5QyCqUq0sndz2riTtOP57piTtSIlVJ80Yx4KJiKRRK8nClnckacdx6GxJ2pGS2NvnWTjeSImILIhlfvc2CJMFIqoR0ZcVAlxaSMRkgYhqhDdSor8I/LfAZIFkJfoEQE7+I7IiTBb+dujQISxatAjJyclITU3VW0jq119/xbRp05CYmIiSkhK0bNkSX331Ffz8/ACUbQP9xhtvYPPmzSgsLERYWBg+/vhjeHl5GRxHA8d6xoZucQpLiuUOweSc7BzlDsGkHnF0lzsEk/st/w+5QzA5tcDr5wGgoFT8zxqqGUlLVAPAlStX0LVrV0RGRmLevHlwdnbGL7/8AgcHB+05kydPxrfffoutW7fCxcUF48ePx3PPPYcffvjB4DhyCu8bG7rFEf0DCgCKBC/hXGoFP8Oswny5QzA50f8WLXRRnPkR+PdE8hLVw4YNg62tLf73v//pfU1WVhY8PDywadMm/Pvf/wYAnD9/HkFBQTh27BiefPJJg65tDUsnyfJx+SuReaiVpZOfRUvSjuOLMZK0IyVJ5yyo1Wp8++23eOuttxAWFoZTp06hadOmiI6O1iYUycnJKC4uRmhoqPZ1gYGB8PPzMypZ4AxssgS8kRJZEYF7aCS942ZkZCA3NxcLFy5Enz598P333+PZZ5/Fc889h8TERABAWloa7OzsUL9+fZ3Xenl5abeGNkSpWi38QUREZA4k71kAgEGDBmHy5MkAgHbt2uHo0aNYtWoVunXrVq129ZWoVilthK8PUSz4eD4RkVAE/pInabLg7u4OlUqFli1b6jweFBSEI0eOAAC8vb1RVFSEzMxMnd6F9PR0eHt76223ohLVSpaoJiKqMaXgX7xqjcDJgqTDEHZ2dujUqRMuXLig8/jFixfRuHFjAECHDh1ga2uLffv2aZ+/cOECbt68iZCQEL3tRkdHIysrS+dQKJ2kDJ2IyGqpNRrhD6oZSUtU+/n5YerUqXj++efx9NNPo0ePHoiPj8fOnTtx8OBBAICLiwsiIyMxZcoUuLq6wtnZGRMmTEBISEiFkxtZopqIiMyewEsnjU4WTpw4oVOiesqUKQDKSlSvX78ezz77LFatWoWYmBhMnDgRAQEB+Oqrr9C1a1ftaz788EMolUoMHjxYZ1MmIiIiS6VRi9uDYbElqv1cW8sdgsndLxV/2Z2jjdj7EDR29JQ7BJO7VXhX7hBM7n5JYdUnWbC84gK5QzC57LyrJr9G/prJkrRTZ9yHkrQjJYutDXE7V/wPKGtwT+4ATIy/p0RWROAJjhabLPT0aiN3CCZ3tzRP7hBMzt/WVe4QTOrlAvuqT7Jw6x3ErytwuzRX7hBM6mbhn3KHIAbOWTA/+9LPyB0CSeAUrsgdgkltlTuAWsAtrYnEZ/TSyUOHDmHgwIHw9fWFQqHA9u3bdZ5PT0/HSy+9BF9fX9SpUwd9+vTBpUuXtM/fvXsXEyZMQEBAABwdHeHn54eJEyciKyurxm+GLI+NUin0YQ0KSoqEP4gMotZIc5ghSatOajQahIeHw9bWFt988w2cnZ2xdOlShIaG4ty5c6hbty5u376N27dvY/HixWjZsiVu3LiBV199Fbdv38a2bdske2NkGbitNREJQ+DPM0mrTl68eBEBAQFISUlBq1atAJRtAe3t7Y0FCxbg5Zdf1tvO1q1bMXLkSOTl5UGlMix/YdVJsgR17RyqPsnC5RWJP5OeLF9tVJ3MX/6qJO3UeX2VJO1ISdI5Cw/qNzg4/P0BqVQqYW9vjyNHjlSYLGRlZcHZ2dngRIHIUpSoS+UOgYioxiS9Oz8oNR0dHY3Vq1ejbt26+PDDD/H7778jNTVV72vu3LmD+fPnY9y4cVKGQmQWCkvEXylARH+xzG2LDCLpDCxbW1t8/fXXuHjxIlxdXVGnTh0cOHAAffv2hVLPZK/s7Gz0798fLVu2xNy5cytst7CwENnZ2TqHhe4lRUREolKrpTmMEBMTg06dOsHJyQmenp4IDw8vV5+poKAAUVFRcHNzQ7169TB48GCkp6cbdR3Jp2t36NABp0+fRmZmJlJTUxEfH48///wTzZo10zkvJycHffr0gZOTE+Li4mBra1thmzExMXBxcdE5NOocqUM3O3LP5OdqASIi85aYmIioqCj8+OOPSEhIQHFxMXr37o28vL/36Zk8eTJ27tyJrVu3IjExEbdv3y63QKEqkk5w1OfSpUsIDAzE7t270bt3bwBlPQphYWGwt7fHd999hzp16lR6ncLCQu18iAcauAWymBSZPe5BQGQeamWC42L98/KMVefNT6r92j/++AOenp5ITEzE008/jaysLHh4eGDTpk3497//DQA4f/48goKCcOzYsQoLOP6T5FUnt27dCg8PD/j5+eHs2bN4/fXXER4erpMo9O7dG/n5+di4caN2WAEAPDw8YGNjU+6arDpJloo3UiIrYgY7OD7Ys8jVtWx33OTkZBQXFyM0NFR7zoP5hSZNFqqqOpmamoopU6YgPT0dPj4+ePHFFzFr1izt+SdPnsTx48cBAP7+/jptX7t2DU2aNDE2JCIiImHo603X96X5n9RqNSZNmoQuXbrgscceAwCkpaXBzs4O9evX1znXy8sLaWlpBsdkdLLQvXv3SicXTpw4ERMnTqz26w2ltIKeBWuYxCl6D5E1DEMUloq/4kMt8GY7JCGJdl+MiYnBvHnzdB6bM2dOpQsBACAqKgopKSk4cuSIJHE8zGI3NlBbwY3UGtgoxJ7kmF8sdmljIvqbRqKkMjo6Wttr/0BVvQrjx4/Hrl27cOjQITRs2FD7uLe3N4qKipCZmanTu5Ceng5vb2+DY7LYZIHEYGcj9q8gN2UiImMZMuTwgEajwYQJExAXF4eDBw+iadOmOs936NABtra22LdvHwYPHgwAuHDhAm7evImQkBCDYxL7k5rMnujfvMUeZCmjEjzhA4Di0hK5QyBLIEMRqKioKGzatAnffPMNnJyctPMQXFxc4OjoCBcXF0RGRmLKlClwdXWFs7MzJkyYgJCQEIMnNwJMFsyaSll+ZYhoRP/mbQ2DZbyREv1FhtUQsbGxAMrmAz5s3bp1eOmllwAAH374IZRKJQYPHozCwkKEhYXh448/Nuo6Ru2zEBMTg6+//hrnz5+Ho6MjOnfujPfffx8BAQEAyspPz5kzB99//z1u3rwJDw8PhIeHY/78+XBxcSnX3p9//om2bdvi1q1buHfvXrnZmpVhISkiIjJUbeyzkPfOCEnaqTv7c0nakZJRs8uq2inq4fLTKSkpWL9+PeLj4xEZGam3vcjISLRp06bm74KIiIhMpkY7OP5zpyh9Kio/HRsbiy+//BKzZ89Gz549je5ZcHDwq27YFkP0LnoiotpSKz0Lc4dL0k7duV9I0o6UajRn4Z87RVV0zj/LT587dw7vvPMOjh8/jqtXr1br2ryREpkHW05wJCojwwTH2lLtv3J9O0X9k77y04WFhRg+fDgWLVoEPz+/aicL1oAfwmQJ+DMkEl+170ZV7RRVUfnp6OhoBAUFYeTIkQZfS9/WlxqNRvjd//ghbPnE/g0tI+53qb+J/nO0hp9hrTCD2hCmUq1koaKdoh6orPz0/v37cfbsWWzbtg3A31sau7u7Y8aMGeW2uAT0b33ZxKkZmjk3r074FuPyfcP37bZULeuIvaolWFnxEJ0oEksz5A7B5P4syZU7BJPKLSmQOwQxCDwMYdQEx3/uFNWiRYty51RVfvrKlSu4f/++9t9JSUkYM2YMjh49iubNm8PT07NcmyxRTURENVErExxnDJGknbrvbZWkHSkZ1bNQ1U5RhpSfbt5ctzfgzp07AICgoKAKV0Po2/ryOd9OxoRuke6U5ssdgskFqhrIHYJJRRSJP5S0zc6wbWkt2YmSP+QOwaTSi7LlDkEIUtWGMEdGJQtV7RRVm+Wn41JPSNYWyeew3AGY2CdyB1ALxO14JTKSwMMQRiULVY1YVKf8tFQlq8kyib7ig5NUiUgEYn9Sk9njzZSIhMGeBSIiIqoUl06SHGyURpXusEilAk8IIiIrw54FkgNvpEREZA6MShaqKlENlE1YTExM1HndK6+8glWrVuk8tn79eixduhQXL16Es7MzhgwZgpUrVxoci3sdZ2NCt0j3S4rkDsHknOwc5Q7BpNzsxP89vVOYJXcIJid6LZrcYm7KJAUNexbKPChR3alTJ5SUlODtt99G7969ce7cOdStW1d73tixY/HOO+9o//3PjZmWLl2KJUuWYNGiRQgODkZeXh6uX79uVODWcCPNKxL/D1j095iGe3KHQES1hclCmfj4eJ1/r1+/Hp6enkhOTtYpUV2nTh14e3vrbePevXuYOXMmdu7ciZ49e2ofb9OmjTGhCH+TsRZKwXfhVHNZMBEJwCQlqj///HNs3LgR3t7eGDhwIGbNmqXtXUhISIBarcatW7cQFBSEnJwcdO7cGUuWLEGjRo0MvvZmt+41Cd0iHLIXf1nhOGWe3CGYVMBPK+QOweRuPP2a3CGYXFKmu9whmNQxO/E/a2qFwPPMJC9R/cILL6Bx48bw9fXFmTNnMG3aNFy4cAFff/01AODq1atQq9VYsGABli9fDhcXF8ycORO9evXCmTNnYGdnV+5a+mpDPH/nAGtDCOBjuQMwMZuG3eQOweQ4EZcsQa2k7RyGKK+iEtXjxo3T/nfr1q3h4+ODnj174sqVK2jevDnUajWKi4uxYsUK9O7dGwDwxRdfwNvbGwcOHEBYWFi5a+mrOqlQ1oPCRvzJY2TZeCMlIhGYpET1w4KDgwEAly9fRvPmzeHj4wMAaNmypfYcDw8PuLu74+bNm3rbiI6OxpQpU3Qec/doKXzPAm80REQWhD0LZf5Zorpp06ZVvub06dMAoE0SunTpAgC4cOGCNtG4e/cu7ty5g8aNG+ttQ1/VSbVGA3DyGBHVgrp2DnKHYFKcMC4NkescKTRGvLv/+7//05aofnhvhQclqq9cuYJNmzahX79+cHNzw5kzZzB58mQ0bNhQZ++F8PBwXL58GWvWrIGzszOio6Nx9epVnD59Gra2tgbForJ7xIi3SURE1qyk6JbJr5H9Svlh9OpwXr1HknakZFSyUFG3/4MS1b/99htGjhyJlJQU5OXloVGjRnj22Wcxc+ZMODv/Pb8gOzsbkydPxtdffw2lUolu3bph+fLlRq2GYLJAlkCltJE7BJMTfcMiEkOtJAtje0vSjvPa7yVpR0pGJQvmhMkCWQJ7lWE9ZZassKRY7hCIqlQryUJkL0nacf40QZJ2pMTaEEQmxBspkfXgds9mqJmLj9whmFxWUa7cIZjcI3XE3uymkW19uUMwuetFd+UOweQK1WInfX8WZssdApk5i00Wrmalyh0CSeDP+zlyh2BSZ+QOgIhqj8A9C0pjTo6JiUGnTp3g5OQET09PhIeH48KFCzrnpKWlYdSoUfD29kbdunXx+OOP46uvvtI55+LFixg0aBDc3d3h7OyMrl274sCBAzV/N0RERHJRS3SYIaOShQdVJ3/88UckJCSguLgYvXv3Rl7e3/v7v/jii7hw4QJ27NiBs2fP4rnnnsPQoUNx6tQp7TkDBgxASUkJ9u/fj+TkZLRt2xYDBgxAWlqadO+MiIiIJFGj1RB//PEHPD09kZiYqK06Wa9ePcTGxmLUqFHa89zc3PD+++/j5Zdfxp07d+Dh4YFDhw7hqaeeAgDk5OTA2dkZCQkJCA0NNejaXA1BRESGqo3VEJkjnpGknfqf75ekHSkZ1bPwT/qqTnbu3Blffvkl7t69C7Vajc2bN6OgoADdu3cHUJY4BAQE4LPPPkNeXh5KSkqwevVqeHp6okOHDjUJh4iISD5qjTSHGZK86uSWLVvw/PPPw83NDSqVCnXq1EFcXBz8/f0BlG3stHfvXoSHh8PJyQlKpRKenp6Ij49HgwYNav6OiIiISFKSV52cNWsWMjMzsXfvXri7u2P79u0YOnQoDh8+jNatW0Oj0SAqKgqenp44fPgwHB0d8cknn2DgwIFISkrS1pB4mL4S1RqNRvhCUkREZEHMdHKiFKo1Z2H8+PH45ptvcOjQIZ1iUleuXIG/vz9SUlLQqlUr7eOhoaHw9/fHqlWrsG/fPvTu3Rv37t3T2QK6RYsWiIyMxPTp08tdb+7cuXpLVCtZopqIiAxQG3MW7g3pLkk7DbYelKQdKRk1Z0Gj0WD8+PGIi4vD/v37y1WdzM/PL2tUqdusjY0N1H+VW67oHKVSqT3nn6Kjo5GVlaVzKJROxoROZkqpUAh9EBGJwKhhiKioKG3VSScnJ+1SxwdVJwMDA+Hv749XXnkFixcvhpubG7Zv346EhATs2rULABASEoIGDRogIiICs2fPhqOjI9auXYtr166hf//+eq+rr0Q1hyDEoLbM0iQGs4aEQfSfIZHBOAzx18lVVJ0EgEuXLmH69Ok4cuQIcnNz4e/vjzfffFNnKeWJEycwY8YMnDhxAsXFxWjVqhVmz56Nvn37Ghy4T/2WBp9rqQpKiuQOweSc7BzlDsGkGjl6yB2Cyf1ecEfuEEwur7hA7hBMqsAKapjk5l8z+TXuPttNknZc4xIlaUdKrDpJZEIOKju5QzA5a0hqyfLVxpyFu4MkSha+Mb9kwWJrQxBZAt5IiUgETBaITEj8GQuARXZNGkmltJE7BJMqUZfKHYIQNALPWWCyQGRC1nAjtQa8mZJBBE4WarTdMxEREYnPqJ6F2NhYxMbG4vr16wCgs4rh7t27mDNnDr7//nvcvHkTHh4eCA8Px/z58+Hi4qJt4+bNm3jttddw4MAB1KtXDxEREYiJiYFKZVwnxwb3Hkadb4m+t7svdwgmN+K+rdwhmFSXCeJ33u1aKX7/yV57seee3CzNlTsEIXAY4i8NGzbEwoUL0aJFC2g0GmzYsAGDBg3CqVOnoNFocPv2bSxevBgtW7bEjRs38Oqrr+L27dvYtm0bAKC0tBT9+/eHt7c3jh49itTUVLz44ouwtbXFggULjAo84s4Bo84n8/SF4PsQqN8R/0ZKRH8ROFmo8dJJV1dXLFq0CJGRkeWe27p1K0aOHIm8vDyoVCrs3r0bAwYMwO3bt+Hl5QUAWLVqFaZNm4Y//vgDdnaGLzPj0kkiIjJUbSydvBMmzdJJ9z3mt3Sy2nMWSktLsXnzZuTl5SEkJETvOVlZWXB2dtYOMRw7dgytW7fWJgoAEBYWhuzsbPzyyy/VDYWIiEh2GrU0hzkyekD17NmzCAkJQUFBAerVq4e4uDi0bFl+N8U7d+5g/vz5GDdunPaxtLQ0nUQBgPbfD7aONpSzfR1jQ7c41jADW/QdHD3t68sdgsmlFdyTOwSTE32/jGIr+KypDeZ6o5eC0clCQEAATp8+jaysLGzbtg0RERFITEzUSRiys7PRv39/tGzZEnPnzq1xkPpKVGcV5LE+hADyiwurPsmCpedlyh0CEdUSJgsPsbOzg7+/PwCgQ4cOSEpKwvLly7F69WoAQE5ODvr06QMnJyfExcXB1vbv2e7e3t746aefdNpLT0/XPleRmJgYvSWqFSxRTUS1gJsykbWr8boutVqt/dafnZ2NsLAw2NvbY8eOHXBwcNA5NyQkBO+99x4yMjLg6ekJAEhISICzs7PeoYwHoqOjMWXKFJ3HGrgF1jR0IiKD8GZKBtGI29ttVLIQHR2Nvn37ws/PDzk5Odi0aRMOHjyIPXv2IDs7G71790Z+fj42btyI7OxsZGdnAwA8PDxgY2OD3r17o2XLlhg1ahQ++OADpKWlYebMmYiKiipXgvphLFFNlspGKf6+Z6VqgfteiYzAYYi/ZGRk4MUXX0RqaipcXFzQpk0b7NmzB7169cLBgwdx/PhxANAOUzxw7do1NGnSBDY2Nti1axdee+01hISEoG7duoiIiMA777wj3TsiMiO8kRKRCCy2RLWdfUO5QzA5C/3RGEX0HiKlQvyeBbXIX6f+Ymsj9k6chSXFcodgcrWxz0JqV2l2FvY5Yn6bDlrsX4DaCm6kok+qAsQfC9ZoxH5/gHUUy7KGmynVnMh5s8UmC9ZA9BspIH5CZA0/QyISH5MFkhVvpkQkCo3AqyGMGlCNjY1FmzZt4OzsDGdnZ4SEhGD37t3a57t37w6FQqFzvPrqq9rnf/75ZwwfPhyNGjWCo6MjgoKCsHz5cuneDVmcOrb2Qh9EZD243fNfKqs62apVKwDA2LFjdVY31Knz97bMycnJ8PT0xMaNG9GoUSMcPXoU48aNg42NDcaPHy/RWyJLIvoOjkREIjCqZ2HgwIHo168fWrRogUcffRTvvfce6tWrhx9//FF7Tp06deDt7a09nJ3/3mVxzJgxWL58Obp164ZmzZph5MiRGD16NL7++mvp3hEREZEMNGqFJIexDh06hIEDB8LX1xcKhQLbt2/Xef6ll14q1+vfp08fo65R7TkLpaWl2Lp1a7mqk59//jk2btwIb29vDBw4ELNmzdLpXfinrKwsuLq6VjcMIrPmoDK87LqlEr3IEpGh5Fqkl5eXh7Zt22LMmDF47rnn9J7Tp08frFu3TvvvyjZC1EfSqpMvvPACGjduDF9fX5w5cwbTpk3DhQsXKuw5OHr0KL788kt8++23xoZBZBF4IyWyHtXpFZBC37590bdv30rPsbe3r7QGU1UkrTr5cDnq1q1bw8fHBz179sSVK1fQvHlznXZSUlIwaNAgzJkzB7179670mvqqTmo0GuE39LEGde0cqj7JguUVFcgdAhFZGH33PH1lD4xx8OBBeHp6okGDBnjmmWfw7rvvws3NzeDX13gHx9DQUDRv3lxbdfJheXl5qFevHuLj4xEWFqZ9/Ny5c+jRowdefvllvPfee1VeY+7cuXqrTipZdZKIiAxQGzs4Xm/XS5J21od3KXfPmzNnDubOnVvlaxUKBeLi4hAeHq59bPPmzahTpw6aNm2KK1eu4O2330a9evVw7Ngx2NgYtteNpFUn/+n06dMAAB8fH+1jv/zyC5555hlEREQYlCgArDpJRETmT6o5C/rueTXpVRg2bJj2v1u3bo02bdqgefPmOHjwIHr27GlQG5JVnbxy5Qo2bdqEfv36wc3NDWfOnMHkyZPx9NNPo02bNgDKhh6eeeYZhIWFYcqUKUhLSwMA2NjYwMPDo8LrsuokERFZi5oOOVSlWbNmcHd3x+XLl02TLFRWdfK3337D3r17sWzZMuTl5aFRo0YYPHgwZs6cqX39tm3b8Mcff2Djxo3YuHGj9vHGjRvj+vXrxoRCRERkVuSa4Gis33//HX/++adOr39VLLbqpIODn9whmJw1bIVsGX9a1WcNPWAW+hFiFPHfofhqY87ClcfCqj7JAM1T9hh1fm5uLi5fvgwAaN++PZYuXYoePXrA1dUVrq6umDdvHgYPHgxvb29cuXIFb731FnJycnD27FmDezAstjaENdxIrYHoH8LWcCMlInmdOHECPXr8XR77wXyHiIgIxMbG4syZM9iwYQMyMzPh6+uL3r17Y/78+UYNdVhsz4K9QyO5QzC5UrWZbhJORGRhaqNn4XJLaXoW/M8Z17NQGyy2Z8EadsbjGn0iIsuhFrjqpMUmC7yREhER1Q6jkoXY2FjExsZqVy60atUKs2fP1m4zmZaWhqlTpyIhIQE5OTkICAjAjBkzMHjw4HJtFRYWIjg4GD///DNOnTqFdu3aGRW4jdKoGlgWSW0FwxBKwX+OKqVhG56QeSsuLZE7BJOy0NFos6Nhz0KZqkpUv/jii8jMzMSOHTvg7u6OTZs2YejQoThx4gTat2+v09Zbb70FX19f/Pzzz9UK/APPbtV6nSXZqflD7hBM7v+KDd9u1BKF/Z+4Hx4P7FgldwSmd8FW7ghMK6EkVe4QhGApSyero8YTHF1dXbFo0SJERkaiXr16iI2NxahRo7TPu7m54f3338fLL7+sfWz37t2YMmUKvvrqK7Rq1apaPQsqu0dqEjYREVmR2pjg+GuLfpK0E3TpO0nakZKkJao7d+6ML7/8Ev3790f9+vWxZcsWFBQUoHv37trXpaenY+zYsdi+fXulpavJOoZauOKDiMj8SVqiesuWLXj++efh5uYGlUqFOnXqIC4uDv7+/gDKxsVeeuklvPrqq+jYsSN3bawCb6RkCexVgvfRAygsKZY7BLIAIg9DSFqietasWcjMzMTevXvh7u6O7du3Y+jQoTh8+DBat26Njz76CDk5OYiOjjbqmixRTWS+mNQSlRF56aRkJarfeust+Pv7IyUlBa1atdJ53t/fH6tWrUJ4eDh27typc5MvLS2FjY0NRowYgQ0bNui9BktUE5GcRN/XpaCkSO4QTK425iykNBsgSTuPXd0lSTtSkqxEdX5+PoDyS+FsbGy0SwBXrFiBd999V/vc7du3ERYWhi+//BLBwcEVXkNfuc4xj42AjULsZWmXiu7IHYLJBdv7yh2CSb1QIP637uN2DnKHYHLJily5QzCpc4UZcocgBC6d/EtlJaoDAwPh7++PV155BYsXL4abmxu2b9+OhIQE7NpVliX5+ekWf6pXrx4AoHnz5mjYsGGF19VXrnN72kljQiczdQbX5A7BpNbKHQAR1RqRt6uQrEQ1AHz33XeYPn06Bg4ciNzcXPj7+2PDhg3o10+a5SQPe9ano+RtmpsrRX/KHYLJhdmLXT00qFj8FS27VWJ/6waAy8V35Q7BpFiYj6pisYWkuM8CEREZqjbmLJxu/C9J2ml3Y4ck7UjJYmtDEBERmROR5yyI30dKRERENcKeBSIiIglY5qC+YWrUs7Bw4UIoFApMmjRJ+9iaNWvQvXt3ODs7Q6FQIDMzU+9rv/32WwQHB8PR0RENGjRAeHh4TUIhIpnYKJXCH0SGUGsUkhzmqNo9C0lJSVi9ejXatGmj83h+fj769OmDPn36VLhT41dffYWxY8diwYIFeOaZZ1BSUoKUlJTqhkJktszzz15a3MHR8rGUujREnrNQrWQhNzcXI0aMwNq1a3U2WQKg7WU4ePCg3teWlJTg9ddf11aqfOBBfQlDrfDqYdT5lihRKf6StCFFdeUOwaQGfC3Njm7mLPnZr+QOweR+sBd746nDmky5QyAzV61kISoqCv3790doaGi5ZKEqJ0+exK1bt6BUKtG+fXukpaWhXbt2WLRoER577DGD25mYfsDYsMkMCX+b6XZQ7giIqJaY6xCCFIxOFjZv3oyTJ08iKSmpWhe8evUqgLJ6D0uXLkWTJk2wZMkSdO/eHRcvXoSrq6tB7bRza1at61uSjMJMuUMwuSaOnnKHYFJDlD5yh2By30H8zcN+K7ondwgmlV2cJ3cIQhB4fqNxycJvv/2G119/HQkJCXBwqF633IM6ETNmzMDgwYMBAOvWrUPDhg2xdetWvPLKK+Veo6/q5Kk7V1h1UgC3c8XeGe8ozssdAhFRjRk1zTc5ORkZGRl4/PHHoVKpoFKpkJiYiBUrVkClUqG0tOotQ318yr5pPTxHwd7eHs2aNcPNmzf1viYmJgYuLi46h0adY0zoREREJiXyagijkoWePXvi7NmzOH36tPbo2LEjRowYgdOnT8PGpuoZtR06dIC9vT0uXLigfay4uBjXr19H48aN9b4mOjoaWVlZOodC6WRM6ERERCal0SgkOcyRUcMQTk5O5SYh1q1bF25ubtrH09LSkJaWhsuXLwMAzp49CycnJ/j5+cHV1RXOzs549dVXMWfOHDRq1AiNGzfGokWLAABDhgzRe119VSc5BEFERFQ7JN/BcdWqVZg3b572308//TSAsnkJL730EgBg0aJFUKlUGDVqFO7fv4/g4GDs378fDRo0MPg6g306SRq3Ofq9JFvuEEyura273CGY1AyfO3KHYHIzUw3/u7VUv5WKvYw5t7Sw6pOoSiLvOMKqk0REJLzaqDp5yFt/77ixnk7bKkk7UmJtCJKVrY3Yv4LFpSVyh0BEVGNif1KT2RP9ZuqgspM7BJMrKCmSOwQis6C2yH56wzBZIDIh3kiJrIda4GowTBaIqEbsVbZyh2ByhSXFcodAFkDDZEG/hQsXIjo6Gq+//jqWLVum85xGo0G/fv0QHx+PuLg4nRLUSUlJmD59OpKTk6FQKPDEE0/ggw8+QNu2bQ2+dgPHejUJ3SIUCd5FDwAONmLfaDwc6ssdgsndKxJ/g7RCldjJgjV81lDNSF6i+oFly5bp3QshNzcXffr0wb/+9S98/PHHKCkpwZw5cxAWFobffvsNtraG3Tzu3Rd7KZO1yEOB3CGY1J/3xb+RElEZkZdOGrWD4wMPl6jWtzfC6dOnsWTJEvz3v/8t99z58+dx9+5dvPPOOwgICECrVq0wZ84cpKen48aNGwbHoLCCg4iILIcGCkkOcyR5ier8/Hy88MILWLlyJby9vcu9NiAgAG5ubvj000/x9ttvo7S0FJ9++imCgoLQpEkTg2MQeNIpEVGtqmtXvcKAZD0kL1E9efJkdO7cGYMGDdL7vJOTEw4ePIjw8HDMnz8fANCiRQvs2bMHKhXnW5JYlFawLbnaMvd1o4fkFYk9HFhbRB6GkLRE9Y4dO7B//36cOnWqwjbu37+PyMhIdOnSBV988QVKS0uxePFi9O/fH0lJSXB0dCz3Gn0lqjUaDetDkNkTfdMpgCsFiB4QOVkwarvn7du349lnn9WpLllaWgqFQgGlUonXXnsNK1euhFKp1HleqVTiqaeewsGDB7XDD6mpqdrzioqK0KBBA3z66acYNmxYuevOnTtXp94EACiU9aC0cTb6DRORtFTKqqvNWroSdancIVAN1cZ2z995lb9/VUe/9M2StCMlo772PChR/bDRo0cjMDAQ06ZNg7u7O1555RWd51u3bo0PP/wQAwcOBFA2p0GpVOr0Cjz4t1qtPy+Ljo7GlClTdB5r4BZoTOhEREQmZa6TE6UgeYlqfZMa/fz80LRpUwBAr169MHXqVERFRWHChAlQq9VYuHAhVCoVevToofe6LFFNZL74rZuojFrg21KtD6gGBgZi586dmDdvHkJCQqBUKtG+fXvEx8fDx8entsMhMinubkhEIrDYEtWvNRkqdwgmd7r4D7lDMLkutuV7okQS3fq23CGYXMxZX7lDMLkCoaeuASklf8odgskd/H2vya/xjfcLkrQzKG2TJO1IyWKnaq+9/YPcIZAETuCi3CGY1IpUgfsl/6LRXJY7BJOzyG9UVOtE/j2x2GSBxCDyHxdQtsSXiKyDyP1PFpssiP99jUSgsoJ9FkqtYIKj6Emf2O+OpFCt2hAPLFy4EAqFApMmTdI+lpaWhlGjRsHb2xt169bF448/jq+++krndXfv3sWIESPg7OyM+vXrIzIyErm5xhWG0vDgYQFHcWmJ8IdaoxH+kPv3yNQHSUOtUEhymCPJq06++OKLyMzMxI4dO+Du7o5NmzZh6NChOHHiBNq3bw8AGDFiBFJTU5GQkIDi4mKMHj0a48aNw6ZN5jepg6gmuGERkfUQOfGqVrLwcNXJfxaSOnr0KGJjY/HEE08AAGbOnIkPP/wQycnJaN++PX799VfEx8cjKSkJHTt2BAB89NFH6NevHxYvXgxfX/FnVpP14I1UDA4qO7lDMKmCkiK5QyAzJ3nVyc6dO+PLL79E//79Ub9+fWzZsgUFBQXo3r07AODYsWOoX7++NlEAgNDQUCiVShw/fhzPPvts9d8NEZEJ8GZKhuAEx4dUVXVyy5YteP755+Hm5gaVSoU6deogLi4O/v7+AMrmNHh6euoGoVLB1dUVaWlp1XgLRERE8uMOjn+pquokAMyaNQuZmZnYu3cv3N3dsX37dgwdOhSHDx9G69atqxUkq06Ki927RETmz6hkITk5GRkZGXj88ce1j5WWluLQoUP4z3/+gwsXLuA///kPUlJS0KpVKwBA27ZtcfjwYaxcuRKrVq2Ct7c3MjIydNotKSnB3bt39daVAICYmBhWnRRUUanYWwVbwwRHtUbkztcyNoL/HItLS+QOQQhqgRf1S1p1Mj8/HwB0SlQDgI2NjbaiZEhICDIzM5GcnIwOHToAAPbv3w+1Wo3g4GC9162o6qTIM0+thejr19UaTnAUgdipAklF5E8zSatOFhcXw9/fH6+88goWL14MNzc3bN++HQkJCdi1axcAICgoCH369MHYsWOxatUqFBcXY/z48Rg2bFiFKyFYdZKI5MRv3mTtJN1eztbWFt999x2mT5+OgQMHIjc3F/7+/tiwYQP69eunPe/zzz/H+PHj0bNnTyiVSgwePBgrVqyQMhSyEKKnfNaQ1IreOwSIPwzBJb7SEHmCo8VWnVTZPSJ3CERkJWyUNdrs1uyVqsWfd1JSdMvk11j/yEhJ2nnp1kZJ2pGS+BvXExHVkDXcTKnmLPKbt4HETpeJiIioxtizQEREJAGR5yywZ8GMOajshD+IiEShlugw1qFDhzBw4ED4+vpCoVBg+/btOs9rNBrMnj0bPj4+cHR0RGhoKC5dumTUNYzqWZg7d265zZECAgJw/vx5AMCaNWuwadMmnDx5Ejk5Obh37x7q16+vPff69euYP38+9u/fj7S0NPj6+mLkyJGYMWMG7OyMu3FYw43GGmYouzk6yR2CSdnaiN95l1dUIHcIJlcq+MZThYJvjia6vLw8tG3bFmPGjMFzzz1X7vkPPvgAK1aswIYNG9C0aVPMmjULYWFhOHfuXIW7Mf+T0Z9krVq1wt69e/9uQPV3E/n5+ejTpw/69OmD6Ojocq89f/481Go1Vq9eDX9/f6SkpGDs2LHIy8vD4sWLjYqD2+iK4c/7OXKHQEQkCblSyr59+6Jv3756n9NoNFi2bBlmzpyJQYMGAQA+++wzeHl5Yfv27Rg2bJhB1zA6WVCpVBVuyzxp0iQAwMGDB/U+/yCReKBZs2a4cOECYmNjjU4WiIiIzIlGojkL+uoh6duc0BDXrl1DWloaQkNDtY+5uLggODgYx44dMzhZMHrOwqVLl+Dr64tmzZphxIgRuHnzprFN6MjKyoKrq2uN2iDLpRD8ICIyVkxMDFxcXHSOmJiYarX1oJqzl5eXzuNeXl5GVXo2qmchODgY69evR0BAAFJTUzFv3jw89dRTSElJgZOT8WPPly9fxkcffcReBSsm8rpkIrIuUg1D6KuHVJ1eBSkZlSw8PCbSpk0bBAcHo3HjxtiyZQsiIyONuvCtW7fQp08fDBkyBGPHjq30XJaoJiIicydVslDdIQd9HkwbSE9Ph4+Pj/bx9PR0tGvXzuB2arR0sn79+nj00Udx+fJlo153+/Zt9OjRA507d8aaNWuqPF9fl4xGzYlxRERElWnatCm8vb2xb98+7WPZ2dk4fvw4QkJCDG6nRslCbm4urly5opOtVOXWrVvo3r07OnTogHXr1pUrZ61PdHQ0srKydA6FUuwld0REZFk0Eh3Gys3NxenTp3H69GkAZZMaT58+jZs3b0KhUGDSpEl49913sWPHDpw9exYvvvgifH19ER4ebvA1jBqGePPNNzFw4EA0btwYt2/fxpw5c2BjY4Phw4cDKJtIkZaWpu1pOHv2LJycnODn5wdXV1dtotC4cWMsXrwYf/zxh7btilZYACxRTZZLaQW/p0qF+Hu7WcOeJ1Rzcu3geOLECfTo0UP77wfzHSIiIrB+/Xq89dZbyMvLw7hx45CZmYmuXbsiPj7e4D0WACOrTg4bNgyHDh3Cn3/+CQ8PD3Tt2hXvvfcemjdvDkD/pk0AsG7dOrz00ktYv349Ro8erbdtY4tfsuokEREZqjaqTn7oJ03Vyck3za/qpMWWqHZw8JM7BJPjtxkiImkwWagZi92LtpNbC7lDMLn0oiy5QzC5R+wbyB2CSUVovKo+ycJtsbkrdwgmd7Xgj6pPsmDF/GIiCZE3BbfYZOHYH+flDoEkcBWpcodgUodxTu4QiKiWWGQ3vYHEn5lERERENWKxPQtEZB7EX+8h9jdGko5cqyFqg1E9C3PnzoVCodA5AgMDy52n0WjQt29fvXW1H/jzzz/RsGFDKBQKZGZmVid2IjIDUq0tN+eDyBBqiQ5zJGmJ6geWLVtW5T4IkZGRaNOmDW7dqt4MVVsb8TtFLHShilFUShu5QzApJztHuUMwubziArlDMDnRJwCqNeZ6iyJzIWmJagA4ffo0lixZghMnTlS4s2NsbCwyMzMxe/Zs7N6929gQAAClgv/xAoDaCpIF0ZeHFpUWyx2CyVlDUiv+OyQpiPx7YnSy8KBEtYODA0JCQhATEwM/v7I9D/Lz8/HCCy9g5cqVFSYU586dwzvvvIPjx4/j6tWr1Q482D2g2q+1FHdLcuUOweScbMT+5j3ItqHcIZjcD5p7codgcr8Vif0eM4vF/6ypDWqB0wVJS1RPnjwZnTt3xqBBg/S+vrCwEMOHD8eiRYvg5+dXo2SBSyfFYK+ylTsEkzpRcknuEIiIakyyEtUeHh7Yv38/Tp06VeHro6OjERQUhJEjjdvliiWqxVVYIn43PVm+unaG76FvifKKxJ93UhtEnvlRo1mCD5eoPnv2LK5cuYL69evrnDN48GA89dRTOHjwIPbv34+zZ89i27ZtAP4e63R3d8eMGTP01pUAykpU//M5hbIeFDbONQmfzICDyk7uEEyqoKRI7hBIAryZkiHEHYSoYW2I3Nxc+Pn5Ye7cuRg6dCju3Lmj83zr1q2xfPlyDBw4EE2bNsWVK1dw//597fNJSUkYM2YMjh49iubNm8PT01PvdfT1LDRwC2TPApk9a/gNFfkDksRRG7Uh5jYeIU07Nz6XpB0pSVai2sPDQ++kRj8/PzRt2hQAtNUpH3iQXAQFBZXrkXgYS1STpeKNVAyiL/EVfVUS1ZxRycLvv/+O4cOH65So/vHHH+Hh4WGq+IjIzFnDnifFpSVyh0AWQOQdHI36K9+8ebNRjVc1wtG9e3erWKNNRETi49JJIhMRfemkNaz24LduIvFZbLIg+lImwDpmYFvDzZSIrIO4/QoWnCxYw42UyBLYKMWvdF+qFnkFPUlF5N8So5KFuXPnltvvICAgAOfPn8f169e1qx7+acuWLRgyZIj23+vXr8fSpUtx8eJFODs7Y8iQIVi5cmU1wicyb6LvIwFwLwkiayBZ1clGjRohNTVV59w1a9Zg0aJFOjs/Ll26FEuWLMGiRYsQHByMvLw8XL9+vZrhk6UTfTiJPWBE1oMTHB9+QQVVJ21sbMo9HhcXh6FDh6JevXoAgHv37mHmzJnYuXMnevbsqT2vTZs2xoZhFaxhSZroN1OBV1JpifvxSGQckf8WJK06+bDk5GScPn1aZ3ghISEBarUat27dQlBQEHJyctC5c2csWbIEjRo1qtk7ERBnmVs+kT88rAk3ZSJrJ2nVyYd9+umnCAoKQufOnbWPXb16FWq1GgsWLMDy5cvh4uKCmTNnolevXjhz5gzs7MQf3yUSDedlEJXhBMe/VFZ1MjIyUvvc/fv3sWnTJsyaNUvn9Wq1GsXFxVixYgV69+4NAPjiiy/g7e2NAwcOICwsTO919dWG6On5GJQKsWdhXyu8U/VJFq61o6/cIZjUwBKnqk+ycN+qcuUOweQySvPkDsGkfi+8K3cIQuCchQo8XHXyYdu2bUN+fj5efPFFncd9fHwAAC1bttQ+5uHhAXd3d9y8ebPC61RUdVLJqpMW73LmbblDMKm9do5yh2ByOUX3qz6JyAqImyrUMFnIzc3FlStXMGrUKJ3HP/30U/zrX/8qVzOiS5cuAIALFy6gYcOGAIC7d+/izp07aNy4cYXXiY6OxpQpU3Qe82/YEQrBexYKSsXfsKiOyr7qkyxYwzrucodgcqkF4n8rLRT8b7GI86OoCpJVnXzg8uXLOHToEL777rtyr3/00UcxaNAgvP7661izZg2cnZ0RHR2NwMBA9OjRo8Lr6qs6ebdA7G5BgKshRHAnP0vuEExO5G9TRMbgnIW/GFJ18r///S8aNmyonZPwT5999hkmT56M/v37Q6lUolu3boiPj4etrdg1AqqDqyEsnzXcSEWv7wFwW3IyjEbgv3iFxkLLPqrsHpE7BJKA6Dca3mSIzENJ0S2TX2Nik+claWfF9S8laUdK4vdzk1njzdTyib4HAcB9CMgwHIYgIqoAb6REZUReOin2cgIiIiKqMYvtWbCGrk+RJ8s8IPrGWnZWsKLFGpbdqTUidzADtkrxf09rg8if2Eb/hty6dQvTpk3D7t27kZ+fD39/f6xbtw4dO3YEAGg0GsyZMwdr165FZmYmunTpgtjYWLRo0ULbxsWLFzF16lT88MMPKCoqQps2bTB//vxKl0/+E7s+xVAq9Cif+DcZAChVi/8eRVeq5nbWUuAwxF/u3buHLl26wNbWFrt378a5c+ewZMkSNGjQQHvOBx98gBUrVmDVqlU4fvw46tati7CwMBQU/L2efsCAASgpKcH+/fuRnJyMtm3bYsCAAUhLS5PunRGZgVK1WvjDGigEP4iqYtTSyenTp+OHH37A4cOH9T6v0Wjg6+uLN954A2+++SYAICsrC15eXli/fj2GDRuGO3fuwMPDA4cOHcJTTz0FAMjJyYGzszMSEhIQGhpqUCxcOklERIaqjaWTY5sMkaSdtde3StKOlIzqWdixYwc6duyIIUOGwNPTE+3bt8fatWu1z1+7dg1paWk6N3wXFxcEBwfj2LFjAAA3NzcEBATgs88+Q15eHkpKSrB69Wp4enqiQ4cOEr0tshS2NiqhDyKyHhqJ/meOjPo0u3r1KmJjYzFlyhS8/fbbSEpKwsSJE2FnZ4eIiAjtMIKXl5fO67y8vLTPKRQK7N27F+Hh4XBycoJSqYSnpyfi4+N1hjPIOoi+S6U1TMTl/CGiMiIPyhmVLKjVanTs2BELFiwAALRv3x4pKSlYtWoVIiIiDGpDo9EgKioKnp6eOHz4MBwdHfHJJ59g4MCBSEpK0lamfJi+EtUqpQ0UCrFH20S/kQKAUvCfobl+S5CS2D9B6yD+bynVlFHJgo+Pj055aQAICgrCV199BQDw9vYGAKSnp+vc9NPT09GuXTsAwP79+7Fr1y7cu3cPzs5lJaY//vhjJCQkYMOGDZg+fXq567JEtbjUlrnbuOFEf39EpCXylwOjkoUuXbrgwoULOo9dvHhRW166adOm8Pb2xr59+7TJQXZ2No4fP47XXnsNAJCfnw8AUCp1p0solUqoK5hZra9EdQO3QGNCJyITEb2+B8BtyckwHIb4y+TJk9G5c2csWLAAQ4cOxU8//YQ1a9ZgzZo1AMrmI0yaNAnvvvsuWrRogaZNm2LWrFnw9fVFeHg4ACAkJAQNGjRAREQEZs+eDUdHR6xduxbXrl1D//799V5XX4lq0YcgiCwFb6RE4jMqWejUqRPi4uIQHR2Nd955B02bNsWyZcswYsQI7TlvvfUW8vLyMG7cOGRmZqJr166Ij4+Hg4MDAMDd3R3x8fGYMWMGnnnmGRQXF6NVq1b45ptv0LZtW2nfHRERVckaeodqg8jDqixRTUREwquNfRZGNn5OknY23vhaknakJPbG/ERERFRjFrtrDNevExGRORG5NoTFJgu8kZIlsIZdHK1hPxAiQ4i8dNLoYYhbt25h5MiRcHNzg6OjI1q3bo0TJ07oPffVV1+FQqHAsmXLdB6/e/cuRowYAWdnZ9SvXx+RkZHIzc2t1hsgMmfFpSXCH9bARqkU+iCqilFfex5UnezRowd2794NDw8PXLp0Se82zXFxcfjxxx/h6+tb7rkRI0YgNTUVCQkJKC4uxujRozFu3Dhs2rSp+u+EiMhErKW6JtWMyL8lRiUL77//Pho1aoR169ZpH2vatGm5827duoUJEyZgz5495fZO+PXXXxEfH4+kpCR07NgRAPDRRx+hX79+WLx4sd7kgoiIyNyJPGdB0qqTQFn9iFGjRmHq1Klo1apVuTaOHTuG+vXraxMFAAgNDYVSqcTx48er+TaIiIjkJXLVSaOShQdVJ1u0aIE9e/bgtddew8SJE7FhwwbtOe+//z5UKhUmTpyot420tDR4enrqPKZSqeDq6qqtTEkkCoUVHEQkPkmrTiYnJ2P58uU4efKkpNsx66s6qdFouOUzmT3z/I5ARKYg8pwFo3oWKqo6efPmTQDA4cOHkZGRAT8/P6hUKqhUKty4cQNvvPEGmjRpAqCsMmVGRoZOGyUlJbh79662auU/xcTEwMXFRefQqHOMCZ1IFnJ/62fPAlHt0Wg0khzmSNKqk6NGjUJoaKjO82FhYRg1ahRGjx4NoKyQVGZmJpKTk9GhQwcAZWWr1Wo1goOD9V5XX9VJH682wvcsFJQUyR0C1ZB5/tkTERlH0qqTbm5ucHNz03mNra0tvL29ERAQAKCsJ6JPnz4YO3YsVq1aheLiYowfPx7Dhg2rcCWEvqqTJZpS4T+JxU6FyvyzVLlobJVWsCmTWvy9Fsz1255URH9/tUXk1RCSV500xOeff47x48ejZ8+eUCqVGDx4MFasWGFUG1z3LAbRf46lavYOEVkLkT/NWHXSjNWxta/6JAuXX1xY9UlERDVUG1UnB/oNkKSdnTd3GXzu3LlzMW/ePJ3HAgICcP78eUlieUD8PlILxhspkXmwV9nKHYJJFZYUyx2CEOTaI6FVq1bYu3ev9t8qlfS3diYLRERV4M2UDCHXnAWVSlXhakKpiD27jIiISHCXLl2Cr68vmjVrhhEjRmi3M5ASexbMmDWshrDICTNERHpINQVQ30aE+lYFAkBwcDDWr1+PgIAApKamYt68eXjqqaeQkpICJycnSeIBTFCiWqFQ6D0WLVoEALh+/ToiIyPRtGlTODo6onnz5pgzZw6Kijhr/J80VnCITu4Nk7gpE1HtUUt06NuIMCYmRu81+/btiyFDhqBNmzYICwvDd999h8zMTGzZskXS9yZ5ierU1FSd1+zevRuRkZEYPHgwAOD8+fNQq9VYvXo1/P39kZKSgrFjxyIvLw+LFy82OJa6dg7GhG6R8ooK5A6BasgaEiIiKiPVBEd9GxHq61XQp379+nj00Udx+fJlSWJ5wKilk9OnT8cPP/yAw4cPG3yB8PBw5OTkYN++fRWes2jRIsTGxuLq1asGt2sNSyeJiEgatbF0snejPpK08/1v8dV+bW5uLvz8/DB37twKCzpWh+Qlqh+Wnp6Ob7/9FpGRkZW2m5WVBVdXV2NCISIiMitqaCQ5jPHmm28iMTER169fx9GjR/Hss8/CxsYGw4cPl/S9GTUM8aBE9ZQpU/D2228jKSkJEydOhJ2dHSIiIsqdv2HDBjg5OeG5556rsM3Lly/jo48+MmoIgojMh0ppI3cIJleiLpU7BLIAcuxx+Pvvv2P48OH4888/4eHhga5du+LHH3+Eh4eHpNcxahjCzs4OHTt2xNGjR7WPTZw4EUlJSTh27Fi58wMDA9GrVy989NFHetu7desWunXrhu7du+OTTz6p8Lr6ZoY2cAsUvpAUERFJozaGIXo27C1JO/t+/16SdqQkaYnqhx0+fBgXLlzAyy+/rLet27dvo0ePHujcubO2EFVFWKKaiIjMnRzDELVF0hLVD/v000/RoUMHtG3bttxzt27dQo8ePdChQwesW7euysqD+maGuroFCr9syzx/ZaQl+s9Q9KqaAKAWvBgYAKhsxN6SprhU/MqhtUGu7Z5rg6Qlqh/Izs7G1q1bsWTJknJt3Lp1C927d0fjxo2xePFi/PHHH9rnKtquUu9mFAqFwD8W6yH6z1D0qprWgjdTsnYmKVG9efNmaDQavbMxExIScPnyZVy+fBkNGzbUec5CC2ASVUj0nhNA/ISPyFBqge9hLFFNRETCq40Jjk890lOSdg7fqnhfIrmIP6BKRERENSL2rB0iIqqSksvQJWGuKxmkwGSBiGrEGm4z4t4Cyog81l6bRE4WjBqGaNKkid6KklFRUQCAgoICREVFwc3NDfXq1cPgwYORnp6ut60///wTDRs2hEKhQGZmZo3fCBHJQ+7KpayOSuZCo9FIcpgjo5KFpKQkpKamao+EhAQAwJAhQwCULa3cuXMntm7disTERNy+fbvCrZ4jIyPRpk2bGoZPZN7kLh/NEtVEJAWjhiH+udf0woUL0bx5c3Tr1g1ZWVn49NNPsWnTJjzzzDMAgHXr1iEoKAg//vgjnnzySe3rYmNjkZmZidmzZ2P37t0SvA0i82Se3xGIyBQ4DKFHUVERNm7ciDFjxkChUCA5ORnFxcUIDQ3VnhMYGAg/Pz+duhHnzp3DO++8g88++8wqdrcjIiLroJHof+ao2nfr7du3IzMzEy+99BIAIC0tDXZ2dqhfv77OeV5eXkhLSwNQVhBq+PDhWLRoEfz8/KodNBEREdWeaq+G+PTTT9G3b1/4+voa/Jro6GgEBQVh5MiRRl1LX9VJjUbDqpNERGQ2zHVyohSqlSzcuHEDe/fuxddff619zNvbG0VFRcjMzNTpXUhPT9fWfNi/fz/Onj2Lbdu2Afj7/1h3d3fMmDED8+bN03u9mJiYcs/Vd/RCgzo+1QnfYuSXFMgdgsl5OtSXOwST8reXtqa8ObpQoH/Fk0hyS+7LHYJJ5RSJ/f5qi8hzFqq13fPcuXOxevVq/Pbbb1CpyvKNrKwseHh44IsvvsDgwYMBABcuXEBgYCCOHTuGJ598EleuXMH9+3//UiYlJWHMmDE4evQomjdvDk9PT73X09ez0MAtkD0LRERkkNrY7vlxn66StHMy9Ygk7UjJ6J4FtVqNdevWISIiQpsoAICLiwsiIyMxZcoUuLq6wtnZGRMmTEBISIh2JUTz5s112rpz5w4AICgoqNxch4fpqzrJREEMKqWN3CGYVIm6VO4QiKiWcBjiIXv37sXNmzcxZsyYcs99+OGHUCqVGDx4MAoLCxEWFoaPP/5YkkBJTLyZWj5r2CqYOxySITgMYYZYdZIsga2N+DuqF5eWyB0CUZVqYxiirXdnSdr5Oe2oJO1ISfxPMgtmr7KVOwSTKywpljsEk+KNlMh6mOseCVJgsmDGRL+REhGJROThKiYLRCbE3iEi68GeBTM0wfcpuUMwubOl9+QOweT+DbH3IejrkSZ3CCa3/Y633CGYXKIiW+4QTOq34ky5QyAzZ1Sy0KRJE9y4caPc4//3f/+HlStX4pVXXsHevXtx+/Zt1KtXD507d8b777+PwMBAnfPXr1+PpUuX4uLFi3B2dsaQIUOwcuVKowL/6PZho84n83RQ7gBMzOmeo9whmFxO0a9yh0BkFjgM8ZekpCSUlv691C0lJQW9evXSlqju0KEDRowYAT8/P9y9exdz585F7969ce3aNdjYlK2nX7p0KZYsWYJFixYhODgYeXl5uH79unTviMiMcGc8Iush8jBEjZZOTpo0Cbt27cKlS5f0bpJ05swZtG3bFpcvX0bz5s1x7949PPLII9i5cyd69uxZo8BtrWDppLi/dn8TfYW+NWweZqGrr+kh1vATrI2lk4GenSRp53xGkiTtSKnacxYelKieMmWK3g/EvLw8rFu3Dk2bNkWjRo0AAAkJCVCr1bh16xaCgoKQk5ODzp07Y8mSJdpzDGUNv9zWQPSfI2+kYhB9oionqUqDwxB6/LNE9QMff/wx3nrrLeTl5SEgIAAJCQmws7MDAFy9ehVqtRoLFizA8uXL4eLigpkzZ6JXr144c+aM9jwiInPCmykZQuRhCGV1X1hRieoRI0bg1KlTSExMxKOPPoqhQ4eioKCseqJarUZxcTFWrFiBsLAwPPnkk/jiiy9w6dIlHDhwoMJrFRYWIjs7W+fgNzayBAorOIhIfNVKFh6UqH755ZfLPefi4oIWLVrg6aefxrZt23D+/HnExcUBAHx8ykpKt2zZUnu+h4cH3N3dcfPmzQqvFxMTAxcXF51Do86pTuhEtUpjBQcRlVFrNJIc5qhaycK6devg6emJ/v37V3qeRqOBRqPRlpfu0qULgLLS1Q/cvXsXd+7cQePGjStsJzo6GllZWTqHQulUndCJiIhMQiPR/8yRZCWqr169ii+//BK9e/eGh4cHfv/9dyxcuBCOjo7o168fAODRRx/FoEGD8Prrr2PNmjVwdnZGdHQ0AgMD0aNHjwqvyRLV4hL9p2ief/ZERMaRrES1g4MDDh8+jGXLluHevXvw8vLC008/jaNHj8LT01N73meffYbJkyejf//+UCqV6NatG+Lj42FrK/ZsY9KPN1PLJ3rCB/D3lAyj0ajlDsFkWKKayISUVtADZq5jrEQPq419Fhq7tZGknRt/npGkHSlZbG0IIkvAGymR9bDQ794GqfbSSSIiIrIO7FkgMqG6dg5yh2ByeUUFcodAZBbUAs9uYbJAZEK8kRJZD5GHISQtUQ0Ax44dw4wZM3D8+HHY2NigXbt22LNnDxwdy0r1Xrx4EVOnTsUPP/yAoqIitGnTBvPnz6906aQ+Tnbil/4tUpfIHYLJ1bevK3cIJlXfrp7cIZjc3ULxN0jLLymUOwSTKioV/7OGakbSEtXHjh1Dnz59EB0djY8++ggqlQo///wzlMq/p0YMGDAALVq0wP79++Ho6Ihly5ZhwIABuHLlCry9vQ2OhaV/xZBekil3CCaVnpcpdwgmp1LayB2CyZWoS6s+iayeyBOaJS1R/eSTT6JXr16YP3++3vPv3LkDDw8PHDp0CE899RQAICcnB87OzkhISEBoaKjB1+bSSbIEtjbij/QV81spWYDaWDrpXT9IknbSMn+VpB0pVXs1xIMS1WPGjIFCoUBGRgaOHz8OT09PdO7cGV5eXujWrRuOHDmifY2bmxsCAgLw2WefIS8vDyUlJVi9ejU8PT3RoUMHSd4QkTkpLi0R/iAi8UlWovrq1asAgLlz52Lx4sVo164dPvvsM/Ts2RMpKSlo0aIFFAoF9u7di/DwcDg5OUGpVMLT0xPx8fFo0KBBhdcqLCzU1pd4QKPRcMtnMnvclInIeog8wVGyEtVqddk2l6+88gpGjx6N9u3b48MPP0RAQAD++9//Aij7PzIqKgqenp44fPgwfvrpJ4SHh2PgwIFITU2t8FqsOkmWSqoqdOZ8EFEZNTSSHOZIshLV+spPA0BQUJC2/PT+/fuxa9cubN68GV26dMHjjz+Ojz/+GI6OjtiwYUOF12PVSSIiIvlUaxhCX4nqJk2awNfXV6f8NFC2VLJv374AgPz8fADQWR3x4N8Peib0YdVJIiIydyIPQ0hWolqhUGDq1KmYM2cO2rZti3bt2mHDhg04f/48tm3bBgAICQlBgwYNEBERgdmzZ8PR0RFr167FtWvXdBIPsh72KrGrjRaWFMsdAhHVEpGH5SQrUQ2ULaUsKCjA5MmTcffuXbRt2xYJCQlo3rw5AMDd3R3x8fGYMWMGnnnmGRQXF6NVq1b45ptv0LZt25q/G7I4ot9MRU+GAPF/hkSGErlngSWqSVai107gds9E5qE29lloUM9fknbu5V6WpB0pib9jDJk13kzJEoi+SyV3qJSGua5kkAKTBSKiKvBmSoaw0I56g1R7nwUiIiKyDkb1LJSWlmLu3LnYuHEj0tLS4Ovri5deegkzZ87ULmXUaDSYM2cO1q5di8zMTHTp0gWxsbFo0aKFtp27d+9iwoQJ2LlzJ5RKJQYPHozly5ejXj3DK/TZKMXPcypbTiqKfy6jFY1SIfb7AwC1RvzfU5G/MQLiv7/awtUQf3n//fcRGxuLDRs2oFWrVjhx4gRGjx4NFxcXTJw4EQDwwQcfYMWKFdiwYQOaNm2KWbNmISwsDOfOnYODQ9lkthEjRiA1NRUJCQkoLi7G6NGjMW7cOGzatMngWEqt4EZqDUT/OSqU4u8HIvrPkMhQGoHnLBi1GmLAgAHw8vLCp59+qn1s8ODBcHR0xMaNG6HRaODr64s33ngDb775JgAgKysLXl5eWL9+PYYNG4Zff/0VLVu2RFJSEjp27AgAiI+PR79+/fD7779rt4+uCldDEJkH8dMhCHwLsB61sRqibp0mkrSTl39dknakZFQfaefOnbFv3z5cvHgRAPDzzz/jyJEj2h0ar127hrS0NJ1S0y4uLggODsaxY8cAAMeOHUP9+vW1iQIAhIaGQqlU4vjx4zV+Q0TmRKW0Ef7QAMIfRIYQud6KUcMQ06dPR3Z2NgIDA2FjY4PS0lK89957GDFiBAAgLS0NAODl5aXzOi8vL+1zaWlp8PT01A1CpYKrq6v2HCJRcBY9kfUQee6HUcnCli1b8Pnnn2PTpk1o1aoVTp8+jUmTJsHX1xcRERGmipElqomIiGRkVLIwdepUTJ8+HcOGDQMAtG7dGjdu3EBMTAwiIiLg7e0NAEhPT9dWoXzw73bt2gEAvL29kZGRodNuSUkJ7t69q339P8XExGDevHk6jymU9aCwcTYmfKJap7SChNZcu02JapvIExyNmrOQn59fbqmbjY2Ndolf06ZN4e3tjX379mmfz87OxvHjxxESEgKgrJhUZmYmkpOTtefs378farUawcHBeq/LEtVkqaQawzTng4jKaDQaSQ5zZFTPwsCBA/Hee+/Bz88PrVq1wqlTp7B06VJtUSmFQoFJkybh3XffRYsWLbRLJ319fREeHg4ACAoKQp8+fTB27FisWrUKxcXFGD9+PIYNG1bhSgiWqCYiOXG7ZzKEud7opWDU0smcnBzMmjULcXFxyMjIgK+vL4YPH47Zs2fDzs4OwN+bMq1ZswaZmZno2rUrPv74Yzz66KPadu7evYvx48frbMq0YsUKozZl4tJJIiIyVG0snbSV6L5UXAuxGotVJ4moRhxUdnKHYHIFJUVyh0A1VBvJglT3pdqI1WgaMkhBQYFmzpw5moKCArlDMQnR359Gw/coAtHfn0bD90jmyWJ7FmpbdnY2XFxckJWVBWdn8VZhiP7+AL5HEYj+/gC+RzJP4le5ISIiohphskBERESVYrJARERElWKyYCB7e3vMmTOn3H4PohD9/QF8jyIQ/f0BfI9knjjBkYiIiCrFngUiIiKqFJMFIiIiqhSTBSIiIqoUkwUiIiKqFJMFA6xcuRJNmjSBg4MDgoOD8dNPP8kdkmQOHTqEgQMHwtfXFwqFAtu3b5c7JMnFxMSgU6dOcHJygqenJ8LDw3HhwgW5w5JMbGws2rRpA2dnZzg7OyMkJAS7d++WOyyTWrhwobbKrSjmzp0LhUKhcwQGBsodlqRu3bqFkSNHws3NDY6OjmjdujVOnDghd1hkACYLVfjyyy8xZcoUzJkzBydPnkTbtm0RFhaGjIwMuUOTRF5eHtq2bYuVK1fKHYrJJCYmIioqCj/++CMSEhJQXFyM3r17Iy8vT+7QJNGwYUMsXLgQycnJOHHiBJ555hkMGjQIv/zyi9yhmURSUhJWr16NNm3ayB2K5Fq1aoXU1FTtceTIEblDksy9e/fQpUsX2NraYvfu3Th37hyWLFmCBg0ayB0aGULe0hTm74knntBERUVp/11aWqrx9fXVxMTEyBiVaQDQxMXFyR2GyWVkZGgAaBITE+UOxWQaNGig+eSTT+QOQ3I5OTmaFi1aaBISEjTdunXTvP7663KHJJk5c+Zo2rZtK3cYJjNt2jRN165d5Q6Dqok9C5UoKipCcnIyQkNDtY8plUqEhobi2LFjMkZGNZGVlQUAcHV1lTkS6ZWWlmLz5s3Iy8tDSEiI3OFILioqCv3799f5mxTJpUuX4Ovri2bNmmHEiBG4efOm3CFJZseOHejYsSOGDBkCT09PtG/fHmvXrpU7LDIQk4VK3LlzB6WlpfDy8tJ53MvLC2lpaTJFRTWhVqsxadIkdOnSBY899pjc4Ujm7NmzqFevHuzt7fHqq68iLi4OLVu2lDssSW3evBknT55ETEyM3KGYRHBwMNavX4/4+HjExsbi2rVreOqpp5CTkyN3aJK4evUqYmNj0aJFC+zZswevvfYaJk6ciA0bNsgdGhlAJXcARLUpKioKKSkpQo0FA0BAQABOnz6NrKwsbNu2DREREUhMTBQmYfjtt9/w+uuvIyEhAQ4ODnKHYxJ9+/bV/nebNm0QHByMxo0bY8uWLYiMjJQxMmmo1Wp07NgRCxYsAAC0b98eKSkpWLVqFSIiImSOjqrCnoVKuLu7w8bGBunp6TqPp6enw9vbW6aoqLrGjx+PXbt24cCBA2jYsKHc4UjKzs4O/v7+6NChA2JiYtC2bVssX75c7rAkk5ycjIyMDDz++ONQqVRQqVRITEzEihUroFKpUFpaKneIkqtfvz4effRRXL58We5QJOHj41MueQ0KChJqqEVkTBYqYWdnhw4dOmDfvn3ax9RqNfbt2yfkeLCoNBoNxo8fj7i4OOzfvx9NmzaVOySTU6vVKCwslDsMyfTs2RNnz57F6dOntUfHjh0xYsQInD59GjY2NnKHKLnc3FxcuXIFPj4+cociiS5dupRbsnzx4kU0btxYpojIGByGqMKUKVMQERGBjh074oknnsCyZcuQl5eH0aNHyx2aJHJzc3W+uVy7dg2nT5+Gq6sr/Pz8ZIxMOlFRUdi0aRO++eYbODk5aeebuLi4wNHRUeboai46Ohp9+/aFn58fcnJysGnTJhw8eBB79uyROzTJODk5lZtjUrduXbi5uQkz9+TNN9/EwIED0bhxY9y+fRtz5syBjY0Nhg8fLndokpg8eTI6d+6MBQsWYOjQofjpp5+wZs0arFmzRu7QyBByL8ewBB999JHGz89PY2dnp3niiSc0P/74o9whSebAgQMaAOWOiIgIuUOTjL73B0Czbt06uUOTxJgxYzSNGzfW2NnZaTw8PDQ9e/bUfP/993KHZXKiLZ18/vnnNT4+Pho7OzvNI488onn++ec1ly9fljssSe3cuVPz2GOPaezt7TWBgYGaNWvWyB0SGYglqomIiKhSnLNARERElWKyQERERJViskBERESVYrJARERElWKyQERERJViskBERESVYrJARERElWKyQERERJViskBERESVYrJARERElWKyQERERJViskBERESV+n9BvhWd/p/P2gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hm= sns.heatmap(data = Phi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5de3333",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d57996c9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
