{
 "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_49756\\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_49756\\4057615484.py:25: DeprecationWarning: Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "  from IPython.core.display import display, HTML\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>.container { width:90% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import collections\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "from torch import Tensor\n",
    "import torch_geometric\n",
    "from torch_geometric.utils import to_networkx\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import networkx as nx\n",
    "from networkx.algorithms import community\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "data_dir = \"./data\"\n",
    "os.makedirs(data_dir, exist_ok=True)\n",
    "\n",
    "import numpy\n",
    "import torch\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "%matplotlib inline\n",
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:90% !important; }</style>\"))\n",
    "\n",
    "\n",
    "from random import sample\n",
    "from networkx.generators.random_graphs import erdos_renyi_graph\n",
    "from networkx.generators.random_graphs import barabasi_albert_graph\n",
    "from networkx.generators.community import stochastic_block_model\n",
    "from networkx.generators.random_graphs import watts_strogatz_graph\n",
    "from networkx.generators.community import random_partition_graph\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import FactorAnalysis\n",
    "import random\n",
    "\n",
    "from scipy.sparse import csr_matrix\n",
    "from scipy.sparse import csgraph\n",
    "from scipy.sparse.linalg import inv\n",
    "\n",
    "import os\n",
    "os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3669a0f9",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "3669a0f9",
    "outputId": "213cddc0-551b-4948-a025-9704edf67d7e"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite\\\\Cora'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset = os.path.join(os.getcwd(),'Cora')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "067c3d06",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "067c3d06",
    "outputId": "9c7402f2-2cfc-46ea-e604-13ef4b07d6ff"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dataset: Cora\n",
      "num_nodes: 2708\n",
      "num_edges: 10556\n",
      "num_classes: 7\n",
      "num_features: 1433\n"
     ]
    }
   ],
   "source": [
    "import os.path as osp\n",
    "import torch\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import torch_geometric.transforms as T\n",
    "\n",
    "def get_planetoid_dataset(name, normalize_features=False, transform=None, split=\"public\"):\n",
    "    path = osp.join(osp.dirname(osp.realpath(os.getcwd())), '..', 'data', name)\n",
    "    if split == 'complete':\n",
    "        dataset = Planetoid(path, name)\n",
    "        dataset[0].train_mask.fill_(False)\n",
    "        dataset[0].train_mask[:dataset[0].num_nodes - 1000] = 1\n",
    "        dataset[0].val_mask.fill_(False)\n",
    "        dataset[0].val_mask[dataset[0].num_nodes - 1000:dataset[0].num_nodes - 500] = 1\n",
    "        dataset[0].test_mask.fill_(False)\n",
    "        dataset[0].test_mask[dataset[0].num_nodes - 500:] = 1\n",
    "    else:\n",
    "        dataset = Planetoid(path, name, split=split)\n",
    "    if transform is not None and normalize_features:\n",
    "        dataset.transform = T.Compose([T.NormalizeFeatures(), transform])\n",
    "    elif normalize_features:\n",
    "        dataset.transform = T.NormalizeFeatures()\n",
    "    elif transform is not None:\n",
    "        dataset.transform = transform\n",
    "    return dataset\n",
    "\n",
    "\n",
    "if __name__ == '__main__':\n",
    "#     lst_names = ['Cora', 'CiteSeer', 'PubMed']\n",
    "    lst_names = ['Cora']\n",
    "    for name in lst_names:\n",
    "        dataset = get_planetoid_dataset(name)\n",
    "        print(f\"dataset: {name}\")\n",
    "        print(f\"num_nodes: {dataset[0]['x'].shape[0]}\")\n",
    "        print(f\"num_edges: {dataset[0]['edge_index'].shape[1]}\")\n",
    "        print(f\"num_classes: {dataset.num_classes}\")\n",
    "        print(f\"num_features: {dataset.num_node_features}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7f8577f3",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "7f8577f3",
    "outputId": "de9c336b-dbd9-40ca-e1fa-58107ade7ce8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data(x=[2708, 1433], edge_index=[2, 10556], y=[2708], train_mask=[2708], val_mask=[2708], test_mask=[2708])\n",
      "torch.Size([2708, 1433]) torch.Size([2708, 2708])\n",
      "torch.Size([2708, 1433]) torch.Size([2708, 2708])\n"
     ]
    }
   ],
   "source": [
    "from torch_geometric.datasets import Planetoid\n",
    "from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "# # dataset = NELL(root='/nell')\n",
    "\n",
    "# dataset= Planetoid(root=dataset, name='Cora')\n",
    "k_ = dataset.num_classes\n",
    "print(dataset[0])\n",
    "adj = to_dense_adj(dataset[0].edge_index)\n",
    "adj = adj[0]\n",
    "labels = dataset[0].y\n",
    "labels = labels.numpy()\n",
    "\n",
    "X = dataset[0].x\n",
    "X = X.to_dense()\n",
    "N = X.shape[0]\n",
    "NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "A = adj[:nn,:nn]\n",
    "AT= torch.transpose(A,0,1)\n",
    "labels = labels[:nn]\n",
    "print(X.shape,adj.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "475846d5",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "475846d5",
    "outputId": "c6102e64-ae54-46d6-8f9b-48ba85a81564"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2708, 1433])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7aec8d70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2708,)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a0757b15",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "a0757b15",
    "outputId": "d35c00b4-f747-4b97-c075-b98efcdb77eb"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([2708, 2708])\n"
     ]
    }
   ],
   "source": [
    "def get_laplacian(adj):\n",
    "    b=torch.ones(adj.shape[0])\n",
    "    return torch.diag(adj@b)-adj\n",
    "\n",
    "theta = get_laplacian(adj)\n",
    "print(theta.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "36a2d1ca",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "36a2d1ca",
    "outputId": "47e7d15b-491d-49ad-9dff-fcdb283b16a7"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'torch.FloatTensor'"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(theta@A).type()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cad0c60b",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "cad0c60b",
    "outputId": "4de3ae5a-7f39-4649-bae9-c437127dc115"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "theta.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "114a42e0",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "114a42e0",
    "outputId": "62b0a402-9d33-44be-8e7f-20de623be138"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7 2708\n"
     ]
    }
   ],
   "source": [
    "\n",
    "features = torch.Tensor(X)\n",
    "NO_OF_NODES = X.shape[0]\n",
    "print(NO_OF_CLASSES,NO_OF_NODES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2ba32732",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "2ba32732",
    "outputId": "4d8096c2-cca6-41e5-f7f9-ebd3e815a404"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b33c30e2",
   "metadata": {
    "id": "b33c30e2"
   },
   "outputs": [],
   "source": [
    "def convertScipyToTensor(coo):\n",
    "  try:\n",
    "    coo = coo.tocoo()\n",
    "  except:\n",
    "    coo = coo\n",
    "  values = coo.data\n",
    "  indices = np.vstack((coo.row, coo.col))\n",
    "\n",
    "  i = torch.LongTensor(indices)\n",
    "  v = torch.FloatTensor(values)\n",
    "  shape = coo.shape\n",
    "\n",
    "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b7f9d72b",
   "metadata": {
    "id": "b7f9d72b"
   },
   "outputs": [],
   "source": [
    "from scipy.sparse import random\n",
    "from scipy.sparse.linalg import norm\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "p = X.shape[0]\n",
    "k = int(p*0.3)\n",
    "n = X.shape[1]\n",
    "lr = 1e-5\n",
    "thresh = 1e-10\n",
    "\n",
    "from scipy.sparse import random\n",
    "from scipy.stats import rv_continuous\n",
    "class CustomDistribution(rv_continuous):\n",
    "    def _rvs(self,  size=None, random_state=None):\n",
    "        return random_state.standard_normal(size)\n",
    "temp = CustomDistribution(seed=1)\n",
    "temp2 = temp()  # get a frozen version of the distribution\n",
    "C = random(p, k, density=0.25, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "eecc9adb",
   "metadata": {
    "id": "eecc9adb"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.nn import GCNConv\n",
    "\n",
    "\n",
    "class Net(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Net, self).__init__()\n",
    "        self.conv1 = GCNConv(X.shape[1], 64)\n",
    "        self.conv2 = GCNConv(64, NO_OF_CLASSES)\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.conv1.reset_parameters()\n",
    "        self.conv2.reset_parameters()\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "        x = self.conv1(x, edge_index)\n",
    "        x = F.relu(x)\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return F.log_softmax(x, dim=1)\n",
    "    \n",
    "    \n",
    "####### NO output layer is written\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1c5a519a",
   "metadata": {
    "id": "1c5a519a"
   },
   "outputs": [],
   "source": [
    "def get_accu(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # Lc=C_0_new.T@L@C_0_new\n",
    "        en_mat = Lc\n",
    "        print(\"L:\", Lc.shape)\n",
    "        entropy(en_mat)\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        model=Net().to(device)\n",
    "        lr=0.01\n",
    "        decay=0.0001\n",
    "        features_= features.cpu().detach().numpy()\n",
    "        try:\n",
    "          X=np.array(features_.todense())\n",
    "        except:\n",
    "          X = np.array(features_)\n",
    "        #print(\"X:\",X.shape)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=decay)\n",
    "        # criterion=torch.nn.CrossEntropyLoss()\n",
    "        x=sample(range(0, int(k)), k)\n",
    "      \n",
    "        from datetime import datetime\n",
    "        Xt=P@X\n",
    "        # Xt=X_t_0\n",
    "        def train():\n",
    "            model.train()\n",
    "            optimizer.zero_grad()\n",
    "            out = model(torch.Tensor(Xt).to(device),edge_index_coarsen2)\n",
    "            loss = F.nll_loss(out[x], labels_coarse[x])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            return loss\n",
    "        now1 = datetime.now()\n",
    "        losses=[]\n",
    "        for epoch in range(100):\n",
    "            loss=train()\n",
    "            losses.append(loss)\n",
    "            if(epoch%100==0):\n",
    "                print(f'Epoch: {epoch:03d},loss: {loss:.4f}')\n",
    "        now2 = datetime.now()        \n",
    "        pred=model(torch.Tensor(Xt).to(device),edge_index_coarsen2).argmax(dim=1)        \n",
    "        def train_accuracy():\n",
    "            model.eval()\n",
    "            correct = (pred[x] == labels_coarse[x]).sum()\n",
    "            acc = int(correct) /len(x)\n",
    "            return acc\n",
    "    \n",
    "        t+=[(now2-now1).total_seconds()]\n",
    "\n",
    "        zz=sample(range(0, int(NO_OF_NODES)), NO_OF_NODES)\n",
    "        adj_ = adj.cpu().detach().numpy()\n",
    "        Wc=sparse.csr_matrix(adj_)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_coarsen).argmax(dim=1)\n",
    "        pred=np.array(pred)\n",
    "        correct =(pred[zz]==labels[zz]).sum()\n",
    "        acc = int(correct) /NO_OF_NODES\n",
    "        return acc\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "8a4725d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "\n",
    "def entropy(en_mat):\n",
    "  EV, _ = np.linalg.eig(en_mat)\n",
    "  my_list = [x for x in EV.tolist() if x]\n",
    "  leng = len(my_list)\n",
    "  Sum = np.sum(np.real(my_list))\n",
    "  entropy = 0\n",
    "\n",
    "  for i in range(leng):\n",
    "      ratio = np.real(my_list[i]) / Sum\n",
    "      if ratio > 0:\n",
    "        entropy += -(ratio * math.log2(ratio))\n",
    "  print(\"Entropy..................\", entropy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "1f724733",
   "metadata": {
    "id": "1f724733"
   },
   "outputs": [],
   "source": [
    "def experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A):\n",
    "      p = X.shape[0]\n",
    "      k = int(p*0.3)\n",
    "      n = X.shape[1]\n",
    "      ones = csr_matrix(np.ones((k,k)))\n",
    "      ones = convertScipyToTensor(ones)  \n",
    "      ones = ones.to_dense()\n",
    "      \n",
    "      try:\n",
    "        C = convertScipyToTensor(C)\n",
    "        C = C.to_dense()\n",
    "      except:\n",
    "        C=C\n",
    "      try:\n",
    "        theta = convertScipyToTensor(theta)\n",
    "      except:\n",
    "        theta = theta\n",
    "      try:\n",
    "        X = convertScipyToTensor(X)\n",
    "        X = X.to_dense()\n",
    "      except:\n",
    "        X = X\n",
    "      if(torch.cuda.is_available()):\n",
    "        print(\"GPU is available\")\n",
    "        C = C  \n",
    "        theta = theta  \n",
    "        X = X  \n",
    "        ones = ones  \n",
    "      \n",
    "        \n",
    "      def bracket_term2fun(C,CT,theta):\n",
    "          # U  = update_V(C,theta).double()\n",
    "          U = torch.stack(update_V(C, theta)).double()\n",
    "          UT= torch.transpose(U,0,1)\n",
    "          Lw = (CT @theta @C).double()\n",
    "          lb= 1e-5\n",
    "          ub = 1e+4\n",
    "          beta = 0.5 \n",
    "          lambda_ =  laplacian_lambda_update(lb, ub, beta, U, Lw, k_,C)   \n",
    "          lambda_matrix =  torch.diag(lambda_,0)  \n",
    "          # print(lambda_matrix)\n",
    "          # print(f'Shape of U is: {U.shape}')\n",
    "          # print(f'Shape of lambda: {}')\n",
    "          # print(f'Shape of lambda_matrix is: {lambda_matrix.shape}')\n",
    "          return UT@lambda_matrix@U\n",
    "        \n",
    "      def update_V(C,theta):\n",
    "            \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        product = CT @ A @ C               \n",
    "        matrix = torch.tensor(product)         \n",
    "        eigenvalues, eigenvectors = torch.linalg.eig(product)\n",
    "\n",
    "        # select non-zero eigenvalues and eigenvectors\n",
    "        non_zero_eigenvalues = []\n",
    "        non_zero_eigenvectors = []\n",
    "          \n",
    "        # for i in range(matrix.shape[0]):\n",
    "        #     if matrix[i, i] != 0:\n",
    "        #         non_zero_eigenvalues.append(eigenvalues[i])\n",
    "        #         non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        # U = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        # return U    \n",
    "\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if eigenvalues[i] != 0:\n",
    "                non_zero_eigenvalues.append(eigenvalues[i])\n",
    "                non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        return V \n",
    " \n",
    "\n",
    "      def update_C(C):\n",
    "          CT = torch.transpose(C,0,1)\n",
    "          C.size()\n",
    "          t1 = alpha_param*(C@ones)  \n",
    "          bracket_term1 = (CT@theta@C)\n",
    "          bracket_term3 = (CT@A@C)\n",
    "          bracket_term2 = bracket_term2fun(C,CT,theta) \n",
    "          bracket_term = bracket_term3 - bracket_term2             # bracket term (CT*A*C - U*lambda*UT)\n",
    "          t22 = -2*(theta@C)                                      # Check for multiplication of gamma\n",
    "#           print(t22.type())\n",
    "          t3 = bracket_term1\n",
    "          t7 = bracket_term2\n",
    "          t6 = (CT@A@C)  \n",
    "          t5 = 2* beta_param*(A@C)\n",
    "          t5 = t5.float()\n",
    "          t4 = (1.0/k)\n",
    "          t44 = t4*((torch.ones(k,k)).double())  \n",
    "#           print(t3.device)\n",
    "#           print(t44.device)\n",
    "          t8 = (t3 + t44)  \n",
    "          t9 = torch.pinverse(t8)                  \n",
    "          t9 = t9.float()\n",
    "#           print(t9.type())\n",
    "#           print(t9)x\n",
    "          t10 = (t22@t9)  \n",
    "          t11 = (t6 - t7)  \n",
    "          t11 = t11.float()\n",
    "          t12 = (t5@t11)\n",
    "          t13 = (t1 + t10 +t12)  \n",
    "        \n",
    "          #t2 = beta_param*(theta@C@bracket_term.float())\n",
    "          grad_fc= t13\n",
    "          C_new=C-gamma_param*grad_fc\n",
    "          C_new[C_new<thresh] = thresh\n",
    "          for i in range(len(C_new)):\n",
    "              C_new[i] = C_new[i]/torch.linalg.norm(C_new[i],1)\n",
    "          return C_new        \n",
    "            \n",
    "\n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "\n",
    "      #We set c1 = 10−5 and c2 = 10^4 We observed that the experimental performances of the algorithms \n",
    "       #are not sensitive to different values of c1 and c2 as long as they are reasonably small and large,respectively\n",
    "      # K is the number of smallest eigenvalues of the Laplacian matrix that are being ignored while updating the eigenvalues.\n",
    "      def laplacian_lambda_update(lb, ub, beta, U, Lw, k, C):\n",
    "        q = Lw.size(1) - k\n",
    "        # print(f'q is: {q}')\n",
    "        U = U\n",
    "        UT= torch.transpose(U,0,1)\n",
    "        UT = UT.type(torch.float64)\n",
    "        UT = UT\n",
    "        \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        CT = CT.type(torch.float64)\n",
    "        CT = CT\n",
    "        \n",
    "        AC=(A@C).double()\n",
    "        AC = AC\n",
    "        \n",
    "        Af=(CT@AC).double()\n",
    "        Af = Af  \n",
    "        Af.device\n",
    "        U.device\n",
    "        dd = U@Af@UT\n",
    "          \n",
    "        # cc = UT@A@U\n",
    "        \n",
    "        product = dd\n",
    "        matrix = torch.tensor(product)     \n",
    "\n",
    "        non_zero_diag_elements = []\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if matrix[i, i] != 0:\n",
    "                non_zero_diag_elements.append(matrix[i, i])\n",
    "            if len(non_zero_diag_elements) == len(matrix):\n",
    "                break\n",
    "\n",
    "        k = len(non_zero_diag_elements)\n",
    "        e = non_zero_diag_elements\n",
    "        d = torch.diag(torch.tensor(non_zero_diag_elements))\n",
    "#-----------------------------------------------------------------------------------------------------------------------------------------------\n",
    "\n",
    "       # Trial-2                 -########################################\n",
    "\n",
    "        e_bar = torch.tensor([])\n",
    "        if(k%2 == 0):\n",
    "            for i in range(k//2):\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)\n",
    "            \n",
    "        if(k%2 != 0):\n",
    "            for i in range((k+1)//2) :\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)       \n",
    "                \n",
    "        lambda_,indices = torch.sort(e_bar, dim=- 1, descending=True)\n",
    "        eps = 1\n",
    "        qq = lambda_.size(0)-1\n",
    "        condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "\n",
    "#                                   (lambda_[1:(q)] - lambda_[0:(q-1)]) >= -eps])\n",
    "        \n",
    "          \n",
    "        if condition.all():\n",
    "            # while(lambda_.size(0) != 135):\n",
    "            #     lambda_ = torch.cat((lambda_, torch.tensor(0).unsqueeze(0)), dim=0)\n",
    "            for i in range(k//2):\n",
    "                lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)\n",
    "            # print(f'Shape of updated lambda1_ is: {lambda_.shape}')\n",
    "            # hm= sns.heatmap(data =lambda_)\n",
    "            # plt.show()\n",
    "            # print(lambda_)\n",
    "            return lambda_\n",
    "        else:\n",
    "            greater_ub = lambda_ > ub\n",
    "            lesser_lb = lambda_ < lb\n",
    "            lambda_[greater_ub] = ub\n",
    "            lambda_[lesser_lb] = lb\n",
    "            condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "        for i in range(k//2):\n",
    "            lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)            \n",
    "            \n",
    "\n",
    "        print(f'Shape of updated lambda2_ is: {lambda_.shape}')\n",
    "        if condition.all():\n",
    "            return lambda_\n",
    "        else:\n",
    "#           print(lambda_)\n",
    "            raise ValueError(\"eigenvalues are not in increasing order, consider increasing the value of beta\")\n",
    "\n",
    "      for i in tqdm(range(10)): #update C only 21\n",
    "         C = update_C(C)\n",
    "            \n",
    "      return C\n",
    "          \n",
    "#-----------------------------------------------------------------------------------------------------------------------------------------------\n",
    "\n",
    "        # Trial-1                 -########################################\n",
    "          \n",
    "#         e = 0.5 * (d + torch.sqrt(d.pow(2) + 4 / beta))\n",
    "#         # print(f'e is:{e}')\n",
    "#         # print(f'e is: {e}')  \n",
    "#         print(f'Shape of e is: {e.shape}')\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",
    "#         # print(f'e_bar is: {e_bar}')\n",
    "#         print(f'Shape of e_bar is: {e_bar.shape}')\n",
    "#         # e_bar_tensor = torch.tensor(e_bar, dtype=torch.float32)\n",
    "          \n",
    "#         lambda_,indices = torch.sort(e_bar, dim=- 1, descending=True)\n",
    "          \n",
    "#         # print(f'Shape of lambda_ is: {lambda_.shape}')\n",
    "        \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",
    "\n",
    "# #                                   (lambda_[1:q] - lambda_[0:(q-1)]) >= -eps])\n",
    "\n",
    "#         # while(lambda_.size(0) != 135):\n",
    "#         #     lambda_ = torch.cat((lambda_, torch.tensor(0).unsqueeze(0)), dim=0)\n",
    "            \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",
    "            \n",
    "#       for i in tqdm(range(10)): #update C only 21\n",
    "#          C = update_C(C)\n",
    "            \n",
    "#       return C\n",
    "        \n",
    "\n",
    "\n",
    "#-----------------------------------------------------------------------------------------------------------------------------------------------\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    \n",
    "       \n",
    "#         lambda_ = 0.5 * (d + torch.sqrt(d.pow(2) + 4 / beta))\n",
    "# #         print(lambda_)\n",
    "#         lambda_,indices = torch.sort(lambda_, dim=- 1, descending=False)\n",
    "#         eps = 1\n",
    "#         condition = torch.stack([(lambda_[q] - ub) >= eps,\n",
    "#                          (lambda_[0] - lb) <= -eps]).all(dim=0)\n",
    "\n",
    "# #                                   (lambda_[1:(q)] - lambda_[0:(q-1)]) >= -eps])\n",
    "#         if condition.all():\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_[q] - ub) >= eps,\n",
    "#                          (lambda_[0] - lb) <= -eps]).all(dim=0)\n",
    "\n",
    "# #                                   (lambda_[1:q] - lambda_[0:(q-1)]) >= -eps])\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",
    "\n",
    "#       for i in tqdm(range(10)): #update C only 21\n",
    "#          C = update_C(C)\n",
    "            \n",
    "#       return C"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "556afd48",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "556afd48",
    "outputId": "7f0b9b03-7a98-4a01-ac78-fc754863ff46"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_49756\\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_49756\\838881801.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_49756\\838881801.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_49756\\838881801.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_49756\\838881801.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Accuracy = 0.27031019202363366 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_49756\\838881801.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_49756\\838881801.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_49756\\838881801.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.772525849335306 +/- 0.25849335302806364\n",
      "Params =  1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.72304283604136 +/- 0.3138847858197944\n",
      "Params =  1000 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.63s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.94460856720827 +/- 0.7939438700147725\n",
      "Params =  1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.52s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.237075332348596 +/- 0.5723781388478566\n",
      "Params =  1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.0768094534712 +/- 1.5878877400295435\n",
      "Params =  1000 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.09231905465288 +/- 1.7540620384047272\n",
      "Params =  1000 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 26.126292466765143 +/- 0.31388478581979296\n",
      "Params =  1000 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.070901033973414 +/- 0.0\n",
      "Params =  1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 22.913589364844906 +/- 0.3138847858197944\n",
      "Params =  1000 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.997045790251107 +/- 0.590841949778434\n",
      "Params =  1000 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.200147710487443 +/- 0.6093057607090085\n",
      "Params =  1000 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.90768094534712 +/- 0.4246676514032502\n",
      "Params =  1000 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "Average accuracy = 25.129246676514033 +/- 0.31388478581979157\n",
      "Params =  1000 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 23.024372230428362 +/- 1.384785819793205\n",
      "Params =  1000 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "Average accuracy = 25.240029542097485 +/- 1.6432791728212701\n",
      "Params =  1000 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "Average accuracy = 25.609305760709013 +/- 0.05539143279172931\n",
      "Params =  1000 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 26.08936484490399 +/- 0.2031019202363371\n",
      "Params =  1000 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.59s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.052437223042833 +/- 0.38774002954209685\n",
      "Params =  1000 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 25.018463810930573 +/- 0.8677991137370764\n",
      "Params =  1000 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 25.94165435745938 +/- 0.276957163958641\n",
      "Params =  1000 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 23.81831610044313 +/- 0.4800590841949781\n",
      "Params =  1000 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.516986706056134 +/- 0.44313146233382616\n",
      "Params =  1000 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.8862724992005562\n",
      "Epoch: 000,loss: 1.9462\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 19.903988183161005 +/- 6.868537666174299\n",
      "Params =  1000 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.262849330943965\n",
      "Epoch: 000,loss: 6839538176.0000\n",
      "Accuracy = 0.31388478581979323 1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 4.639131673250543\n",
      "Epoch: 000,loss: 1.9440\n",
      "Accuracy = 0.776218611521418 1000 10 0.0001\n",
      "Average accuracy = 54.505169867060566 +/- 23.116691285081238\n",
      "Params =  1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.75701624815362 +/- 0.09231905465287849\n",
      "Params =  1000 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "Average accuracy = 24.63072378138848 +/- 0.775480059084195\n",
      "Params =  1000 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 25.572378138847856 +/- 0.2031019202363371\n",
      "Params =  1000 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 23.81831610044313 +/- 0.9970457902511082\n",
      "Params =  1000 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 24.612259970457902 +/- 0.9785819793205336\n",
      "Params =  1000 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.849335302806498 +/- 0.44313146233382616\n",
      "Params =  1000 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 26.218611521418023 +/- 0.4800590841949781\n",
      "Params =  1000 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.52483206627902\n",
      "Epoch: 000,loss: 1.9443\n",
      "Accuracy = 0.8249630723781388 1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 6.080188033362816\n",
      "Epoch: 000,loss: 1.9542\n",
      "Average accuracy = 82.29320531757755 +/- 0.2031019202363371\n",
      "Params =  1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.97858197932053 +/- 0.7570162481536191\n",
      "Params =  1000 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.6284197685772346\n",
      "Epoch: 000,loss: 1.9454\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "Average accuracy = 26.864844903988182 +/- 0.4615952732644035\n",
      "Params =  1000 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.5384047267356 +/- 0.276957163958641\n",
      "Params =  1000 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.392258260463877\n",
      "Epoch: 000,loss: 1.9461\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.52s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 23.190546528803544 +/- 2.2895125553914335\n",
      "Params =  1000 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.661742983751846 +/- 0.6277695716395859\n",
      "Params =  1000 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.465435681099111\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 23.72599704579025 +/- 2.2341211225997055\n",
      "Params =  1000 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.63s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.9716525390216133\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 19.49778434268833 +/- 4.542097488921713\n",
      "Params =  1000 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.463106439994121\n",
      "Epoch: 000,loss: 1.9481\n",
      "Accuracy = 0.829394387001477 1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.395655057995187\n",
      "Epoch: 000,loss: 1.9429\n",
      "Accuracy = 0.8581979320531757 1000 0.1 0.0001\n",
      "Average accuracy = 84.37961595273265 +/- 1.4401772525849343\n",
      "Params =  1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.061990987675416\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 19.571639586410637 +/- 6.166912850812409\n",
      "Params =  1000 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.63072378138848 +/- 1.1078286558345654\n",
      "Params =  1000 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.3262901960966897\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 18.556129985228953 +/- 6.333087149187593\n",
      "Params =  1000 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.24298375184638 +/- 1.7171344165435753\n",
      "Params =  1000 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.30s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.16912850812408 +/- 0.3508124076809449\n",
      "Params =  1000 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.5050166417474027\n",
      "Epoch: 000,loss: 1.9461\n",
      "Average accuracy = 26.403249630723778 +/- 0.553914327917282\n",
      "Params =  1000 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.4933849375125479\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 18.870014771048744 +/- 4.135893648449039\n",
      "Params =  1000 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.580776710484671\n",
      "Epoch: 000,loss: 1.9538\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.138270530231758\n",
      "Epoch: 000,loss: 1.9433\n",
      "Average accuracy = 84.0288035450517 +/- 0.16617429837518793\n",
      "Params =  1000 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.63s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.129246676514033 +/- 0.3508124076809449\n",
      "Params =  1000 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 25.0 +/- 0.3692762186115209\n",
      "Params =  1000 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.47s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.03397341211226 +/- 0.7016248153618898\n",
      "Params =  1000 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.47s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 23.947562776957167 +/- 0.4985228951255541\n",
      "Params =  1000 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.59s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.0190288038177986\n",
      "Epoch: 000,loss: 1.9456\n",
      "Average accuracy = 22.968980797636632 +/- 0.5169867060561301\n",
      "Params =  1000 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.2149324467442524\n",
      "Epoch: 000,loss: 1.9462\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 18.777695716395865 +/- 3.3788774002954214\n",
      "Params =  1000 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.040815589056814\n",
      "Epoch: 000,loss: 1.9461\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.6364299311941948\n",
      "Epoch: 000,loss: 1.9468\n",
      "Average accuracy = 23.596750369276222 +/- 9.12112259970458\n",
      "Params =  1000 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.715492281181496\n",
      "Epoch: 000,loss: 1.9432\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.582760515178241\n",
      "Epoch: 000,loss: 1.9435\n",
      "Average accuracy = 81.14844903988183 +/- 0.72008862629247\n",
      "Params =  1000 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.904726735598228 +/- 0.31388478581979296\n",
      "Params =  1000 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9461\n",
      "Average accuracy = 25.36927621861152 +/- 0.8124076809453471\n",
      "Params =  1000 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 22.32274741506647 +/- 0.4246676514032502\n",
      "Params =  1000 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 22.747415066469717 +/- 1.2186115214180213\n",
      "Params =  1000 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.72304283604136 +/- 0.5354505169867074\n",
      "Params =  1000 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.5465841009828274\n",
      "Epoch: 000,loss: 1.9461\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.6879413564773686\n",
      "Epoch: 000,loss: 1.9464\n",
      "Average accuracy = 19.091580502215656 +/- 4.357459379615952\n",
      "Params =  1000 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.2680861785263167\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.2545335364178472\n",
      "Epoch: 000,loss: 1.9462\n",
      "Average accuracy = 26.624815361890697 +/- 2.1418020679468257\n",
      "Params =  1000 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 6.101065537736474\n",
      "Epoch: 000,loss: 1.9535\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.612163583919984\n",
      "Epoch: 000,loss: 1.9464\n",
      "Average accuracy = 83.75184638109306 +/- 0.036927621861154725\n",
      "Params =  1000 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.240029542097485 +/- 1.6063515509601194\n",
      "Params =  100 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.05539143279173 +/- 0.6462333825701618\n",
      "Params =  100 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.889217134416544 +/- 1.6248153618906942\n",
      "Params =  100 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 24.5384047267356 +/- 0.7200886262924672\n",
      "Params =  100 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.477104874446088 +/- 0.25849335302806364\n",
      "Params =  100 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.073855243722303 +/- 1.3293943870014757\n",
      "Params =  100 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.329394387001475 +/- 0.0738552437223039\n",
      "Params =  100 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:11<00:00,  1.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.386190769638704\n",
      "Epoch: 000,loss: 1.9423\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.882444678982384\n",
      "Epoch: 000,loss: 1.9495\n",
      "Average accuracy = 77.17872968980797 +/- 1.8463810930576086\n",
      "Params =  100 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.59s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.683161004431316 +/- 0.09231905465287849\n",
      "Params =  100 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.221565731166912 +/- 1.0339734121122601\n",
      "Params =  100 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9458\n",
      "Average accuracy = 23.04283604135894 +/- 0.18463810930576113\n",
      "Params =  100 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.52s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.47s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 26.587887740029544 +/- 0.3692762186115195\n",
      "Params =  100 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.775480059084195 +/- 0.3323485967503703\n",
      "Params =  100 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 25.240029542097492 +/- 0.3508124076809463\n",
      "Params =  100 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 22.87666174298375 +/- 1.9756277695716404\n",
      "Params =  100 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:11<00:00,  1.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 8.499833112946353\n",
      "Epoch: 000,loss: 1.9454\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:11<00:00,  1.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 8.555154013750391\n",
      "Epoch: 000,loss: 1.9531\n",
      "Average accuracy = 85.45051698670605 +/- 0.3323485967503703\n",
      "Params =  100 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 4.066564042568728\n",
      "Epoch: 000,loss: 1.9452\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.28s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 4.066564042568728\n",
      "Epoch: 000,loss: 1.9453\n",
      "Average accuracy = 35.561299852289515 +/- 1.2924667651403265\n",
      "Params =  100 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.5289197395024576\n",
      "Epoch: 000,loss: 1.9468\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.5289197395024576\n",
      "Epoch: 000,loss: 1.9461\n",
      "Average accuracy = 31.591580502215656 +/- 0.055391432791726536\n",
      "Params =  100 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.485290962176998\n",
      "Epoch: 000,loss: 86088007680.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.485290962176998\n",
      "Epoch: 000,loss: 39214047232.0000\n",
      "Average accuracy = 17.946824224519943 +/- 1.7725258493353033\n",
      "Params =  100 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.966801434226211\n",
      "Epoch: 000,loss: 55702593536.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.966801434226211\n",
      "Epoch: 000,loss: 33012658176.0000\n",
      "Average accuracy = 31.443870014771047 +/- 0.2031019202363371\n",
      "Params =  100 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:11<00:00,  1.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 4.108920317521813\n",
      "Epoch: 000,loss: 68792590336.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 4.108920317521813\n",
      "Epoch: 000,loss: 62210142208.0000\n",
      "Average accuracy = 30.188330871491875 +/- 0.16617429837518516\n",
      "Params =  100 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.6959113210640098\n",
      "Epoch: 000,loss: 1.9461\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.6959113210640098\n",
      "Epoch: 000,loss: 1.9461\n",
      "Average accuracy = 14.161742983751846 +/- 0.018463810930575975\n",
      "Params =  100 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.5220450728296286\n",
      "Epoch: 000,loss: 1.9457\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.5220450728296286\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 26.99409158050221 +/- 0.44313146233382616\n",
      "Params =  100 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 7.254147028052682\n",
      "Epoch: 000,loss: 1.9476\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 7.108722425166841\n",
      "Epoch: 000,loss: 1.9436\n",
      "Average accuracy = 84.47193500738553 +/- 0.09231905465287849\n",
      "Params =  100 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.8742237540521023\n",
      "Epoch: 000,loss: 1.9454\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.8742237540521023\n",
      "Epoch: 000,loss: 1.9453\n",
      "Average accuracy = 41.06351550960118 +/- 0.9231905465288043\n",
      "Params =  100 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.9856355507126746\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 0.9856355507126746\n",
      "Epoch: 000,loss: 1.9461\n",
      "Average accuracy = 19.387001477104874 +/- 0.22156573116691308\n",
      "Params =  100 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.6162473368788186\n",
      "Epoch: 000,loss: 1.9457\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.6162473368788186\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 18.796159527326438 +/- 0.4431314623338248\n",
      "Params =  100 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.331330458946195\n",
      "Epoch: 000,loss: 1.9461\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.331330458946195\n",
      "Epoch: 000,loss: 1.9467\n",
      "Average accuracy = 49.150664697193506 +/- 5.428360413589364\n",
      "Params =  100 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.670885766012019\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.670885766012019\n",
      "Epoch: 000,loss: 1.9457\n",
      "Average accuracy = 24.612259970457902 +/- 2.7880354505169875\n",
      "Params =  100 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.4182018523277045\n",
      "Epoch: 000,loss: 1.9464\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.094498068342505\n",
      "Epoch: 000,loss: 1.9459\n",
      "Average accuracy = 31.9423929098966 +/- 5.6129985228951265\n",
      "Params =  100 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.20s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 4.11560708648388\n",
      "Epoch: 000,loss: 66484645888.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.517727001127403\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 55.66838995568686 +/- 25.350812407680944\n",
      "Params =  100 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 9.138169555953871\n",
      "Epoch: 000,loss: 1.9440\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 9.074946942963177\n",
      "Epoch: 000,loss: 1.9415\n",
      "Average accuracy = 81.97932053175776 +/- 0.7385524372230445\n",
      "Params =  100 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.108078870277136\n",
      "Epoch: 000,loss: 1.9466\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:11<00:00,  1.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.815239967062202\n",
      "Epoch: 000,loss: 1.9456\n",
      "Average accuracy = 31.462333825701627 +/- 2.2156573116691307\n",
      "Params =  100 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.086127457904143\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.1587178216631506\n",
      "Epoch: 000,loss: 1.9461\n",
      "Average accuracy = 24.501477104874443 +/- 2.529542097488921\n",
      "Params =  100 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.013988364590696\n",
      "Epoch: 000,loss: 1.9459\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:11<00:00,  1.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.505846643192748\n",
      "Epoch: 000,loss: 1.9457\n",
      "Average accuracy = 35.21048744460856 +/- 5.631462333825701\n",
      "Params =  100 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.682182506678906\n",
      "Epoch: 000,loss: 1.9460\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.3704813843500667\n",
      "Epoch: 000,loss: 1.9465\n",
      "Average accuracy = 37.592319054652876 +/- 10.339734121122598\n",
      "Params =  100 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 3.4678673211240825\n",
      "Epoch: 000,loss: 1.9455\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:13<00:00,  1.37s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 1.9467291132459426\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 36.20753323485968 +/- 6.111521418020679\n",
      "Params =  100 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.5886013374222827\n",
      "Epoch: 000,loss: 86681550848.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:12<00:00,  1.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 2.5917232770248133\n",
      "Epoch: 000,loss: 1.9460\n",
      "Average accuracy = 27.511078286558345 +/- 1.181683899556868\n",
      "Params =  100 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.48s/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[19], line 28\u001b[0m\n\u001b[0;32m     26\u001b[0m L \u001b[38;5;241m=\u001b[39m theta\n\u001b[0;32m     27\u001b[0m L\u001b[38;5;241m=\u001b[39mL\n\u001b[1;32m---> 28\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     29\u001b[0m X_t_0 \u001b[38;5;241m=\u001b[39m pseudo_C\u001b[38;5;129m@X\u001b[39m\n\u001b[0;32m     30\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",
    "import time   \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [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",
    "            X=X\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              A = A\n",
    "              theta = theta\n",
    "              a = time.time()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              b = time.time()\n",
    "              C_0 = C_0\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              L=L\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              c = time.time()\n",
    "              acc = get_accu(C_test,L_test,X_t_test)\n",
    "              d = time.time()\n",
    "              # print(\"Time taken:\", b-a+d-c) 10 0.001 0.01\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "pqDLVv1Wn9RD",
   "metadata": {
    "id": "pqDLVv1Wn9RD"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8581979320531757"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "highest_accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e90f24f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "09f31bd5",
   "metadata": {},
   "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_49756\\838881801.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_49756\\838881801.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_49756\\838881801.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:49<00:00,  4.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.1440035343832475\n",
      "Epoch: 000,loss: 1.9423\n",
      "Accuracy = 0.835672082717873 1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:21<00:00, 14.20s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (812, 812)\n",
      "Entropy.................. 5.45326908231658\n",
      "Epoch: 000,loss: 1.9475\n",
      "Accuracy = 0.8474889217134417 1000 0.1 0.0001\n",
      "Average accuracy = 84.15805022156573 +/- 0.5908419497784367\n",
      "Params =  1000 0.1 0.0001\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "import time   \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [1000]:                                                        #\n",
    "  for beta_param in [0.1]:\n",
    "      for gamma_param in [0.0001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(2):\n",
    "            avg_accuracy_all=[]\n",
    "            X=X\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              A = A\n",
    "              theta = theta\n",
    "              a = time.time()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              b = time.time()\n",
    "              C_0 = C_0\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              L=L\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              c = time.time()\n",
    "              acc = get_accu(C_test,L_test,X_t_test)\n",
    "              d = time.time()\n",
    "              # print(\"Time taken:\", b-a+d-c) 10 0.001 0.01\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ba7ea36",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "910fcef7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a09f2c9e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "FN7Cp3UQoMKv",
   "metadata": {
    "id": "FN7Cp3UQoMKv"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvgAAAK9CAYAAABRtxg8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABSSUlEQVR4nO3deXQUVf7+8acTSAICIkISiGyyukHYBRdcolERh3FQxIVFx0FkUTIqxIXFLSIjRgHBZRQXGFAUFEEEUVAUF1BGxDGAgDhIAqggBE0g3b8//NFfe9KpNEUuteT9OodzpOx03RR17n3qU/dWBUKhUEgAAAAAfCHO6QYAAAAAqDgEfAAAAMBHCPgAAACAjxDwAQAAAB8h4AMAAAA+QsAHAAAAfISADwAAAPgIAR8AAADwEQI+AAAA4CMEfAC+c/DgQd1xxx1q2LCh4uLi1KtXL6ebVK5zzjlH55xzjq2fHTBggJo0aVKh7flf06dPVyAQ0JYtWyw/N3bsWAUCAVv7aNKkiS699FJbP1uWQCCgsWPHVuh3AoDbEfABFzkUolatWhX1/59zzjk69dRTjbZh4cKFng9Ezz77rCZMmKDevXvr+eef14gRI5xuEgAAR00VpxsAwF0WLlyoKVOmeDrkv/vuu0pLS9Ojjz7qdFNitnjxYts/+/TTTysYDFZgawAAXkYFH4Dv7NixQ7Vr166w7wsGg/rtt98q7Pv+aP/+/ZKkhIQEJSQk2PqOqlWrKjExsSKbBQDwMAI+4AMvvfSSOnTooGrVqqlOnTq66qqr9P3330d85oMPPtAVV1yhRo0aKTExUQ0bNtSIESP066+/hj8zYMAATZkyRdLvc5cP/ZGkLVu2KBAI6B//+IemTJmiE088UdWrV9eFF16o77//XqFQSPfdd59OOOEEVatWTX/605/0008/RbTh9ddfV48ePdSgQQMlJiaqWbNmuu+++1RSUhLxuUNTkVavXq1u3bqpWrVqatq0qaZNm2Z5HA618b333tO6devC7V+2bJkkqbCwUH//+9/VsGFDJSYmqlWrVvrHP/6hUCgU8T2BQEBDhw7VjBkzdMoppygxMVGLFi2y3PcTTzwR/myDBg00ZMgQ7d69u8zf6+yzz1b16tV15513hv/f/87B/+6773TZZZfpmGOOUXJyskaMGKG333474neSSs/B/+O/1VNPPaVmzZopMTFRnTp10meffRaxjy+//FIDBgzQiSeeqKSkJKWmpur666/Xjz/+aPn7Ho7nnntO5513npKTk5WYmKiTTz5ZU6dOLfPzixcvVnp6upKSknTyySfrtddeK/WZ3bt369Zbbw3/WzZv3lzjx48v907G3r17deutt6pJkyZKTExUcnKyLrjgAn3++edH/HsCgFswRQdwoT179mjXrl2lth84cKDUtgceeED33HOPrrzySv31r3/Vzp07NWnSJJ199tn64osvwpXsV155Rfv379fgwYN1/PHH69NPP9WkSZP03//+V6+88ookadCgQfrhhx+0ZMkSvfjii1HbNmPGDBUXF2vYsGH66aef9PDDD+vKK6/Ueeedp2XLlmnkyJHauHGjJk2apNtuu03PPvts+GenT5+uGjVqKCsrSzVq1NC7776r0aNH65dfftGECRMi9vPzzz/rkksu0ZVXXqm+ffvq5Zdf1uDBg5WQkKDrr78+atvq1aunF198UQ888ID27dunnJwcSdJJJ52kUCikyy67TO+9955uuOEGpaen6+2339btt9+ubdu2lZrO8+677+rll1/W0KFDVbduXctFrGPHjtW4ceOUkZGhwYMHKy8vT1OnTtVnn32mDz/8UFWrVg1/9scff9TFF1+sq666Stdee61SUlKifmdhYaHOO+88bd++XbfccotSU1M1c+ZMvffee2W243/NnDlTe/fu1aBBgxQIBPTwww/r8ssv16ZNm8JtWrJkiTZt2qSBAwcqNTVV69at01NPPaV169bp448/tr1g9o+mTp2qU045RZdddpmqVKmi+fPn6+abb1YwGNSQIUMiPrthwwb16dNHN910k/r376/nnntOV1xxhRYtWqQLLrhA0u93Pbp3765t27Zp0KBBatSokT766CNlZ2dr+/btys3NLbMtN910k+bMmaOhQ4fq5JNP1o8//qgVK1boP//5j9q3b3/EvysAuEIIgGs899xzIUmWf0455ZTw57ds2RKKj48PPfDAAxHfs3bt2lCVKlUitu/fv7/U/nJyckKBQCD03XffhbcNGTIkFK1r2Lx5c0hSqF69eqHdu3eHt2dnZ4ckhdq2bRs6cOBAeHvfvn1DCQkJod9++82yDYMGDQpVr1494nPdu3cPSQo98sgj4W1FRUWh9PT0UHJycqi4uLj0wfuD7t27RxynUCgUmjdvXkhS6P7774/Y3rt371AgEAht3LgxvE1SKC4uLrRu3TrL/YRCodCOHTtCCQkJoQsvvDBUUlIS3j558uSQpNCzzz5b6veaNm1a1DZ37949/PdHHnkkJCk0b9688LZff/011Lp165Ck0HvvvRfe3r9//1Djxo3Dfz/0b3X88ceHfvrpp/D2119/PSQpNH/+/PC2aP8m//rXv0KSQu+//35426Fzc/PmzZbHY8yYMaXOn2j7yMzMDJ144okR2xo3bhySFHr11VfD2/bs2ROqX79+qF27duFt9913X+iYY44JrV+/PuLnR40aFYqPjw9t3bo1vE1SaMyYMeG/H3vssaEhQ4ZY/g4A4HVM0QFcaMqUKVqyZEmpP23atIn43GuvvaZgMKgrr7xSu3btCv9JTU1VixYtIqq91apVC/93YWGhdu3apW7duikUCumLL76IuW1XXHGFjj322PDfu3TpIkm69tprVaVKlYjtxcXF2rZtW9Q27N27V7t27dJZZ52l/fv365tvvonYT5UqVTRo0KDw3xMSEjRo0CDt2LFDq1evjrm9hyxcuFDx8fEaPnx4xPa///3vCoVCeuuttyK2d+/eXSeffHK53/vOO++ouLhYt956q+Li/q9LvfHGG1WrVi0tWLAg4vOJiYkaOHBgud+7aNEipaWl6bLLLgtvS0pK0o033ljuzx7Sp08fHXfcceG/n3XWWZKkTZs2hbf98d/kt99+065du3T66adLUoVNW/njPg7dnerevbs2bdqkPXv2RHy2QYMG+vOf/xz+e61atdSvXz998cUXys/Pl/T73aizzjpLxx13XMR5n5GRoZKSEr3//vtltqV27dr65JNP9MMPP1TI7wYAbsQUHcCFOnfurI4dO5bafijQHLJhwwaFQiG1aNEi6vf8cWrI1q1bNXr0aL3xxhv6+eefIz73vyHLSqNGjSL+fijsN2zYMOr2P+5r3bp1uvvuu/Xuu+/ql19+sWxDgwYNdMwxx0Rsa9mypaTf55gfCqGx+u6779SgQQPVrFkzYvtJJ50U/v9/1LRp05i/V5JatWoVsT0hIUEnnnhiqe9NS0uLaTHtd999p2bNmpWaItO8efOY2iWV/rc6FPb/+G/y008/ady4cZo1a5Z27NgR8fnDOS+sfPjhhxozZoxWrlwZXlT8x3388YKxefPmpX7nP/67p6amasOGDfryyy9Vr169qPv739/jjx5++GH1799fDRs2VIcOHXTJJZeoX79+OvHEE+3+egDgOgR8wMOCwaACgYDeeustxcfHl/r/NWrUkCSVlJToggsu0E8//aSRI0eqdevWOuaYY7Rt2zYNGDDgsB6xGG0/VttD/38B6+7du9W9e3fVqlVL9957r5o1a6akpCR9/vnnGjlypOse8/jHqrMXvjea8v5NJOnKK6/URx99pNtvv13p6emqUaOGgsGgLrroogr5N/n22291/vnnq3Xr1po4caIaNmyohIQELVy4UI8++qitfQSDQV1wwQW64447ov7/QxcE0Vx55ZU666yzNHfuXC1evFgTJkzQ+PHj9dprr+niiy8+7LYAgBsR8AEPa9asmUKhkJo2bWoZatauXav169fr+eefV79+/cLblyxZUuqzFbGoMpply5bpxx9/1Guvvaazzz47vH3z5s1RP//DDz+osLAwooq/fv16SbL11tbGjRvrnXfe0d69eyOq+IemBjVu3Piwv/OPP5eXlxdRBS4uLtbmzZuVkZFh+3u//vprhUKhiH+TjRs32vq+aH7++WctXbpU48aN0+jRo8PbN2zYUGH7mD9/voqKivTGG29E3FEoa7Hwxo0bS/3O//vv3qxZM+3bt8/2sa1fv75uvvlm3XzzzdqxY4fat2+vBx54gIAPwDeYgw942OWXX674+HiNGzeu1KMeQ6FQ+FGHhyq5f/xMKBTSY489Vuo7DwXq/33E45GK1obi4mI98cQTUT9/8OBBPfnkkxGfffLJJ1WvXj116NDhsPd/ySWXqKSkRJMnT47Y/uijjyoQCNgOdxkZGUpISNDjjz8e8bv985//1J49e9SjRw9b35uZmalt27bpjTfeCG/77bff9PTTT9v6vmii/ZtIsnwKTUXsY8+ePXruueeifv6HH37Q3Llzw3//5Zdf9MILLyg9PV2pqamSfq/Cr1y5Um+//Xapn9+9e7cOHjwY9btLSkpKTTtKTk5WgwYNVFRUdHi/GAC4GBV8wMOaNWum+++/X9nZ2dqyZYt69eqlmjVravPmzZo7d67+9re/6bbbblPr1q3VrFkz3Xbbbdq2bZtq1aqlV199tdRcfEnh8Dx8+HBlZmYqPj5eV1111RG3tVu3bjruuOPUv39/DR8+XIFAQC+++GKpcHlIgwYNNH78eG3ZskUtW7bU7NmztWbNGj311FMRawti1bNnT5177rm66667tGXLFrVt21aLFy/W66+/rltvvVXNmjWz9XvVq1dP2dnZGjdunC666CJddtllysvL0xNPPKFOnTrp2muvtfW9gwYN0uTJk9W3b1/dcsstql+/vmbMmKGkpCRJFXOnpVatWjr77LP18MMP68CBA0pLS9PixYvLvKtix4UXXqiEhAT17NlTgwYN0r59+/T0008rOTlZ27dvL/X5li1b6oYbbtBnn32mlJQUPfvssyooKIi4ILj99tv1xhtv6NJLL9WAAQPUoUMHFRYWau3atZozZ462bNmiunXrlvruvXv36oQTTlDv3r3Vtm1b1ahRQ++8844+++wzPfLIIxX2OwOA0wj4gMeNGjVKLVu21KOPPqpx48ZJ+n3B64UXXhh+AkvVqlU1f/58DR8+XDk5OUpKStKf//xnDR06VG3bto34vssvv1zDhg3TrFmz9NJLLykUClVIwD/++OP15ptv6u9//7vuvvtuHXfccbr22mt1/vnnKzMzs9TnjzvuOD3//PMaNmyYnn76aaWkpGjy5MmH9RSZP4qLi9Mbb7yh0aNHa/bs2XruuefUpEkTTZgwQX//+9+P6HcbO3as6tWrp8mTJ2vEiBGqU6eO/va3v+nBBx+0dTEiKfyegGHDhumxxx5TjRo11K9fP3Xr1k1/+ctfwkH/SM2cOVPDhg3TlClTFAqFdOGFF+qtt95SgwYNKuT7W7VqpTlz5ujuu+/WbbfdptTUVA0ePFj16tWL+j6DFi1aaNKkSbr99tuVl5enpk2bavbs2RHnSPXq1bV8+XI9+OCDeuWVV/TCCy+oVq1aatmypcaNGxexaPePqlevrptvvlmLFy8OP4GqefPmeuKJJzR48OAK+X0BwA0CobLKZwDgkHPOOUe7du3SV1995XRTXCc3N1cjRozQf//7X6WlpTndHACACzEHHwBc6tdff434+2+//aYnn3xSLVq0INwDAMrEFB0AcKnLL79cjRo1Unp6uvbs2aOXXnpJ33zzjWbMmOF00wAALkbABwCXyszM1DPPPKMZM2aopKREJ598smbNmqU+ffo43TQAgIsxBx8AAAAw4P3339eECRO0evVqbd++XXPnzlWvXr0sf2bZsmXKysrSunXr1LBhQ919990aMGDAYe2XOfgAAACAAYWFhWrbtq2mTJkS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FStWON0kX/n55591xhlnqGrVqnrrrbf09ddf65FHHtFxxx3ndNPgYzwm00KXLl3UqVMnTZ48WdLvbx5r2LChhg0bplGjRjncOv8JBAKaO3euevXq5XRTfGvnzp1KTk7W8uXLdfbZZzvdHF+qU6eOJkyYoBtuuMHppvjGvn371L59ez3xxBO6//77lZ6ertzcXKeb5Qtjx47VvHnztGbNGqeb4lujRo3Shx9+qA8++MDppqASoYJfhuLiYq1evVoZGRnhbXFxccrIyNDKlSsdbBlg3549eyT9HkJRsUpKSjRr1iwVFhYe1uvEUb4hQ4aoR48eEf0xKs6GDRvUoEEDnXjiibrmmmu0detWp5vkK2+88YY6duyoK664QsnJyWrXrp2efvppp5sFnyPgl2HXrl0qKSkJv2XskJSUFOXn5zvUKsC+YDCoW2+9VWecccZhvQ0P1tauXasaNWooMTFRN910k+bOnauTTz7Z6Wb5xqxZs/T555+HX+GOitWlSxdNnz5dixYt0tSpU7V582adddZZ2rt3r9NN841NmzZp6tSpatGihd5++20NHjxYw4cP1/PPP+900+BjVZxuAICjY8iQIfrqq6+YX1vBWrVqpTVr1mjPnj2aM2eO+vfvr+XLlxPyK8D333+vW265RUuWLFFSUpLTzfGliy++OPzfbdq0UZcuXdS4cWO9/PLLTDOrIMFgUB07dtSDDz4oSWrXrp2++uorTZs2Tf3793e4dfArKvhlqFu3ruLj41VQUBCxvaCgQKmpqQ61CrBn6NChevPNN/Xee+/phBNOcLo5vpKQkKDmzZurQ4cOysnJUdu2bfXYY4853SxfWL16tXbs2KH27durSpUqqlKlipYvX67HH39cVapUUUlJidNN9J3atWurZcuW2rhxo9NN8Y369euXuuA/6aSTmAoFowj4ZUhISFCHDh20dOnS8LZgMKilS5cyvxaeEQqFNHToUM2dO1fvvvuumjZt6nSTfC8YDKqoqMjpZvjC+eefr7Vr12rNmjXhPx07dtQ111yjNWvWKD4+3ukm+s6+ffv07bffqn79+k43xTfOOOOMUo8nXr9+vRo3buxQi1AZMEXHQlZWlvr376+OHTuqc+fOys3NVWFhoQYOHOh003xj3759EZWizZs3a82aNapTp44aNWrkYMv8YciQIZo5c6Zef/111axZM7x+5Nhjj1W1atUcbp33ZWdn6+KLL1ajRo20d+9ezZw5U8uWLdPbb7/tdNN8oWbNmqXWixxzzDE6/vjjWUdSQW677Tb17NlTjRs31g8//KAxY8YoPj5effv2dbppvjFixAh169ZNDz74oK688kp9+umneuqpp/TUU0853TT4GAHfQp8+fbRz506NHj1a+fn5Sk9P16JFi0otvIV9q1at0rnnnhv+e1ZWliSpf//+mj59ukOt8o+pU6dKks4555yI7c8995wGDBhw9BvkMzt27FC/fv20fft2HXvssWrTpo3efvttXXDBBU43DYjJf//7X/Xt21c//vij6tWrpzPPPFMff/yx6tWr53TTfKNTp06aO3eusrOzde+996pp06bKzc3VNddc43TT4GM8Bx8AAADwEebgAwAAAD5CwAcAAAB8hIAPAAAA+AgBHwAAAPARAj4AAADgIwR8AAAAwEcI+AAAAICPEPABAAAAHyHgA8Bhmj59umrXrn3E3xMIBDRv3rwj/h4AAP6IgA+gUhowYIB69erldDMAAKhwBHwAAADARwj4APA/Jk6cqNNOO03HHHOMGjZsqJtvvln79u0r9bl58+apRYsWSkpKUmZmpr7//vuI///666+rffv2SkpK0oknnqhx48bp4MGDUfdZXFysoUOHqn79+kpKSlLjxo2Vk5Nj5PcDAPgbAR8A/kdcXJwef/xxrVu3Ts8//7zeffdd3XHHHRGf2b9/vx544AG98MIL+vDDD7V7925dddVV4f//wQcfqF+/frrlllv09ddf68knn9T06dP1wAMPRN3n448/rjfeeEMvv/yy8vLyNGPGDDVp0sTkrwkA8KlAKBQKOd0IADjaBgwYoN27d8e0yHXOnDm66aabtGvXLkm/L7IdOHCgPv74Y3Xp0kWS9M033+ikk07SJ598os6dOysjI0Pnn3++srOzw9/z0ksv6Y477tAPP/wg6fdFtnPnzlWvXr00fPhwrVu3Tu+8844CgUDF/8IAgEqDCj4A/I933nlH559/vtLS0lSzZk1dd911+vHHH7V///7wZ6pUqaJOnTqF/966dWvVrl1b//nPfyRJ//73v3XvvfeqRo0a4T833nijtm/fHvE9hwwYMEBr1qxRq1atNHz4cC1evNj8LwoA8CUCPgD8wZYtW3TppZeqTZs2evXVV7V69WpNmTJF0u/z5GO1b98+jRs3TmvWrAn/Wbt2rTZs2KCkpKRSn2/fvr02b96s++67T7/++quuvPJK9e7du8J+LwBA5VHF6QYAgJusXr1awWBQjzzyiOLifq+BvPzyy6U+d/DgQa1atUqdO3eWJOXl5Wn37t066aSTJP0e2PPy8tS8efOY912rVi316dNHffr0Ue/evXXRRRfpp59+Up06dSrgNwMAVBYEfACV1p49e7RmzZqIbXXr1tWBAwc0adIk9ezZUx9++KGmTZtW6merVq2qYcOG6fHHH1eVKlU0dOhQnX766eHAP3r0aF166aVq1KiRevfurbi4OP373//WV199pfvvv7/U902cOFH169dXu3btFBcXp1deeUWpqakV8kItAEDlwhQdAJXWsmXL1K5du4g/L774oiZOnKjx48fr1FNP1YwZM6I+rrJ69eoaOXKkrr76ap1xxhmqUaOGZs+eHf7/mZmZevPNN7V48WJ16tRJp59+uh599FE1btw4altq1qyphx9+WB07dlSnTp20ZcsWLVy4MHwXAQCAWPEUHQAAAMBHKA0BAAAAPkLABwAAAHyEgA8AAAD4CAEfAAAA8BECPgAAAOAjBHwAAADARwj4AAAAgI8Q8AEAAAAfIeADAAAAPkLABwAAAHyEgA8AAAD4yP8DTLH5szDuQxEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAv0AAAK9CAYAAAC3ntN4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABSl0lEQVR4nO3dfZxN9d7/8feeMWbGYERjxohpiNxEyv1NKHOaSkqRdOk0JDkdElMpnZCiOeUiKZHTDXW4ikQ3V5GQ0nETpVOcUNENZtw1bgZzt9fvDz/7spuZzNqzl7XX2q/n4zGPR7NmzV6fWW17v/d3fb7f5TEMwxAAAAAA14qwuwAAAAAA1iL0AwAAAC5H6AcAAABcjtAPAAAAuByhHwAAAHA5Qj8AAADgcoR+AAAAwOUI/QAAAIDLEfoBAAAAlyP0A6iQoqIijR49WvXq1VNERIR69+5t6fG6d++u7t27m/69Xbt2yePx6L//+7+DVssnn3wij8ejTz75JGiPWR5Lly5Vq1atFBMTI4/Ho9zc3HN6fPwfu54DAGAWoR9ha86cOfJ4PNq4cWOpP+/evbsuueQSS2v44IMP9Nhjj1l6DKu98sormjx5svr27au5c+dq1KhRdpfkagcPHlS/fv0UGxurGTNm6PXXX1dcXJyefPJJLVmyxO7yAAAhqpLdBQDh7IMPPtCMGTMcHfxXrlypunXr6plnnrG7lLDwxRdf6OjRo3riiSeUlpbm2/7kk0+qb9++ll9pgb+uXbvqxIkTqly5st2lAMAfYqQfQIXs27dPNWrUCNrjeb1enTx5MmiP5zb79u2TpKCe87KcPHlSXq/X8uNU1PHjx207dkREhGJiYhQRwdspgNDGqxRg0j//+U+1bt1asbGxqlmzpvr3769ffvnFb5/PPvtMt9xyi+rXr6/o6GjVq1dPo0aN0okTJ3z7DBw4UDNmzJAkeTwe35fk338+Y8YMNWjQQFWqVNHVV1+tX375RYZh6IknntAFF1yg2NhY3XjjjTp06JBfDe+884569uyp5ORkRUdHq2HDhnriiSdUXFzst9/pNqZNmzapU6dOio2NVWpqqmbNmvWH5+F0jatWrdKWLVt89Z/ubc7Ly9P999+vevXqKTo6WhdffLH++7//W4Zh+D2Ox+PR8OHDNW/ePDVv3lzR0dFaunRpuf9/FBQUaNy4cWrdurXi4+MVFxenK664QqtWrSrzd5555hmlpKQoNjZW3bp107fffltin++++059+/ZVzZo1FRMTozZt2ujdd989az07duxQnz59lJSUpJiYGF1wwQXq37+/Dh8+/Ie/V57nTPfu3ZWRkSFJatu2rTwejwYOHCiPx6O8vDzNnTvX9/9h4MCBvt/bvXu37rzzTiUmJio6OlrNmzfXK6+84nf8073pb7zxhh599FHVrVtXVapU0ZEjR8qs2ev16tlnn1WLFi0UExOjhIQEXXPNNX4tc0VFRXriiSfUsGFDRUdH68ILL9Qjjzyi/Px8v8cK5PnatWtXValSRY888ogkaePGjUpPT9f555/vex7feeedJWqeNm2amjdvrpiYGCUmJmro0KH67bff/Pa78MILdf3112vNmjVq166dYmJi1KBBA7322mulnrcze/pP17h161ZdeeWVqlKliurWraunn366xDn86aefdMMNNyguLk61a9fWqFGjtGzZMuYJAAg62nsQ9g4fPqwDBw6U2F5YWFhi26RJkzR27Fj169dPd911l/bv36/nnntOXbt21VdffeUbfV24cKGOHz+ue+65R7Vq1dKGDRv03HPP6ddff9XChQslSUOHDtWePXu0fPlyvf7666XWNm/ePBUUFOjee+/VoUOH9PTTT6tfv3666qqr9Mknn+ihhx7S999/r+eee04PPPCAX5CbM2eOqlatqszMTFWtWlUrV67UuHHjdOTIEU2ePNnvOL/99puuu+469evXT7fddpsWLFige+65R5UrVy4Rmk5LSEjQ66+/rkmTJunYsWPKysqSJDVt2lSGYeiGG27QqlWrNHjwYLVq1UrLli3Tgw8+qN27d5doBVq5cqUWLFig4cOH6/zzz9eFF15Y+v+sUhw5ckQvvfSSbrvtNg0ZMkRHjx7Vyy+/rPT0dG3YsEGtWrXy2/+1117T0aNHNWzYMJ08eVLPPvusrrrqKn3zzTdKTEyUJG3ZskWdO3dW3bp19fDDDysuLk4LFixQ7969tWjRIt10002l1lJQUKD09HTl5+fr3nvvVVJSknbv3q33339fubm5io+PL/PvKM9z5m9/+5suvvhizZ49W48//rhSU1PVsGFDpaWl6a677lK7du109913S5IaNmwoScrJyVGHDh18H64SEhL04YcfavDgwTpy5IhGjhzpV8cTTzyhypUr64EHHlB+fv4ftq0MHjxYc+bM0bXXXqu77rpLRUVF+uyzz7Ru3Tq1adNGknTXXXdp7ty56tu3r+6//36tX79eWVlZ+s9//qPFixf7HsvM8/XgwYO69tpr1b9/f91+++1KTEzUvn37dPXVVyshIUEPP/ywatSooV27duntt9/2+92hQ4dqzpw5GjRokEaMGKGdO3fq+eef11dffaXPP/9cUVFRvn2///579e3bV4MHD1ZGRoZeeeUVDRw4UK1bt1bz5s3LPC/SqX9T11xzjW6++Wb169dPb731lh566CG1aNFC1157raRTH4yvuuoq7d27V/fdd5+SkpI0f/78P/zACgABM4Aw9eqrrxqS/vCrefPmvv137dplREZGGpMmTfJ7nG+++caoVKmS3/bjx4+XOF5WVpbh8XiMn376ybdt2LBhRmn/DHfu3GlIMhISEozc3Fzf9jFjxhiSjEsvvdQoLCz0bb/tttuMypUrGydPnvzDGoYOHWpUqVLFb79u3boZkowpU6b4tuXn5xutWrUyateubRQUFJQ8eWfo1q2b33kyDMNYsmSJIcmYOHGi3/a+ffsaHo/H+P77733bJBkRERHGli1b/vA4Zx6vW7duvu+LioqM/Px8v31+++03IzEx0bjzzjt9206f09jYWOPXX3/1bV+/fr0hyRg1apRvW48ePYwWLVr4nSev12t06tTJaNSokW/bqlWrDEnGqlWrDMMwjK+++sqQZCxcuLBcf8uZyvucOf28/eKLL/z2jYuLMzIyMko8xuDBg406deoYBw4c8Nvev39/Iz4+3nfc039LgwYNSq3l91auXGlIMkaMGFHiZ16v1zAMw9i8ebMhybjrrrv8fv7AAw8YkoyVK1f6tpl9vs6aNctv38WLF5d6Xs702WefGZKMefPm+W1funRpie0pKSmGJOPTTz/1bdu3b58RHR1t3H///b5tv38OnFnja6+95tuWn59vJCUlGX369PFtmzJliiHJWLJkiW/biRMnjCZNmpR4TACoKNp7EPZmzJih5cuXl/hq2bKl335vv/22vF6v+vXrpwMHDvi+kpKS1KhRI7/RudjYWN9/5+Xl6cCBA+rUqZMMw9BXX31V7tpuueUWv9Hh9u3bS5Juv/12VapUyW97QUGBdu/eXWoNR48e1YEDB3TFFVfo+PHj+u677/yOU6lSJQ0dOtT3feXKlTV06FDt27dPmzZtKne9p33wwQeKjIzUiBEj/Lbff//9MgxDH374od/2bt26qVmzZqaPI0mRkZG+0Wiv16tDhw6pqKhIbdq00Zdfflli/969e6tu3bq+79u1a6f27dvrgw8+kCQdOnRIK1euVL9+/Xzn7cCBAzp48KDS09O1Y8cOv/N8ptP/r5YtW2a6zzxYz5kzGYahRYsWqVevXjIMw+95m56ersOHD5c4RxkZGX61lGXRokXyeDwaP358iZ+dblM7fU4zMzP9fn7//fdLkv73f//Xt83M8zU6OlqDBg3y23b6Ktv7779f6lU66dTVlPj4eP3pT3/yOxetW7dW1apVS4ywN2vWTFdccYXv+4SEBF188cX68ccfS338M1WtWlW333677/vKlSurXbt2fr+7dOlS1a1bVzfccINvW0xMjIYMGXLWxwcAs2jvQdhr166drxXhTOedd55f28+OHTtkGIYaNWpU6uOc2Rbw888/a9y4cXr33XdL9Aqfrbf7TPXr1/f7/nSorFevXqnbzzzWli1b9Oijj2rlypUl+rJ/X0NycrLi4uL8tjVu3FjSqd79Dh06lLtm6VSfcnJysqpVq+a3vWnTpr6fnyk1NdXU4//e3LlzNWXKFH333Xd+ga+0xy3t/1/jxo21YMECSadaOgzD0NixYzV27NhSj7dv3z6/Dw5nHi8zM1NTp07VvHnzdMUVV+iGG27Q7bff/oetPVLwnjNn2r9/v3JzczV79mzNnj27zL/l939Defzwww9KTk5WzZo1y9znp59+UkREhC666CK/7UlJSapRo4bf88DM87Vu3bol2o66deumPn36aMKECXrmmWfUvXt39e7dW//1X/+l6OhoSaf+DR8+fFi1a9cutd7fn4vf//uTTr0u/P7/T2kuuOAC34efM3/33//+t+/7n376SQ0bNiyx3+/PFwAEA6EfKCev1yuPx6MPP/xQkZGRJX5etWpVSVJxcbH+9Kc/6dChQ3rooYfUpEkTxcXFaffu3Ro4cKCp1VBKO84fbTf+/yTZ3NxcdevWTdWrV9fjjz+uhg0bKiYmRl9++aUeeuihkFuRpTwjy2X55z//qYEDB6p379568MEHVbt2bUVGRiorK0s//PCD6cc7fW4eeOABpaenl7rPH4WyKVOmaODAgXrnnXf00UcfacSIEcrKytK6det0wQUXlPo7wXzOlPa33H777b4JwL/3+ytaFfl/UZbfh9rfM/t8La1Gj8ejt956S+vWrdN7772nZcuW6c4779SUKVO0bt06Va1aVV6vV7Vr19a8efNKrSMhIcHv+7P9O/sjFfldALACoR8op4YNG8owDKWmpvpGwUvzzTffaPv27Zo7d67uuOMO3/bly5eX2PdsYShQn3zyiQ4ePKi3335bXbt29W3fuXNnqfvv2bNHeXl5fqP927dvlyRTk2pPS0lJ0ccff6yjR4/6jfafbtNISUkx/Zhleeutt9SgQQO9/fbbfueztLYT6dRo7+9t377d93c2aNBA0qkrN2eug29GixYt1KJFCz366KP617/+pc6dO2vWrFmaOHFiqfubec6UpbTnUkJCgqpVq6bi4uKA/5ayNGzYUMuWLdOhQ4fKHO1PSUmR1+vVjh07fFd5pFOTi3Nzc33PA7PP1z/SoUMHdejQQZMmTdL8+fM1YMAAvfHGG7rrrrvUsGFDffzxx+rcubMlH27MSklJ0datW2UYht//v++//97GqgC4FT39QDndfPPNioyM1IQJE0qM1hmGoYMHD0r6vxG+M/cxDEPPPvtsicc8HbJzc3ODWmtpNRQUFOiFF14odf+ioiK9+OKLfvu++OKLSkhIUOvWrU0f/7rrrlNxcbGef/55v+3PPPOMPB6Pb/WSYCjtb12/fr3Wrl1b6v5Llizx68nfsGGD1q9f76updu3a6t69u1588UXt3bu3xO/v37+/zFqOHDmioqIiv20tWrRQREREiSUqz/Y3lPWcKUtcXFyJ51FkZKT69OmjRYsWlbos6R/9LWfTp08fGYahCRMmlPjZ6b/juuuukyRNmzbN7+dTp06VJPXs2dNX55m/J/3x87U0v/32W4l/l6dXbjp97vv166fi4mI98cQTJX6/qKgo6P8OzyY9PV27d+/2Wwr25MmT+sc//nFO6wAQHhjpB8qpYcOGmjhxosaMGaNdu3apd+/eqlatmnbu3KnFixfr7rvv1gMPPKAmTZqoYcOGeuCBB7R7925Vr15dixYtKrUP+HSgHjFihNLT0xUZGan+/ftXuNZOnTrpvPPOU0ZGhkaMGCGPx6PXX3+9zNaC5ORkPfXUU9q1a5caN26sN998U5s3b9bs2bP95iqUV69evXTllVfqb3/7m3bt2qVLL71UH330kd555x2NHDnSt5xkMFx//fV6++23ddNNN6lnz57auXOnZs2apWbNmunYsWMl9r/ooovUpUsX3XPPPcrPz9e0adNUq1YtjR492rfPjBkz1KVLF7Vo0UJDhgxRgwYNlJOTo7Vr1+rXX3/V119/XWotK1eu1PDhw3XLLbeocePGKioq0uuvv+4L32Ux85wpS+vWrfXxxx9r6tSpSk5OVmpqqtq3b6+///3vWrVqldq3b68hQ4aoWbNmOnTokL788kt9/PHHJe7vUF5XXnml/vznP2v69OnasWOHrrnmGnm9Xn322We68sorNXz4cF166aXKyMjQ7NmzfS08GzZs0Ny5c9W7d29deeWVksw/X0szd+5cvfDCC7rpppvUsGFDHT16VP/4xz9UvXp134ePbt26aejQocrKytLmzZt19dVXKyoqSjt27NDChQv17LPPqm/fvgGdj0AMHTpUzz//vG677Tbdd999qlOnjubNm6eYmBhJ1l0JBBCmztUyQUCoKWvpw9NKW4rSMAxj0aJFRpcuXYy4uDgjLi7OaNKkiTFs2DBj27Ztvn22bt1qpKWlGVWrVjXOP/98Y8iQIcbXX39tSDJeffVV335FRUXGvffeayQkJBgej8e3fOfp5SUnT57sd+zTywP+fknI0v6Wzz//3OjQoYMRGxtrJCcnG6NHjzaWLVtW6vKCzZs3NzZu3Gh07NjRiImJMVJSUoznn3++XOexrPN09OhRY9SoUUZycrIRFRVlNGrUyJg8ebJvOcfTJBnDhg0r17FOH+/MJTu9Xq/x5JNPGikpKUZ0dLRx2WWXGe+//76RkZFhpKSk+PY785xOmTLFqFevnhEdHW1cccUVxtdff13iOD/88INxxx13GElJSUZUVJRRt25d4/rrrzfeeust3z6/X67xxx9/NO68806jYcOGRkxMjFGzZk3jyiuvND7++OOz/l3lfc6U9bz97rvvjK5duxqxsbGGJL/lO3Nycoxhw4YZ9erVM6KiooykpCSjR48exuzZs0v8LWaWGy0qKjImT55sNGnSxKhcubKRkJBgXHvttcamTZt8+xQWFhoTJkwwUlNTjaioKKNevXrGmDFj/JbhNAzzz9ff+/LLL43bbrvNqF+/vhEdHW3Url3buP76642NGzeW2Hf27NlG69atjdjYWKNatWpGixYtjNGjRxt79uzx7ZOSkmL07NmzxO/+/vlX1pKd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",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_nodes = len(labels)\n",
    "num_labels = len(set(labels))\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((num_nodes, num_labels))\n",
    "\n",
    "# Fill in the one-hot encoded values\n",
    "for node_idx, label_idx in enumerate(labels):\n",
    "    Y[node_idx, label_idx] = 1\n",
    "Phi = C_t_0@Y \n",
    "Phi[Phi<1]=0\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": 72,
   "id": "dce60711",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hm= sns.heatmap(data = Phi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "3231a4f4-6700-4bc5-a6ef-20773767f40a",
   "metadata": {},
   "outputs": [],
   "source": [
    "highest_accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "6011535b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArcAAAIjCAYAAAAZajMiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABNPUlEQVR4nO3de1hU1f7H8c+giIICYgqaeLcEL2GaOKmZQqKRYVpHT17Lsgy1NK04XsNMM9PUg5ZliJmnu3XUAm+Vp8RLmuUtL6VCyaVCIDEBZf/+6GF+TmgyMji6eb+eZz8Ps/bae3/3AvLTYs0ei2EYhgAAAAATcHN1AQAAAICzEG4BAABgGoRbAAAAmAbhFgAAAKZBuAUAAIBpEG4BAABgGoRbAAAAmAbhFgAAAKZBuAUAAIBpEG4BON3nn38ui8Wi999/39WllEpGRobuvfde1apVSxaLRS+//LKrS7pibr/9dt1+++2uLqPMGjVqpLvuusvVZdhZtmyZLBaLjh075upSgAqFcAtco4r/4axatap+/vnnEvtvv/12tWrVygWVXXvGjh2rpKQkxcTE6M0331TPnj0v2G/YsGGyWCx/uzVq1OjKFn+VKf65vNi2detWV5d4UWfOnNG8efMUGhoqHx8fVa1aVTfccINGjRqlQ4cOubo8AKVU2dUFACib/Px8zZo1SwsXLnR1KdesTZs2KSoqSuPHj//bfo888ojCw8MvuG/jxo1atmyZOnbsWB4llpt169aVy3ljY2PVuHHjEu3NmjUrl+uV1a+//qqePXtq586duuuuu3T//ferevXqOnjwoN5++20tWbJEBQUFri4TQCkQboFrXEhIiF577TXFxMSoXr16ri7nisrLy5OXl1eZz5OZmSlfX99L9rNarbJarSXa09LSNG7cODVs2FCLFy8ucz2S8+7tUqpUqVIu5+3Vq5fat29fLucuD8OGDdM333yj999/X/369bPbN336dE2cONFFlQFwFMsSgGvcv/71L507d06zZs36237Hjh2TxWLRsmXLSuyzWCyaNm2a7fW0adNksVh06NAhDRo0SD4+Pqpdu7YmT54swzCUmpqqqKgoeXt7KyAgQC+99NIFr3nu3Dn961//UkBAgLy8vHT33XcrNTW1RL9t27apZ8+e8vHxkaenp7p27aqvvvrKrk9xTfv379f999+vmjVrqnPnzn97zz/++KPuu+8++fn5ydPTUx07dtTatWtt+4v/hG4YhuLi4mx/OndEUVGRBg4cqJMnT2rlypWqWbOmU+/t7Nmzmj59upo2bSoPDw81atRI//rXv5Sfn293jq+//loRERG67rrrVK1aNTVu3FgPPvjgJev/65rb4vXS7777rmbMmKH69euratWqCgsL05EjRxwam0uZM2eObr31VtWqVUvVqlVTu3btLrpOe8WKFerQoYM8PT1Vs2ZN3XbbbRecdf7yyy/VoUMHVa1aVU2aNNHy5csvWce2bdu0du1aDR8+vESwlSQPDw/NmTPHrm3Tpk3q0qWLvLy85Ovrq6ioKB04cOCS1/rr71qxRo0aadiwYbbXxT+bX375pcaMGaPatWvL19dXjzzyiAoKCpSdna0hQ4aoZs2aqlmzpp566ikZhmE7vvj3fc6cOVqyZInt5+eWW27Rjh07LlkncC0j3ALXuMaNG2vIkCF67bXXdOLECaeeu3///ioqKtKsWbMUGhqq5557Ti+//LLuuOMOXX/99XrhhRfUrFkzjR8/Xps3by5x/IwZM7R27Vo9/fTTGjNmjNavX6/w8HD98ccftj6bNm3SbbfdptzcXE2dOlXPP/+8srOz1b17d23fvr3EOe+77z6dPn1azz//vB5++OGL1p6RkaFbb71VSUlJeuyxxzRjxgydOXNGd999t1atWiVJuu222/Tmm29Kku644w69+eabttelNX36dH322Wd69tlndeutt9rtc8a9PfTQQ5oyZYpuvvlmzZs3T127dtXMmTM1YMAA23GZmZnq0aOHjh07pmeeeUYLFy7UwIEDy7S+ddasWVq1apXGjx+vmJgYbd26VQMHDiz18Tk5Ofr111/ttt9++82uz/z589W2bVvFxsbq+eefV+XKlXXffffZ/Q+IJD377LMaPHiw3N3dFRsbq2effVaBgYHatGmTXb8jR47o3nvv1R133KGXXnpJNWvW1LBhw7Rv376/rfW///2vJGnw4MGlurcNGzYoIiJCmZmZmjZtmsaNG6ctW7aoU6dOTn/z2OjRo3X48GE9++yzuvvuu7VkyRJNnjxZvXv31rlz5/T888+rc+fOevHFFy/4s7ty5Uq9+OKLeuSRR/Tcc8/p2LFj6tu3rwoLC51aJ3BVMQBck+Lj4w1Jxo4dO4wffvjBqFy5sjFmzBjb/q5duxotW7a0vT569KghyYiPjy9xLknG1KlTba+nTp1qSDJGjBhhazt79qxRv359w2KxGLNmzbK1nzx50qhWrZoxdOhQW9tnn31mSDKuv/56Izc319b+7rvvGpKM+fPnG4ZhGEVFRUbz5s2NiIgIo6ioyNbv9OnTRuPGjY077rijRE3//Oc/SzU+TzzxhCHJ+N///mdr+/33343GjRsbjRo1Ms6dO2d3/9HR0aU67/k+//xzo1KlSkZYWJjd+Zx1b7t37zYkGQ899JBd+/jx4w1JxqZNmwzDMIxVq1bZfhYc1bVrV6Nr166218Xfu6CgICM/P9/WPn/+fEOSsWfPnr89X/HP5YU2Dw8Pu76nT5+2e11QUGC0atXK6N69u63t8OHDhpubm3HPPfdccIyLNWzY0JBkbN682daWmZlpeHh4GE8++eTf1nzPPfcYkoyTJ0/+bb9iISEhRp06dYzffvvN1vbtt98abm5uxpAhQ2xtxWNx9OhRW9tff9fOr//836HiY//682O1Wg2LxWI8+uijtrbi383zv4/Fv++1atUysrKybO0ff/yxIclYvXp1qe4VuBYxcwuYQJMmTTR48GAtWbJEaWlpTjvvQw89ZPu6UqVKat++vQzD0PDhw23tvr6+uvHGG/Xjjz+WOH7IkCGqUaOG7fW9996runXr6pNPPpEk7d69W4cPH9b999+v3377zTbDl5eXp7CwMG3evFlFRUV253z00UdLVfsnn3yiDh062C1dqF69ukaMGKFjx45p//79pRuEi/j11191//33q1atWlqxYoXc3Oz/c+qMeysep3Hjxtm1P/nkk5Jkm+EsXi+8Zs0ap83IPfDAA3brcbt06SJJF/w+X0hcXJzWr19vt3366ad2fapVq2b7+uTJk8rJyVGXLl20a9cuW/tHH32koqIiTZkypcQY/3UJSXBwsK1OSapdu/ZFfzbPl5ubK0l2P6sXk5aWpt27d2vYsGHy8/Oztbdp00Z33HGH7XvmLMOHD7e7z9DQ0BK/g8W/mxe6z/79+9stlXH0+whci3hDGWASkyZN0ptvvqlZs2Zp/vz5TjlngwYN7F4XPx7puuuuK9H+1z85S1Lz5s3tXlssFjVr1sz2p9vDhw9LkoYOHXrRGnJycuz+cb7QO/Av5Pjx4woNDS3RHhQUZNt/uY9KMwxDQ4YMUVpamj799FMFBASU6OOMezt+/Ljc3NxKPGEgICBAvr6+On78uCSpa9eu6tevn5599lnNmzdPt99+u/r06aP7779fHh4el3WPf/3eF9d58uTJUh3foUOHS76hbM2aNXruuee0e/duuzXE54e5H374QW5ubgoODna45uK6L1Wzt7e3JOn333+/5BsLi8f8xhtvLLEvKChISUlJTn0z4IV+ByUpMDCwRPuF7rOs30fgWkS4BUyiSZMmGjRokJYsWaJnnnmmxP6LvVHq3LlzFz1npUqVStUmye7NLKVVPHP54osvKiQk5IJ9qlevbvf6/Nk+V5kzZ44+/fRTTZgwQRERERfs48x7u9Sb3Io/MGPr1q1avXq1kpKS9OCDD+qll17S1q1bS1ynNJz5fb6Q//3vf7r77rt12223adGiRapbt67c3d0VHx+vlStXXtY5L7fmFi1aSJL27NljN/N7JV3s9/Bi93Sh9gvdZ3l/H4GrEeEWMJFJkyZpxYoVeuGFF0rsK56xyc7OtmsvnokqD8Wzl8UMw9CRI0fUpk0bSVLTpk0l/TlzdrHnx16uhg0b6uDBgyXav//+e9v+y7Ft2zZNnDhRoaGhmjFjxkX7OePeGjZsqKKiIh0+fNg24yz9+Wa57OzsEvfQsWNHdezYUTNmzNDKlSs1cOBAvf3223bLS64WH3zwgapWraqkpCS72eX4+Hi7fk2bNlVRUZH2799/0f9JKKvevXtr5syZWrFixSXDbfGYX+xn67rrrvvbWduaNWuW+B0sKChw6nIioKJjzS1gIk2bNtWgQYP06quvKj093W6ft7e3rrvuuhJPNVi0aFG51bN8+XL9/vvvttfvv/++0tLS1KtXL0lSu3bt1LRpU82ZM0enTp0qcfwvv/xy2de+8847tX37diUnJ9va8vLytGTJEjVq1KhUf+b+q+zsbA0YMECenp76z3/+I3d394v2dca93XnnnZJU4uOA586dK0mKjIyU9OefmP86E1ccBP/6yLCrRaVKlWSxWOxmLI8dO6aPPvrIrl+fPn3k5uam2NjYEmuUnTX7aLVa1bNnT73++uslri/9GT6LP+Cjbt26CgkJUUJCgl1I3bt3r9atW2f7nl1M06ZNS/wOLlmy5G//ggLAMczcAiYzceJEvfnmmzp48KBatmxpt++hhx7SrFmz9NBDD6l9+/bavHlzuX6sqJ+fnzp37qwHHnhAGRkZevnll9WsWTPbY67c3Nz0+uuvq1evXmrZsqUeeOABXX/99fr555/12WefydvbW6tXr76saz/zzDP6z3/+o169emnMmDHy8/NTQkKCjh49qg8++KDEm5NK49FHH9WxY8fUv39/ffXVVyWeV1ts0KBBTrm3m266SUOHDtWSJUuUnZ2trl27avv27UpISFCfPn3UrVs3SVJCQoIWLVqke+65R02bNtXvv/+u1157Td7e3pcMW+Xl008/tc2Sn+/WW29VkyZNFBkZqblz56pnz566//77lZmZqbi4ODVr1kzfffedrX+zZs00ceJETZ8+XV26dFHfvn3l4eGhHTt2qF69epo5c6ZT6l2+fLl69Oihvn37qnfv3goLC5OXl5cOHz6st99+W2lpabZn3b744ovq1auXrFarhg8frj/++EMLFy6Uj4/PBZ9he76HHnpIjz76qPr166c77rhD3377rZKSkkqsYwdw+Qi3gMk0a9ZMgwYNUkJCQol9U6ZM0S+//KL3339f7777rnr16qVPP/1UderUKZda/vWvf+m7777TzJkz9fvvvyssLEyLFi2Sp6enrc/tt9+u5ORkTZ8+Xf/+97916tQpBQQEKDQ0VI888shlX9vf319btmzR008/rYULF+rMmTNq06aNVq9ebZvxdFTxc2PfeecdvfPOOxftN2jQIEnOubfXX39dTZo00bJly7Rq1SoFBAQoJiZGU6dOtfUpDr1vv/22MjIy5OPjow4dOuitt94q9RvwnG3KlCkXbI+Pj1eTJk3UvXt3LV26VLNmzdITTzyhxo0b64UXXtCxY8fswq30/x/lu3DhQk2cOFGenp5q06ZNqZ9LWxq1a9fWli1btGjRIr3zzjuaOHGiCgoK1LBhQ9199916/PHHbX3Dw8OVmJioqVOnasqUKXJ3d1fXrl31wgsvXHK8H374YR09elRLly5VYmKiunTpovXr1yssLMxp9wJUdBaDVeUAAAAwCdbcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANnnOrPz8D/sSJE6pRo8YlP8MdAAAAV55hGPr9999Vr169v/0gHsKtpBMnTigwMNDVZQAAAOASUlNTVb9+/Yvud2m4PXfunKZNm6YVK1YoPT1d9erV07BhwzRp0iTbDKphGJo6dapee+01ZWdnq1OnTlq8eLGaN29uO09WVpZGjx6t1atXy83NTf369dP8+fNVvXr1UtVRo0YNSX8Olre3t/NvFAAAAGWSm5urwMBAW267GJeG2xdeeEGLFy9WQkKCWrZsqa+//loPPPCAfHx8NGbMGEnS7NmztWDBAiUkJKhx48aaPHmyIiIitH//flWtWlWSNHDgQKWlpWn9+vUqLCzUAw88oBEjRmjlypWlqqM4SHt7exNuAQAArmKXWkLq0o/fveuuu+Tv76+lS5fa2vr166dq1appxYoVMgxD9erV05NPPqnx48dLknJycuTv769ly5ZpwIABOnDggIKDg7Vjxw61b99ekpSYmKg777xTP/30k+rVq3fJOnJzc+Xj46OcnBzCLQAAwFWotHnNpU9LuPXWW7Vx40YdOnRIkvTtt9/qyy+/VK9evSRJR48eVXp6usLDw23H+Pj4KDQ0VMnJyZKk5ORk+fr62oKtJIWHh8vNzU3btm274HXz8/OVm5trtwEAAODa59JlCc8884xyc3PVokULVapUSefOndOMGTM0cOBASVJ6erokyd/f3+44f39/27709HTVqVPHbn/lypXl5+dn6/NXM2fO1LPPPuvs2wEAAICLuXTm9t1339Vbb72llStXateuXUpISNCcOXOUkJBQrteNiYlRTk6ObUtNTS3X6wEAAODKcOnM7YQJE/TMM89owIABkqTWrVvr+PHjmjlzpoYOHaqAgABJUkZGhurWrWs7LiMjQyEhIZKkgIAAZWZm2p337NmzysrKsh3/Vx4eHvLw8CiHOwIAAIAruXTm9vTp0yUewlupUiUVFRVJkho3bqyAgABt3LjRtj83N1fbtm2T1WqVJFmtVmVnZ2vnzp22Pps2bVJRUZFCQ0OvwF0AAADgauHSmdvevXtrxowZatCggVq2bKlvvvlGc+fO1YMPPijpz0c9PPHEE3ruuefUvHlz26PA6tWrpz59+kiSgoKC1LNnTz388MN65ZVXVFhYqFGjRmnAgAGlelICAAAAzMOl4XbhwoWaPHmyHnvsMWVmZqpevXp65JFHNGXKFFufp556Snl5eRoxYoSys7PVuXNnJSYm2p5xK0lvvfWWRo0apbCwMNuHOCxYsMAVtwQAAAAXculzbq8WPOcWAADg6nZNPOcWAAAAcCbCLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyD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hO+++8729ZgxY/T444/ryJEj6tixoyRp69atiouL06xZs8qnSgAAAKAUShVuQ0JCZLFYZBiGre2pp54q0e/+++9X//79nVcdAAAA4IBShdujR4+Wdx0AAABAmZUq3DZs2LC86wAAAADK7LI+xOHEiRP68ssvlZmZqaKiIrt9Y8aMcUphAAAAgKMcDrfLli3TI488oipVqqhWrVqyWCy2fRaLhXALAAAAl3E43E6ePFlTpkxRTEyM3NwcfpIYAAAAUG4cTqenT5/WgAEDCLYAAAC46jicUIcPH6733nuvPGoBAAAAysThZQkzZ87UXXfdpcTERLVu3Vru7u52++fOneu04gAAAABHXFa4TUpK0o033ihJJd5QBgAAALiKw+H2pZde0htvvKFhw4aVQzkAAADA5XN4za2Hh4c6depUHrUAAAAAZeJwuH388ce1cOHC8qgFAAAAKBOHlyVs375dmzZt0po1a9SyZcsSbyj78MMPnVYcAAAA4AiHw62vr6/69u1bHrUAAAAAZeJwuI2Pjy+POgAAAIAy42PGAAAAYBoOz9w2btz4b59n++OPP5apIAAAAOByORxun3jiCbvXhYWF+uabb5SYmKgJEyY4qy4AAADAYQ6H28cff/yC7XFxcfr666/LXBAAAABwuZy25rZXr1764IMPnHU6AAAAwGFOC7fvv/++/Pz8nHU6AAAAwGEOL0to27at3RvKDMNQenq6fvnlFy1atMipxQEAAACOcDjc9unTx+61m5ubateurdtvv10tWrRwVl0AAACAwxwOt1OnTi2POgAAAIAy40McAAAAYBqlnrl1c3P72w9vkCSLxaKzZ8+WuSgAAADgcpQ63K5ateqi+5KTk7VgwQIVFRU5pSgAAADgcpQ63EZFRZVoO3jwoJ555hmtXr1aAwcOVGxsrFOLAwAAABxxWWtuT5w4oYcfflitW7fW2bNntXv3biUkJKhhw4bOrg8AAAAoNYfCbU5Ojp5++mk1a9ZM+/bt08aNG7V69Wq1atWqvOoDAAAASq3U4Xb27Nlq0qSJ1qxZo//85z/asmWLunTpUqaLL168WG3atJG3t7e8vb1ltVr16aef2vafOXNG0dHRqlWrlqpXr65+/fopIyPD7hwpKSmKjIyUp6en6tSpowkTJvCmNgAAgAqq1Gtun3nmGVWrVk3NmjVTQkKCEhISLtjvww8/LPXF69evr1mzZql58+YyDEMJCQmKiorSN998o5YtW2rs2LFau3at3nvvPfn4+GjUqFHq27evvvrqK0nSuXPnFBkZqYCAAG3ZskVpaWkaMmSI3N3d9fzzz5e6DgAAAJhDqcPtkCFDLvkoMEf17t3b7vWMGTO0ePFibd26VfXr19fSpUu1cuVKde/eXZIUHx+voKAgbd26VR07dtS6deu0f/9+bdiwQf7+/goJCdH06dP19NNPa9q0aapSpYpT6wUAAMDVrdThdtmyZeVYxp+zsO+9957y8vJktVq1c+dOFRYWKjw83NanRYsWatCggZKTk9WxY0clJyerdevW8vf3t/WJiIjQyJEjtW/fPrVt2/aC18rPz1d+fr7tdW5ubvndGAAAAK4Yl39C2Z49e1S9enV5eHjo0Ucf1apVqxQcHKz09HRVqVJFvr6+dv39/f2Vnp4uSUpPT7cLtsX7i/ddzMyZM+Xj42PbAgMDnXtTAAAAcAmXh9sbb7xRu3fv1rZt2zRy5EgNHTpU+/fvL9drxsTEKCcnx7alpqaW6/UAAABwZZR6WUJ5qVKlipo1ayZJateunXbs2KH58+erf//+KigoUHZ2tt3sbUZGhgICAiRJAQEB2r59u935ip+mUNznQjw8POTh4eHkOwEAAICruXzm9q+KioqUn5+vdu3ayd3dXRs3brTtO3jwoFJSUmS1WiVJVqtVe/bsUWZmpq3P+vXr5e3treDg4CteOwAAAFzLpTO3MTEx6tWrlxo0aKDff/9dK1eu1Oeff66kpCT5+Pho+PDhGjdunPz8/OTt7a3Ro0fLarWqY8eOkqQePXooODhYgwcP1uzZs5Wenq5JkyYpOjqamVkAAIAKyKXhNjMzU0OGDFFaWpp8fHzUpk0bJSUl6Y477pAkzZs3T25uburXr5/y8/MVERGhRYsW2Y6vVKmS1qxZo5EjR8pqtcrLy0tDhw5VbGysq24JAAAALuTScLt06dK/3V+1alXFxcUpLi7uon0aNmyoTz75xNmlAQAA4Bp01a25BQAAAC4X4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACm4dJwO3PmTN1yyy2qUaOG6tSpoz59+ujgwYN2fc6cOaPo6GjVqlVL1atXV79+/ZSRkWHXJyUlRZGRkfL09FSdOnU0YcIEnT179kreCgAAAK4CLg23X3zxhaKjo7V161atX79ehYWF6tGjh/Ly8mx9xo4dq9WrV+u9997TF198oRMnTqhv3762/efOnVNkZKQKCgq0ZcsWJSQkaNmyZZoyZYorbgkAAAAuVNmVF09MTLR7vWzZMtWpU0c7d+7UbbfdppycHC1dulQrV65U9+7dJUnx8fEKCgrS1q1b1bFjR61bt0779+/Xhg0b5O/vr5CQEE2fPl1PP/20pk2bpipVqrji1gAAAOACV9Wa25ycHEmSn5+fJGnnzp0qLCxUeHi4rU+LFi3UoEEDJScnS5KSk5PVunVr+fv72/pEREQoNzdX+/btu+B18vPzlZuba7cBAADg2nfVhNuioiI98cQT6tSpk1q1aiVJSk9PV5UqVeTr62vX19/fX+np6bY+5wfb4v3F+y5k5syZ8vHxsW2BgYFOvhsAAAC4wlUTbqOjo7V37169/fbb5X6tmJgY5eTk2LbU1NRyvyYAAADKn0vX3BYbNWqU1qxZo82bN6t+/fq29oCAABUUFCg7O9tu9jYjI0MBAQG2Ptu3b7c7X/HTFIr7/JWHh4c8PDycfBcAAABwNZfO3BqGoVGjRmnVqlXatGmTGjdubLe/Xbt2cnd318aNG21tBw8eVEpKiqxWqyTJarVqz549yszMtPVZv369vL29FRwcfGVuBAAAAFcFl87cRkdHa+XKlfr4449Vo0YN2xpZHx8fVatWTT4+Pho+fLjGjRsnPz8/eXt7a/To0bJarerYsaMkqUePHgoODtbgwYM1e/Zspaena9KkSYqOjmZ2FgAAoIJxabhdvHixJOn222+3a4+Pj9ewYcMkSfPmzZObm5v69eun/Px8RUREaNGiRba+lSpV0po1azRy5EhZrVZ5eXlp6NChio2NvVK3AQAAgKuES8OtYRiX7FO1alXFxcUpLi7uon0aNmyoTz75xJmlAQAA4Bp01TwtAQAAACgrwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMg3ALAAAA0yDcAgAAwDQItwAAADANwi0AAABMw6XhdvPmzerdu7fq1asni8Wijz76yG6/YRiaMmWK6tatq2rVqik8PFyHDx+265OVlaWBAwfK29tbvr6+Gj58uE6dOnUF7wIAAABXC5eG27y8PN10002Ki4u74P7Zs2drwYIFeuWVV7Rt2zZ5eXkpIiJCZ86csfUZOHCg9u3bp/Xr12vNmjXavHmzRowYcaVuAQAAAFeRyq68eK9evdSrV68L7jMMQy+//LImTZqkqKgoSdLy5cvl7++vjz76SAMGDNCBAweUmJioHTt2qH379pKkhQsX6s4779ScOXNUr169K3YvAAAAcL2rds3t0aNHlZ6ervDwcFubj4+PQkNDlZycLElKTk6Wr6+vLdhKUnh4uNzc3LRt27aLnjs/P1+5ubl2GwAAAK59V224TU9PlyT5+/vbtfv7+9v2paenq06dOnb7K1euLD8/P1ufC5k5c6Z8fHxsW2BgoJOrBwAAgCtcteG2PMXExCgnJ8e2paamurokAAAAOMFVG24DAgIkSRkZGXbtGRkZtn0BAQHKzMy023/27FllZWXZ+lyIh4eHvL297TYAAABc+67acNu4cWMFBARo48aNtrbc3Fxt27ZNVqtVkmS1WpWdna2dO3fa+mzatElFRUUKDQ294jUDAADAtVz6tIRTp07pyJEjttdHjx7V7t275efnpwYNGuiJJ57Qc889p+bNm6tx48aaPHmy6tWrpz59+kiSgoKC1LNnTz388MN65ZVXVFhYqFGjRmnAgAE8KQEAAKACcmm4/frrr9WtWzfb63HjxkmShg4dqmXLlumpp55SXl6eRowYoezsbHXu3FmJiYmqWrWq7Zi33npLo0aNUlhYmNzc3NSvXz8tWLDgit8LAAAAXM+l4fb222+XYRgX3W+xWBQbG6vY2NiL9vHz89PKlSvLozwAAABcY67aNbcAAACAowi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3CLQAAAEyDcAsAAADTINwCAADANAi3AAAAMA3ThNu4uDg1atRIVatWVWhoqLZv3+7qkgAAAHCFmSLcvvPOOxo3bpymTp2qXbt26aabblJERIQyMzNdXRoAAACuIFOE27lz5+rhhx/WAw88oODgYL3yyivy9PTUG2+84erSAAAAcAVVdnUBZVVQUKCdO3cqJibG1ubm5qbw8HAlJydf8Jj8/Hzl5+fbXufk5EiScnNzy7fY8xTln75i17qaOWPMGcs/MZbOU9axZBz/H2PpPIyl8zCWznElc9P51zMM4+87Gte4n3/+2ZBkbNmyxa59woQJRocOHS54zNSpUw1JbGxsbGxsbGxs19iWmpr6t9nwmp+5vRwxMTEaN26c7XVRUZGysrJUq1YtWSwWF1Z25eTm5iowMFCpqany9vZ2dTnXNMbSeRhL52EsnYexdA7G0Xkq6lgahqHff/9d9erV+9t+13y4ve6661SpUiVlZGTYtWdkZCggIOCCx3h4eMjDw8OuzdfXt7xKvKp5e3tXqF+M8sRYOg9j6TyMpfMwls7BODpPRRxLHx+fS/a55t9QVqVKFbVr104bN260tRUVFWnjxo2yWq0urAwAAABX2jU/cytJ48aN09ChQ9W+fXt16NBBL7/8svLy8vTAAw+4ujQAAABcQaYIt/3799cvv/yiKVOmKD09XSEhIUpMTJS/v7+rS7tqeXh4aOrUqSWWZ8BxjKXzMJbOw1g6D2PpHIyj8zCWf89iGJd6ngIAAABwbbjm19wCAAAAxQi3AAAAMA3CLQAAAEyDcGsC06ZNU0hIiKvLMAXG0nkYS+dhLJ2DcXQextJ5GEvnI9y6WHp6ukaPHq0mTZrIw8NDgYGB6t27t91ze691Y8aMUbt27eTh4VGuv8BmH8tvv/1W//znPxUYGKhq1aopKChI8+fPL5drmX0sf/vtN/Xs2VP16tWz3d+oUaPK5XPSzT6W5/vtt99Uv359WSwWZWdnO/XcFWEcLRZLie3tt992+nUqwlhK0rJly9SmTRtVrVpVderUUXR0tNOvYfaxXLZs2QV/Li0WizIzM11d3kWZ4lFg16pjx46pU6dO8vX11YsvvqjWrVursLBQSUlJio6O1vfff+/qEp3mwQcf1LZt2/Tdd9+Vy/krwlju3LlTderU0YoVKxQYGKgtW7ZoxIgRqlSpkkaNGuW061SEsXRzc1NUVJSee+451a5dW0eOHFF0dLSysrK0cuVKp12nIozl+YYPH642bdro559/dup5K9I4xsfHq2fPnrbXzv70zIoylnPnztVLL72kF198UaGhocrLy9OxY8eceo2KMJb9+/e3+3mUpGHDhunMmTOqU6eOi6oqBQMu06tXL+P66683Tp06VWLfyZMnbV8fP37cuPvuuw0vLy+jRo0axn333Wekp6fb9k+dOtW46aabbK+7du1qPP7443bni4qKMoYOHWp73bBhQ2P69OnG4MGDDS8vL6NBgwbGxx9/bGRmZtqu1bp1a2PHjh22Y+Lj4w0fHx8jMTHRaNGiheHl5WVEREQYJ06cKNX9/rVOZ6poY1nsscceM7p16+bQMZdSUcdy/vz5Rv369R065lIq0lguWrTI6Nq1q7Fx40ZDkt39lVVFGUdJxqpVq0o1JperIoxlVlaWUa1aNWPDhg2lH5jLUBHG8q8yMzMNd3d3Y/ny5aU+xhVYluAiWVlZSkxMVHR0tLy8vErsL/6/9aKiIkVFRSkrK0tffPGF1q9frx9//FH9+/cvcw3z5s1Tp06d9M033ygyMlKDBw/WkCFDNGjQIO3atUtNmzbVkCFDZJz3KOTTp09rzpw5evPNN7V582alpKRo/PjxZa6lLCryWObk5MjPz6/M9RerqGN54sQJffjhh+ratWuZ6y9WkcZy//79io2N1fLly+Xm5tx/VirSOEpSdHS0rrvuOnXo0EFvvPGG3TnLqqKM5fr161VUVKSff/5ZQUFBql+/vv7xj38oNTW1zPUXqyhj+VfLly+Xp6en7r333jLXX65cl6srtm3bthmSjA8//PBv+61bt86oVKmSkZKSYmvbt2+fIcnYvn27YRiX/399gwYNsr1OS0szJBmTJ0+2tSUnJxuSjLS0NMMw/vy/PknGkSNHbH3i4uIMf3//Ut1zec3cVsSxNAzD+Oqrr4zKlSsbSUlJpT7mUiraWA4YMMCoVq2aIcno3bu38ccff1zymNKqKGN55swZo02bNsabb75pGIZhfPbZZ06dua0o42gYhhEbG2t8+eWXxq5du4xZs2YZHh4exvz58//2GEdUlLGcOXOm4e7ubtx4441GYmKikZycbISFhRk33nijkZ+f/7f3XloVZSz/KigoyBg5cmSp+7sKM7cuYpTy/8YPHDigwMBABQYG2tqCg4Pl6+urAwcOlKmGNm3a2L4u/qji1q1bl2g7f9G4p6enmjZtantdt25dly8qr4hjuXfvXkVFRWnq1Knq0aNHmWo/X0Uby3nz5mnXrl36+OOP9cMPP2jcuHFlqv18FWUsY2JiFBQUpEGDBpWp1oupKOMoSZMnT1anTp3Utm1bPf3003rqqaf04osvlqn281WUsSwqKlJhYaEWLFigiIgIdezYUf/5z390+PBhffbZZ2Wqv1hFGcvzJScn68CBAxo+fHiZ6r4SCLcu0rx5c1kslnJZcO7m5lbiF6+wsLBEP3d3d9vXFovlom1FRUUXPKa4T2l/yctLRRvL/fv3KywsTCNGjNCkSZNKcRelV9HGMiAgQC1atNDdd9+tV199VYsXL1ZaWlop7ubSKspYbtq0Se+9954qV66sypUrKywsTJJ03XXXaerUqaW9pYuqKON4IaGhofrpp5+Un5/v0HEXU1HGsm7dupL+DJHFateureuuu04pKSmXvJfSqChjeb7XX39dISEhateuXan6uxLh1kX8/PwUERGhuLg45eXlldhf/BidoKAgpaam2q0V2r9/v7Kzs+1+cc9Xu3Ztu3+gz507p7179zr3Bq4iFWks9+3bp27dumno0KGaMWOG089fkcbyr4r/AXBWkKgoY/nBBx/o22+/1e7du7V79269/vrrkqT//e9/Tnn0UkUZxwvZvXu3atasKQ8PD6ecr6KMZadOnSRJBw8etLVlZWXp119/VcOGDZ1yjYoylsVOnTqld99995qYtZUIty4VFxenc+fOqUOHDvrggw90+PBhHThwQAsWLJDVapUkhYeHq3Xr1ho4cKB27dql7du3a8iQIeratavat29/wfN2795da9eu1dq1a/X9999r5MiRTn/mpCOOHDmi3bt3Kz09XX/88YftH8GCggKnXaMijOXevXvVrVs39ejRQ+PGjVN6errS09P1yy+/OPU6FWEsP/nkE8XHx2vv3r06duyY1q5dq0cffVSdOnVSo0aNnHadijCWTZs2VatWrWxb48aNJf35j7qzHhVUEcZx9erVev3117V3714dOXJEixcv1vPPP6/Ro0c79ToVYSxvuOEGRUVF6fHHH9eWLVu0d+9eDR06VC1atFC3bt2cdp2KMJbF3nnnHZ09e7bclh85G+HWhZo0aaJdu3apW7duevLJJ9WqVSvdcccd2rhxoxYvXizpzz8ZfPzxx6pZs6Zuu+02hYeHq0mTJnrnnXcuet4HH3xQQ4cOtf0CNWnSxKm/0I566KGH1LZtW7366qs6dOiQ2rZtq7Zt2+rEiRNOu0ZFGMv3339fv/zyi1asWKG6devatltuucWp16kIY1mtWjW99tpr6ty5s4KCgjR27FjdfffdWrNmjVOvUxHG8kqoCOPo7u6uuLg4Wa1WhYSE6NVXX9XcuXOdsrTjfBVhLKU/39UfGhqqyMhIde3aVe7u7kpMTCzxZ/myqChjKUlLly5V3759nf7c5fJiMVy9YBIAAABwEmZuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAQAAYBqEWwAAAJgG4RYAAACmQbgFAACAaRBuAeAaMW3aNIWEhLi6DAC4qhFuAeAKSU9P1+jRo9WkSRN5eHgoMDBQvXv31saNG11dGgCYRmVXFwAAFcGxY8fUqVMn+fr66sUXX1Tr1q1VWFiopKQkRUdH6/vvv3d1iQBgCszcAsAV8Nhjj8lisWj79u3q16+fbrjhBrVs2VLjxo3T1q1bJUkpKSmKiopS9erV5e3trX/84x/KyMi46Dlvv/12PfHEE3Ztffr00bBhw2yvGzVqpOeee05DhgxR9erV1bBhQ/33v//VL7/8YrtWmzZt9PXXX9uOWbZsmXx9fZWUlKSgoCBVr15dPXv2VFpamq3P559/rg4dOsjLy0u+vr7q1KmTjh8/7pzBAoAyINwCQDnLyspSYmKioqOj5eXlVWK/r6+vioqKFBUVpaysLH3xxRdav369fvzxR/Xv37/M1583b546deqkb775RpGRkRo8eLCGDBmiQYMGadeuXWratKmGDBkiwzBsx5w+fVpz5szRm2++qc2bNyslJUXjx4+XJJ09e1Z9+vRR165d9d133yk5OVkjRoyQxWIpc60AUFYsSwCAcnbkyBEZhqEWLVpctM/GjRu1Z88eHT16VIGBgZKk5cuXq2XLltqxY4duueWWy77+nXfeqUceeUSSNGXKFC1evFi33HKL7rvvPknS008/LavVqoyMDAUEBEiSCgsL9corr6hp06aSpFGjRik2NlaSlJubq5ycHN111122/UFBQZddHwA4EzO3AFDOzp8RvZgDBw4oMDDQFmwlKTg4WL6+vjpw4ECZrt+mTRvb1/7+/pKk1q1bl2jLzMy0tXl6etqCqyTVrVvXtt/Pz0/Dhg1TRESEevfurfnz59stWQAAVyLcAkA5a968uSwWi9PfNObm5lYiOBcWFpbo5+7ubvu6eOnAhdqKiooueExxn/OvFR8fr+TkZN1666165513dMMNN9jWDgOAKxFuAaCc+fn5KSIiQnFxccrLyyuxPzs7W0FBQUpNTVVqaqqtff/+/crOzlZwcPAFz1u7dm27GdNz585p7969zr+Bi2jbtq1iYmK0ZcsWtWrVSitXrrxi1waAiyHcAsAVEBcXp3PnzqlDhw764IMPdPjwYR04cEALFiyQ1WpVeHi4WrdurYEDB2rXrl3avn27hgwZoq5du6p9+/YXPGf37t21du1arV27Vt9//71Gjhyp7Ozscr+Xo0ePKiYmRsnJyTp+/LjWrVunw4cPs+4WwFWBN5QBwBXQpEkT7dq1SzNmzNCTTz6ptLQ01a5dW+3atdPixYtlsVj08ccfa/To0brtttvk5uamnj17auHChRc954MPPqhvv/1WQ4YMUeXKlTV27Fh169at3O/F09NT33//vRISEvTbb7+pbt26io6Otr1pDQBcyWKU5p0OAAAAwDWAZQkAAAAwDcItAAAATINwCwAAANMg3AIAAMA0CLcAAAAwDcItAAAATINwCwAAANMg3AIAAMA0CLcAAAAwDcItAAAATINwCwAAANP4P6jkjLmt4osVAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "num_nodes = len(labels)\n",
    "num_labels = len(set(labels))\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((num_nodes, num_labels))\n",
    "\n",
    "# Fill in the one-hot encoded values\n",
    "for node_idx, label_idx in enumerate(labels):\n",
    "    Y[node_idx, label_idx] = 1\n",
    "Phi = C_t_0@Y \n",
    "\n",
    "Phi[Phi<1]=0\n",
    "Phi = Phi.detach().cpu().numpy()\n",
    "\n",
    "num_zeros_per_column = np.sum(Phi == 0, axis=0)\n",
    "\n",
    "plt.figure(figsize=(8, 6))  # Adjust the figure size as needed\n",
    "plt.bar(range(1, 8), num_zeros_per_column, tick_label=[f\"Column {i+1}\" for i in range(7)])\n",
    "plt.xlabel(\"Columns\")\n",
    "plt.ylabel(\"Number of Zeros\")\n",
    "plt.title(\"Number of Zeros in Each Column\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "56147249",
   "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
}
