{
 "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_49556\\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_49556\\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\\\\PUBMed'"
      ]
     },
     "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\\\\PUBMed\\\\PubMed'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "dataset = os.path.join(os.getcwd(),'PubMed')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "067c3d06",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "067c3d06",
    "outputId": "9c7402f2-2cfc-46ea-e604-13ef4b07d6ff"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dataset: PubMed\n",
      "num_nodes: 19717\n",
      "num_edges: 88648\n",
      "num_classes: 3\n",
      "num_features: 500\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 = ['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=[19717, 500], edge_index=[2, 88648], y=[19717], train_mask=[19717], val_mask=[19717], test_mask=[19717])\n",
      "torch.Size([19717, 500]) torch.Size([19717, 19717])\n",
      "torch.Size([19717, 500]) torch.Size([19717, 19717])\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)\n",
    "adj = adj[0]\n",
    "labels = dataset[0].y\n",
    "labels = labels.numpy()\n",
    "\n",
    "X = dataset[0].x\n",
    "X = X.to_dense()\n",
    "N = X.shape[0]\n",
    "NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "A = adj[:nn,:nn]\n",
    "AT= torch.transpose(A,0,1)\n",
    "labels = labels[:nn]\n",
    "print(X.shape,adj.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "475846d5",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "475846d5",
    "outputId": "c6102e64-ae54-46d6-8f9b-48ba85a81564"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([19717, 500])"
      ]
     },
     "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([19717, 19717])\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": 8,
   "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": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(theta@A).type()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "theta.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "114a42e0",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "114a42e0",
    "outputId": "62b0a402-9d33-44be-8e7f-20de623be138"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3 19717\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": 11,
   "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": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": 13,
   "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": 14,
   "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": 15,
   "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(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": 16,
   "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": 35,
   "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_2284\\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_2284\\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_2284\\1999241371.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_2284\\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 [05:54<00:00, 35.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Accuracy = 0.20809453770857636 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_2284\\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_2284\\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_2284\\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 [06:03<00:00, 36.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:41<00:00, 34.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:31<00:00, 33.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:43<00:00, 34.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:31<00:00, 33.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:59<00:00, 35.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:13<00:00, 37.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:27<00:00, 32.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:41<00:00, 34.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:17<00:00, 37.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:38<00:00, 33.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:31<00:00, 33.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:30<00:00, 33.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:57<00:00, 35.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:21<00:00, 32.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:37<00:00, 33.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:02<00:00, 42.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [08:02<00:00, 48.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:51<00:00, 41.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:05<00:00, 42.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:48<00:00, 40.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:59<00:00, 42.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:43<00:00, 40.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:50<00:00, 41.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:04<00:00, 42.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:02<00:00, 42.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:06<00:00, 42.67s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:32<00:00, 39.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:55<00:00, 41.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:06<00:00, 42.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:10<00:00, 43.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:02<00:00, 42.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:14<00:00, 43.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:54<00:00, 41.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:56<00:00, 47.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:29<00:00, 44.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:18<00:00, 43.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:00<00:00, 42.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:09<00:00, 42.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:18<00:00, 43.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:51<00:00, 41.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:58<00:00, 41.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:27<00:00, 44.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:37<00:00, 45.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:51<00:00, 41.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Accuracy = 0.20931176142415175 1000 10 0.001\n",
      "Average accuracy = 20.870314956636406 +/- 0.0608611857787697\n",
      "Params =  1000 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:27<00:00, 38.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0987\n",
      "Accuracy = 0.4140082162600801 1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:50<00:00, 35.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 37.842978140690775 +/- 3.5578434853172385\n",
      "Params =  1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:11<00:00, 43.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:41<00:00, 46.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:47<00:00, 40.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:48<00:00, 40.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:39<00:00, 39.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:18<00:00, 43.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [08:30<00:00, 51.03s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [08:10<00:00, 49.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:32<00:00, 45.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:44<00:00, 46.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:39<00:00, 39.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:08<00:00, 42.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:53<00:00, 41.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:49<00:00, 40.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:39<00:00, 33.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0989\n",
      "Accuracy = 0.8250240908860375 1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:23<00:00, 38.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0992\n",
      "Average accuracy = 81.63767307399705 +/- 0.8647360146066874\n",
      "Params =  1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:48<00:00, 46.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:01<00:00, 42.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:16<00:00, 43.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:53<00:00, 47.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:29<00:00, 44.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:18<00:00, 43.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:24<00:00, 44.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:38<00:00, 45.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:35<00:00, 45.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:40<00:00, 46.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:35<00:00, 39.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:56<00:00, 41.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:55<00:00, 41.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:27<00:00, 38.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.80184612263529 +/- 0.007607648222346386\n",
      "Params =  1000 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:58<00:00, 41.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0982\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:36<00:00, 39.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 81.83293604503727 +/- 0.360095349191053\n",
      "Params =  1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:29<00:00, 44.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:02<00:00, 42.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:06<00:00, 42.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:54<00:00, 41.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:53<00:00, 47.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:56<00:00, 41.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:50<00:00, 41.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:18<00:00, 43.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:17<00:00, 43.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:25<00:00, 44.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:58<00:00, 35.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:18<00:00, 43.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:55<00:00, 41.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:01<00:00, 42.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0986\n",
      "Average accuracy = 20.809453770857637 +/- 0.0\n",
      "Params =  1000 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:20<00:00, 44.04s/it]\n"
     ]
    },
    {
     "ename": "_LinAlgError",
     "evalue": "linalg.svd: The algorithm failed to converge because the input matrix is ill-conditioned or has too many repeated singular values (error code: 1).",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31m_LinAlgError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[35], line 25\u001b[0m\n\u001b[0;32m     22\u001b[0m C_0_t \u001b[38;5;241m=\u001b[39m C_0\u001b[38;5;241m.\u001b[39mT\n\u001b[0;32m     23\u001b[0m L \u001b[38;5;241m=\u001b[39m theta\n\u001b[1;32m---> 25\u001b[0m pseudo_C \u001b[38;5;241m=\u001b[39m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlinalg\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mpinv\u001b[49m\u001b[43m(\u001b[49m\u001b[43mC_0\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     26\u001b[0m X_t_0 \u001b[38;5;241m=\u001b[39m pseudo_C\u001b[38;5;129m@X\u001b[39m\n\u001b[0;32m     27\u001b[0m C_test \u001b[38;5;241m=\u001b[39m C_0\u001b[38;5;241m.\u001b[39mcpu()\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mnumpy()\n",
      "\u001b[1;31m_LinAlgError\u001b[0m: linalg.svd: The algorithm failed to converge because the input matrix is ill-conditioned or has too many repeated singular values (error code: 1)."
     ]
    }
   ],
   "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 [1000,100,10,1,0.1,0.01,0.001,0.0001]:\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",
    "         \n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              \n",
    "             \n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_0_t = C_0.T\n",
    "              L = theta\n",
    "             \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": 17,
   "id": "VYrR83c2grMy",
   "metadata": {
    "id": "VYrR83c2grMy"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_49556\\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_49556\\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_49556\\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_49556\\1999241371.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_49556\\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 [02:52<00:00, 17.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.0983\n",
      "Accuracy = 0.8174164426636912 1000 1 0.0001\n",
      "Average accuracy = 81.74164426636912 +/- 0.0\n",
      "Params =  1000 1 0.0001\n"
     ]
    }
   ],
   "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 [1000]:\n",
    "  for beta_param in [1]:\n",
    "      for gamma_param in [0.0001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(1):\n",
    "            avg_accuracy_all=[]\n",
    "         \n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              \n",
    "             \n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_0_t = C_0.T\n",
    "              L = theta\n",
    "             \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": 41,
   "id": "pqDLVv1Wn9RD",
   "metadata": {
    "id": "pqDLVv1Wn9RD"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8298422680935233"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "highest_accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "FN7Cp3UQoMKv",
   "metadata": {
    "id": "FN7Cp3UQoMKv"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvgAAAK9CAYAAABRtxg8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABLbklEQVR4nO3de5iVZbk4/nsGYfB8SA5CKIrnTFBOaSmWKG1PUV8TrQSsjFQ8USaUcbCUrZSSglmWZ92i5jHMVBTNpFLMrbkVT6BtFRQNVFRQZv3+8OdspxnfmXlE1noWn891zXU5L+9azzODi/d+7ve+n7emVCqVAgAAqAq15Z4AAACw6gjwAQCgigjwAQCgigjwAQCgigjwAQCgigjwAQCgigjwAQCgigjwAQCgigjwAQCgigjwgarz7rvvxg9+8IPo0aNH1NbWxtChQ8s9pRbttddesddeeyW9duTIkdGzZ89VOp9/d/HFF0dNTU0sWLCg8LyJEydGTU1N0hg9e/aMAw44IOm1H6ampiYmTpy4St8ToNIJ8KGCvB9EPfDAA83++V577RU77bTTxzqHW265JfuA6MILL4wpU6bEwQcfHJdcckmceOKJ5Z4SAKw2a5V7AkBlueWWW2L69OlZB/l33nlndO/ePc4+++xyT6XVbrvttuTXXnDBBVFfX78KZwNAzmTwgarz0ksvxUYbbbTK3q++vj7efvvtVfZ+H/Tmm29GRESHDh2iQ4cOSe/Rvn37qKurW5XTAiBjAnyoApdffnn07ds31l577dhkk03i0EMPjX/+85+NzvnTn/4UX/3qV2PzzTePurq66NGjR5x44onx1ltvNZwzcuTImD59ekS8V7v8/ldExIIFC6KmpiZ+9rOfxfTp02OrrbaKddZZJ/bdd9/45z//GaVSKX7yk5/EJz/5yVh77bXjS1/6Urz66quN5nDjjTfG/vvvH926dYu6urro1atX/OQnP4mVK1c2Ou/9UqS5c+fG7rvvHmuvvXZsueWWcf755xf+Ht6f41133RWPPvpow/xnz54dERHLli2L733ve9GjR4+oq6uL7bbbLn72s59FqVRq9D41NTUxevTouOKKK+JTn/pU1NXVxa233lo49nnnnddwbrdu3eKYY46JJUuWfOjPteeee8Y666wTP/zhDxv+7N9r8J999tk46KCDYt11143OnTvHiSeeGH/84x8b/UwRTWvwP/h39etf/zp69eoVdXV10b9//7j//vsbjfHwww/HyJEjY6uttoqOHTtG165d45vf/Ga88sorhT9vW1x00UXxhS98ITp37hx1dXWx4447xi9/+csPPf+2226LPn36RMeOHWPHHXeM6667rsk5S5YsiRNOOKHh73LrrbeOM844o8U7Ga+//nqccMIJ0bNnz6irq4vOnTvHPvvsEw8++OBH/jkBKoUSHahAS5cujcWLFzc5/s477zQ5dtppp8WPf/zjOOSQQ+Lb3/52vPzyy3HuuefGnnvuGX//+98bMtnXXHNNvPnmm3HUUUfFJz7xifjb3/4W5557bvzv//5vXHPNNRERMWrUqHjhhRfi9ttvj8suu6zZuV1xxRWxYsWKOPbYY+PVV1+NM888Mw455JD4whe+ELNnz46TTz45nnrqqTj33HPj+9//flx44YUNr7344otjvfXWizFjxsR6660Xd955Z4wfPz5ee+21mDJlSqNx/vWvf8V+++0XhxxySBx22GFx9dVXx1FHHRUdOnSIb37zm83OrVOnTnHZZZfFaaedFm+88UZMnjw5IiJ22GGHKJVKcdBBB8Vdd90V3/rWt6JPnz7xxz/+MU466aR4/vnnm5Tz3HnnnXH11VfH6NGjY9NNNy1sYp04cWJMmjQpBg8eHEcddVTMmzcvfvnLX8b9998ff/7zn6N9+/YN577yyivxH//xH3HooYfGN77xjejSpUuz77ls2bL4whe+EC+++GIcf/zx0bVr17jyyivjrrvu+tB5/Lsrr7wyXn/99Rg1alTU1NTEmWeeGV/5ylfimWeeaZjT7bffHs8880wcccQR0bVr13j00Ufj17/+dTz66KPxl7/8Jblh9oN++ctfxqc+9ak46KCDYq211oqbb745jj766Kivr49jjjmm0blPPvlkDBs2LL773e/GiBEj4qKLLoqvfvWrceutt8Y+++wTEe/d9Rg0aFA8//zzMWrUqNh8883jvvvui3HjxsWLL74YU6dO/dC5fPe7341rr702Ro8eHTvuuGO88sorce+998Zjjz0Wu+6660f+WQEqQgmoGBdddFEpIgq/PvWpTzWcv2DBglK7du1Kp512WqP3eeSRR0prrbVWo+Nvvvlmk/EmT55cqqmpKT377LMNx4455phSc/80zJ8/vxQRpU6dOpWWLFnScHzcuHGliCj17t279M477zQcP+yww0odOnQovf3224VzGDVqVGmdddZpdN6gQYNKEVH6+c9/3nBs+fLlpT59+pQ6d+5cWrFiRdNf3gcMGjSo0e+pVCqVbrjhhlJElH760582On7wwQeXampqSk899VTDsYgo1dbWlh599NHCcUqlUumll14qdejQobTvvvuWVq5c2XB82rRppYgoXXjhhU1+rvPPP7/ZOQ8aNKjh+5///OeliCjdcMMNDcfeeuut0vbbb1+KiNJdd93VcHzEiBGlLbbYouH79/+uPvGJT5ReffXVhuM33nhjKSJKN998c8Ox5v5O/uu//qsUEaV77rmn4dj7/2/Onz+/8PcxYcKEJv//NDfGkCFDSltttVWjY1tssUUpIkq/+93vGo4tXbq0tNlmm5V22WWXhmM/+clPSuuuu27piSeeaPT6sWPHltq1a1d67rnnGo5FRGnChAkN32+44YalY445pvBnAMidEh2oQNOnT4/bb7+9ydfOO+/c6Lzrrrsu6uvr45BDDonFixc3fHXt2jW22WabRtnetddeu+G/ly1bFosXL47dd989SqVS/P3vf2/13L761a/Ghhtu2PD9wIEDIyLiG9/4Rqy11lqNjq9YsSKef/75Zufw+uuvx+LFi2OPPfaIN998Mx5//PFG46y11loxatSohu87dOgQo0aNipdeeinmzp3b6vm+75Zbbol27drFcccd1+j49773vSiVSvGHP/yh0fFBgwbFjjvu2OL73nHHHbFixYo44YQTorb2//5JPfLII2ODDTaImTNnNjq/rq4ujjjiiBbf99Zbb43u3bvHQQcd1HCsY8eOceSRR7b42vcNGzYsNt5444bv99hjj4iIeOaZZxqOffDv5O23347FixfHZz7zmYiIVVa28sEx3r87NWjQoHjmmWdi6dKljc7t1q1bfPnLX274foMNNojhw4fH3//+91i4cGFEvHc3ao899oiNN9640f/3gwcPjpUrV8Y999zzoXPZaKON4q9//Wu88MILq+RnA6hESnSgAg0YMCD69evX5Pj7Ac37nnzyySiVSrHNNts0+z4fLA157rnnYvz48XHTTTfFv/71r0bn/XuQVWTzzTdv9P37wX6PHj2aPf7BsR599NE45ZRT4s4774zXXnutcA7dunWLddddt9GxbbfdNiLeqzF/PwhtrWeffTa6desW66+/fqPjO+ywQ8Off9CWW27Z6veNiNhuu+0aHe/QoUNstdVWTd63e/furWqmffbZZ6NXr15NSmS23nrrVs0rounf1fvB/gf/Tl599dWYNGlSXHXVVfHSSy81Or8t/18U+fOf/xwTJkyIOXPmNDQVf3CMDy4Yt9566yY/8wf/3rt27RpPPvlkPPzww9GpU6dmx/v3n+ODzjzzzBgxYkT06NEj+vbtG/vtt18MHz48ttpqq9QfD6DiCPAhY/X19VFTUxN/+MMfol27dk3+fL311ouIiJUrV8Y+++wTr776apx88smx/fbbx7rrrhvPP/98jBw5sk1bLDY3TtHx0v/fwLpkyZIYNGhQbLDBBnHqqadGr169omPHjvHggw/GySefXHHbPH4w65zD+zanpb+TiIhDDjkk7rvvvjjppJOiT58+sd5660V9fX188YtfXCV/J08//XTsvffesf3228dZZ50VPXr0iA4dOsQtt9wSZ599dtIY9fX1sc8++8QPfvCDZv/8/QVBcw455JDYY4894vrrr4/bbrstpkyZEmeccUZcd9118R//8R9tngtAJRLgQ8Z69eoVpVIpttxyy8Kg5pFHHoknnngiLrnkkhg+fHjD8dtvv73JuauiqbI5s2fPjldeeSWuu+662HPPPRuOz58/v9nzX3jhhVi2bFmjLP4TTzwREZH01NYtttgi7rjjjnj99dcbZfHfLw3aYost2vyeH3zdvHnzGmWBV6xYEfPnz4/Bgwcnv+///M//RKlUavR38tRTTyW9X3P+9a9/xaxZs2LSpEkxfvz4huNPPvnkKhvj5ptvjuXLl8dNN93U6I7ChzULP/XUU01+5n//e+/Vq1e88cYbyb/bzTbbLI4++ug4+uij46WXXopdd901TjvtNAE+UDXU4EPGvvKVr0S7du1i0qRJTbZ6LJVKDVsdvp/J/eA5pVIpfvGLXzR5z/cD6n/f4vGjam4OK1asiPPOO6/Z899999341a9+1ejcX/3qV9GpU6fo27dvm8ffb7/9YuXKlTFt2rRGx88+++yoqalJDu4GDx4cHTp0iHPOOafRz/bb3/42li5dGvvvv3/S+w4ZMiSef/75uOmmmxqOvf3223HBBRckvV9zmvs7iYjCXWhWxRhLly6Niy66qNnzX3jhhbj++usbvn/ttdfi0ksvjT59+kTXrl0j4r0s/Jw5c+KPf/xjk9cvWbIk3n333Wbfe+XKlU3Kjjp37hzdunWL5cuXt+0HA6hgMviQsV69esVPf/rTGDduXCxYsCCGDh0a66+/fsyfPz+uv/76+M53vhPf//73Y/vtt49evXrF97///Xj++edjgw02iN/97ndNavEjoiF4Pu6442LIkCHRrl27OPTQQz/yXHfffffYeOONY8SIEXHcccdFTU1NXHbZZU2Cy/d169YtzjjjjFiwYEFsu+22MWPGjHjooYfi17/+daPegtY68MAD4/Of/3z86Ec/igULFkTv3r3jtttuixtvvDFOOOGE6NWrV9LP1alTpxg3blxMmjQpvvjFL8ZBBx0U8+bNi/POOy/69+8f3/jGN5Led9SoUTFt2rQ47LDD4vjjj4/NNtssrrjiiujYsWNErJo7LRtssEHsueeeceaZZ8Y777wT3bt3j9tuu+1D76qk2HfffaNDhw5x4IEHxqhRo+KNN96ICy64IDp37hwvvvhik/O33Xbb+Na3vhX3339/dOnSJS688MJYtGhRowXBSSedFDfddFMccMABMXLkyOjbt28sW7YsHnnkkbj22mtjwYIFsemmmzZ579dffz0++clPxsEHHxy9e/eO9dZbL+644464//774+c///kq+5kByk2AD5kbO3ZsbLvttnH22WfHpEmTIuK9htd99923YQeW9u3bx8033xzHHXdcTJ48OTp27Bhf/vKXY/To0dG7d+9G7/eVr3wljj322Ljqqqvi8ssvj1KptEoC/E984hPx+9//Pr73ve/FKaecEhtvvHF84xvfiL333juGDBnS5PyNN944Lrnkkjj22GPjggsuiC5dusS0adPatIvMB9XW1sZNN90U48ePjxkzZsRFF10UPXv2jClTpsT3vve9j/SzTZw4MTp16hTTpk2LE088MTbZZJP4zne+E6effnrSYiQiGp4TcOyxx8YvfvGLWG+99WL48OGx++67x//7f/+vIdD/qK688so49thjY/r06VEqlWLfffeNP/zhD9GtW7dV8v7bbbddXHvttXHKKafE97///ejatWscddRR0alTp2afZ7DNNtvEueeeGyeddFLMmzcvttxyy5gxY0aj/0fWWWeduPvuu+P000+Pa665Ji699NLYYIMNYtttt41JkyY1atr9oHXWWSeOPvrouO222xp2oNp6663j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HEOqyqzBL3mSbSG/HQAAqCIy+JARWUhI4+4XpKnUEp1SaLItIoMPAABVRAYfMiILCWnc/YJUlVmDTzEBPmREkAJpLI4hTcWW6GiyLeS3AwAAVUQGHwCAvHiSbSEBPmREmQGkUd4GqdTg50iADwBAVkqqzAsJ8CEjspCQxt0vSFOpTbYUE+BDRgQpkMbiGFIp0cmRAB8yIkiBNBbHkKZSM/glTbaFFDABAEAVkcEHACArHnRVzG8HAACqiAw+ZEQdMaTRvwKpNNnmSIAPGRGkQBqLY0hTsU22ocm2SNkCfIEKtJ0gBQBoSdkCfIEKtJ2FMaRxzYHqosm2mN8OAABUETX4kBFZSEjj7hekqswmWw+6KiaDDwAAVSQpg//ggw9G+/bt49Of/nRERNx4441x0UUXxY477hgTJ06MDh06rNJJAu+RhYQ07n5BmkrdRYdiSQH+qFGjYuzYsfHpT386nnnmmTj00EPjy1/+clxzzTXx5ptvxtSpU1t8D4EKtJ0gBQBsk9mSpBKdJ554Ivr06RMREddcc03sueeeceWVV8bFF18cv/vd71bl/AAAgDZIyuCXSqWor6+PiIg77rgjDjjggIiI6NGjRyxevLhV7yETCW3nzhekcc2B6mKbzGJJv51+/frFT3/607jsssvi7rvvjv33f69Ca/78+dGlS5dVOkEAAKD1kjL4U6dOja9//etxww03xI9+9KPYeuutIyLi2muvjd13332VThD4P7KQkMbdL0hVmdtkUiwpwN95553jkUceaXJ8ypQp0a5du488KQAA+DCabIvVlEqlUsoLlyxZEtdee208/fTTcdJJJ8Umm2wSDz74YHTp0iW6d+/e4utntt8uZVhYo8ngA7A63XvzoHJPoVnPPflY2cbefJsdyjZ2ayVl8B9++OHYe++9Y6ONNooFCxbEkUceGZtssklcd9118dxzz8Wll17a4nsIVABYXZToQKrKLNHRZFss6bczZsyYOOKII+LJJ5+Mjh07Nhzfb7/94p577lllkwMAANomKYN///33x69+9asmx7t37x4LFy78yJMCmicLCWncNYY0nmSbp6QAv66uLl577bUmx5944ono1KnTR54U0DxBCqSxOIZUFVqio8m2UFKT7be//e145ZVX4uqrr45NNtkkHn744WjXrl0MHTo09txzz5g6dWqL76HJFtpOgA/A6lSpTbYLnnqibGP33Hrbso3dWkkB/tKlS+Pggw+OBx54IF5//fXo1q1bLFy4MHbbbbe45ZZbYt11123xPT534N1JEwaAtpLBhzT7v1OZGfz5Tz9VtrG37LV12cZuraQSnQ033DBuv/32uPfee+Phhx+ON954I3bdddcYPHjwqp4f8AGCFEjj7hekUYOfp+R98D8qGXwAVheLY0hTqRn8Z55+umxjb9WrV9nGbq1WZ/DPOeecVr/pcccdlzQZoJggBdLI4EMaGfw8tTrAP/vssxt9//LLL8ebb74ZG220UUS892TbddZZJzp37izABwCAMml1gD9//vyG/77yyivjvPPOi9/+9rex3Xbv7YYzb968OPLII2PUqFGtej+ZSGg7WUgAiCjV2CazSFINfq9eveLaa6+NXXbZpdHxuXPnxsEHH9xoMfBh1OBD21kYQxqLY0hTqdtkPv3MM2Ubu9dWW5Vt7NZK2kXnxRdfjHfffbfJ8ZUrV8aiRYs+8qSA5glSII3FMaSqzCbbUkkGv0hSgL/33nvHqFGj4je/+U3suuuuEfFe9v6oo46yVSZ8jAQpkMbiGNJoss1TbcqLLrzwwujatWv069cv6urqoq6uLgYMGBBdunSJ3/zmN6t6jgAAQCslZfA7deoUt9xySzzxxBPx2GOPRU1NTWy//fax7baV/+heAADyVkrLUa8xPvKDrt5/eU0bu5k12QKwuihvgzSV+qCrJ59+tmxjb9Nri7KN3VpJGfyIiEsvvTSmTJkSTz75ZEREbLvttnHSSSfF4YcfvsomBzQmSIE0avAhTaXW4JdCk22RpAD/rLPOih//+McxevTo+OxnPxsREffee29897vfjcWLF8eJJ564SicJAAC0TlKAf+6558Yvf/nLGD58eMOxgw46KD71qU/FxIkTBfgAAHxsZPCLJXUovPjii7H77rs3Ob777rvHiy+++JEnBQAApEnK4G+99dZx9dVXxw9/+MNGx2fMmBHbbLPNKpkY0JQ6YkijfwVSVWaTLcWSAvxJkybFsGHD4p577mmowf/zn/8cs2bNiquvvnqVThD4P4IUSGNxDGk02eYpeZvMuXPnxllnnRWPP/54RETssMMO8b3vfS922WWXVr3eNpkArC4Wx5CmUrfJfPzp/y3b2Nv3+mTZxm6tj7wPfqqZ7bcrx7CQNVlIAFane28eVO4pNOuxp58v29g79OpetrFbq00lOrW1tS0+0KqmpibefffdFt9LoALA6iKDD6kqM4NPsTYF+Ndff/2H/tmcOXPinHPOifr6+o88KaB5ghRII6kEaSq1Bp9ibQrwv/SlLzU5Nm/evBg7dmzcfPPN8fWvfz1OPfXUVTY5AAD4d6WSJtsiSbvoRES88MILMWHChLjkkktiyJAh8dBDD8VOO+3U6tfLRELbyUICAC1pc4C/dOnSOP300+Pcc8+NPn36xKxZs2KPPfZo88ACFWg7C2NI45oD1cU2mcXaFOCfeeaZccYZZ0TXrl3jv/7rv5ot2QE+PoIUSGNxDKk02eaoTdtk1tbWxtprrx2DBw+Odu3afeh51113XYvvZZtMaDsBPgCrU6Vuk/mPpxaWbeydtu5atrFbq00Z/OHDh7e4TWZrCVSg7WQhIY1rDrAmaVOAf/HFF39M0wAAAFaF5F10AACgHDTZFitbgK/UANpOmQEA0BIZfAAAsuJBV8XKFuDLRELbufMFaVxzgDWJDD5kRJACaSyOIZV98HMkwAcAICv1mmwLCfAhI7KQkMbdL0izf7knQBIBPgAAWbFNZjEBPmREFhLSuPsFqdTg50iADxkRpEAai2NIU6klOrbJLFZb7gkAAACrjgw+ZEQWEtK4+wWplOjkSIAPGRGkQBqLY0hTsSU6mmwLCfAhI4IUSGNxDKlk8HNUUyqVSuUYeGb77coxLGRNgA/A6nTvzYPKPYVmPTDvX2Ubu992G5dt7NbSZAsAAFWkbCU6MpEArC5KdCCVEp0cKdGBjFgYA7A6VWqJzv3zlpRt7P7bbVS2sVtLBh8yIgsJaVxzgDWJXXQAAMiKJ9kWK1uALxMJbScLCQC0RIkOAFVPUglSVWaTbX25J1DhlOhARgQpkEZSCdJU6pNsKWYffAAAqCIy+AAAZEWTbTEBPmREmQGkUd4GqSqzBp9iAnwAALJSChn8Ip5kCxmRwQdgdarUJ9ne99jrZRt79x3WL9vYrWWbTMiIMgNI45oDrEk86AoyIkgBAE22LZHBB6DqSSpBKk22OdJkCxkRpEAaSSVIU6kPutJkW0yJDmREkAIAtESJDmTEwhjSuOZAdakvyx6Q6aZPnx5TpkyJhQsXRu/evePcc8+NAQMGtPi6q666Kg477LD40pe+FDfccEOrx6v9CHMFAAAKzJgxI8aMGRMTJkyIBx98MHr37h1DhgyJl156qfB1CxYsiO9///uxxx57tHnMsu2D/7kD7y7HsACsgdz9gjT7v1OZTbb3PLqsbGPv+al123T+wIEDo3///jFt2rSIiKivr48ePXrEscceG2PHjm32NStXrow999wzvvnNb8af/vSnWLJkSZsy+JpsISOCFEijRAfSaLJtavny5bF8+fJGx+rq6qKurq7JuStWrIi5c+fGuHHjGo7V1tbG4MGDY86cOR86xqmnnhqdO3eOb33rW/GnP/2pzXPUZAsZEaQAQHlNnjw5Jk2a1OjYhAkTYuLEiU3OXbx4caxcuTK6dOnS6HiXLl3i8ccfb/b977333vjtb38bDz30UPIcNdkCUPUklSBVZZbolPNBV+PGjYsxY8Y0OtZc9j7F66+/HocffnhccMEFsemmmya/jww+ZMTCGNL47ECaSi3RKacPK8dpzqabbhrt2rWLRYsWNTq+aNGi6Nq1a5Pzn3766ViwYEEceOCBDcfq6+sjImKttdaKefPmRa9evVocVwYfMmJhDGlcc4By6NChQ/Tt2zdmzZoVQ4cOjYj3AvZZs2bF6NGjm5y//fbbxyOPPNLo2CmnnBKvv/56/OIXv4gePXq0alxNtgAAZKU8e0CmGTNmTIwYMSL69esXAwYMiKlTp8ayZcviiCOOiIiI4cOHR/fu3WPy5MnRsWPH2GmnnRq9fqONNoqIaHK8iAAfAAA+JsOGDYuXX345xo8fHwsXLow+ffrErbfe2tB4+9xzz0Vt7ap9NJUAHwCArNSXcZvMFKNHj262JCciYvbs2YWvvfjii9s8ngAfMqKOGNLoX4FUlbmLDsUE+JARQQqksTiGNHbRyZMAHzIiSIE0FseQqjIz+OXcBz8HAnzIiCAF0lgcQxoZ/DwJ8CEjghRIY3EMqSo1g1/uGVS2mlKpPL+ime23K8ewkDUBPgCr0703Dyr3FJp1+38vL9vY+/Ru3VNsy8mTbAGoejL4kKpCM/iZbZO5uinRgYwIUiCNpBKkUYOfp7IF+AIVaDtBCgDQEhl8AACyUq/JtlBtuScAAACsOppsISNK2yCNaw5UFw+6KqZEBzIiSIE0FseQqjJ30aGYEh0AAKgiMvgAAGTFk2yLeZItZESJDgCrU6U+yfaWB98p29j77dq+bGO3liZbAKqeGnxIVZk1+PWeZFtIiQ5kRJACaSSVII0n2eZJgA8AQFbU4Beziw4AAFQRGXzIiDIDSKO8DVJVZg0+xQT4AABkxZNsi9kmEzIigw/A6lSp22Te9MDKso19UL92ZRu7tWTwAQDISr0m20L2wQeg6qnBh1Rq8HOkRAcyYmEMwOpUqSU6N9xfvhKdof2V6HwogQq0nSwkpHHNgepiH/xi9sEHAIAqUrYMvkwktJ0sJABElMI2mUWU6ABQ9SSVIJUm2xzZJhMAgKzYJrOYAB8yIgsJadw1hjT7l3sCJNFkCwAAVUQGHwCArNgms5gMPgAAVBEZfAAAsiKDX0wGHwAAqogMPmTETiCQxg5UkMo++DkS4ENGBCmQxuIY0lTqNpn1JU+yLaJEBwAAqogMPgAAWdFkW0yADxlRZgBplLdBKjX4ORLgAwCQFRn8YgJ8yIgsJKRx9wvSVGqTLcUE+JARQQqksTiGVEp0clRTKpXnJsfM9tuVY1jImgAfgNXp3psHlXsKzbr8T+Wr0fnGHpW/RWfZMvgCFQBWFxl8SCWDnyMZfMiIhTEAq1OlZvAvu6d8Yx++Z/nGbi0ZfACqngw+pJLBz5EMPmTEwhiA1UkGvykZfAAAWMXsg1+sttwTAAAAVh01+JARdcSQxjUHqku9DH4hGXwAAKgiavAhI7KQkMbdL0hVmbvoqMEvZhcdyIgAH4DVqVJ30bnorvKNfcTnyzd2a6nBh4zIQkIa1xxgTaJEBwCArCjRKSbAh4zIQkIad78gVWXW4FNMgA8AQFZsk1lMky1kRAYfgNWpUptsfzOrfGN/e+/yjd1a9sEHAIAqokQHAICsaLItZptMAKqeJltIpck2RzL4AABkpb6+3DOobGrwAQCgisjgQ0aUGUAaZaGQZv9yT+BDqMEvJsCHjAhSII3FMaRSg58jAT5kRJACaSyOIU2lZvApJsAHACArSnSKabIFAIAqIoMPGVFmAGmUt0GqyqzBr5fBLyTAh4wIUiCNxTGkUYOfJwE+ZESQAmksjiFVZWbwKSbABwAgK6WydtnWlHHs1hHgQ0ZkISGNu1+QRolOngT4kBFBCqSxOIZUlVmiY5vMYgJ8yIggBdJYHEMaGfw82QcfAACqiAw+ZEQWEtK4+wWpKrNEp76+3DOobGUL8P1jC20nwIc0PjuQRolOnsoW4PvHFtrOwhjSuOZAddFkW0wNPgAAVBElOpARWUgAiKiXwS8kgw8AAFVEgA8AAFVEky0AVU9ZKKSqzG0yNdkWk8EHAIAq4kFXAABkpVTWLtuaMo7dOnbRgYwobYM0PjuQxoOu8qQGHzJiYQxpXHOANYkMPmREkAIA9sFviQw+ZMTCGNK45gBrEk22kBFBCqSxOIZUtsnMkQAfMiJIgTQWx5BGk22eBPiQEUEKpLE4hlSVmcGvV4RfSIAPGRGkQBqLY0gjg58nT7IFAIAqIoMPAEBWNNkWE+BDRpQZQBrlbZCqMmvwKSbAh4wIUiCNxTGkqdQafBn8YmrwAQCgigjwAQCgipStREepAbSdMgMAiKhXo1NIBh8AAKpI2TL4MpHQdu58QRrXHKgupfpyz6CyKdGBjAhSAICWyOADUPUklSBVZe6DX1KDX8g++JARQQqkkVSCNJW6Dz7FBPiQEUEKpLE4hlSVmcGnmAAfAICs1GuyLSTAh4zIQkIad78gjRKdPAnwISOCFEhjcQypKrNER5NtMQE+ZESQAmksjiGNDP6qMX369JgyZUosXLgwevfuHeeee24MGDCg2XMvuOCCuPTSS+Mf//hHRET07ds3Tj/99A89vzmeZAsAAB+TGTNmxJgxY2LChAnx4IMPRu/evWPIkCHx0ksvNXv+7Nmz47DDDou77ror5syZEz169Ih99903nn/++VaPWVMq0z2Ozx14dzmGBWAN5O4XpNn/ncos0Tnl4hVlG/unIzu06fyBAwdG//79Y9q0aRERUV9fHz169Ihjjz02xo4d2+LrV65cGRtvvHFMmzYthg8f3qoxlehARgQpkEaJDqRRotPU8uXLY/ny5Y2O1dXVRV1dXZNzV6xYEXPnzo1x48Y1HKutrY3BgwfHnDlzWjXem2++Ge+8805ssskmrZ6jEh0AALJSqi+V7Wvy5Mmx4YYbNvqaPHlys/NcvHhxrFy5Mrp06dLoeJcuXWLhwoWt+llPPvnk6NatWwwePLjVvx8ZfAAAaKVx48bFmDFjGh1rLnu/Kvznf/5nXHXVVTF79uzo2LFjq19XtgBfqQG0nTIDAIgo5y6ZH1aO05xNN9002rVrF4sWLWp0fNGiRdG1a9fC1/7sZz+L//zP/4w77rgjdt555zbNsWwBvkAFgNVFUglSVWaTbS46dOgQffv2jVmzZsXQoUMj4r0m21mzZsXo0aM/9HVnnnlmnHbaafHHP/4x+vXr1+ZxlehARgQpkEZSCdJosv3oxowZEyNGjIh+/frFgAEDYurUqbFs2bI44ogjIiJi+PDh0b1794Y6/jPOOCPGjx8fV155ZfTs2bOhVn+99daL9dZbr1VjCvAhI4IUSGNxDKkqM4NfX5/Pk2yHDRsWL7/8cowfPz4WLlwYffr0iVtvvbWh8fa5556L2tr/2/fml7/8ZaxYsSIOPvjgRu8zYcKEmDhxYqvGFOADAMDHaPTo0R9akjN79uxG3y9YsOAjjyfAh4zIQkIad78gTaWW6JTpOa3ZEOBDRgQpkMbiGFJVZokOxWyTCRkR4EManx1IU6kZfIrZJhOAqiepBKkqM4Nfqi/3DCqbEh3IiCAF0kgqQRoZ/DwJ8CEjghRIY3EMqSozg1+vybaQAB8yIkiBNBbHkEYGP0+abCEjghQAsE1mS2pbPgUAAMiFXXQAqHruGkOqyqzBp5gSHciIhTGk8dmBNJVag19fr0SniAw+ZMTCGNK45gBrEhl8yIggBQAi9NgWk8GHjFgYQxrXHGBNIoMPGRGkAAAtkcEHoOpJKkGqytxFp6TJtpB98AEAoIqULYMPAAAp6nXZFlKDDxlR2gZpfHYgTaXug08xNfiQEQtjSOOaA9VFDX4xJTqQEUEKpLE4hlSV2WRLMSU6kBEBPqTx2YE0SnTypEQHMmJhDGlcc6C6KNEpJoMPGRGkAAAtkcGHjFgYQxrXHKguEvjFNNlCRgQpkMbiGFJpss2RJ9kCAEAVkcGHjMhCQhp3vyBNpe6io8m2mAw+AABUERl8AACyUirJ4BcR4ENGlBlAGuVtkEqTbY7sgw8ZEeBDGp8dSFOpNfgUsw8+AFVPUglSVWYGv16TbSElOpARQQqkkVSCNDL4eRLgQ0YEKZDG4hhSVWYGX5NtMQE+ZESQAmksjiGNDH6eBPiQEUEKpLE4hlQVmsFXg1/Ig64AAKCKCPABAKCKKNGBjCgzgDTK2yBNpdbgK9EpJsCHjAhSII3FMaSqzBp8ignwAQDISr1tMgupwQcAgCpStgy+26XQdkp0II3PDqSp1Bp8ipUtwPePLQCri6QSpKrMGnxNtsVk8CEjFsaQxmcH0sjg50mTLQAAWSlpsi2kyRYAAKqIGnwAqp6yUEhVmTX49WrwC6nBh4xYGEManx1IowY/T0p0AACgiijRgYy48wVpXHOgutgms5gSHciIIAUAaIkMPgBVT1IJUlVmk61tMoupwQcAgCriQVeQEVlISOOuMaSxi06eBPiQEUEKpLE4hlQVWqJTX1/uKVQ0JToAAFBFZPABAMiKJ9kWs00mZESJDqTx2YE0avDzZJtMyIiFMaRxzYHqYpvMYmrwAQCgiijRgYzIQgIALdFkCwBAVkqabAupwYeMuPMFaVxzgDWJDD5kRJACaSyOIVWlPuhKBr+IGnzIiAAf0vjsQBrbZOZJiQ4AVU9SCVJVZgafYkp0ICOCFEgjqQRpKjWDX1+qL/cUKpoSHciIIAUAaIkSHQCqnqQSpKrMEh1NtsU8yRYAAKqIGnwAALIig19MBh8AAKqIDD5kRB0xpNH3BWkqdRcdignwISOCFEhjcQypKrTJtqREp4htMiEjAnxI47MDaWTw8ySDDwBAVurrPeiqiH3wISPufEEa1xxgTSKDDxkRpEAai2NIVZk1+BQT4AMAkBX74BezDz4AAFQRGXwAALJSKmmyLWKbTMiIGnxI47MDaWyTmSe76ABQ9SSVIFVlNtmqwS8mgw8ZsTCGND47kEYGP0+abAEAoIoo0YGMuPMFaVxzoLoo0SmmRAcyIkgBAFoigw8ZsTCGNK45UF3qbZNZSA0+AABUEQE+AABUEU+yBQAgK5psi8ngAwBAFZHBh4xoFIQ0GtQhVaU+yVaTbREZfAAAqCIy+JARWUhI4+4XpNm/3BP4EGrwiwnwISOCFEhjcQypKrNEh2ICfMiIIAXSWBxDmkrN4FNMgA8AQFZKnmRbSJMtAABUERl8AACyUq/JtpAAHzKijhjS6F+BVJpsc6REBwAAqkjZMviyKdB2MviQxmcH0lTqLjqeZFtMBh8AAKpI2TL4sikArC7uGkOqyqzB9yTbYppsISOCFEgjqQRpKrVEh2ICfMiIIAXSWBxDqsrM4FNMgA8AQFY8ybaYJlsAAKgiMviQEWUGkEZ5G6Sp1Bp8TbbFZPABAOBjNH369OjZs2d07NgxBg4cGH/7298Kz7/mmmti++23j44dO8anP/3puOWWW9o0ngw+ZEQWEtK4+wWpKrPJNqcHXc2YMSPGjBkT559/fgwcODCmTp0aQ4YMiXnz5kXnzp2bnH/ffffFYYcdFpMnT44DDjggrrzyyhg6dGg8+OCDsdNOO7VqzJpSqVSWexyfO/DucgwLWROkQBqLY0hz782Dyj2FZpUzjmzr72TgwIHRv3//mDZtWkRE1NfXR48ePeLYY4+NsWPHNjl/2LBhsWzZsvj973/fcOwzn/lM9OnTJ84///xWjSmDDxkRpEAai2NIVZkZ/HJavnx5LF++vNGxurq6qKura3LuihUrYu7cuTFu3LiGY7W1tTF48OCYM2dOs+8/Z86cGDNmTKNjQ4YMiRtuuKHVcyxbgF+pK8I13fLly2Py5Mkxbty4Zv9HBZrns1PpBCmVyOeGVOWMIydOnBiTJk1qdGzChAkxceLEJucuXrw4Vq5cGV26dGl0vEuXLvH44483+/4LFy5s9vyFCxe2eo6abGlk+fLlMWnSpCYrU6CYzw60nc8NORo3blwsXbq00dcHM/SVQIkOAAC00oeV4zRn0003jXbt2sWiRYsaHV+0aFF07dq12dd07dq1Tec3RwYfAAA+Bh06dIi+ffvGrFmzGo7V19fHrFmzYrfddmv2Nbvttluj8yMibr/99g89vzky+AAA8DEZM2ZMjBgxIvr16xcDBgyIqVOnxrJly+KII46IiIjhw4dH9+7dY/LkyRERcfzxx8egQYPi5z//eey///5x1VVXxQMPPBC//nXrN9oQ4NNIXV1dTJgwQbMTtJHPDrSdzw1rgmHDhsXLL78c48ePj4ULF0afPn3i1ltvbWikfe6556K29v+Kanbfffe48sor45RTTokf/vCHsc0228QNN9zQ6j3wI8q4Dz4AALDqqcEHAIAqIsAHAIAqIsAHAIAqIsAHAIAqIsCnwfTp06Nnz57RsWPHGDhwYPztb38r95Sg4t1zzz1x4IEHRrdu3aKmpiZuuOGGck8JKt7kyZOjf//+sf7660fnzp1j6NChMW/evHJPC6qGAJ+IiJgxY0aMGTMmJkyYEA8++GD07t07hgwZEi+99FK5pwYVbdmyZdG7d++YPn16uacC2bj77rvjmGOOib/85S9x++23xzvvvBP77rtvLFu2rNxTg6pgm0wiImLgwIHRv3//mDZtWkS895S1Hj16xLHHHhtjx44t8+wgDzU1NXH99dfH0KFDyz0VyMrLL78cnTt3jrvvvjv23HPPck8HsieDT6xYsSLmzp0bgwcPbjhWW1sbgwcPjjlz5pRxZgCsCZYuXRoREZtsskmZZwLVQYBPLF68OFauXNnwRLX3denSJRYuXFimWQGwJqivr48TTjghPvvZz7bpSZ3Ah1ur3BMAANZcxxxzTPzjH/+Ie++9t9xTgaohwCc23XTTaNeuXSxatKjR8UWLFkXXrl3LNCsAqt3o0aPj97//fdxzzz3xyU9+stzTgaqhRIfo0KFD9O3bN2bNmtVwrL6+PmbNmhW77bZbGWcGQDUqlUoxevTouP766+POO++MLbfcstxTgqoig09ERIwZMyZGjBgR/fr1iwEDBsTUqVNj2bJlccQRR5R7alDR3njjjXjqqacavp8/f3489NBDsckmm8Tmm29explB5TrmmGPiyiuvjBtvvDHWX3/9hn6vDTfcMNZee+0yzw7yZ5tMGkybNi2mTJkSCxcujD59+sQ555wTAwcOLPe0oKLNnj07Pv/5zzc5PmLEiLj44otX/4QgAzU1Nc0ev+iii2LkyJGrdzJQhQT4AABQRdTgAwBAFRHgAwBAFRHgAwBAFRHgAwBAFRHgAwBAFRHgAwBAFRHgAwBAFRHgAwBAFRHgA7TRxRdfHBtttNFHfp+ampq44YYbPvL7AMAHCfCBNdLIkSNj6NCh5Z4GAKxyAnwAAKgiAnyAf3PWWWfFpz/96Vh33XWjR48ecfTRR8cbb7zR5Lwbbrghttlmm+jYsWMMGTIk/vnPfzb68xtvvDF23XXX6NixY2y11VYxadKkePfdd5sdc8WKFTF69OjYbLPNomPHjrHFFlvE5MmTP5afD4DqJsAH+De1tbVxzjnnxKOPPhqXXHJJ3HnnnfGDH/yg0TlvvvlmnHbaaXHppZfGn//851iyZEkceuihDX/+pz/9KYYPHx7HH398/M///E/86le/iosvvjhOO+20Zsc855xz4qabboqrr7465s2bF1dccUX07Nnz4/wxAahSNaVSqVTuSQCsbiNHjowlS5a0qsn12muvje9+97uxePHiiHivyfaII46Iv/zlLzFw4MCIiHj88cdjhx12iL/+9a8xYMCAGDx4cOy9994xbty4hve5/PLL4wc/+EG88MILEfFek+31118fQ4cOjeOOOy4effTRuOOOO6KmpmbV/8AArDFk8AH+zR133BF77713dO/ePdZff/04/PDD45VXXok333yz4Zy11lor+vfv3/D99ttvHxtttFE89thjERHx3//933HqqafGeuut1/B15JFHxosvvtjofd43cuTIeOihh2K77baL4447Lm677baP/wcFoCoJ8AE+YMGCBXHAAQfEzjvvHL/73e9i7ty5MX369Ih4r06+td54442YNGlSPPTQQw1fjzzySDz55JPRsWPHJufvuuuuMX/+/PjJT34Sb731VhxyyCFx8MEHr7KfC4A1x1rlngBAJZk7d27U19fHz3/+86itfS8HcvXVVzc57913340HHnggBgwYEBER8+bNiyVLlsQOO+wQEe8F7PPmzYutt9661WNvsMEGMWzYsBg2bFgcfPDB8cUvfjFeffXV2GSTTVbBTwbAmkKAD6yxli5dGg899FCjY5tuumm88847ce6558aBBx4Yf/7zn+P8889v8tr27dvHscceG+ecc06stdZaMXr06PjMZz7TEPCPHz8+DjjggNh8883j4IMPjtra2vjv//7v+Mc//hE//elPm7zfWWedFZtttlnssssuUVtbG9dcc0107dp1lTxQC4A1ixIdYI01e/bs2GWXXRp9XXbZZXHWWWfFGWecETvttFNcccUVzW5Xuc4668TJJ58cX/va1+Kzn/1srLfeejFjxoyGPx8yZEj8/ve/j9tuuy369+8fn/nMZ+Lss8+OLbbYotm5rL/++nHmmWdGv379on///rFgwYK45ZZbGu4iAEBr2UUHAACqiNQQAABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUEQE+AABUkf8PNs5SpauUb40AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAusAAAK9CAYAAACdLiLXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABeY0lEQVR4nO3deXRUVdb38V0JmQiTgTAkQAgJEAggMgUIgyKKCtrYRsB2AAcau0EUHLFVIIpReUQcaJHWBlRsQJm6fVSURkRQZJAZwjwoc8IMkpDUff/wJQ9FgqSuSfY9db+ftVxLLlV1fglJ1a5T+5zjsSzLEgAAAACOE6QdAAAAAEDRKNYBAAAAh6JYBwAAAByKYh0AAABwKIp1AAAAwKEo1gEAAACHolgHAAAAHIpiHQAAAHAoinUAAADAoSjWAfwueXl58sQTT0idOnUkKChIevXqVarjXX311XL11Vf7fb9du3aJx+OR//mf/ymxLAsXLhSPxyMLFy4ssccsji+++EJatGgh4eHh4vF45NixY2U6Pv6P1s8AAPegWIdrTZ48WTwej6xYsaLIv7/66quladOmpZrhs88+k5EjR5bqGKXtn//8p4wZM0bS0tJkypQpMnToUO1IAS07O1t69+4tERERMn78ePnggw8kMjJSXnzxRZkzZ452PABACSunHQBws88++0zGjx9vdMG+YMECiY2Nlddee007iissX75cTp48Kc8//7x069at4PqLL74oaWlppf7JBnx17txZfvnlFwkNDdWOAiBAMbMO4Hc5dOiQVKlSpcQez+v1ytmzZ0vs8QLNoUOHRERK9Ht+KWfPnhWv11vq4/xeZ86cURs7KChIwsPDJSiIl1MApYNnF8BPH374obRq1UoiIiIkKipK+vbtKz/99JPPbb799lu5/fbbpW7duhIWFiZ16tSRoUOHyi+//FJwm/79+8v48eNFRMTj8RT8J+LbXz1+/HipX7++lC9fXq6//nr56aefxLIsef7556V27doSEREhf/jDH+TIkSM+GebOnSs9evSQmJgYCQsLk4SEBHn++eclPz/f53bn231WrlwpHTp0kIiICImPj5cJEyb85vfhfMavv/5aNmzYUJD/fO/u6dOn5dFHH5U6depIWFiYNGrUSP7nf/5HLMvyeRyPxyODBw+WqVOnSnJysoSFhckXX3xR7H+P3Nxc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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",
    "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": 43,
   "id": "69f9a80d",
   "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": 24,
   "id": "f63ca0ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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+OOP1bZtW23atEnp6ekaOHDgFeuLiIi4bgE4Pj5en332mfbs2WPeEfXggw+qfv36evzxx7Vr165Lruvu7q74+Hg9+uijSklJuWyAWLFihUaMGKHvvvtOt912mySpd+/eKigo0Pjx49WvXz9VrVr1uhyT1dW8TypUqGDWd7GaNWsW+T29ksKwZB0TKcm8RHqlUCn98bexU6dOkqT77rtPy5cv13333ac9e/ZcciwbbjwCEm4aHx8fhYSEaN++fVe1XknPFBT3h+jw4cPq2LGj6tatq9mzZys0NFTu7u768MMP9dJLL6mgoOCqailUuXJlRUZG6v3339e5c+eueXzFxx9/rJ49e6pt27Z67bXXFBwcLDc3Ny1evLjIgGWpZH90S6Pw9XjooYcUGxtbbJ9LjWsqtGzZMkm65FmmH3744ao/iK7EZrMVGfQu/TH+qzjFvX5vvPGGBg8erF69emncuHEKCAiQq6urEhMTzQ/gqxETE6PAwEC98cYbatu2rd544w0FBQWZH4SXk5mZWaLngbm7u182qOXk5GjhwoV6+umnHW4Xd3NzU5cuXfTqq68qJyfnsreih4aGSvrvOLxLee2119S0adMi4aNnz55asmSJvvzyyxId+43m4eFR7K3zWVlZJTpr4+rqap59LLzR5OTJk0X6nTx5Uv7+/lc8e1Sc3r17a+DAgVqxYgUByYkISLipunfvrgULFig5OVlRUVGX7RsWFqaCggJ9//33qlevntmenp6ujIwMhYWFXXF/H3zwgbKzs7VmzRqHu0yKuzPpauXl5Un64w/r5QJSQUGBfvjhB/OskSR99913kv57t8q7774rT09PbdiwweEP6uLFi0tcz9Veciquf/Xq1eXt7a38/PxSfZgdOXJEO3fuVHx8vNq1a+ewrKCgQAMHDtTy5cs1adIkc1D4vn37ipwlLHRxn8vVU6VKFf3www9F2q1nGS/nnXfeUc2aNfXee+85vDbWS2m1atXShg0bdObMmcuGE1dXV/Xv319LlizRCy+8oNWrV2v48OElekbW448/rqVLl16xX7t27S77YNBff/1VeXl5xQbF3NxcFRQUXDJEFip8Xa2XJK3S09OLveRXeCau8PflRijp++RyZs2apSlTplyxX1hYmHnm9y9/+YuqV69u3r14MevA/quRnZ2tgoICZWZmlmp9XB/c5o+b6umnn5aXl5eGDRum9PT0IssPHz5s3pbbtWtXSdKcOXMc+syePVuSitzZVZzCD6OLzy5kZmZeVfAozpkzZ7Rz504FBQUpICDgiv1fffVV82fDMPTqq6/Kzc1NHTt2NOssHKdS6OjRo1f1pOvCu3FKemuwl5dXkb6urq7q06eP3n333WLP9F3p6cCFZ4+efvpp3X///Q7Tgw8+qHbt2pl9oqOj5e3trcTExCJ3bBX+ezVr1kw1atTQnDlzitR68b9prVq1dODAAYf6vvrqqyJjai6nuPfKrl27lJyc7NCvT58+Mgyj2A9T61msgQMH6uzZs3rkkUeUlZVVonFF0h+vX1JS0hWnF1988bLbCQgIkJ+fn1atWqWcnByzPSsrSx988IHq1q1rnk0r7t/2t99+05w5c1StWjU1b97cbP/ll1904MABh0vWtWvX1pdffmmG/0JvvvmmXFxcrnjm8VqU9H1yOYMGDSrRa174/i3Up08frV27VsePHzfbNm/erO+++04PPPCA2Zabm6sDBw44nG3KyMhwuJRb6H//938lqdi743DzcAYJN1WtWrW0fPly/c///I/q1avn8CTtnTt36u233zafx9O4cWPFxsZqwYIFysjIULt27bR7924tXbpUvXr1chigfSnR0dFyd3dXjx49zA+pf//73woICCj2tPilvPPOO6pcubIMw9CJEye0cOFCnT17Vq+//voVz9x4enpq/fr1io2NVWRkpD766COtW7dOEydONP9X3q1bN82ePVudO3dW//79derUKc2bN0933HGH9u7dW6IaK1asqIiICK1cuVK1a9eWv7+/GjRocMlxGc2bN9emTZs0e/ZshYSEqEaNGoqMjNT06dO1detWRUZGavjw4YqIiNCZM2e0Z88ebdq06bKXWpYtW6YmTZqYl2WsevbsqVGjRmnPnj1q1qyZXnrpJQ0bNkwtW7ZU//79VaVKFX311Vf6/ffftXTpUrm4uGj+/Pnq0aOHmjRpoocffljBwcE6cOCA9u/frw0bNkj6YzDx7NmzFRMTo6FDh+rUqVN6/fXXVb9+ffPmgCvp3r273nvvPf3tb39Tt27ddOTIEb3++uuKiIhwuPTSoUMHDRw4UC+//LK+//57de7cWQUFBfr444/VoUMHh8HITZs2VYMGDfT222+rXr16atasWYlquV5jkFxdXfXUU09p0qRJ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/HxJUlpamgICAhzWqVChgvz9/ZWWlmb2CQwMdOhTOF/YxyoxMVG+vr7mFBoaer0PDQAAlGFOvcR2JX379jV/btiwoRo1aqRatWpp27Zt6tix4w3b74QJEzR27Fhz3m63E5IAALiFlOkzSFY1a9ZUtWrVdOjQIUlSUFCQTp065dAnLy9PZ86cMcctBQUFKT093aFP4fylxjZ5eHjIx8fHYQIAALeOchWQfvrpJ/36668KDg6WJEVFRSkjI0MpKSlmny1btqigoECRkZFmnx07dig3N9fsk5SUpDp16qhKlSo39wAAAEC54NSAlJWVpdTUVKWmpkqSjhw5otTUVB07dkxZWVkaN26cPvvsMx09elSbN2/WfffdpzvuuEMxMTGSpHr16qlz584aPny4du/erU8//VTx8fHq27evQkJCJEn9+/eXu7u7hg4dqv3792vlypWaO3euwyU0AACAizk1IH3xxRdq2rSpmjZtKkkaO3asmjZtqueee06urq7au3evevbsqdq1a2vo0KFq3ry5Pv74Y3l4eJjbWLZsmerWrauOHTuqa9euuuuuuxyeceTr66uNGzfqyJEjat68uZ588kk999xz3OIPAAAuyWYYhuHsIso6u90uX19fZWZmXnY8Uvgz625iVUDxjk7v5uwSAKBMKOnnd3HK1RgkAACAm4GABAAAYEFAAgAAsCAgAQAAWBCQAAAALAhIAAAAFgQkAAAACwISAACABQEJAADAgoAEAABgQUACAACwICABAABYEJAAAAAsCEgAAAAWBCQAAAALAhIAAIAFAQkAAMCCgAQAAGBBQAIAALAgIAEAAFgQkAAAACwISAAAABYEJAAAAAsCEgAAgAUBCQAAwIKABAAAYEFAAgAAsCAgAQAAWBCQAAAALAhIAAAAFgQkAAAACwISAACABQEJAADAwqkBaceOHerRo4dCQkJks9m0evVqc1lubq7Gjx+vhg0bysvLSyEhIRo0aJBOnDjhsI3w8HDZbDaHafr06Q599u7dq7vvvluenp4KDQ3VjBkzbsbhAQCAcsqpAencuXNq3Lix5s2bV2TZ77//rj179ujZZ5/Vnj179N577+ngwYPq2bNnkb5Tp07VyZMnzWnUqFHmMrvdrujoaIWFhSklJUUzZ87U5MmTtWDBght6bAAAoPyq4Mydd+nSRV26dCl2ma+vr5KSkhza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PHhV2yAgwelWrlypsWPHKiEhQXv27FHjxo0VExOjU6dOObs0oEw5d+6cGjdurHnz5jm7FKBM2759u+Li4vTZZ58pKSlJubm5io6O1rlz50q8DW7zh9NFRkaqZcuWevXVVyX98TUwoaGhGjVqlJ555hknVweUTTabTatWrTK/PgnApZ0+fVoBAQHavn272rZtW6J1OIMEp8rJyVFKSoo6depktrm4uKhTp05KTk52YmUAgD+LzMxMSbqqL60lIMGpfvnlF+Xn5xf5ypfAwEClpaU5qSoAwJ9FQUGBnnjiCbVp00YNGjQo8Xq31FeNAACAW0tcXJz27dunTz755KrWIyDBqapVqyZXV1elp6c7tKenpysoKMhJVQEA/gzi4+O1du1a7dixQ7fddttVrcslNjiVu7u7mjdvrs2bN5ttBQUF2rx5s6KiopxYGQCgvDIMQ/Hx8Vq1apW2bNmiGjVqXPU2OIMEpxs7dqxiY2PVokULtWrVSnPmzNG5c+f08MMPO7s0oEzJysrSoUOHzPkjR44oNTVV/v7+uv32251YGVC2xMXFafny5Xr//ffl7e1tjmn19fVVxYoVS7QNbvNHmfDqq69q5syZSktLU5MmTfTyyy8rMjLS2WUBZcq2bdvUoUOHIu2xsbFasmTJzS8IKKNsNlux7YsXL9bgwYNLtg0CEgAAgCPGIAEAAFgQkAAAACwISAAAABYEJAAAAAsCEgAAgAUBCQAAwIKABAAAYEFAAlCmHT16VDabTampqc4uxXTgwAG1bt1anp6eatKkibPLAXADEJAAXNbgwYNls9k0ffp0h/bVq1df8mm1f3YJCQny8vLSwYMHHb5HsNC2bdtks9kuORX3NGwAZQsBCcAVeXp66oUXXtDZs2edXcp1k5OTU+p1Dx8+rLvuukthYWGqWrVqkeV33nmnTp48WWT617/+JZvNpscee8wpdQMoOQISgCvq1KmTgoKClJiYeMk+kydPLnK5ac6cOQoPDzfnBw8erF69emnatGkKDAyUn5+fpk6dqry8PI0bN07+/v667bbbtHjx4iLbP3DggO688055enqqQYMG2r59u8Pyffv2qUuXLqpcubICAwM1cOBA/fLLL+by9u3bKz4+Xk888YSqVaummJiYYo+joKBAU6dO1W233SYPDw81adJE69evN5fbbDalpKRo6tSpstlsmjx5cpFtuLu7KygoyGE6e/asnnrqKU2cOFEPPPDANde9fft2tWrVSh4eHgoODtYzzzyjvLw8c7133nlHDRs2VMWKFVW1alV16tRJ586dK/aYARRFQAJwRa6urpo2bZpeeeUV/fTTT9e0rS1btujEiRPasWOHZs+erYSEBHXv3l1VqlTRrl279Oijj+qRRx4psp9x48bpySef1JdffqmoqCj16NFDv/76qyQpIyND99xzj5o2baovvvhC69evV3p6uh588EGHbSxdulTu7u769NNP9frrrxdb39y5c/Xiiy9q1qxZ2rt3r2JiYtSzZ099//33kqSTJ0+qfv36evLJJ3Xy5Ek99dRTVzzmjIwM3XfffWrfvr2ef/55h/bS1P3zzz+ra9euatmypb766ivNnz9fCxcu1D/+8Q+zxn79+mnIkCH69ttvtW3bNvXu3Vt89SZwFQwAuIzY2FjjvvvuMwzDMFq3bm0MGTLEMAzDWLVqlXHxn5CEhASjcePGDuu+9NJLRlhYmMO2wsLCjPz8fLOtTp06xt13323O5+XlGV5eXsabb75pGIZhHDlyxJBkTJ8+3eyTm5tr3HbbbcYLL7xgGIZhPP/880Z0dLTDvo8fP25IMg4ePGgYhmG0a9fOaNq06RWPNyQkxPjnP//p0NayZUvjscceM+cbN25sJCQkXHFbhmEY+fn5RpcuXYx69eoZdrvdYVlp6544caJRp04do6CgwGybN2+eUblyZSM/P99ISUkxJBlHjx4tUY0AiuIMEoASe+GFF7R06VJ9++23pd5G/fr15eLy3z89gYGBatiwoTnv6uqqqlWr6tSpUw7rRUVFmT9XqFBBLVq0MOv46quvtHXrVlWuXNmc6tatK+mP8UKFmjdvftna7Ha7Tpw4oTZt2ji0t2nTptTHPHHiRCUnJ+v999+Xt7e3w7LS1v3tt98qKirKYZB8mzZtlJWVpZ9++kmNGzdWx44d1bBhQz3wwAP697///acaPwbcDBWcXQCA8qNt27aKiYnRhAkTNHjwYIdlLi4uRS7h5ObmFtmGm5ubw7zNZiu2raCgoMR1ZWVlqUePHnrhhReKLAsODjZ/9vLyKvE2r4cVK1Zo1qxZWrdunf76178WWX6j6nZ1dVVSUpJ27typjRs36pVXXtHf//537dq1SzVq1Lj6AwFuQZxBAnBVpk+frg8++EDJyckO7dWrV1daWppDSLqezy767LPPzJ/z8vKUkpKievXqSZKaNWum/fv3Kzw8XHfccYfDdDXhwsfHRyEhIfr0008d2j/99FNFRERcVb2pqakaOnSopk+ffskB4aWtu169ekpOTnZ4rT/99FN5e3vrtttuk/RHyGzTpo2mTJmiL7/8Uu7u7lq1atVVHQNwKyMgAbgqDRs21IABA/Tyyy87tLdv316nT5/WjBkzdPjwYc2bN08fffTRddvvvHnztGrVKh04cEBxcXE6e/ashgwZIkmKi4vTmTNn1K9fP33++ec6fPiwNmzYoIcfflj5+flXtZ9x48bphRde0MqVK3Xw4EE988wzSk1N1eOPP17ibfzyyy/q1auX2rdvr4ceekhpaWkO0+nTp6+p7scee0zHjx/XqFGjdODAAb3//vtKSEjQ2LFj5eLiol27dmnatGn64osvdOzYMb333ns6ffq0GSgBXBkBCcBVmzp1apFLYPXq1dNrr72mefPmqXHjxtq9e3eJ7vAqqenTp2v69Olq3LixPvnkE61Zs0bVqlWTJPOsT35+vqKjo9WwYUM98cQT8vPzcxjvVBKjR4/W2LFj9eSTT6phw4Zav3691qxZU+wlsktZt26dfvzxR3344YcKDg4uMrVs2fKa6v7LX/6iDz/8ULt371bjxo316KOPaujQoZo0aZKkP86E7dixQ127dlXt2rU1adIkvfjii+rSpctVvRbArcxmWAcNAAAA3OI4gwQAAGBBQAIAALAgIAEAAFgQkAAAACwISAAAABYEJAAAAAsCEgAAgAUBCQAAwIKABAAAYEFAAgAAsCAgAQAAWBCQAAAALP4fslhdeVqPgqwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from collections import Counter\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((NO_OF_NODES, NO_OF_CLASSES))\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",
    "    \n",
    "Phi = C_t_0@Y\n",
    "Phi[Phi<1]=0\n",
    "Phi = Phi.detach().cpu().numpy()\n",
    "# Generate a sample num_zeros_per_row array with shape (998, 6)\n",
    "# num_zeros_per_row = np.random.randint(0, 6, size=(998, 6))  # Replace with your actual data\n",
    "num_zeros_per_row = np.sum(Phi == 0, axis=1)\n",
    "\n",
    "filtered_counts = [count for count in num_zeros_per_row if count <= 2]\n",
    "counts = Counter(filtered_counts)\n",
    "\n",
    "# Create a bar plot\n",
    "plt.bar(counts.keys(), counts.values())\n",
    "plt.xlabel(\"Number of Zeros\")\n",
    "plt.ylabel(\"Count\")\n",
    "plt.xticks(range(3))\n",
    "plt.title(\"Cora Bipartite Accuracy = 85.81, cr=0.3\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bdf84e9c",
   "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
}
