{
 "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_33560\\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_33560\\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\\\\DBLP'"
      ]
     },
     "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\\\\DBLP\\\\DBLP'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "dataset = os.path.join(os.getcwd(),'DBLP')\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": [],
   "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 = ['PubMed']\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=[17716, 1639], edge_index=[2, 105734], y=[17716])\n",
      "torch.Size([17716, 1639]) torch.Size([17716, 17716])\n",
      "torch.Size([17716, 1639]) torch.Size([17716, 17716])\n"
     ]
    }
   ],
   "source": [
    "# # from torch_geometric.datasets import Planetoid\n",
    "# from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "# # # dataset = NELL(root='/nell')\n",
    "# k_ = dataset.num_classes\n",
    "\n",
    "# # dataset= Planetoid(root=dataset, name='Cora')\n",
    "# print(dataset[0])\n",
    "# adj = to_dense_adj(dataset[0].edge_index).cuda()\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)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "from torch_geometric.datasets import DBLP\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "from torch_geometric.datasets import CitationFull\n",
    "from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "dataset = CitationFull(root='/DBLP',name='dblp')\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",
    "k_=NO_OF_CLASSES\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "labels = labels[: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([17716, 1639])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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([17716, 17716])\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": 8,
   "id": "114a42e0",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "114a42e0",
    "outputId": "62b0a402-9d33-44be-8e7f-20de623be138"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 17716\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": 9,
   "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": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": 12,
   "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": 13,
   "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": 14,
   "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",
    "        # 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('cuda' if torch.cuda.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('cuda' if torch.cuda.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(200):\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": 15,
   "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": null,
   "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_33560\\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_33560\\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_33560\\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_33560\\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_33560\\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 [36:18<00:00, 217.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Accuracy = 0.4470535109505532 1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/10 [00:00<?, ?it/s]C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_33560\\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_33560\\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_33560\\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 [37:17<00:00, 223.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [32:37<00:00, 195.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [34:12<00:00, 205.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [35:52<00:00, 215.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [36:15<00:00, 217.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [38:14<00:00, 229.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [37:31<00:00, 225.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [34:33<00:00, 207.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [33:01<00:00, 198.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [38:23<00:00, 230.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████| 10/10 [34:13<00:00, 205.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Epoch: 100,loss: 0.0001\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|████████████████████████▌                                                         | 3/10 [07:48<20:23, 174.84s/it]"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "#RUN FROM alpha 10 ......11sep_6pm\n",
    "for alpha_param in [1000,100,1,0.1,0.01,0.001,0.0001,10]:\n",
    "  for beta_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "      for gamma_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(2):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\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",
    "              acc = get_accu(C_test,L_test,X_t_test)\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": null,
   "id": "e5be4965",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "#RUN FROM alpha 10 ......11sep_6pm\n",
    "for alpha_param in [0.1,0.01,0.001,0.0001,10]:\n",
    "  for beta_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "      for gamma_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(2):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\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",
    "              acc = get_accu(C_test,L_test,X_t_test)\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": 26,
   "id": "pqDLVv1Wn9RD",
   "metadata": {
    "id": "pqDLVv1Wn9RD"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7971325355610748"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "highest_accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8fe6add",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in []:\n",
    "  for beta_param in []:\n",
    "      for gamma_param in []:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(2):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\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",
    "              acc = get_accu(C_test,L_test,X_t_test)\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": 37,
   "id": "FN7Cp3UQoMKv",
   "metadata": {
    "id": "FN7Cp3UQoMKv"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvgAAAK9CAYAAABRtxg8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABFdElEQVR4nO3de5hVZdk4/nsGYUZEPISAEIriuRQUhNAUzVFM1HjLRDtwyBRNPFEepgzE06QmooLHQrTkK2oek0jF0FejVJQ3pRw0QXqVQdEARQVl9u8Pf87rxLgcxmGvWYvP57r2dTGLtddz7z37WnOve9/Ps0oKhUIhAACAXChNOwAAAKD5SPABACBHJPgAAJAjEnwAAMgRCT4AAOSIBB8AAHJEgg8AADkiwQcAgByR4AMAQI5I8IHc+fDDD+Oss86Kbt26RWlpaQwePDjtkD7TAQccEAcccECTnjt8+PDo3r17s8bzn6ZMmRIlJSWxcOHCxP3OO++8KCkpadIY3bt3j8MPP7xJz/00JSUlcd555zXrMQFaOgk+tCAfJ1FPP/10g/9/wAEHxJe//OX1GsP06dMznxBNnjw5LrvssjjqqKPi5ptvjjPOOCPtkACgaDZKOwCgZZk+fXpMmjQp00n+I488El27do0rrrgi7VAa7cEHH2zyc2+88caora1txmgAyDIVfCB3Xn/99dh8882b7Xi1tbXx/vvvN9vxPundd9+NiIg2bdpEmzZtmnSM1q1bR1lZWXOGBUCGSfAhB377299G7969Y+ONN44tt9wyjjnmmPjXv/5Vb5///u//jm9/+9uxzTbbRFlZWXTr1i3OOOOMeO+99+r2GT58eEyaNCkiPupd/vgREbFw4cIoKSmJX/7ylzFp0qTYfvvto23btnHIIYfEv/71rygUCnHBBRfEF7/4xdh4443jG9/4Rrz11lv1Yrj33ntj0KBB0aVLlygrK4sePXrEBRdcEGvWrKm338etSHPmzIl99tknNt5449huu+3iuuuuS3wfPo7xT3/6U8ybN68u/lmzZkVExMqVK+PHP/5xdOvWLcrKymLnnXeOX/7yl1EoFOodp6SkJEaNGhW33nprfOlLX4qysrKYMWNG4tjXXHNN3b5dunSJk08+OZYtW/apr2v//fePtm3bxk9/+tO6//vPHvxXXnkljjzyyNhkk02iY8eOccYZZ8Qf//jHeq8pYu0e/E/+rm644Ybo0aNHlJWVxd577x1PPfVUvTH+9re/xfDhw2P77beP8vLy6Ny5c/zgBz+IN998M/H1roubbropvva1r0XHjh2jrKwsdtttt7j22ms/df8HH3wwevXqFeXl5bHbbrvFXXfdtdY+y5Yti9NPP73ud7nDDjvEJZdc8pnfZLz99ttx+umnR/fu3aOsrCw6duwYBx98cDzzzDOf+3UCtBRadKAFWr58eSxdunSt7R988MFa2y666KL4+c9/HkcffXT88Ic/jDfeeCOuvvrq2H///ePZZ5+tq2Tfcccd8e6778ZJJ50UX/jCF+LJJ5+Mq6++Ov73f/837rjjjoiIGDlyZLz22mvx0EMPxW9+85sGY7v11ltj9erVccopp8Rbb70Vl156aRx99NHxta99LWbNmhVnn312vPTSS3H11VfHT37yk5g8eXLdc6dMmRLt2rWL0aNHR7t27eKRRx6JMWPGxIoVK+Kyyy6rN86///3vOOyww+Loo4+OY489Nm6//fY46aSTok2bNvGDH/ygwdi22mqr+M1vfhMXXXRRvPPOO1FVVRUREbvuumsUCoU48sgj409/+lMcd9xx0atXr/jjH/8YZ555Zrz66qtrtfM88sgjcfvtt8eoUaOiQ4cOiZNYzzvvvBg3blxUVFTESSedFNXV1XHttdfGU089FU888US0bt26bt8333wzvv71r8cxxxwT3/ve96JTp04NHnPlypXxta99LRYvXhynnXZadO7cOaZOnRp/+tOfPjWO/zR16tR4++23Y+TIkVFSUhKXXnppfPOb34yXX365LqaHHnooXn755RgxYkR07tw55s2bFzfccEPMmzcv/vKXvzR5wuwnXXvttfGlL30pjjzyyNhoo43i/vvvjx/96EdRW1sbJ598cr19X3zxxRgyZEiceOKJMWzYsLjpppvi29/+dsyYMSMOPvjgiPjoW48BAwbEq6++GiNHjoxtttkm/vznP0dlZWUsXrw4JkyY8KmxnHjiiXHnnXfGqFGjYrfddos333wzHn/88fjHP/4Re+211+d+rQAtQgFoMW666aZCRCQ+vvSlL9Xtv3DhwkKrVq0KF110Ub3jPPfcc4WNNtqo3vZ33313rfGqqqoKJSUlhVdeeaVu28knn1xo6NSwYMGCQkQUttpqq8KyZcvqtldWVhYiotCzZ8/CBx98ULf92GOPLbRp06bw/vvvJ8YwcuTIQtu2bevtN2DAgEJEFC6//PK6batWrSr06tWr0LFjx8Lq1avXfvM+YcCAAfXep0KhULjnnnsKEVG48MIL620/6qijCiUlJYWXXnqpbltEFEpLSwvz5s1LHKdQKBRef/31Qps2bQqHHHJIYc2aNXXbJ06cWIiIwuTJk9d6Xdddd12DMQ8YMKDu58svv7wQEYV77rmnbtt7771X2GWXXQoRUfjTn/5Ut33YsGGFbbfdtu7nj39XX/jCFwpvvfVW3fZ77723EBGF+++/v25bQ7+T//f//l8hIgqPPfZY3baPP5sLFixIfD/Gjh271uenoTEGDhxY2H777ett23bbbQsRUfjd735Xt2358uWFrbfeurDnnnvWbbvgggsKm2yySWH+/Pn1nn/OOecUWrVqVVi0aFHdtogojB07tu7nzTbbrHDyyScnvgaArNOiAy3QpEmT4qGHHlrrsccee9Tb76677ora2to4+uijY+nSpXWPzp07x4477liv2rvxxhvX/XvlypWxdOnS2GeffaJQKMSzzz7b6Ni+/e1vx2abbVb3c79+/SIi4nvf+15stNFG9bavXr06Xn311QZjePvtt2Pp0qWx3377xbvvvhsvvPBCvXE22mijGDlyZN3Pbdq0iZEjR8brr78ec+bMaXS8H5s+fXq0atUqTj311Hrbf/zjH0ehUIg//OEP9bYPGDAgdtttt8887sMPPxyrV6+O008/PUpL/++Uevzxx0f79u3jgQceqLd/WVlZjBgx4jOPO2PGjOjatWsceeSRddvKy8vj+OOP/8znfmzIkCGxxRZb1P283377RUTEyy+/XLftk7+T999/P5YuXRpf+cpXIiKarW3lk2N8/O3UgAED4uWXX47ly5fX27dLly7xX//1X3U/t2/fPoYOHRrPPvts1NTURMRH30btt99+scUWW9T73FdUVMSaNWviscce+9RYNt988/jrX/8ar732WrO8NoCWSIsOtEB9+/aNPn36rLX944TmYy+++GIUCoXYcccdGzzOJ1tDFi1aFGPGjIn77rsv/v3vf9fb7z+TrCTbbLNNvZ8/Tva7devW4PZPjjVv3rw499xz45FHHokVK1YkxtClS5fYZJNN6m3baaedIuKjHvOPk9DGeuWVV6JLly6x6aab1tu+66671v3/J2233XaNPm5ExM4771xve5s2bWL77bdf67hdu3Zt1GTaV155JXr06LFWi8wOO+zQqLgi1v5dfZzsf/J38tZbb8W4cePitttui9dff73e/uvyuUjyxBNPxNixY2P27Nl1k4o/OcYnLxh32GGHtV7zJ3/vnTt3jhdffDH+9re/xVZbbdXgeP/5Oj7p0ksvjWHDhkW3bt2id+/ecdhhh8XQoUNj++23b+rLA2hxJPiQYbW1tVFSUhJ/+MMfolWrVmv9f7t27SIiYs2aNXHwwQfHW2+9FWeffXbssssusckmm8Srr74aw4cPX6clFhsaJ2l74f+fwLps2bIYMGBAtG/fPs4///zo0aNHlJeXxzPPPBNnn312i1vm8ZNV5ywctyGf9TuJiDj66KPjz3/+c5x55pnRq1evaNeuXdTW1sahhx7aLL+Tf/7zn3HQQQfFLrvsEuPHj49u3bpFmzZtYvr06XHFFVc0aYza2to4+OCD46yzzmrw/z++IGjI0UcfHfvtt1/cfffd8eCDD8Zll10Wl1xySdx1113x9a9/fZ1jAWiJJPiQYT169IhCoRDbbbddYlLz3HPPxfz58+Pmm2+OoUOH1m1/6KGH1tq3OSZVNmTWrFnx5ptvxl133RX7779/3fYFCxY0uP9rr70WK1eurFfFnz9/fkREk+7auu2228bDDz8cb7/9dr0q/setQdtuu+06H/OTz6uurq5XBV69enUsWLAgKioqmnzcv//971EoFOr9Tl566aUmHa8h//73v2PmzJkxbty4GDNmTN32F198sdnGuP/++2PVqlVx33331ftG4dMmC7/00ktrveb//L336NEj3nnnnSa/t1tvvXX86Ec/ih/96Efx+uuvx1577RUXXXSRBB/IDT34kGHf/OY3o1WrVjFu3Li1lnosFAp1Sx1+XMn95D6FQiGuvPLKtY75cUL9n0s8fl4NxbB69eq45pprGtz/ww8/jOuvv77evtdff31stdVW0bt373Ue/7DDDos1a9bExIkT622/4ooroqSkpMnJXUVFRbRp0yauuuqqeq/t17/+dSxfvjwGDRrUpOMOHDgwXn311bjvvvvqtr3//vtx4403Nul4DWnodxIRiavQNMcYy5cvj5tuuqnB/V977bW4++67635esWJF3HLLLdGrV6/o3LlzRHxUhZ89e3b88Y9/XOv5y5Ytiw8//LDBY69Zs2attqOOHTtGly5dYtWqVev2wgBaMBV8yLAePXrEhRdeGJWVlbFw4cIYPHhwbLrpprFgwYK4++6744QTToif/OQnscsuu0SPHj3iJz/5Sbz66qvRvn37+N3vfrdWL35E1CXPp556agwcODBatWoVxxxzzOeOdZ999oktttgihg0bFqeeemqUlJTEb37zm7WSy4916dIlLrnkkli4cGHstNNOMW3atJg7d27ccMMN9eYWNNYRRxwRBx54YPzsZz+LhQsXRs+ePePBBx+Me++9N04//fTo0aNHk17XVlttFZWVlTFu3Lg49NBD48gjj4zq6uq45pprYu+9947vfe97TTruyJEjY+LEiXHsscfGaaedFltvvXXceuutUV5eHhHN801L+/btY//9949LL700Pvjgg+jatWs8+OCDn/qtSlMccsgh0aZNmzjiiCNi5MiR8c4778SNN94YHTt2jMWLF6+1/0477RTHHXdcPPXUU9GpU6eYPHlyLFmypN4FwZlnnhn33XdfHH744TF8+PDo3bt3rFy5Mp577rm48847Y+HChdGhQ4e1jv3222/HF7/4xTjqqKOiZ8+e0a5du3j44Yfjqaeeissvv7zZXjNA2iT4kHHnnHNO7LTTTnHFFVfEuHHjIuKjCa+HHHJI3QosrVu3jvvvvz9OPfXUqKqqivLy8viv//qvGDVqVPTs2bPe8b75zW/GKaecErfddlv89re/jUKh0CwJ/he+8IX4/e9/Hz/+8Y/j3HPPjS222CK+973vxUEHHRQDBw5ca/8tttgibr755jjllFPixhtvjE6dOsXEiRPXaRWZTyotLY377rsvxowZE9OmTYubbropunfvHpdddln8+Mc//lyv7bzzzoutttoqJk6cGGeccUZsueWWccIJJ8TFF1/cpIuRiKi7T8App5wSV155ZbRr1y6GDh0a++yzT3zrW9+qS/Q/r6lTp8Ypp5wSkyZNikKhEIccckj84Q9/iC5dujTL8Xfeeee4884749xzz42f/OQn0blz5zjppJNiq622avB+BjvuuGNcffXVceaZZ0Z1dXVst912MW3atHqfkbZt28ajjz4aF198cdxxxx1xyy23RPv27WOnnXaKcePG1Zu0+0lt27aNH/3oR/Hggw/WrUC1ww47xDXXXBMnnXRSs7xegJagpPBp5TOAlBxwwAGxdOnSeP7559MOpcWZMGFCnHHGGfG///u/0bVr17TDAaAF0oMP0EK999579X5+//334/rrr48dd9xRcg/Ap9KiA9BCffOb34xtttkmevXqFcuXL4/f/va38cILL8Stt96admgAtGASfIAWauDAgfGrX/0qbr311lizZk3stttucdttt8WQIUPSDg2AFkwPPgAArAePPfZYXHbZZTFnzpxYvHhx3H333TF48ODE58yaNStGjx4d8+bNi27dusW5554bw4cPX6dx9eADAMB6sHLlyujZs2dMmjSpUfsvWLAgBg0aFAceeGDMnTs3Tj/99PjhD3/Y4H0/kqjgAwDAelZSUvKZFfyzzz47HnjggXqryB1zzDGxbNmymDFjRqPHUsEHAIBGWrVqVaxYsaLeo7nuhj179uyoqKiot23gwIExe/bsdTpOapNsH2i9c1pDs4GpOvSGtEMAgEx6/P4BaYfQoDTzyKd+dmzdjSU/Nnbs2DjvvPM+97FramqiU6dO9bZ16tQpVqxYEe+9915svPHGjTqOVXQAAKCRKisrY/To0fW2lZWVpRRNwyT4AABkSknrktTGLisrW28JfefOnWPJkiX1ti1ZsiTat2/f6Op9RIoJvrYJiqVyxglph8AGwnkNgM+jf//+MX369HrbHnrooejfv/86HSe1BF/SRbFIugCANLzzzjvx0ksv1f28YMGCmDt3bmy55ZaxzTbbRGVlZbz66qtxyy23RETEiSeeGBMnToyzzjorfvCDH8QjjzwSt99+ezzwwAPrNK4WHQAAMqV0o/RadNbF008/HQceeGDdzx/37g8bNiymTJkSixcvjkWLFtX9/3bbbRcPPPBAnHHGGXHllVfGF7/4xfjVr34VAwcOXKdxJfgAALAeHHDAAZF0y6kpU6Y0+Jxnn332c40rwQcAIFNKWruVUxLvDgAA5IgKPgAAmZKVHvy0qOADAECOSPABACBHtOgAAJApad7JNgtU8AEAIEdU8AEAyBSTbJOlluBXHXpDWkMDQKZVzjgh7RDYYFSnHQBNUFJIur3WevRA653TGJYNkItJAGiax+8fkHYIDXqk+x6pjf21hX9LbezGUsEHgIxRwad4WmYF3yTbZHrwAZqJpItiUSSjWAalHQBNklqC7w8hxeIPIcXiswZQHCbZJrNMJgAA5IgWHQAAMqWklQp+EpNsASBjtLlS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Uxu7sVz+AABAjphkCwBAphRMsk2kgg8AADmigg8AQLa40VUiq+iQe1aboFic1wBoCVTwyT1JF5A3ChcUTwtdJpNElskk9yT4ANA0LXWZzPdm/b/Uxt74gGNTG7uxNDABAECOaNEBACBTLJOZTAUfAAByRIIPAAA5okUHAIBssQ5+Iu8OAADkiAo+AADZYpJtIhV8AADIERV8AACypVSNOol3BwAAckSCDwAAOaJFBwCATHEn22Qq+AAAkCMq+AAAZIsbXSXy7gAAQI5I8AEAIEe06AAAkCkFLTqJvDsAAJAjKvgAAGSLZTITpZbgVx16Q1pDA0CmVc44Ie0Q2GBUpx0ATVBSKBQKaQz8QOud0xiWDZCLSQBomsfvH5B2CA16+8kHUht7076DUhu7sfTgAwBAjkjwAQBgPZo0aVJ07949ysvLo1+/fvHkk08m7r9s2bI4+eSTY+utt46ysrLYaaedYvr06Y0ezyRbAACyJUOTbKdNmxajR4+O6667Lvr16xcTJkyIgQMHRnV1dXTs2HGt/VevXh0HH3xwdOzYMe68887o2rVrvPLKK7H55ps3ekwJPgAArCfjx4+P448/PkaMGBEREdddd1088MADMXny5DjnnHPW2n/y5Mnx1ltvxZ///Odo3bp1RER07959ncbUogMAQLaUlKb2WLVqVaxYsaLeY9WqVQ2GuXr16pgzZ05UVFTUbSstLY2KioqYPXt2g8+57777on///nHyySdHp06d4stf/nJcfPHFsWbNmka/PRJ8AABopKqqqthss83qPaqqqhrcd+nSpbFmzZro1KlTve2dOnWKmpqaBp/z8ssvx5133hlr1qyJ6dOnx89//vO4/PLL48ILL2x0jFp0AACgkSorK2P06NH1tpWVlTXb8Wtra6Njx45xww03RKtWraJ3797x6quvxmWXXRZjx45t1DHc6Ircc0MYisV5DaA4CilOsi0rK2t0Qt+hQ4do1apVLFmypN72JUuWROfOnRt8ztZbbx2tW7eOVq1a1W3bddddo6amJlavXh1t2rT5zHFTS/AlXRSLpAsASEObNm2id+/eMXPmzBg8eHBEfFShnzlzZowaNarB5+y7774xderUqK2tjdLSj7rp58+fH1tvvXWjkvsIPfgAAGRNipNs19Xo0aPjxhtvjJtvvjn+8Y9/xEknnRQrV66sW1Vn6NChUVlZWbf/SSedFG+99VacdtppMX/+/HjggQfi4osvjpNPPrnRY+rBBwCA9WTIkCHxxhtvxJgxY6KmpiZ69eoVM2bMqJt4u2jRorpKfUREt27d4o9//GOcccYZsccee0TXrl3jtNNOi7PPPrvRY5YUCoVCs7+SRnig9c5pDMsGSIsOADTN4/cPSDuEBi1/5uHUxt5sr4rP3illWnQAACBHJPgAAJAjevABAMiUQhMmu25IvDsAAJAjKvgAAGSLCn4i7w4AAOSIBB8AAHJEiw4AAJlSKClJO4QWTQUfAAByRAUfAIBMsUxmMu8OAADkiAo+AADZogc/kQo+AADkiAQfAAByRIsOAACZYpJtMu8OAADkSGoV/KpDb0hraDYwlTNOSDsENhDOawDFUQiTbJOkluBLuigWSRcAsCFRwSf3XExSLM5rALQEKvjknqQLAPLFJNtk3h0AAMgRy2QCAJAt7mSbSAUfAAByRAUfAIBMKahRJ/LuAABAjkjwAQAgR6yDT+5ZkpVicV4DKI6CSbaJrINP7km6AIANiUm2AABkihtdJdOiAwAZ41twiqc67QBogpJCoVBIY+AHWu+cxrBsgFxMAkDTPH7/gLRDaFDNC8+mNnbnXfZMbezGUsEHgIxRwad4WmYFvxAm2SZRwSf3XEwCQNO01Ar+4hfmpjb21rv0Sm3sxlLBB4CMUcGneFpoBd8k20Qq+OSei0kAaJqWWsF/rfpvqY3dZec9Uhu7sVTwASBjVPApnpZawdeDn0QFn9xzMQkATdNSK/ivzn8utbG77rR7amM3VpMamJ555pl47rn/e2PvvffeGDx4cPz0pz+N1atXN1twAADAumlSgj9y5MiYP39+RES8/PLLccwxx0Tbtm3jjjvuiLPOOqtZAwQAgE8qRElqjyxoUoI/f/786NWrV0RE3HHHHbH//vvH1KlTY8qUKfG73/2uOeMDAADWQZMm2RYKhaitrY2IiIcffjgOP/zwiIjo1q1bLF26tPmiAwCA/2CZzGRNSvD79OkTF154YVRUVMSjjz4a1157bURELFiwIDp16tSoY5j4CABNYxUdiqdlrqJDsiatovO3v/0tvvvd78aiRYti9OjRMXbs2IiIOOWUU+LNN9+MqVOnfuYxrKJDsbiYBICmaamr6Pzrxb+nNna3HXdLbezGatZlMt9///1o1apVtG7d+jP3/eoRjzbXsJBIpYticTEJ5E1LTfAXvfiP1MbeZsddUxu7sZp8o6tly5bFnXfeGf/85z/jzDPPjC233DL+/ve/R6dOnaJr167NGSN8LpIuIG8ULigeLTpZ1OQWnYMOOig233zzWLhwYVRXV8f2228f5557bixatChuueWWzzyGFh2KRYIPAE3TUiv4r7yU3oXHtju0/By2SVOQR48eHSNGjIgXX3wxysvL67Yfdthh8dhjjzVbcAAAwLppUovOU089Fddff/1a27t27Ro1NTWNOoaqKsXiq2yKxXkNgJagSQl+WVlZrFixYq3t8+fPj6222qpRx5B0USySLgDIl6zcUTYtTWrROfLII+P888+PDz74ICIiSkpKYtGiRXH22WfHt771rWYNEAAAaLwmTbJdvnx5HHXUUfH000/H22+/HV26dImampro379/TJ8+PTbZZJPPPIZlMikW3xZRLL4tAvKmpU6yXfDPl1Ibe7seO6Q2dmN9rnXwH3/88fjb3/4W77zzTuy1115RUVHR6OdaRYdikXQBQNNI8NeWhQS/yevgR0R89atfja9+9avNFQsAAHwmPfjJGp3gX3XVVY0+6KmnntqkYAAAgM+n0Qn+FVdcUe/nN954I959993YfPPNI+KjO9u2bds2OnbsKMEHAICUNDrBX7BgQd2/p06dGtdcc038+te/jp13/qiXvrq6Oo4//vgYOXJko46nLxrIGxO6KRZ/Q9nQFUq06CRp0iTbHj16xJ133hl77rlnve1z5syJo446qt7FwKcxyZZi8YcQAJqmpU6y/efLL6c2do/tt09t7MZq0iTbxYsXx4cffrjW9jVr1sSSJUs+d1AAAPBpCgUV/CRNutHVQQcdFCNHjoxnnnmmbtucOXPipJNOWqelMgEAgObVpAR/8uTJ0blz5+jTp0+UlZVFWVlZ9O3bNzp16hS/+tWvmjtGAACgkT7Xja7mz58f//jHP6KkpCR22WWX2GmnnRr9XHeyBYCmMaGbYhn0QXXaITToxX++ktrYO/bYNrWxG+tzJfgRER8/vWQdZzObZEuxmGQLAE3TUifZSvCTNalFJyLilltuid133z023njj2HjjjWOPPfaI3/zmN80ZGwAArKUQJak9sqBJq+iMHz8+fv7zn8eoUaNi3333jYiIxx9/PE488cRYunRpnHHGGc0aJAAA0DhNSvCv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wIHx+uuvN7j/n//85zj22GPjuOOOi2effTYGDx4cgwcPjueff77RY0rwAQBgPRk/fnwcf/zxMWLEiNhtt93iuuuui7Zt28bkyZMb3P/KK6+MQw89NM4888zYdddd44ILLoi99torJk6c2OgxJfgAANBIq1atihUrVtR7rFq1qsF9V69eHXPmzImKioq6baWlpVFRURGzZ89u8DmzZ8+ut39ExMCBAz91/4akNsn28fsHpDV0Jq1atSqqqqqisrIyysrK0g6HHPNZo1h81j6P6rQDyBSftfxJM48877zzYty4cfW2jR07Ns4777y19l26dGmsWbMmOnXqVG97p06d4oUXXmjw+DU1NQ3uX1NT0+gYVfAzYtWqVTFu3LhPvUKE5uKzRrH4rFEsPms0p8rKyli+fHm9R2VlZdph1WOZTAAAaKSysrJGfxPUoUOHaNWqVSxZsqTe9iVLlkTnzp0bfE7nzp3Xaf+GqOADAMB60KZNm+jdu3fMnDmzblttbW3MnDkz+vfv3+Bz+vfvX2//iIiHHnroU/dviAo+AACsJ6NHj45hw4ZFnz59om/fvjFhwoRYuXJljBgxIiIihg4dGl27do2qqqqIiDjttNNiwIABcfnll8egQYPitttui6effjpuuOGGRo8pwc+IsrKyGDt2rMlBrHc+axSLzxrF4rNGmoYMGRJvvPFGjBkzJmpqaqJXr14xY8aMuom0ixYtitLS/2uq2WeffWLq1Klx7rnnxk9/+tPYcccd45577okvf/nLjR6zpFAouNcvAADkhB58AADIEQk+AADkiAQfAAByRIIPAAA5IsHPiEmTJkX37t2jvLw8+vXrF08++WTaIZEzjz32WBxxxBHRpUuXKCkpiXvuuSftkMipqqqq2HvvvWPTTTeNjh07xuDBg6O6ujrtsMiha6+9NvbYY49o3759tG/fPvr37x9/+MMf0g4L1jsJfgZMmzYtRo8eHWPHjo1nnnkmevbsGQMHDozXX3897dDIkZUrV0bPnj1j0qRJaYdCzj366KNx8sknx1/+8pd46KGH4oMPPohDDjkkVq5cmXZo5MwXv/jF+MUvfhFz5syJp59+Or72ta/FN77xjZg3b17aocF6ZZnMDOjXr1/svffeMXHixIj46A5o3bp1i1NOOSXOOeeclKMjj0pKSuLuu++OwYMHpx0KG4A33ngjOnbsGI8++mjsv//+aYdDzm255ZZx2WWXxXHHHZd2KLDeqOC3cKtXr445c+ZERUVF3bbS0tKoqKiI2bNnpxgZQPNYvnx5RHyUeMH6smbNmrjtttti5cqV0b9//7TDgfXKnWxbuKVLl8aaNWvq7nb2sU6dOsULL7yQUlQAzaO2tjZOP/302HfffdfpLo3QWM8991z0798/3n///WjXrl3cfffdsdtuu6UdFqxXEnwAUnPyySfH888/H48//njaoZBTO++8c8ydOzeWL18ed955ZwwbNiweffRRST65JsFv4Tp06BCtWrWKJUuW1Nu+ZMmS6Ny5c0pRAXx+o0aNit///vfx2GOPxRe/+MW0wyGn2rRpEzvssENERPTu3TueeuqpuPLKK+P6669POTJYf/Tgt3Bt2rSJ3r17x8yZM+u21dbWxsyZM/UQAplUKBRi1KhRcffdd8cjjzwS2223XdohsQGpra2NVatWpR0GrFcq+BkwevToGDZsWPTp0yf69u0bEyZMiJUrV8aIESPSDo0ceeedd+Kll16q+3nBggUxd+7c2HLLLWObbbZJMTLy5uSTT46pU6fGvffeG5tuumnU1NRERMRmm20WG2+8ccrRkSeVlZXx9a9/PbbZZpt4++23Y+rUqTFr1qz44x//mHZosF5ZJjMjJk6cGJdddlnU1NREr1694qqrrop+/fqlHRY5MmvWrDjwwAPX2j5s2LCYMmVK8QMit0pKShrcftNNN8Xw4cOLGwy5dtxxx8XMmTNj8eLFsdlmm8Uee+wRZ599dhx88MFphwbrlQQfAAByRA8+AADkiAQfAAByRIIPAAA5IsEHAIAckeADAECOSPABACBHJPgAAJAjEnwAAMgRCT7AOpoyZUpsvvnmn/s4JSUlcc8993zu4wDAJ0nwgQ3S8OHDY/DgwWmHAQDNToIPAAA5IsEH+A/jx4+P3XffPTbZZJPo1q1b/OhHP4p33nlnrf3uueee2HHHHaO8vDwGDhwY//rXv+r9/7333ht77bVXlJeXx/bbbx/jxo2LDz/8sMExV69eHaNGjYqtt946ysvLY9ttt42qqqr18voAyDcJPsB/KC0tjauuuirmzZsXN998czzyyCNx1lln1dvn3XffjYsuuihuueWWeOKJJ2LZsmVxzDHH1P3/f//3f8fQoUPjtNNOi7///e9x/fXXx5QpU+Kiiy5qcMyrrroq7rvvvrj99tujuro6br311ujevfv6fJkA5FRJoVAopB0EQLENHz48li1b1qhJrnfeeWeceOKJsXTp0oj4aJLtiBEj4i9/+Uv069cvIiJeeOGF2HXXXeOvf/1r9O3bNyoqKuKggw6KysrKuuP89re/jbPOOitee+21iPhoku3dd98dgwcPjlNPPTXmzZsXDz/8cJSUlDT/CwZgg6GCD/AfHn744TjooIOia9eusemmm8b3v//9ePPNN+Pdd9+t22ejjTaKvffeu+7nXXbZJTbffPP4xz/+ERER//M//xPnn39+tGvXru5x/PHHx+LFi+sd52PDhw+PuXPnxs477xynnnpqPPjgg+v/hQKQSxJ8gE9YuHBhHH744bHHHnvE7373u5gzZ05MmjQpIj7qk2+sd955J8aNGxdz586tezz33HPx4osvRnl5+Vr777XXXrFgwYK44IIL4r333oujjz46jjrqqGZ7XQBsODZKOwCAlmTOnDlRW1sbl19+eZSWflQDuf3229fa78MPP4ynn346+vbtGxER1dXVsWzZsth1110j4qOEvbq6OnbYYYdGj92+ffsYMmRIDBkyJI466qg49NBD46233oott9yyGV4ZABsKCT6wwVq+fHnMnTu33rYOHTrEBx98EFdffXUcccQR8cQTT8R111231nNbt24dp5xySlx11VWx0UYbxahRo+IrX/lKXcI/ZsyYOPzww2ObbbaJo446KkpLS+N//ud/4vnnn48LL7xwreONHz8+tt5669hzzz2jtLQ07rjjjujcuXOz3FALgA2LFh1ggzVr1qzYc8896z1+85vfxPjx4+OSSy6JL3/5y3Hrrbc2uFxl27Zt4+yzz47vfOc7se+++0a7du1i2rRpdf8/cODA+P3vfx8PPvhg7L333vGVr3wlrrjiith2220bjGXTTTeNSy+9NPr06RN77713LFy4MKZPn173LQIANJZVdAAAIEeUhgAAIEck+AAAkCMSfAAAyBEJPgAA5IgEHwAAckSCDwAAOSLBBwCAHJHgAwBAjkjwAQAgRyT4AACQIxJ8AADIkf8PG6hnmq/B/XkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvQAAAK9CAYAAABLi/iyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABsoUlEQVR4nO3deXzU1fX/8ZN1EhKyQUJIIGHfERQUBRWoVIpapUqp1loQtbRFUXHFagGXUqUibnXpIqj4tSqC1rqLgCvIKmDYA0RICNn3kGQ+vz/8EfORoEkc7snMfT0fDx8P88lkzpswwMln7j03yHEcRwAAAAD4pWDtAAAAAABajoYeAAAA8GM09AAAAIAfo6EHAAAA/BgNPQAAAODHaOgBAAAAP0ZDDwAAAPgxGnoAAADAj9HQAwAAAH6Mhh7Aj1JbWyu33nqrdO7cWYKDg2X8+PEntN6oUaNk1KhRzf66vXv3SlBQkPztb3/zWZYVK1ZIUFCQrFixwmfP2RRvv/22DB48WCIiIiQoKEiKioqM1se3tF4DANAQDT2stXDhQgkKCpK1a9c2+vlRo0bJgAEDTmiGN998U2bPnn1Ca5xo//73v2XevHkyYcIEWbRokdx4443akQJafn6+TJw4USIjI+Xxxx+X5557TqKiouQvf/mLLFu2TDseAEBBqHYAwGZvvvmmPP74437d1C9fvlxSU1PloYce0o5ihS+++EJKS0vlnnvukTFjxtRf/8tf/iITJkw44e+QwO3ss8+WyspKCQ8P144CwGLcoQfwo+Tm5kpcXJzPns/r9UpVVZXPni/Q5Obmioj49Ht+PFVVVeL1ek94nR+roqJCrXZwcLBERERIcDD/nALQw99AQDM9//zzMmTIEImMjJSEhAS59NJLJSsry/WYjz76SH75y19KWlqaeDwe6dy5s9x4441SWVlZ/5jJkyfL448/LiIiQUFB9f+JuNd7P/7449KtWzdp06aNnHvuuZKVlSWO48g999wjnTp1ksjISLnoooukoKDAleG1116T888/X1JSUsTj8Uj37t3lnnvukbq6Otfjji4tWrdunQwfPlwiIyOla9eu8uSTT37v9+Foxg8//FC2bt1an//oWuLy8nK56aabpHPnzuLxeKR3797yt7/9TRzHcT1PUFCQXHvttbJ48WLp37+/eDweefvtt5v8+3HkyBH585//LEOGDJHY2FiJioqSs846Sz788MPjfs1DDz0k6enpEhkZKSNHjpQtW7Yc85ht27bJhAkTJCEhQSIiImTo0KHy+uuv/2CenTt3yiWXXCLJyckSEREhnTp1kksvvVSKi4u/9+ua8poZNWqUTJo0SURETj31VAkKCpLJkydLUFCQlJeXy6JFi+p/HyZPnlz/dQcOHJApU6ZIhw4dxOPxSP/+/eXf//63q/7RteAvvvii3HnnnZKamipt2rSRkpKS42b2er3y8MMPy8CBAyUiIkISExPlZz/7mWsZW21trdxzzz3SvXt38Xg80qVLF7njjjukurra9Vwteb2effbZ0qZNG7njjjtERGTt2rUyduxYad++ff3reMqUKcdkXrBggfTv318iIiKkQ4cOMnXqVCksLHQ9rkuXLnLBBRfIxx9/LKeddppERERIt27d5Nlnn230+9ZwDf3RjF999ZWMHj1a2rRpI6mpqfLAAw8c8z3ct2+fXHjhhRIVFSVJSUly4403yjvvvMO6fADNwpIbWK+4uFjy8vKOuV5TU3PMtfvuu0/uuusumThxolx99dVy+PBhefTRR+Xss8+WDRs21N81ffnll6WiokL+8Ic/SLt27WTNmjXy6KOPytdffy0vv/yyiIhMnTpVDh48KO+9954899xzjWZbvHixHDlyRK677jopKCiQBx54QCZOnCg/+clPZMWKFXLbbbfJrl275NFHH5Wbb77Z1aQtXLhQoqOjZcaMGRIdHS3Lly+XP//5z1JSUiLz5s1z1SksLJTzzjtPJk6cKJdddpm89NJL8oc//EHCw8OPaYiOSkxMlOeee07uu+8+KSsrk7lz54qISN++fcVxHLnwwgvlww8/lKuuukoGDx4s77zzjtxyyy1y4MCBY5bnLF++XF566SW59tprpX379tKlS5fGf7MaUVJSIv/85z/lsssuk2uuuUZKS0vlX//6l4wdO1bWrFkjgwcPdj3+2WefldLSUpk2bZpUVVXJww8/LD/5yU9k8+bN0qFDBxER2bp1q4wYMUJSU1Pl9ttvl6ioKHnppZdk/PjxsmTJEvnFL37RaJYjR47I2LFjpbq6Wq677jpJTk6WAwcOyBtvvCFFRUUSGxt73F9HU14zf/rTn6R3797y9NNPy9133y1du3aV7t27y5gxY+Tqq6+W0047TX73u9+JiEj37t1FROTQoUNy+umn1//glJiYKG+99ZZcddVVUlJSIjfccIMrxz333CPh4eFy8803S3V19fcuJbnqqqtk4cKFMm7cOLn66qultrZWPvroI/n8889l6NChIiJy9dVXy6JFi2TChAly0003yerVq2Xu3LmSkZEhS5curX+u5rxe8/PzZdy4cXLppZfKb37zG+nQoYPk5ubKueeeK4mJiXL77bdLXFyc7N27V1599VXX106dOlUWLlwoV155pUyfPl0yMzPlsccekw0bNsgnn3wiYWFh9Y/dtWuXTJgwQa666iqZNGmS/Pvf/5bJkyfLkCFDpH///sf9voh882fqZz/7mVx88cUyceJEeeWVV+S2226TgQMHyrhx40Tkmx96f/KTn0h2drZcf/31kpycLC+88ML3/jAKAI1yAEs988wzjoh873/9+/evf/zevXudkJAQ57777nM9z+bNm53Q0FDX9YqKimPqzZ071wkKCnL27dtXf23atGlOY38MMzMzHRFxEhMTnaKiovrrM2fOdETEGTRokFNTU1N//bLLLnPCw8Odqqqq780wdepUp02bNq7HjRw50hER58EHH6y/Vl1d7QwePNhJSkpyjhw5cuw3r4GRI0e6vk+O4zjLli1zRMS59957XdcnTJjgBAUFObt27aq/JiJOcHCws3Xr1u+t07DeyJEj6z+ura11qqurXY8pLCx0OnTo4EyZMqX+2tHvaWRkpPP111/XX1+9erUjIs6NN95Yf+2cc85xBg4c6Po+eb1eZ/jw4U7Pnj3rr3344YeOiDgffvih4ziOs2HDBkdEnJdffrlJv5aGmvqaOfq6/eKLL1yPjYqKciZNmnTMc1x11VVOx44dnby8PNf1Sy+91ImNja2ve/TX0q1bt0azfNfy5csdEXGmT59+zOe8Xq/jOI6zceNGR0Scq6++2vX5m2++2RERZ/ny5fXXmvt6ffLJJ12PXbp0aaPfl4Y++ugjR0ScxYsXu66//fbbx1xPT093RMRZtWpV/bXc3FzH4/E4N910U/21774GGmZ89tln669VV1c7ycnJziWXXFJ/7cEHH3RExFm2bFn9tcrKSqdPnz7HPCcAfB+W3MB6jz/+uLz33nvH/HfSSSe5Hvfqq6+K1+uViRMnSl5eXv1/ycnJ0rNnT9ddtcjIyPr/Ly8vl7y8PBk+fLg4jiMbNmxocrZf/vKXrru6w4YNExGR3/zmNxIaGuq6fuTIETlw4ECjGUpLSyUvL0/OOussqaiokG3btrnqhIaGytSpU+s/Dg8Pl6lTp0pubq6sW7euyXmPevPNNyUkJESmT5/uun7TTTeJ4zjy1ltvua6PHDlS+vXr1+w6IiIhISH1d5G9Xq8UFBRIbW2tDB06VNavX3/M48ePHy+pqan1H5922mkybNgwefPNN0VEpKCgQJYvXy4TJ06s/77l5eVJfn6+jB07Vnbu3On6Pjd09PfqnXfeafa6bl+9ZhpyHEeWLFkiP//5z8VxHNfrduzYsVJcXHzM92jSpEmuLMezZMkSCQoKklmzZh3zuaNLx45+T2fMmOH6/E033SQiIv/73//qrzXn9erxeOTKK690XTv67tgbb7zR6LtrIt+8CxIbGys//elPXd+LIUOGSHR09DF3xvv16ydnnXVW/ceJiYnSu3dv2bNnT6PP31B0dLT85je/qf84PDxcTjvtNNfXvv3225KamioXXnhh/bWIiAi55pprfvD5AaAhltzAeqeddlr98oCG4uPjXUtxdu7cKY7jSM+ePRt9noZv1e/fv1/+/Oc/y+uvv37M2twfWkvdUFpamuvjow1j586dG73esNbWrVvlzjvvlOXLlx+zDvq7GVJSUiQqKsp1rVevXiLyzVr5008/vcmZRb5ZF5ySkiJt27Z1Xe/bt2/95xvq2rVrs57/uxYtWiQPPvigbNu2zdXMNfa8jf3+9erVS1566SUR+WaZheM4ctddd8ldd93VaL3c3FzXDwUN682YMUPmz58vixcvlrPOOksuvPBC+c1vfvO9y21EfPeaaejw4cNSVFQkTz/9tDz99NPH/bV899fQFLt375aUlBRJSEg47mP27dsnwcHB0qNHD9f15ORkiYuLc70OmvN6TU1NPWYp0MiRI+WSSy6ROXPmyEMPPSSjRo2S8ePHy69//WvxeDwi8s2f4eLiYklKSmo073e/F9/98yfyzd8L3/39aUynTp3qf7Bp+LVffvll/cf79u2T7t27H/O4736/AOCH0NADTeT1eiUoKEjeeustCQkJOebz0dHRIiJSV1cnP/3pT6WgoEBuu+026dOnj0RFRcmBAwdk8uTJzZoa0lid77vu/P8Np0VFRTJy5EiJiYmRu+++W7p37y4RERGyfv16ue2221rd5JKm3BE+nueff14mT54s48ePl1tuuUWSkpIkJCRE5s6dK7t372728x393tx8880yduzYRh/zfQ3Xgw8+KJMnT5bXXntN3n33XZk+fbrMnTtXPv/8c+nUqVOjX+PL10xjv5bf/OY39Ztpv+u770T9mN+L4/luw/pdzX29NpYxKChIXnnlFfn888/lv//9r7zzzjsyZcoUefDBB+Xzzz+X6Oho8Xq9kpSUJIsXL240R2JiouvjH/pz9n1+zNcCQHPR0ANN1L17d3EcR7p27Vp/97oxmzdvlh07dsiiRYvkt7/9bf31995775jH/lCj01IrVqyQ/Px8efXVV+Xss8+uv56Zmdno4w8ePCjl5eWuu/Q7duwQEWnWBtWj0tPT5f3335fS0lLXXfqjSyfS09Ob/ZzH88orr0i3bt3k1VdfdX0/G1sKIvLNXdrv2rFjR/2vs1u3biLyzTsuDee8N8fAgQNl4MCBcuedd8qnn34qI0aMkCeffFLuvffeRh/fnNfM8TT2WkpMTJS2bdtKXV1di38tx9O9e3d55513pKCg4Lh36dPT08Xr9crOnTvr350R+WajblFRUf3roLmv1+9z+umny+mnny733XefvPDCC3L55ZfLiy++KFdffbV0795d3n//fRkxYsQJ+cGludLT0+Wrr74Sx3Fcv3+7du1STAXAH7GGHmiiiy++WEJCQmTOnDnH3GVzHEfy8/NF5Ns7cw0f4ziOPPzww8c859EGuqioyKdZG8tw5MgR+fvf/97o42tra+Wpp55yPfapp56SxMREGTJkSLPrn3feeVJXVyePPfaY6/pDDz0kQUFB9VM+fKGxX+vq1avls88+a/Txy5Ytc62BX7Nmjaxevbo+U1JSkowaNUqeeuopyc7OPubrDx8+fNwsJSUlUltb67o2cOBACQ4OPmZM4w/9Go73mjmeqKioY15HISEhcskll8iSJUsaHc35fb+WH3LJJZeI4zgyZ86cYz539Ndx3nnniYjIggULXJ+fP3++iIicf/759Tkbfp3I979eG1NYWHjMn8ujE46Ofu8nTpwodXV1cs899xzz9bW1tT7/c/hDxo4dKwcOHHCNQ62qqpJ//OMfRnMA8H/coQeaqHv37nLvvffKzJkzZe/evTJ+/Hhp27atZGZmytKlS+V3v/ud3HzzzdKnTx/p3r273HzzzXLgwAGJiYmRJUuWNLru9mizPH36dBk7dqyEhITIpZde+qOzDh8+XOLj42XSpEkyffp0CQoKkueee+64b/enpKTI/fffL3v37pVevXrJf/7zH9m4caM8/fTTrr0BTfXzn/9cRo8eLX/6059k7969MmjQIHn33XfltddekxtuuKF+pKIvXHDBBfLqq6/KL37xCzn//PMlMzNTnnzySenXr5+UlZUd8/gePXrImWeeKX/4wx+kurpaFixYIO3atZNbb721/jGPP/64nHnmmTJw4EC55pprpFu3bnLo0CH57LPP5Ouvv5ZNmzY1mmX58uVy7bXXyi9/+Uvp1auX1NbWynPPPVffWB9Pc14zxzNkyBB5//33Zf78+ZKSkiJdu3aVYcOGyV//+lf58MMPZdiwYXLNNddIv379pKCgQNavXy/vv//+MecXNNXo0aPliiuukEceeUR27twpP/vZz8Tr9cpHH30ko0ePlmuvvVYGDRokkyZNkqeffrp+Wc2aNWtk0aJFMn78eBk9erSINP/12phFixbJ3//+d/nFL34h3bt3l9LSUvnHP/4hMTEx9T9YjBw5UqZOnSpz586VjRs3yrnnnithYWGyc+dOefnll+Xhhx+WCRMmtOj70RJTp06Vxx57TC677DK5/vrrpWPHjrJ48WKJiIgQkRP3Dh6AAGRqnA7Q2hxv/N9RjY1jdBzHWbJkiXPmmWc6UVFRTlRUlNOnTx9n2rRpzvbt2+sf89VXXzljxoxxoqOjnfbt2zvXXHONs2nTJkdEnGeeeab+cbW1tc51113nJCYmOkFBQfUjLI+OWJw3b56r9tERed8di9jYr+WTTz5xTj/9dCcyMtJJSUlxbr31Vuedd95pdMRe//79nbVr1zpnnHGGExER4aSnpzuPPfZYk76Px/s+lZaWOjfeeKOTkpLihIWFOT179nTmzZtXP9LwKBFxpk2b1qRaR+s1HFvp9Xqdv/zlL056errj8Xick08+2XnjjTecSZMmOenp6fWPa/g9ffDBB53OnTs7Ho/HOeuss5xNmzYdU2f37t3Ob3/7Wyc5OdkJCwtzUlNTnQsuuMB55ZVX6h/z3ZGFe/bscaZMmeJ0797diYiIcBISEpzRo0c777///g/+upr6mjne63bbtm3O2Wef7URGRjoi4hpheejQIWfatGlO586dnbCwMCc5Odk555xznKeffvqYX0tzRm7W1tY68+bNc/r06eOE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dOvWTebMmSO1tbWN1jxy5Ihce+210rFjR4mIiJD09HSZO3fuCfn1AQACCw09AHxHcHCwPPLII7J161ZZtGiRLF++XG699VbXYyoqKuS+++6TZ599Vj755BMpKiqSSy+9tP7zH330kfz2t7+V66+/Xr766it56qmnZOHChXLfffc1WvORRx6R119/XV566SXZvn27LF68WLp06XIif5kAgAAR5DiOox0CAEybPHmyFBUVNWlT6iuvvCK///3vJS8vT0S+2RR75ZVXyueffy7Dhg0TEZFt27ZJ3759ZfXq1XLaaafJmDFj5JxzzpGZM2fWP8/zzz8vt956qxw8eFBEvtkUu3TpUhk/frxMnz5dtm7dKu+//74EBQX5/hcMAAhY3KEHgO94//335ZxzzpHU1FRp27atXHHFFZKfny8VFRX1jwkNDZVTTz21/uM+ffpIXFycZGRkiIjIpk2b5O6775bo6Oj6/6655hrJzs52Pc9RkydPlo0bN0rv3r1l+vTp8u677574XygAICDQ0ANAA3v37pULLrhATjrpJFmyZImsW7dOHn/8cRH5Zp17U5WVlcmcOXNk48aN9f9t3rxZdu7cKREREcc8/pRTTpHMzEy55557pLKyUiZOnCgTJkzw2a8LABC4QrUDAEBrsm7dOvF6vfLggw9KcPA39zxeeumlYx5XW1sra9euldNOO01ERLZv3y5FRUXSt29fEfmmQd++fbv06NGjybVjYmLkV7/6lfzqV7+SCRMmyM9+9jMpKCiQhIQEH/zKAACBioYegLWKi4tl48aNrmvt27eXmpoaefTRR+XnP/+5fPLJJ/Lkk08e87VhYWFy3XXXySOPPCKhoaFy7bXXyumnn17f4P/5z3+WCy64QNLS0mTChAkSHBwsmzZtki1btsi99957zPPNnz9fOnbsKCeffLIEBwfLyy+/LMnJyT45wAoAENhYcgPAWitWrJCTTz7Z9d9zzz0n8+fPl/vvv18GDBggixcvbnR8ZJs2beS2226TX//61zJixAiJjo6W//znP/WfHzt2rLzxxhvy7rvvyqmnniqnn366PPTQQ5Kent5olrZt28oDDzwgQ4cOlVNPPVX27t0rb775Zv27BAAAHA9TbgAAAAA/xq0fAAAAwI/R0AMAAAB+jIYeAAAA8GM09AAAAIAfo6EHAAAA/BgNPQAAAODHaOgBAAAAP0ZDDwAAAPgxGnoAAADAj9HQAwAAAH6Mhh4AAADwY/8Pl8RLBSuREjYAAAAASUVORK5CYII=",
      "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",
    "C_t_0=C_0.T\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": 38,
   "id": "588acbe7",
   "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()"
   ]
  }
 ],
 "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
}
