{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "3f80e3a6",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 53
    },
    "id": "3f80e3a6",
    "outputId": "688d4a21-c2c8-4090-8785-ba9fec49eaef"
   },
   "outputs": [
    {
     "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_9800\\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": 22,
   "id": "c287cb5c",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 71
    },
    "id": "c287cb5c",
    "outputId": "54552bfd-7681-4b66-bce2-74e2c38e399f"
   },
   "outputs": [
    {
     "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_9800\\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": 22,
     "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": 23,
   "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": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset = os.path.join(os.getcwd(),'Cora')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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": 25,
   "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": 26,
   "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": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "7aec8d70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2708,)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "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": 29,
   "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": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(theta@A).type()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "theta.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "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": 32,
   "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": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "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": 34,
   "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.1)\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": 35,
   "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": 36,
   "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": 37,
   "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": 38,
   "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.1)\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": 39,
   "id": "556afd48",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "556afd48",
    "outputId": "7f0b9b03-7a98-4a01-ac78-fc754863ff46"
   },
   "outputs": [
    {
     "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_9800\\1999241371.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_9800\\1999241371.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_9800\\1999241371.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:08<00:00,  1.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (270, 270)\n",
      "Entropy.................. 3.8113864829802964\n",
      "Epoch: 000,loss: 1.9498\n",
      "Accuracy = 0.8094534711964549 1 0.01 10\n",
      "Average accuracy = 80.94534711964549 +/- 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": 40,
   "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/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABZyklEQVR4nO3deXhV1b3/8c/JdBICBIMhkVFmEEEUlFFwoEbqRIWiVisoWuplUNCqtHXAKSpXwQHHtoIWrgIKVqtSBUXhggqIBSyICqJACFMSEsJJTs7+/cElv2wTMAnZrOx13q/nyfOYnZOzPtkcc7757rXWDjiO4wgAAACAL8WYDgAAAACg5ijoAQAAAB+joAcAAAB8jIIeAAAA8DEKegAAAMDHKOgBAAAAH6OgBwAAAHyMgh4AAADwMQp6AAAAwMco6AEck3A4rNtvv10tWrRQTEyMhgwZ4ul455xzjs4555xqf9+WLVsUCAT03//937WW5aOPPlIgENBHH31Ua89ZFe+99566d++uxMREBQIB5ebmHtfx8f+Zeg0AQHkU9IhaM2bMUCAQ0MqVKyv9+jnnnKNTTz3V0wzvvPOO7r33Xk/H8Nrf/vY3TZkyRcOGDdPMmTM1YcIE05GstmfPHg0fPlxJSUmaPn26XnnlFSUnJ+uhhx7SggULTMcDABgQZzoAEM3eeecdTZ8+3ddF/eLFi9WsWTNNnTrVdJSo8Pnnn2v//v26//77NWjQoLLjDz30kIYNG+b5FRK4DRgwQEVFRUpISDAdBUAUo0MP4Jjk5OSoUaNGtfZ8kUhEBw8erLXns01OTo4k1eo5P5KDBw8qEol4Ps6xOnDggLGxY2JilJiYqJgY3k4BmMNvIKCa/v73v6tHjx5KSkpSamqqrrzySv3www+ux3zyySf69a9/rZYtWyoYDKpFixaaMGGCioqKyh4zcuRITZ8+XZIUCATKPiT3fO/p06erTZs2qlevni644AL98MMPchxH999/v5o3b66kpCRddtll2rt3ryvDm2++qYsuukhNmzZVMBhU27Ztdf/996u0tNT1uMNTi1atWqW+ffsqKSlJrVu31nPPPXfU83A444cffqj169eX5T88l7iwsFC33nqrWrRooWAwqI4dO+q///u/5TiO63kCgYDGjh2rWbNmqUuXLgoGg3rvvfeq/O9RXFysu+++Wz169FBKSoqSk5N19tln68MPPzzi90ydOlWtWrVSUlKSBg4cqHXr1lV4zIYNGzRs2DClpqYqMTFRPXv21D/+8Y+fzbNp0yYNHTpUGRkZSkxMVPPmzXXllVcqLy/vqN9XldfMOeecoxEjRkiSzjzzTAUCAY0cOVKBQECFhYWaOXNm2b/DyJEjy75v27Ztuv7665Wenq5gMKguXbrob3/7m2v8w3PBX331Vf35z39Ws2bNVK9ePeXn5x8xcyQS0RNPPKGuXbsqMTFRaWlpuvDCC13T2MLhsO6//361bdtWwWBQJ598sv74xz8qFAq5nqsmr9cBAwaoXr16+uMf/yhJWrlypTIzM3XiiSeWvY6vv/76CpmnTZumLl26KDExUenp6Ro9erT27dvnetzJJ5+siy++WEuXLtVZZ52lxMREtWnTRi+//HKl5638HPrDGb/66iude+65qlevnpo1a6ZHH320wjn8/vvvdemllyo5OVlNmjTRhAkTtHDhQublA6gWptwg6uXl5Wn37t0VjpeUlFQ49uCDD+quu+7S8OHDdcMNN2jXrl166qmnNGDAAH3xxRdlXdO5c+fqwIEDuummm9S4cWN99tlneuqpp/Tjjz9q7ty5kqTRo0dr+/btev/99/XKK69Umm3WrFkqLi7WuHHjtHfvXj366KMaPny4zjvvPH300Ue644479M033+ipp57Sbbfd5irSZsyYofr162vixImqX7++Fi9erLvvvlv5+fmaMmWKa5x9+/bpl7/8pYYPH66rrrpKc+bM0U033aSEhIQKBdFhaWlpeuWVV/Tggw+qoKBAWVlZkqTOnTvLcRxdeuml+vDDDzVq1Ch1795dCxcu1B/+8Adt27atwvScxYsXa86cORo7dqxOPPFEnXzyyZX/Y1UiPz9ff/nLX3TVVVfpxhtv1P79+/XXv/5VmZmZ+uyzz9S9e3fX419++WXt379fY8aM0cGDB/XEE0/ovPPO09q1a5Weni5JWr9+vfr166dmzZrpzjvvVHJysubMmaMhQ4bo9ddf169+9atKsxQXFyszM1OhUEjjxo1TRkaGtm3bprffflu5ublKSUk54s9RldfMn/70J3Xs2FEvvPCC7rvvPrVu3Vpt27bVoEGDdMMNN+iss87S7373O0lS27ZtJUk7d+5U7969y/5wSktL07vvvqtRo0YpPz9ft9xyiyvH/fffr4SEBN12220KhUJHnUoyatQozZgxQ4MHD9YNN9ygcDisTz75RCtWrFDPnj0lSTfccINmzpypYcOG6dZbb9Wnn36qrKws/ec//9H8+fPLnqs6r9c9e/Zo8ODBuvLKK3XNNdcoPT1dOTk5uuCCC5SWlqY777xTjRo10pYtW/TGG2+4vnf06NGaMWOGrrvuOo0fP16bN2/W008/rS+++ELLli1TfHx82WO/+eYbDRs2TKNGjdKIESP0t7/9TSNHjlSPHj3UpUuXI54X6dD/UxdeeKEuv/xyDR8+XPPmzdMdd9yhrl27avDgwZIO/dF73nnnaceOHbr55puVkZGh2bNnH/WPUQColANEqZdeesmRdNSPLl26lD1+y5YtTmxsrPPggw+6nmft2rVOXFyc6/iBAwcqjJeVleUEAgHn+++/Lzs2ZswYp7L/DTdv3uxIctLS0pzc3Nyy45MmTXIkOaeddppTUlJSdvyqq65yEhISnIMHDx41w+jRo5169eq5Hjdw4EBHkvPYY4+VHQuFQk737t2dJk2aOMXFxRVPXjkDBw50nSfHcZwFCxY4kpwHHnjAdXzYsGFOIBBwvvnmm7JjkpyYmBhn/fr1Rx2n/HgDBw4s+zwcDjuhUMj1mH379jnp6enO9ddfX3bs8DlNSkpyfvzxx7Ljn376qSPJmTBhQtmx888/3+natavrPEUiEadv375O+/bty459+OGHjiTnww8/dBzHcb744gtHkjN37twq/SzlVfU1c/h1+/nnn7sem5yc7IwYMaLCc4waNco56aSTnN27d7uOX3nllU5KSkrZuId/ljZt2lSa5acWL17sSHLGjx9f4WuRSMRxHMdZs2aNI8m54YYbXF+/7bbbHEnO4sWLy45V9/X63HPPuR47f/78Ss9LeZ988okjyZk1a5br+HvvvVfheKtWrRxJzscff1x2LCcnxwkGg86tt95aduynr4HyGV9++eWyY6FQyMnIyHCGDh1aduyxxx5zJDkLFiwoO1ZUVOR06tSpwnMCwNEw5QZRb/r06Xr//fcrfHTr1s31uDfeeEORSETDhw/X7t27yz4yMjLUvn17V1ctKSmp7L8LCwu1e/du9e3bV47j6Isvvqhytl//+teurm6vXr0kSddcc43i4uJcx4uLi7Vt27ZKM+zfv1+7d+/W2WefrQMHDmjDhg2uceLi4jR69OiyzxMSEjR69Gjl5ORo1apVVc572DvvvKPY2FiNHz/edfzWW2+V4zh69913XccHDhyoU045pdrjSFJsbGxZFzkSiWjv3r0Kh8Pq2bOnVq9eXeHxQ4YMUbNmzco+P+uss9SrVy+98847kqS9e/dq8eLFGj58eNl52717t/bs2aPMzExt2rTJdZ7LO/xvtXDhwmrP666t10x5juPo9ddf1yWXXCLHcVyv28zMTOXl5VU4RyNGjHBlOZLXX39dgUBA99xzT4WvHZ46dvicTpw40fX1W2+9VZL0z3/+s+xYdV6vwWBQ1113nevY4atjb7/9dqVX16RDV0FSUlL0i1/8wnUuevToofr161fojJ9yyik6++yzyz5PS0tTx44d9d1331X6/OXVr19f11xzTdnnCQkJOuuss1zf+95776lZs2a69NJLy44lJibqxhtv/NnnB4DymHKDqHfWWWeVTQ8o74QTTnBNxdm0aZMcx1H79u0rfZ7yl+q3bt2qu+++W//4xz8qzM39ubnU5bVs2dL1+eGCsUWLFpUeLz/W+vXr9ec//1mLFy+uMA/6pxmaNm2q5ORk17EOHTpIOjRXvnfv3lXOLB2aF9y0aVM1aNDAdbxz585lXy+vdevW1Xr+n5o5c6Yee+wxbdiwwVXMVfa8lf37dejQQXPmzJF0aJqF4zi66667dNddd1U6Xk5OjuuPgvLjTZw4UY8//rhmzZqls88+W5deeqmuueaao063kWrvNVPerl27lJubqxdeeEEvvPDCEX+Wn/4MVfHtt9+qadOmSk1NPeJjvv/+e8XExKhdu3au4xkZGWrUqJHrdVCd12uzZs0qTAUaOHCghg4dqsmTJ2vq1Kk655xzNGTIEP3mN79RMBiUdOj/4by8PDVp0qTSvD89Fz/9/0869Hvhp/8+lWnevHnZHzblv/ff//532efff/+92rZtW+FxPz1fAPBzKOiBKopEIgoEAnr33XcVGxtb4ev169eXJJWWluoXv/iF9u7dqzvuuEOdOnVScnKytm3bppEjR1Zr15DKxjnacef/Fpzm5uZq4MCBatiwoe677z61bdtWiYmJWr16te644446t3NJVTrCR/L3v/9dI0eO1JAhQ/SHP/xBTZo0UWxsrLKysvTtt99W+/kOn5vbbrtNmZmZlT7maAXXY489ppEjR+rNN9/Uv/71L40fP15ZWVlasWKFmjdvXun31OZrprKf5ZprrilbTPtTP70SdSz/Fkfy04L1p6r7eq0sYyAQ0Lx587RixQq99dZbWrhwoa6//no99thjWrFiherXr69IJKImTZpo1qxZleZIS0tzff5z/58dzbF8LwBUFwU9UEVt27aV4zhq3bp1Wfe6MmvXrtXXX3+tmTNn6tprry07/v7771d47M8VOjX10Ucfac+ePXrjjTc0YMCAsuObN2+u9PHbt29XYWGhq0v/9ddfS1K1Fqge1qpVK33wwQfav3+/q0t/eOpEq1atqv2cRzJv3jy1adNGb7zxhut8VjYVRDrUpf2pr7/+uuznbNOmjaRDV1zK7/NeHV27dlXXrl315z//Wf/7v/+rfv366bnnntMDDzxQ6eOr85o5kspeS2lpaWrQoIFKS0tr/LMcSdu2bbVw4ULt3bv3iF36Vq1aKRKJaNOmTWVXZ6RDC3Vzc3PLXgfVfb0eTe/evdW7d289+OCDmj17tq6++mq9+uqruuGGG9S2bVt98MEH6tevnyd/uFRXq1at9NVXX8lxHNe/3zfffGMwFQA/Yg49UEWXX365YmNjNXny5ApdNsdxtGfPHkn/vzNX/jGO4+iJJ56o8JyHC+jc3NxazVpZhuLiYj3zzDOVPj4cDuv55593Pfb5559XWlqaevToUe3xf/nLX6q0tFRPP/206/jUqVMVCATKdvmoDZX9rJ9++qmWL19e6eMXLFjgmgP/2Wef6dNPPy3L1KRJE51zzjl6/vnntWPHjgrfv2vXriNmyc/PVzgcdh3r2rWrYmJiKmzT+HM/w5FeM0eSnJxc4XUUGxuroUOH6vXXX690a86j/Sw/Z+jQoXIcR5MnT67wtcM/xy9/+UtJ0rRp01xff/zxxyVJF110UVnO8t8nHf31Wpl9+/ZV+P/y8A5Hh8/98OHDVVpaqvvvv7/C94fD4Vr///DnZGZmatu2ba7tUA8ePKgXX3zxuOYA4H906IEqatu2rR544AFNmjRJW7Zs0ZAhQ9SgQQNt3rxZ8+fP1+9+9zvddttt6tSpk9q2bavbbrtN27ZtU8OGDfX6669XOu/2cLE8fvx4ZWZmKjY2VldeeeUxZ+3bt69OOOEEjRgxQuPHj1cgENArr7xyxMv9TZs21SOPPKItW7aoQ4cOeu2117RmzRq98MILrrUBVXXJJZfo3HPP1Z/+9Cdt2bJFp512mv71r3/pzTff1C233FK2pWJtuPjii/XGG2/oV7/6lS666CJt3rxZzz33nE455RQVFBRUeHy7du3Uv39/3XTTTQqFQpo2bZoaN26s22+/vewx06dPV//+/dW1a1fdeOONatOmjXbu3Knly5frxx9/1JdffllplsWLF2vs2LH69a9/rQ4dOigcDuuVV14pK6yPpDqvmSPp0aOHPvjgAz3++ONq2rSpWrdurV69eunhhx/Whx9+qF69eunGG2/UKaecor1792r16tX64IMPKty/oKrOPfdc/fa3v9WTTz6pTZs26cILL1QkEtEnn3yic889V2PHjtVpp52mESNG6IUXXiibVvPZZ59p5syZGjJkiM4991xJ1X+9VmbmzJl65pln9Ktf/Upt27bV/v379eKLL6phw4Zlf1gMHDhQo0ePVlZWltasWaMLLrhA8fHx2rRpk+bOnasnnnhCw4YNq9H5qInRo0fr6aef1lVXXaWbb75ZJ510kmbNmqXExERJ3l3BA2Ch47WdDlDXHGn7v8Mq247RcRzn9ddfd/r37+8kJyc7ycnJTqdOnZwxY8Y4GzduLHvMV1995QwaNMipX7++c+KJJzo33nij8+WXXzqSnJdeeqnsceFw2Bk3bpyTlpbmBAKBsi0sD2+xOGXKFNfYh7fI++m2iJX9LMuWLXN69+7tJCUlOU2bNnVuv/12Z+HChZVusdelSxdn5cqVTp8+fZzExESnVatWztNPP12l83ik87R//35nwoQJTtOmTZ34+Hinffv2zpQpU8q2NDxMkjNmzJgqjXV4vPLbVkYiEeehhx5yWrVq5QSDQef000933n77bWfEiBFOq1atyh5X/pw+9thjTosWLZxgMOicffbZzpdffllhnG+//da59tprnYyMDCc+Pt5p1qyZc/HFFzvz5s0re8xPtyz87rvvnOuvv95p27atk5iY6KSmpjrnnnuu88EHH/zsz1XV18yRXrcbNmxwBgwY4CQlJTmSXFtY7ty50xkzZozTokULJz4+3snIyHDOP/9854UXXqjws1Rny81wOOxMmTLF6dSpk5OQkOCkpaU5gwcPdlatWlX2mJKSEmfy5MlO69atnfj4eKdFixbOpEmTXFtROk71X68/tXr1aueqq65yWrZs6QSDQadJkybOxRdf7KxcubLCY1944QWnR48eTlJSktOg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p759+9ZqQAAAAABHVqMpN926dXPtcnPYlClTFBsbe8yhcOyYuwng57DWxlv8Hga8U1cXp5pS4wlIubm5+stf/qJJkyZp7969kqSvvvpKOTk5tRYOAAAAwNHVqEP/73//W+eff74aNWqkLVu26MYbb1RqaqreeOMNbd26VS+//HJt5wQAAAAksSj2p2pU0E+cOFHXXXedHn30UTVo0KDs+C9/+Uv95je/qbVwAADvMCUEAOxQoz9vPv/8c40ePbrC8WbNmik7O/uYQwEAAAComhp16IPBoPLz8ysc//rrr5WWlnbMoQAA3mNRrLe4AgJ4h0WxbjXq0F966aW67777VFJSIkkKBALaunWr7rjjDg0dOrRWAwIAAAA4shp16B977DENGzZMTZo0UVFRkQYOHKjs7Gz16dNHDz74YG1nBBCFEpKCpiNYL1RYZDoCANQIi2LdalTQp6Sk6P3339fSpUv173//WwUFBTrjjDM0aNCg2s4HAAAA4ChqVNAf1r9/f/Xv37+2sgBAmeKikOkIAIA6ijn0blUu6J988skqP+n48eNrFAYAAABA9VS5oJ86darr8127dunAgQNq1KiRpEN3jq1Xr56aNGlCQQ8AAAAcJ1Uu6Ddv3lz237Nnz9Yzzzyjv/71r+rYsaMkaePGjbrxxhsr3Z8eAKorJjbWdATrlUYipiMAQI04AabclBdwHMep7je1bdtW8+bN0+mnn+46vmrVKg0bNsxV/B9J/0uWVHdYAFEkNj7edATrlf7f1sMAcCRL3xpoOkKlvv3uO2Njt23TxtjYR1KjRbE7duxQOByucLy0tFQ7d+485lA4dtwwxnvcNMZbjkP32GuBGLZ985LDFRDAM45Dh768Gv02P//88zV69GitXr267NiqVat00003sXUlAAAAcBzVqEP/t7/9TSNGjFDPnj0V/3+XxcPhsDIzM/WXv/ylVgOiZugew++cSLVnA6Ka4oIJpiNYjd/DAI6XGhX0aWlpeuedd/T111/rP//5jwKBgDp16qQOHTrUdj4AAADAxanZJBNrHdONpTp06KD27dtLkgKsNgYAAACOuxoX9C+//LKmTJmiTZs2STpU3P/hD3/Qb3/721oLh5pjUaz3uJwOv+M1DMCvuFOsW40K+scff1x33XWXxo4dq379+kmSli5dqt///vfavXu3JkyYUKshAQAAAFSuRgX9U089pWeffVbXXntt2bFLL71UXbp00b333ktBXwfQeQMAALaiQ+9WoxUFO3bsUN++fSsc79u3r3bs2HHMoQAAAABUTY069O3atdOcOXP0xz/+0XX8tddeK1skCwDHIiEpaDqC9UKFRaYjAABqQY0K+smTJ+uKK67Qxx9/XDaHftmyZVq0aJHmzJlTqwEBAACA8phy41ajgn7o0KH69NNP9fjjj2vBggWSpM6dO+uzzz7T6aefXpv5gDorEMMeuF4qCRWbjmC9YHKS6QhW4woIgOOlxttW9ujRQ7NmzarNLAAAAMDPokPvVq2CPiYm5mdvIBUIBBQOh48pFAAAAICqqVZBP3/+/CN+bfny5XryyScViUSq9FwxcbHVGRrV5EQc0xGsFxPLa9hL/I7wXiDAtDEv8Rr2Hu91wCHVKugvu+yyCsc2btyoO++8U2+99Zauvvpq3XfffbUWDgAAAPgpx2HKTXk1nkO/fft23XPPPZo5c6YyMzO1Zs0anXrqqVX+/ki4tKZDA3VCTDDBdASrhVkU67mSKl5RBQDUbdW+3pqXl6c77rhD7dq10/r167Vo0SK99dZb1SrmAQAAgJpyFDD2URdVq0P/6KOP6pFHHlFGRob+53/+p9IpOEC0KCk6aDqC1dhS0XtsqwgAdgg4jlPlFSUxMTFKSkrSoEGDFHuUBYFvvPHGzz5X/0uWVHVYAFGIgt57FPQAfs7StwaajlCpdd9kGxv71HYZxsY+kmp16K+99tqf3bYSAAAAwPFTrYJ+xowZtTZwWqumtfZcqKhgX77pCNZLPelE0xGs1jC1vukI1tuTvc90BKuVlrD5g9cKc/ebjgDUCTXe5QYAAAAwoa4uTjXFWEG/6/vtpoYGasW2/ALTEay2mzn0nmMOPQDYgQ49AAAAfIUbS7lx328AAADAxyjoAQAAAB8zNuUmNj7e1NBRIVLK7gpeC8Rwuc9LgQD9Bq/xe9hbjhMxHcF6TqTKt9KBZSIsinXhHRMAAADwMRbFAgAAwFfYttLNWEFfWlJiamigVnA13VuhA2yp6DUnwovYS/FJiaYjWK+k6KDpCECdQIceAAAAvsK2lW4U9AAAeIDuMYDjhUWxAAAAgI/RoQcAwAPMofceV0GiF4ti3ejQAwAAAD5Ghx4AAAC+wqJYNwp6AHVSQlLQdATrhQrZGtRLTAcBcLww5QYAAADwMWMd+mE3DjA1dFT4fmuh6QjWO7lVsukIVhvR/EPTEaw3d895piNYbcvWkOkI1vtxyz7TEWAIi2Ld6NADAAAAPmasQz/vxY9NDQ3Uis9NB7DcP5Lrm45gvVDhEtMRANR5GaYDVIpFsW506AEAAAAfY5cbAHVScRHzj73GjY+8xS43gHcipgPUMXToAQAAAB+joAcAAAB8jCk3AOokbizlPW4sBcCvWBTrRoceAAAA8DFjHXoWY3mLxVjwOxbFAgCOhBtLudGhBwAAAHzMWIeeDjIAAABw7FgUCwAAAF9hUaybsYI+qSG3dfdS6AC7V3gtIZF1IF6KiYs1HcF67HLjrUAMBYfXSkvCpiMAdQIdegAAAPgKi2LdWBQLAAAA+JixDn1RfoGpoYFacbCg0HQEqwWTk0xHsF5pSYnpCABQIxHHdIK6hQ49AAAA4GPcWMpSbAvqvUAMfw97qSRUbDqC9XgNe8uJRExHAGBYVlaW3njjDW3YsEFJSUnq27evHnnkEXXs2LHsMQcPHtStt96qV199VaFQSJmZmXrmmWeUnp5e5XH4bQ4AAABfcRQw9lEdS5Ys0ZgxY7RixQq9//77Kikp0QUXXKDCwv8/bXfChAl66623NHfuXC1ZskTbt2/X5ZdfXq1xAo7jGJmF1P+SJSaGBeATdI+9FxdMMB3BalwphQ2WvjXQdIRKLVl/wNjYA7vUq/H37tq1S02aNNGSJUs0YMAA5eXlKS0tTbNnz9awYcMkSRs2bFDnzp21fPly9e7du0rPy7aVAAAA8BWTN5YKhUIKhUKuY8FgUMFg8Ge/Ny8vT5KUmpoqSVq1apVKSko0aNCgssd06tRJLVu2rFZBTwsMAAAAqKKsrCylpKS4PrKysn72+yKRiG655Rb169dPp556qiQpOztbCQkJatSokeux6enpys7OrnImYx36zn1ONTV0VMjbs990BOudkNbQdASr9emdajqC9T5fmWs6gtVy97C1rdfydueZjoAoNGnSJE2cONF1rCrd+TFjxmjdunVaunRprWdiyg0AAAB8xcwK0EOqOr2mvLFjx+rtt9/Wxx9/rObNm5cdz8jIUHFxsXJzc11d+p07dyojI6PKz2+soN/+3Q5TQ0eFSJjt0rxWmMfN0bz0wX4WFHotNyfXdASrlZaETUewXsThvQ51m+M4GjdunObPn6+PPvpIrVu3dn29R48eio+P16JFizR06FBJ0saNG7V161b16dOnyuPQoQcAAICvRKq5faQpY8aM0ezZs/Xmm2+qQYMGZfPiU1JSlJSUpJSUFI0aNUoTJ05UamqqGjZsqHHjxqlPnz5VXhArGSzoD+Qzt9BLbJcGv8vftc90BOtx4yMA8Nazzz4rSTrnnHNcx1966SWNHDlSkjR16lTFxMRo6NChrhtLVQcdegAAAMADVbndU2JioqZPn67p06fXeBwKegAAAPiKyX3o6yL2oQcAAAB8jA49AAAAfMXktpV1kbGCnkWbAI4mIal6e/yi+kKFRaYjAABqAR16AAAA+Irjk20rjxcKegB1UnFRyHQE68UnJZqOYDWuRAM4XlgUCwAAAPiYsQ59MDnJ1NBRoTRcajqC9RLobnqqYWqK6QjW25+bbzoCcEwivNdFrQiLYl3o0AMAAAA+xhx6AAAA+Ao3lnIzVtCzXRr8LhwqNh3BakX5BaYjWM+JRExHAADUAqbcAAAAAD7GlBsAAAD4CneKdaNDDwAAAPgYHXoAADzAjbu8x827oleEO8W60KEHAAAAfIwOPYA6KRBD98VrcUE6yF6iewx4hzn0bnToAQAAAB+joAcAAAB8zNiUGxYLeYtLvfA7J8L1VK/xewKAX3GnWDc69AAAAICPGevQJ6c0MDV0VChiQaHn6p+QYjqC1RISE0xHsF7e7lzTEayWkBg0HcF6RfsLTEeAIVzEdaNDDwAAAPiYsQ59bvYuU0MDtSJCe8BT4VCx6QjWcyIR0xGsdsB0AABRg33oAQAA4CvsQ+/GlBsAAADAx+jQAzXEln/eCsTQbwAAVM4Rm3+UxzsmAAAA4GPGOvSx8fGmho4KkdJS0xGsF2BrUE8lJHLzOa8VH+QqE/yNG9BFL/7p3ejQAwAAAD5mrENfWlJiamigVjjs+Oep0IEi0xGsx7aV8Lv4JK7kARKLYgEAAOAzbFvpRkEPAFGK7qa32AnLe5xj4BAKegAAAPgKHXo3FsUCAAAAPmasQ3/Blf1MDR0Vtv2QbzqC9Vq1TjEdwWrDem4zHcF6b61tYTqC1X78sdB0BOtt37LHdASgTmDKDQAAAHwl4nAvmPKMFfQfvrnK1NBRgYVC3lu/zHQCu733aqzpCNZzIt+bjmA1tgWFHVqZDoAqoEMPAAAAX2FRrJuxgp4OMoCjiQ8mmI5gvVAhN+8CABvQoQcAAICv0KF3Y9tKAAAAwMfo0AOok4qLQqYjAADgCxT0AAAA8JUIU25cmHIDAAAA+BgdegAAAPiKw42lXIwV9IEYLg54iRuaeC8mjhsfeSmxfrLpCNYryi8wHQE4JrzXAYdQVQMAAAA+ZqxDz1/V8LtIuNR0BKuVlpSYjmA9fg8D8Cv2oXejQw8AAAD4GItiAQAA4CtsW+lGQQ+gTioJFZuOYL1gcpLpCFYLFRaZjgAgSlDQAwAAwFeYQ+9mrKCPT0o0NXRUKCk6aDoCcEwcrqd6jg4yANiBRbEAAACAjxnr0NNBht9xczRvJdavZzqC9Q4WHDAdwWpsCwp4hyk3blQkAAAAgI+xKBaoIbpv3oqUcuMur/EaBuBXLLNyo0MPAAAA+BgFPQAAAOBjTLmxFNuCei/MjY88FS4Om45gPRZ2e4spTYB3WBTrxm9zAAAAwMfo0FuKbUHhd3FJQdMRrBcqLDEdAQBqhAtgbnToAQAAAB8z1qFn7qa3mLvpPV7D3oqJjTUdwXq8hr3F72HAO8yhd+O3OQAAAOBjFPQAAACAjxmbctOgcSNTQ0eFErZU9Fx8MMF0BKtltEo3HcF6OT/uNh3BasUHQ6YjWI/3uujFlBs3OvQAAACAjxnr0Ofv2mtqaKBWFJkOYLn9e3JNR7BeHFeZPMX2wYB3InToXejQAwAAAD7GjaUAIErRQQYAO1DQAwAAwFcco6tiAwbHrpyxgj42Pt7U0FHBcbihide48ZG3khs1MB3BeoW5+01HsJrDJF/PRUpLTUcA6gQ69AAAAPAVtq10Y1EsAAAA4GPGOvSlJSWmhgZqRSTMpV4v5e/aZzqC9ZwIU/O8FJ+UaDqC9aglgEOYcgMAAABfoR/hRkEPAIAH2BYUwPFCQQ8AAABfYVGsG4tiAQAAAB+jQw8AAABf4TYPbnToAQAAAB+jQw+gTkpICpqOYL1QYZHpCACAWkBBDwAAAF9hUaybsYI+Jb2xqaGjQiTMBq1ei4ljxpqXTkhPNR3Berk5uaYjWK20JGw6gvUiDu91gESHHgAAAD7jGF0VGzA4duWMFfR5O/eYGjoqcMtx73HTGG/l79pnOoL1HG61CABWYM4AAAAA4GNMubEU3WP4HbvceI9dbgD4FfvQu9GhBwAAAHyMDj0AAAB8hW0r3YwV9Cza9BZTbuB3xUUh0xEAAPAFOvQAAADwlQiT6F2MFfT/c1+CqaGjwmubzjIdwXqjE2eajmC1Rb/MMh3Beud8/IjpCFbblXaK6QjWe+/bDqYjAHUCi2IBAAAAHws4jpllBRfdsM7EsFEjEuaGMV6LiePvYS+dkJ5qOoL1cnNyTUewWmlJ2HQE60Uc3uu8tnBmd9MRKvXQa6XGxv7jFbHGxj4SKhIAAADAx1gUCwAAAF9h20o3YwV9wd58U0NHhUipuUtR0SIuyMJuL7Ftpfc4x94KxARMR7BebFzdm/oAmMCUGwAAAMDHjHXoY/ir2lOlJSWmI1iPm3d5Kxyi3+A1J8KCQvhbmItMUSvCnBsX3jEBAAAAHzPWoae7CQCwWXxSoukI1qOWiF7sWOpGhx4AAADwMbatBADAA3SPAe8Yui9qnUWHHgAAAPAxCnoAAADAx5hyAwBRikWb3mLKDeAddt11o0MPAAAA+JixDv0vr+lvauio8P3mPNMRrDf4/BTTEazWP+kz0xGs9/buXqYjWO3rb7nrkde+/2a36QgwhEWxbnToAQAAAB8z1qF///WVpoaOCszd9N76ZaYT2O2xGPoNXnMiS0xHAFDnNTMdwNc+/vhjTZkyRatWrdKOHTs0f/58DRkypOzrjuPonnvu0Ysvvqjc3Fz169dPzz77rNq3b1+tcXjHBAAAgK9EHHMf1VFYWKjTTjtN06dPr/Trjz76qJ588kk999xz+vTTT5WcnKzMzEwdPFi9xiy73AAAAAAeGDx4sAYPHlzp1xzH0bRp0/TnP/9Zl112mSTp5ZdfVnp6uhYsWKArr7yyyuMYK+iZEgK/Y8s/b4VDxaYjAADqKKe6rfJaFAqFFAq5F70Hg0EFg8FqPc/mzZuVnZ2tQYMGlR1LSUlRr169tHz58moV9Ey5AQAAAKooKytLKSkpro+srKxqP092drYkKT093XU8PT297GtVxZQboIa4yuStAItiAQBHYHLXykmTJmnixImuY9Xtztc2CnoAAACgimoyvaYyGRkZkqSdO3fqpJNOKju+c+dOde/evVrPRUEPAAB8ibVM8LPWrVsrIyNDixYtKivg8/Pz9emnn+qmm26q1nNR0AMAAMBXIgYXxVZHQUGBvvnmm7LPN2/erDVr1ig1NVUtW7bULbfcogceeEDt27dX69atddddd6lp06auveqrwlhBHxMXa2roqGBy9Xe0CMQETEewWnwwwXQE65WwkxB8jt2wUNetXLlS5557btnnh+fejxgxQjNmzNDtt9+uwsJC/e53v1Nubq769++v9957T4mJ1bv6FHAcM8sKBvxqqYlhowYFvfco6L1FQe89Cnr4He913vvkzbNNR6jUHS8UGRv7kd8lGRv7SNhGAgAAAPAxY1NuIuFSU0MDtcKJmE5gt0Ai/Qav8XsYAOzAolgAAAD4Ck01N2MFfbsenUwNHRXy9+43HcF6Hbo2Nx3Bah3bsR2d175cV2A6gtV2Z+ebjmC93Jxc0xGAOoEOPQAAAHwlYvJWsXWQsYJ+26YfTQ0dFYqLQqYjWO/T7D2mI1jt38vrmY5gvQP5dOi9xA4s3nOYdwFIokMPAAAAnzG063qdZaygL6IzBJ8rLSkxHcFqMezz7zluygMAdmBfOAAAAMDHmHIDAAAAX4mwRsWFgh5AncTCbgAAqoaCHgAAAL7Cmlg3CnqghuKTuPGRl1iwCQBA1bAoFgAAAPAxYx16upveKik6aDqC9TjH3grE0G8AAFSOG7e58Y4JAAAA+Bhz6AEAAOArEVbFuhgr6Nue1tbU0FEhNyffdATrtel8kukIVut9RtB0BOt9/OkB0xGstjdnv+kI1tuXk2s6AlAn0KEHAACArzCH3s1YQb9hxXpTQwO1Ivu7H0xHsNryd1ni4zUnEjEdwWps/uA9Nic4HjqbDoAq4B0TAAAA8DFjHfrOfU41NXRU2LF5p+kI1mvRoanpCFZr3aah6QjW27Rxn+kIVisqDJmOYL0923abjgBDmHLjRoceAAAA8DFjHfr/LF9namigVuRm7zIdwWrrltJv8FpcMMF0BKsxvxvwDg16N94xAQAAAB+joAcAAAB8zNiUm5T0xqaGjgqRMNvReS0mjr+HvXRCeqrpCNbL5aY8niqtl2Q6gvUiDu910YpFsW5UJAAAAICPGevQhwpZLOSlklCx6QjWCybTffPS/r37TUewXmlJ2HQEqxUf5H3Oa+FiXsPRynHo0JdHhx4AAADwMWMd+mAyt8T2Ujzb0XmOOfTeapDawHQE6+XmlJqOYLUE8T7ntbggc+gByWBBDwAAANREhEWxLrQYAQAAAB8z1qHP27nH1NAAfOBgwQHTEawXKiwyHQEAaoRFsW506AEAAAAfYw49gDqpuChkOgJwTOKTWBTrtZIitgaNVtxYyo0OPQAAAOBjxjr0KemNTQ0dFSJhtvLyGttWeuuE9FTTEayXm5NrOoLVuHGX9xKSgqYjAHUCU24AAADgK0y5caPFCAAAAPgYHXoAAAD4SoRtK13o0AMAAAA+xo2lgBpiSzpv5e/aZzqC9ZwIi+cBwAZMuQEAAICvsCjWzVhBf+nIs00NHRW+3ZRrOoL1LruggekIVjs7ssh0BOstOHCh6QhW+25riekI1tv0n12mIwB1Ah16AAAA+IrDolgXYwX9P2Z8YmpooFasX2Y6gd0CMcmmI1jPiSwxHQFAndfUdABUAR16AAAA+EqEOfQubFsJAAAA+JixDn1Gmxamho4KB/YXmo5gvZNaZ5iOYLXmrRqZjmC9zZt2m45gtfw9+01HsB7vdcAhTLkBAACAr7BtpZuxgj77ux9MDQ3UiqKCA6YjWO3rlcWmI1iPG0sBgB3o0AMAAMBX2LbSzVhBH5+UaGroqFBSdNB0BOtxjr0ViGHNPgAAVcE7JgAAAOBjxjr0MTEBU0NHhdj4eNMRrBdMTjIdwWopJzYyHcF6+7L3mI5gNcdhjYLXwsVh0xFgCGuA3OjQAwAAAD7GolgAAAD4CneKdTNW0IcKi0wNDdSKA7klpiNYrbSE8+s1fg8DgB3o0AMAAMBX2LbSjYIeQJ1UXBQyHQFAHccW2MAhLIoFAAAAfIwbS1mKmx4BAGzHe130clgU60KHHgAAAPAx5tADAADAV+jQuxkr6Ju1b2Fq6KhQsK/AdATr1T+hvukIVut6eobpCNb7z7pdpiNYrWBfoekI1ivM470OkJhyAwAAAPiasQ79ln9vMjU0UCt2/2A6gd2+X/et6QjWiwsmmI5gNRZsAt6JOBHTEeoUOvQAAACAj7EoFgCiFB1k+B1bYEcvFsW60aEHAAAAfIwOPYA6KSEpaDqC9UKFRaYjAMeEq0zRiw69Gx16AAAAwMco6AEAAAAfY8oNgDqpuChkOgIAoI5yHKbclEeHHgAAAPAxYx36QAx/S3jJiXDDBa/FxMWajmC1mFjOr9cipaWmI1iNRXve4+Zo0StCneNCVQ0AAAD4mLEO/an9u5oaOirk7y00HcF6J2Y0NB3Baplnc8MYry38hC3/vJS7h9/DXsvbnW86AlAnsCgWAAAAvsKUNjem3AAAAAA+ZqxDv/bjL00NDdSK79eZTmC31YvpN3iNBYXe4i6msEMH0wEq5Tgsii2Pd0wAAADAx5hDDwBRig4yAL9iDr0bHXoAAADAx+jQAzUUn8S2il4Kh4pNRwAAwBco6AEAAOArTLlxo6AHUCfFxMaajmA99ojwlsOt6QEcJxT0AAAA8JUI21a6sCgWAAAA8DFjHfqU9Mamho4KkTB/uXotJo6/h710Qnqq6QjWy83JNR3BaqUlYdMRrEeXFjiEKTcAAADwFRbFuhkr6PN27jE1NAAfyN+1z3QE67Fo01tsbes9bo4GHEKHHgAAAL5CQ8KNgh5AnRSsl2Q6gvUOFhSajmA1uscAjhcKegAAAPgKc+jdKOiBGmJ+rLdCB4pMRwAAwBfYdw8AAADwMTr0AAAA8BWHexC4UNADNcSCN28FYriA6DWmjXmL3xEAjhcKegAAAPhKhEWxLsYK+pT0xqaGjgqRMJeivBYTRwfZSyekp5qOYL3cnFzTEaxWytarnosw7QKQxKJYAAAAwNeYcgMAAABf4U6xbnToAQAAAB+jQw8AAABf4U6xbsYK+ryde0wNDcAHDhYcMB3BeqFC7sYLADZgyg0AAADgY8Y69NzQxFvc0AR+V1wUMh0BAFBHcadYNzr0AAAAgI8Z69DHxbMe10vhEH+reS2W17Cn4oMJpiNYj6sg8LtIaanpCDCERbFuVH0AAACAjxlrMSYkBU0NHRXi4uNNR7BeTBx/D3vphPRU0xGsl5uTazqC1UpLwqYjWC/CPOqoxY2l3KhIAAAAAB+joAcAAAB8LOA4DqsKfkYoFFJWVpYmTZqkYJCpQrWN8+s9zrH3OMfe4vx6j3PsLc4vvERBXwX5+flKSUlRXl6eGjZsaDqOdTi/3uMce49z7C3Or/c4x97i/MJLTLkBAAAAfIyCHgAAAPAxCnoAAADAxyjoqyAYDOqee+5hEYtHOL/e4xx7j3PsLc6v9zjH3uL8wkssigUAAAB8jA49AAAA4GMU9AAAAICPUdADAAAAPkZBDwAAAPgYBf3PmD59uk4++WQlJiaqV69e+uyzz0xHssrHH3+sSy65RE2bNlUgENCCBQtMR7JKVlaWzjzzTDVo0EBNmjTRkCFDtHHjRtOxrPHss8+qW7duatiwoRo2bKg+ffro3XffNR3LWg8//LACgYBuueUW01Gsce+99yoQCLg+OnXqZDqWdbZt26ZrrrlGjRs3VlJSkrp27aqVK1eajgWLUNAfxWuvvaaJEyfqnnvu0erVq3XaaacpMzNTOTk5pqNZo7CwUKeddpqmT59uOoqVlixZojFjxmjFihV6//33VVJSogsuuECFhYWmo1mhefPmevjhh7Vq1SqtXLlS5513ni677DKtX7/edDTrfP7553r++efVrVs301Gs06VLF+3YsaPsY+nSpaYjWWXfvn3q16+f4uPj9e677+qrr77SY489phNOOMF0NFiEbSuPolevXjrzzDP19NNPS5IikYhatGihcePG6c477zSczj6BQEDz58/XkCFDTEex1q5du9SkSRMtWbJEAwYMMB3HSqmpqZoyZYpGjRplOoo1CgoKdMYZZ+iZZ57RAw88oO7du2vatGmmY1nh3nvv1YIFC7RmzRrTUax15513atmyZfrkk09MR4HF6NAfQXFxsVatWqVBgwaVHYuJidGgQYO0fPlyg8mAmsvLy5N0qOhE7SotLdWrr76qwsJC9enTx3Qcq4wZM0YXXXSR6/cxas+mTZvUtGlTtWnTRldffbW2bt1qOpJV/vGPf6hnz5769a9/rSZNmuj000/Xiy++aDoWLENBfwS7d+9WaWmp0tPTXcfT09OVnZ1tKBVQc5FIRLfccov69eunU0891XQca6xdu1b169dXMBjU73//e82fP1+nnHKK6VjWePXVV7V69WplZWWZjmKlXr16acaMGXrvvff07LPPavPmzTr77LO1f/9+09Gs8d133+nZZ59V+/bttXDhQt10000aP368Zs6caToaLBJnOgCA42PMmDFat24d82NrWceOHbVmzRrl5eVp3rx5GjFihJYsWUJRXwt++OEH3XzzzXr//feVmJhoOo6VBg8eXPbf3bp1U69evdSqVSvNmTOHaWO1JBKJqGfPnnrooYckSaeffrrWrVun5557TiNGjDCcDragQ38EJ554omJjY7Vz507X8Z07dyojI8NQKqBmxo4dq7ffflsffvihmjdvbjqOVRISEtSuXTv16NFDWVlZOu200/TEE0+YjmWFVatWKScnR2eccYbi4uIUFxenJUuW6Mknn1RcXJxKS0tNR7ROo0aN1KFDB33zzTemo1jjpJNOqvAHfufOnZnahFpFQX8ECQkJ6tGjhxYtWlR2LBKJaNGiRcyPhW84jqOxY8dq/vz5Wrx4sVq3bm06kvUikYhCoZDpGFY4//zztXbtWq1Zs6bs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",
      "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": 41,
   "id": "dce60711",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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
}
