{
 "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_44964\\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_44964\\4057615484.py:25: DeprecationWarning: Importing display from IPython.core.display is deprecated since IPython 7.14, please import from IPython display\n",
      "  from IPython.core.display import display, HTML\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>.container { width:90% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite\\\\DBLP'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import collections\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "from torch import Tensor\n",
    "import torch_geometric\n",
    "from torch_geometric.utils import to_networkx\n",
    "from torch_geometric.datasets import Planetoid\n",
    "import networkx as nx\n",
    "from networkx.algorithms import community\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "data_dir = \"./data\"\n",
    "os.makedirs(data_dir, exist_ok=True)\n",
    "\n",
    "import numpy\n",
    "import torch\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "%matplotlib inline\n",
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:90% !important; }</style>\"))\n",
    "\n",
    "\n",
    "from random import sample\n",
    "from networkx.generators.random_graphs import erdos_renyi_graph\n",
    "from networkx.generators.random_graphs import barabasi_albert_graph\n",
    "from networkx.generators.community import stochastic_block_model\n",
    "from networkx.generators.random_graphs import watts_strogatz_graph\n",
    "from networkx.generators.community import random_partition_graph\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import math\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "from sklearn.decomposition import FactorAnalysis\n",
    "import random\n",
    "\n",
    "from scipy.sparse import csr_matrix\n",
    "from scipy.sparse import csgraph\n",
    "from scipy.sparse.linalg import inv\n",
    "\n",
    "import os\n",
    "os.getcwd()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3669a0f9",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "3669a0f9",
    "outputId": "213cddc0-551b-4948-a025-9704edf67d7e"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite\\\\DBLP\\\\DBLP'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "dataset = os.path.join(os.getcwd(),'DBLP')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "067c3d06",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "067c3d06",
    "outputId": "9c7402f2-2cfc-46ea-e604-13ef4b07d6ff"
   },
   "outputs": [],
   "source": [
    "# import os.path as osp\n",
    "# import torch\n",
    "# from torch_geometric.datasets import Planetoid\n",
    "# import torch_geometric.transforms as T\n",
    "\n",
    "# def get_planetoid_dataset(name, normalize_features=False, transform=None, split=\"public\"):\n",
    "#     path = osp.join(osp.dirname(osp.realpath(os.getcwd())), '..', 'data', name)\n",
    "#     if split == 'complete':\n",
    "#         dataset = Planetoid(path, name)\n",
    "#         dataset[0].train_mask.fill_(False)\n",
    "#         dataset[0].train_mask[:dataset[0].num_nodes - 1000] = 1\n",
    "#         dataset[0].val_mask.fill_(False)\n",
    "#         dataset[0].val_mask[dataset[0].num_nodes - 1000:dataset[0].num_nodes - 500] = 1\n",
    "#         dataset[0].test_mask.fill_(False)\n",
    "#         dataset[0].test_mask[dataset[0].num_nodes - 500:] = 1\n",
    "#     else:\n",
    "#         dataset = Planetoid(path, name, split=split)\n",
    "#     if transform is not None and normalize_features:\n",
    "#         dataset.transform = T.Compose([T.NormalizeFeatures(), transform])\n",
    "#     elif normalize_features:\n",
    "#         dataset.transform = T.NormalizeFeatures()\n",
    "#     elif transform is not None:\n",
    "#         dataset.transform = transform\n",
    "#     return dataset\n",
    "\n",
    "\n",
    "# if __name__ == '__main__':\n",
    "# #     lst_names = ['Cora', 'CiteSeer', 'PubMed']\n",
    "#     lst_names = ['PubMed']\n",
    "#     for name in lst_names:\n",
    "#         dataset = get_planetoid_dataset(name)\n",
    "#         print(f\"dataset: {name}\")\n",
    "#         print(f\"num_nodes: {dataset[0]['x'].shape[0]}\")\n",
    "#         print(f\"num_edges: {dataset[0]['edge_index'].shape[1]}\")\n",
    "#         print(f\"num_classes: {dataset.num_classes}\")\n",
    "#         print(f\"num_features: {dataset.num_node_features}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7f8577f3",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "7f8577f3",
    "outputId": "de9c336b-dbd9-40ca-e1fa-58107ade7ce8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data(x=[17716, 1639], edge_index=[2, 105734], y=[17716])\n",
      "torch.Size([17716, 1639]) torch.Size([17716, 17716])\n",
      "torch.Size([17716, 1639]) torch.Size([17716, 17716])\n"
     ]
    }
   ],
   "source": [
    "# # from torch_geometric.datasets import Planetoid\n",
    "# from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "# # # dataset = NELL(root='/nell')\n",
    "# k_ = dataset.num_classes\n",
    "\n",
    "# # dataset= Planetoid(root=dataset, name='Cora')\n",
    "# print(dataset[0])\n",
    "# adj = to_dense_adj(dataset[0].edge_index).cuda()\n",
    "# adj = adj[0]\n",
    "# labels = dataset[0].y\n",
    "# labels = labels.numpy()\n",
    "\n",
    "# X = dataset[0].x\n",
    "# X = X.to_dense()\n",
    "# N = X.shape[0]\n",
    "# NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "\n",
    "# print(X.shape, adj.shape)\n",
    "\n",
    "# nn = int(1*N)\n",
    "# X = X[:nn,:]\n",
    "# adj = adj[:nn,:nn]\n",
    "# A = adj[:nn,:nn]\n",
    "# AT= torch.transpose(A,0,1)\n",
    "# labels = labels[:nn]\n",
    "# print(X.shape,adj.shape)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "from torch_geometric.datasets import DBLP\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "from torch_geometric.datasets import CitationFull\n",
    "from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "dataset = CitationFull(root='/DBLP',name='dblp')\n",
    "print(dataset[0])\n",
    "adj = to_dense_adj(dataset[0].edge_index)\n",
    "adj = adj[0]\n",
    "labels = dataset[0].y\n",
    "labels = labels.numpy()\n",
    "\n",
    "X = dataset[0].x\n",
    "X = X.to_dense()\n",
    "N = X.shape[0]\n",
    "NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "k_=NO_OF_CLASSES\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "labels = labels[:nn]\n",
    "A = adj[:nn,:nn]\n",
    "AT= torch.transpose(A,0,1)\n",
    "labels = labels[:nn]\n",
    "print(X.shape,adj.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "475846d5",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "475846d5",
    "outputId": "c6102e64-ae54-46d6-8f9b-48ba85a81564"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([17716, 1639])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a0757b15",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "a0757b15",
    "outputId": "d35c00b4-f747-4b97-c075-b98efcdb77eb"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([17716, 17716])\n"
     ]
    }
   ],
   "source": [
    "def get_laplacian(adj):\n",
    "    b=torch.ones(adj.shape[0])\n",
    "    return torch.diag(adj@b)-adj\n",
    "\n",
    "theta = get_laplacian(adj)\n",
    "print(theta.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "36a2d1ca",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "36a2d1ca",
    "outputId": "47e7d15b-491d-49ad-9dff-fcdb283b16a7"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'torch.FloatTensor'"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(theta@A).type()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "cad0c60b",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "cad0c60b",
    "outputId": "4de3ae5a-7f39-4649-bae9-c437127dc115"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "theta.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "114a42e0",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "114a42e0",
    "outputId": "62b0a402-9d33-44be-8e7f-20de623be138"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 17716\n"
     ]
    }
   ],
   "source": [
    "\n",
    "features = torch.Tensor(X)\n",
    "NO_OF_NODES = X.shape[0]\n",
    "print(NO_OF_CLASSES,NO_OF_NODES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2ba32732",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "2ba32732",
    "outputId": "4d8096c2-cca6-41e5-f7f9-ebd3e815a404"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b33c30e2",
   "metadata": {
    "id": "b33c30e2"
   },
   "outputs": [],
   "source": [
    "def convertScipyToTensor(coo):\n",
    "  try:\n",
    "    coo = coo.tocoo()\n",
    "  except:\n",
    "    coo = coo\n",
    "  values = coo.data\n",
    "  indices = np.vstack((coo.row, coo.col))\n",
    "\n",
    "  i = torch.LongTensor(indices)\n",
    "  v = torch.FloatTensor(values)\n",
    "  shape = coo.shape\n",
    "\n",
    "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b7f9d72b",
   "metadata": {
    "id": "b7f9d72b"
   },
   "outputs": [],
   "source": [
    "from scipy.sparse import random\n",
    "from scipy.sparse.linalg import norm\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "p = X.shape[0]\n",
    "k = int(p*0.1)\n",
    "n = X.shape[1]\n",
    "lr = 1e-5\n",
    "thresh = 1e-10\n",
    "\n",
    "from scipy.sparse import random\n",
    "from scipy.stats import rv_continuous\n",
    "class CustomDistribution(rv_continuous):\n",
    "    def _rvs(self,  size=None, random_state=None):\n",
    "        return random_state.standard_normal(size)\n",
    "temp = CustomDistribution(seed=1)\n",
    "temp2 = temp()  # get a frozen version of the distribution\n",
    "C = random(p, k, density=0.25, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "eecc9adb",
   "metadata": {
    "id": "eecc9adb"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.nn import GCNConv\n",
    "\n",
    "\n",
    "class Net(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Net, self).__init__()\n",
    "        self.conv1 = GCNConv(X.shape[1], 64)\n",
    "        self.conv2 = GCNConv(64, NO_OF_CLASSES)\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.conv1.reset_parameters()\n",
    "        self.conv2.reset_parameters()\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "        x = self.conv1(x, edge_index)\n",
    "        x = F.relu(x)\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return F.log_softmax(x, dim=1)\n",
    "    \n",
    "    \n",
    "####### NO output layer is written\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "07b55b4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.nn import GATConv\n",
    "\n",
    "class GAT(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(GAT, self).__init__()\n",
    "        self.hid = 64\n",
    "        self.in_head = 64\n",
    "        self.out_head = 32\n",
    "        \n",
    "        self.conv1 = GATConv(X.shape[1], self.hid, heads=self.in_head, dropout=0.2)\n",
    "        self.conv2 = GATConv(self.hid*self.in_head, NO_OF_CLASSES, concat=False, heads=self.out_head, dropout=0.2)\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.conv1.reset_parameters()\n",
    "        self.conv2.reset_parameters()\n",
    "\n",
    "\n",
    "    def forward(self, x,edge_index):\n",
    "        \n",
    "        x = F.dropout(x, p=0.2, training=self.training)\n",
    "        x = self.conv1(x, edge_index)\n",
    "        x = F.elu(x)\n",
    "        x = F.dropout(x, p=0.2, training=self.training)\n",
    "        x = self.conv2(x, edge_index)\n",
    "        \n",
    "        return F.log_softmax(x, dim=1)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "1c5a519a",
   "metadata": {
    "id": "1c5a519a"
   },
   "outputs": [],
   "source": [
    "def get_accu(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        model=Net().to(device)\n",
    "        lr=0.01\n",
    "        decay=0.0001\n",
    "        features_= features.cpu().detach().numpy()\n",
    "        try:\n",
    "          X=np.array(features_.todense())\n",
    "        except:\n",
    "          X = np.array(features_)\n",
    "        #print(\"X:\",X.shape)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=decay)\n",
    "        # criterion=torch.nn.CrossEntropyLoss()\n",
    "        x=sample(range(0, int(k)), k)\n",
    "      \n",
    "        from datetime import datetime\n",
    "        Xt=P@X\n",
    "        # Xt=X_t_0\n",
    "        def train():\n",
    "            model.train()\n",
    "            optimizer.zero_grad()\n",
    "            out = model(torch.Tensor(Xt).to(device),edge_index_coarsen2)\n",
    "            loss = F.nll_loss(out[x], labels_coarse[x])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            return loss\n",
    "        now1 = datetime.now()\n",
    "        losses=[]\n",
    "        for epoch in range(100):\n",
    "            loss=train()\n",
    "            losses.append(loss)\n",
    "            if(epoch%100==0):\n",
    "                print(f'Epoch: {epoch:03d},loss: {loss:.4f}')\n",
    "        now2 = datetime.now()        \n",
    "        pred=model(torch.Tensor(Xt).to(device),edge_index_coarsen2).argmax(dim=1)        \n",
    "        def train_accuracy():\n",
    "            model.eval()\n",
    "            correct = (pred[x] == labels_coarse[x]).sum()\n",
    "            acc = int(correct) /len(x)\n",
    "            return acc\n",
    "    \n",
    "        t+=[(now2-now1).total_seconds()]\n",
    "\n",
    "        zz=sample(range(0, int(NO_OF_NODES)), NO_OF_NODES)\n",
    "        adj_ = adj.cpu().detach().numpy()\n",
    "        Wc=sparse.csr_matrix(adj_)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_coarsen).argmax(dim=1)\n",
    "        pred=np.array(pred)\n",
    "        correct =(pred[zz]==labels[zz]).sum()\n",
    "        acc = int(correct) /NO_OF_NODES\n",
    "        return acc\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "b30846ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accu_gat(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        model=GAT().to(device)\n",
    "        lr=0.01\n",
    "        decay=0.0001\n",
    "        features_= features.cpu().detach().numpy()\n",
    "        try:\n",
    "          X=np.array(features_.todense())\n",
    "        except:\n",
    "          X = np.array(features_)\n",
    "        #print(\"X:\",X.shape)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=decay)\n",
    "        # criterion=torch.nn.CrossEntropyLoss()\n",
    "        x=sample(range(0, int(k)), k)\n",
    "      \n",
    "        from datetime import datetime\n",
    "        Xt=P@X\n",
    "        # Xt=X_t_0\n",
    "        def train():\n",
    "            model.train()\n",
    "            optimizer.zero_grad()\n",
    "            out = model(torch.Tensor(Xt).to(device),edge_index_coarsen2)\n",
    "            loss = F.nll_loss(out[x], labels_coarse[x])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            return loss\n",
    "        now1 = datetime.now()\n",
    "        losses=[]\n",
    "        for epoch in range(100):\n",
    "            loss=train()\n",
    "            losses.append(loss)\n",
    "            if(epoch%100==0):\n",
    "                print(f'Epoch: {epoch:03d},loss: {loss:.4f}')\n",
    "        now2 = datetime.now()        \n",
    "        pred=model(torch.Tensor(Xt).to(device),edge_index_coarsen2).argmax(dim=1)        \n",
    "        def train_accuracy():\n",
    "            model.eval()\n",
    "            correct = (pred[x] == labels_coarse[x]).sum()\n",
    "            acc = int(correct) /len(x)\n",
    "            return acc\n",
    "    \n",
    "        t+=[(now2-now1).total_seconds()]\n",
    "\n",
    "        zz=sample(range(0, int(NO_OF_NODES)), NO_OF_NODES)\n",
    "        adj_ = adj.cpu().detach().numpy()\n",
    "        Wc=sparse.csr_matrix(adj_)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_coarsen).argmax(dim=1)\n",
    "        pred=np.array(pred)\n",
    "        correct =(pred[zz]==labels[zz]).sum()\n",
    "        acc = int(correct) /NO_OF_NODES\n",
    "        return acc\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1f724733",
   "metadata": {
    "id": "1f724733"
   },
   "outputs": [],
   "source": [
    "def experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A):\n",
    "      p = X.shape[0]\n",
    "      k = int(p*0.1)\n",
    "      n = X.shape[1]\n",
    "      ones = csr_matrix(np.ones((k,k)))\n",
    "      ones = convertScipyToTensor(ones)  \n",
    "      ones = ones.to_dense()\n",
    "      \n",
    "      try:\n",
    "        C = convertScipyToTensor(C)\n",
    "        C = C.to_dense()\n",
    "      except:\n",
    "        C=C\n",
    "      try:\n",
    "        theta = convertScipyToTensor(theta)\n",
    "      except:\n",
    "        theta = theta\n",
    "      try:\n",
    "        X = convertScipyToTensor(X)\n",
    "        X = X.to_dense()\n",
    "      except:\n",
    "        X = X\n",
    "      if(torch.cuda.is_available()):\n",
    "        print(\"GPU is available\")\n",
    "        C = C  \n",
    "        theta = theta  \n",
    "        X = X  \n",
    "        ones = ones  \n",
    "      \n",
    "        \n",
    "      def bracket_term2fun(C,CT,theta):\n",
    "          # U  = update_V(C,theta).double()\n",
    "          U = torch.stack(update_V(C, theta)).double()\n",
    "          UT= torch.transpose(U,0,1)\n",
    "          Lw = (CT @theta @C).double()\n",
    "          lb= 1e-5\n",
    "          ub = 1e+4\n",
    "          beta = 0.5 \n",
    "          lambda_ =  laplacian_lambda_update(lb, ub, beta, U, Lw, k_,C)   \n",
    "          lambda_matrix =  torch.diag(lambda_,0)  \n",
    "          # print(lambda_matrix)\n",
    "          # print(f'Shape of U is: {U.shape}')\n",
    "          # print(f'Shape of lambda: {}')\n",
    "          # print(f'Shape of lambda_matrix is: {lambda_matrix.shape}')\n",
    "          return UT@lambda_matrix@U\n",
    "        \n",
    "      def update_V(C,theta):\n",
    "            \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        product = CT @ A @ C               \n",
    "        matrix = torch.tensor(product)         \n",
    "        eigenvalues, eigenvectors = torch.linalg.eig(product)\n",
    "\n",
    "        # select non-zero eigenvalues and eigenvectors\n",
    "        non_zero_eigenvalues = []\n",
    "        non_zero_eigenvectors = []\n",
    "          \n",
    "        # for i in range(matrix.shape[0]):\n",
    "        #     if matrix[i, i] != 0:\n",
    "        #         non_zero_eigenvalues.append(eigenvalues[i])\n",
    "        #         non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        # U = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        # return U    \n",
    "\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if eigenvalues[i] != 0:\n",
    "                non_zero_eigenvalues.append(eigenvalues[i])\n",
    "                non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        return V \n",
    " \n",
    "\n",
    "      def update_C(C):\n",
    "          CT = torch.transpose(C,0,1)\n",
    "          C.size()\n",
    "          t1 = alpha_param*(C@ones)  \n",
    "          bracket_term1 = (CT@theta@C)\n",
    "          bracket_term3 = (CT@A@C)\n",
    "          bracket_term2 = bracket_term2fun(C,CT,theta) \n",
    "          bracket_term = bracket_term3 - bracket_term2             # bracket term (CT*A*C - U*lambda*UT)\n",
    "          t22 = -2*(theta@C)                                      # Check for multiplication of gamma\n",
    "#           print(t22.type())\n",
    "          t3 = bracket_term1\n",
    "          t7 = bracket_term2\n",
    "          t6 = (CT@A@C)  \n",
    "          t5 = 2* beta_param*(A@C)\n",
    "          t5 = t5.float()\n",
    "          t4 = (1.0/k)\n",
    "          t44 = t4*((torch.ones(k,k)).double())  \n",
    "#           print(t3.device)\n",
    "#           print(t44.device)\n",
    "          t8 = (t3 + t44)  \n",
    "          t9 = torch.pinverse(t8)                  \n",
    "          t9 = t9.float()\n",
    "#           print(t9.type())\n",
    "#           print(t9)x\n",
    "          t10 = (t22@t9)  \n",
    "          t11 = (t6 - t7)  \n",
    "          t11 = t11.float()\n",
    "          t12 = (t5@t11)\n",
    "          t13 = (t1 + t10 +t12)  \n",
    "        \n",
    "          #t2 = beta_param*(theta@C@bracket_term.float())\n",
    "          grad_fc= t13\n",
    "          C_new=C-gamma_param*grad_fc\n",
    "          C_new[C_new<thresh] = thresh\n",
    "          for i in range(len(C_new)):\n",
    "              C_new[i] = C_new[i]/torch.linalg.norm(C_new[i],1)\n",
    "          return C_new        \n",
    "            \n",
    "\n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "\n",
    "      #We set c1 = 10−5 and c2 = 10^4 We observed that the experimental performances of the algorithms \n",
    "       #are not sensitive to different values of c1 and c2 as long as they are reasonably small and large,respectively\n",
    "      # K is the number of smallest eigenvalues of the Laplacian matrix that are being ignored while updating the eigenvalues.\n",
    "      def laplacian_lambda_update(lb, ub, beta, U, Lw, k, C):\n",
    "        q = Lw.size(1) - k\n",
    "        # print(f'q is: {q}')\n",
    "        U = U\n",
    "        UT= torch.transpose(U,0,1)\n",
    "        UT = UT.type(torch.float64)\n",
    "        UT = UT\n",
    "        \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        CT = CT.type(torch.float64)\n",
    "        CT = CT\n",
    "        \n",
    "        AC=(A@C).double()\n",
    "        AC = AC\n",
    "        \n",
    "        Af=(CT@AC).double()\n",
    "        Af = Af  \n",
    "        Af.device\n",
    "        U.device\n",
    "        dd = U@Af@UT\n",
    "          \n",
    "        # cc = UT@A@U\n",
    "        \n",
    "        product = dd\n",
    "        matrix = torch.tensor(product)     \n",
    "\n",
    "        non_zero_diag_elements = []\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if matrix[i, i] != 0:\n",
    "                non_zero_diag_elements.append(matrix[i, i])\n",
    "            if len(non_zero_diag_elements) == len(matrix):\n",
    "                break\n",
    "\n",
    "        k = len(non_zero_diag_elements)\n",
    "        e = non_zero_diag_elements\n",
    "        d = torch.diag(torch.tensor(non_zero_diag_elements))\n",
    "#-----------------------------------------------------------------------------------------------------------------------------------------------\n",
    "\n",
    "       # Trial-2                 -########################################\n",
    "\n",
    "        e_bar = torch.tensor([])\n",
    "        if(k%2 == 0):\n",
    "            for i in range(k//2):\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)\n",
    "            \n",
    "        if(k%2 != 0):\n",
    "            for i in range((k+1)//2) :\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)       \n",
    "                \n",
    "        lambda_,indices = torch.sort(e_bar, dim=- 1, descending=True)\n",
    "        eps = 1\n",
    "        qq = lambda_.size(0)-1\n",
    "        condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "\n",
    "#                                   (lambda_[1:(q)] - lambda_[0:(q-1)]) >= -eps])\n",
    "        \n",
    "          \n",
    "        if condition.all():\n",
    "            # while(lambda_.size(0) != 135):\n",
    "            #     lambda_ = torch.cat((lambda_, torch.tensor(0).unsqueeze(0)), dim=0)\n",
    "            for i in range(k//2):\n",
    "                lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)\n",
    "            # print(f'Shape of updated lambda1_ is: {lambda_.shape}')\n",
    "            # hm= sns.heatmap(data =lambda_)\n",
    "            # plt.show()\n",
    "            # print(lambda_)\n",
    "            return lambda_\n",
    "        else:\n",
    "            greater_ub = lambda_ > ub\n",
    "            lesser_lb = lambda_ < lb\n",
    "            lambda_[greater_ub] = ub\n",
    "            lambda_[lesser_lb] = lb\n",
    "            condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "        for i in range(k//2):\n",
    "            lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)            \n",
    "            \n",
    "\n",
    "        print(f'Shape of updated lambda2_ is: {lambda_.shape}')\n",
    "        if condition.all():\n",
    "            return lambda_\n",
    "        else:\n",
    "#           print(lambda_)\n",
    "            raise ValueError(\"eigenvalues are not in increasing order, consider increasing the value of beta\")\n",
    "\n",
    "      for i in tqdm(range(10)): #update C only 21\n",
    "         C = update_C(C)\n",
    "            \n",
    "      return C\n",
    "          "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "556afd48",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "556afd48",
    "outputId": "7f0b9b03-7a98-4a01-ac78-fc754863ff46"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/10 [00:00<?, ?it/s]C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_28868\\1999241371.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_28868\\1999241371.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_28868\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:53<00:00, 17.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Accuracy = 0.4470535109505532 1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:51<00:00, 17.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:51<00:00, 17.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:51<00:00, 17.20s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:18<00:00, 25.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:23<00:00, 26.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:12<00:00, 25.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:31<00:00, 27.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:52<00:00, 23.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:23<00:00, 26.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:04<00:00, 24.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:23<00:00, 26.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:49<00:00, 22.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:26<00:00, 26.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:38<00:00, 27.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:17<00:00, 25.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:21<00:00, 26.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:31<00:00, 27.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:15<00:00, 25.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:08<00:00, 24.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:58<00:00, 23.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:00<00:00, 24.03s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:10<00:00, 25.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:05<00:00, 24.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:47<00:00, 22.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:46<00:00, 22.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:31<00:00, 27.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:21<00:00, 32.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:28<00:00, 32.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:22<00:00, 32.30s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:23<00:00, 32.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:08<00:00, 30.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:02<00:00, 30.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:07<00:00, 30.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:29<00:00, 32.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:21<00:00, 32.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:16<00:00, 31.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:35<00:00, 27.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:02<00:00, 30.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:25<00:00, 32.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:44<00:00, 28.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:07<00:00, 30.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:58<00:00, 29.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:13<00:00, 31.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:06<00:00, 30.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:36<00:00, 33.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:58<00:00, 29.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "Accuracy = 0.5717430571235042 1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:20<00:00, 32.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "Average accuracy = 54.278618198238874 +/- 2.895687514111539\n",
      "Params =  1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:23<00:00, 32.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:08<00:00, 30.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:10<00:00, 31.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:23<00:00, 38.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:44<00:00, 34.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:50<00:00, 29.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:43<00:00, 34.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:47<00:00, 34.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:21<00:00, 32.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:14<00:00, 31.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:00<00:00, 30.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:04<00:00, 30.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:16<00:00, 25.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:38<00:00, 27.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:56<00:00, 29.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3866\n",
      "Accuracy = 0.7908105667193498 1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:02<00:00, 24.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3875\n",
      "Accuracy = 0.7997855046285843 1000 1 0.0001\n",
      "Average accuracy = 79.52980356739671 +/- 0.44874689546172686\n",
      "Params =  1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:09<00:00, 36.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:37<00:00, 33.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:06<00:00, 36.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:20<00:00, 32.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:23<00:00, 32.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:34<00:00, 33.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:38<00:00, 33.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:18<00:00, 31.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:58<00:00, 35.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:48<00:00, 28.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:42<00:00, 28.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:12<00:00, 31.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:37<00:00, 39.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:46<00:00, 28.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:46<00:00, 28.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3854\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:39<00:00, 27.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3876\n",
      "Average accuracy = 79.30966358094378 +/- 0.025400767667649315\n",
      "Params =  1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:28<00:00, 26.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:48<00:00, 34.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:09<00:00, 30.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:48<00:00, 28.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:45<00:00, 28.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:24<00:00, 38.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:15<00:00, 37.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:29<00:00, 32.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:09<00:00, 36.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:32<00:00, 33.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:11<00:00, 25.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:56<00:00, 29.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:08<00:00, 30.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:39<00:00, 27.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "Average accuracy = 44.70817340257395 +/- 0.0028223075186267765\n",
      "Params =  1000 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:46<00:00, 28.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3845\n",
      "Accuracy = 0.8075750733799955 1000 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:08<00:00, 24.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3935\n",
      "Average accuracy = 79.91645969744863 +/- 0.8410476405509126\n",
      "Params =  1000 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:57<00:00, 29.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:29<00:00, 32.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:50<00:00, 29.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:59<00:00, 29.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:31<00:00, 33.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:50<00:00, 35.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:49<00:00, 28.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:05<00:00, 30.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:25<00:00, 32.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:16<00:00, 31.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:49<00:00, 28.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:19<00:00, 25.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:53<00:00, 35.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:13<00:00, 43.30s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.77873109053962 +/- 0.045156920298033976\n",
      "Params =  1000 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:26<00:00, 38.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3896\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:56<00:00, 29.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3853\n",
      "Average accuracy = 79.24475050801536 +/- 0.32174305712350804\n",
      "Params =  1000 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:17<00:00, 31.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:21<00:00, 26.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:27<00:00, 32.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:52<00:00, 29.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:09<00:00, 30.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:42<00:00, 34.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:40<00:00, 34.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:12<00:00, 31.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:27<00:00, 32.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:03<00:00, 30.37s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  1000 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:34<00:00, 33.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:57<00:00, 29.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "Average accuracy = 44.70817340257395 +/- 0.0028223075186267765\n",
      "Params =  1000 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:28<00:00, 26.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:11<00:00, 31.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.713818017611196 +/- 0.00846692255588033\n",
      "Params =  1000 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:23<00:00, 32.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:08<00:00, 24.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3896\n",
      "Average accuracy = 79.08952359449086 +/- 0.3302099796793856\n",
      "Params =  1000 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:18<00:00, 31.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [06:18<00:00, 37.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:24<00:00, 44.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:13<00:00, 19.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:16<00:00, 19.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:17<00:00, 19.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:05<00:00, 30.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [07:08<00:00, 42.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:52<00:00, 35.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:07<00:00, 24.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:07<00:00, 18.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:10<00:00, 19.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:08<00:00, 18.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:08<00:00, 18.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:01<00:00, 18.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 17.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:50<00:00, 17.03s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:50<00:00, 17.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 16.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 16.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 16.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:50<00:00, 17.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 16.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:51<00:00, 17.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 16.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:50<00:00, 17.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:49<00:00, 16.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:51<00:00, 17.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:01<00:00, 18.20s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:59<00:00, 17.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:03<00:00, 18.37s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:53<00:00, 17.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:33<00:00, 15.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3865\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:34<00:00, 15.47s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "Average accuracy = 44.70817340257395 +/- 0.0028223075186267765\n",
      "Params =  100 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [03:47<00:00, 22.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:46<00:00, 28.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.78155339805826 +/- 0.01975615263039021\n",
      "Params =  100 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:25<00:00, 26.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:50<00:00, 29.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3861\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:27<00:00, 32.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:34<00:00, 27.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:59<00:00, 29.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:06<00:00, 30.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:48<00:00, 28.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:56<00:00, 29.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:56<00:00, 29.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:20<00:00, 32.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.71946263264846 +/- 0.0028223075186267765\n",
      "Params =  100 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:54<00:00, 29.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:28<00:00, 32.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "Average accuracy = 44.76744186046512 +/- 0.011289230074509882\n",
      "Params =  100 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:53<00:00, 29.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:01<00:00, 30.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.71099571009257 +/- 0.005644615037253553\n",
      "Params =  100 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:19<00:00, 31.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:09<00:00, 30.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:03<00:00, 30.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:02<00:00, 30.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:45<00:00, 28.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:00<00:00, 30.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "Average accuracy = 44.72228494016708 +/- 0.02822307518627054\n",
      "Params =  100 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:17<00:00, 31.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:16<00:00, 31.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:48<00:00, 28.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:45<00:00, 28.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:22<00:00, 26.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3871\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:47<00:00, 28.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3869\n",
      "Average accuracy = 60.383269361029576 +/- 3.237186723865432\n",
      "Params =  100 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:22<00:00, 26.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3947\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:01<00:00, 24.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3871\n",
      "Accuracy = 0.8089862271393091 100 1 0.0001\n",
      "Average accuracy = 79.97855046285844 +/- 0.920072251072479\n",
      "Params =  100 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:48<00:00, 28.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:03<00:00, 30.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:12<00:00, 31.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:55<00:00, 29.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.88597877624746 +/- 0.1636938360803808\n",
      "Params =  100 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:47<00:00, 28.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:38<00:00, 27.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:18<00:00, 31.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:22<00:00, 32.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3863\n",
      "Average accuracy = 44.615037254459246 +/- 0.022578460149016988\n",
      "Params =  100 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:10<00:00, 31.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:13<00:00, 31.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "Average accuracy = 44.70535109505532 +/- 0.0\n",
      "Params =  100 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:48<00:00, 28.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3856\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:09<00:00, 30.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3861\n",
      "Average accuracy = 45.298035673967036 +/- 0.5926845789117174\n",
      "Params =  100 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:26<00:00, 26.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3897\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:44<00:00, 28.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3860\n",
      "Accuracy = 0.8136712576202303 100 0.1 0.001\n",
      "Average accuracy = 80.79984195077895 +/- 0.5672838112440737\n",
      "Params =  100 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:38<00:00, 27.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3809\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:32<00:00, 27.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3747\n",
      "Average accuracy = 58.16493565138858 +/- 11.794423120343195\n",
      "Params =  100 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:51<00:00, 29.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3864\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [04:17<00:00, 25.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3862\n",
      "Average accuracy = 44.92549108150824 +/- 0.22013998645292465\n",
      "Params =  100 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [05:47<00:00, 34.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3866\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 70%|██████████████████████████████████████████████████████████                         | 7/10 [03:21<01:26, 28.76s/it]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[39], line 19\u001b[0m\n\u001b[0;32m     17\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m _ \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m1\u001b[39m):\n\u001b[0;32m     18\u001b[0m   C \u001b[38;5;241m=\u001b[39m random(p, k, density\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0.15\u001b[39m, random_state\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1\u001b[39m, data_rvs\u001b[38;5;241m=\u001b[39mtemp2\u001b[38;5;241m.\u001b[39mrvs)\n\u001b[1;32m---> 19\u001b[0m   C_0 \u001b[38;5;241m=\u001b[39m \u001b[43mexperiment_structure\u001b[49m\u001b[43m(\u001b[49m\u001b[43malpha_param\u001b[49m\u001b[43m,\u001b[49m\u001b[43mlambda_param\u001b[49m\u001b[43m,\u001b[49m\u001b[43mbeta_param\u001b[49m\u001b[43m,\u001b[49m\u001b[43mgamma_param\u001b[49m\u001b[43m,\u001b[49m\u001b[43mC\u001b[49m\u001b[43m,\u001b[49m\u001b[43mtheta\u001b[49m\u001b[43m,\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43mA\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     20\u001b[0m   C_t_0 \u001b[38;5;241m=\u001b[39m C_0\u001b[38;5;241m.\u001b[39mT\n\u001b[0;32m     21\u001b[0m   L \u001b[38;5;241m=\u001b[39m theta\n",
      "Cell \u001b[1;32mIn[34], line 207\u001b[0m, in \u001b[0;36mexperiment_structure\u001b[1;34m(alpha_param, lambda_param, beta_param, gamma_param, C, theta, X, A)\u001b[0m\n\u001b[0;32m    204\u001b[0m       \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124meigenvalues are not in increasing order, consider increasing the value of beta\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m    206\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m tqdm(\u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m10\u001b[39m)): \u001b[38;5;66;03m#update C only 21\u001b[39;00m\n\u001b[1;32m--> 207\u001b[0m    C \u001b[38;5;241m=\u001b[39m \u001b[43mupdate_C\u001b[49m\u001b[43m(\u001b[49m\u001b[43mC\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    209\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m C\n",
      "Cell \u001b[1;32mIn[34], line 79\u001b[0m, in \u001b[0;36mexperiment_structure.<locals>.update_C\u001b[1;34m(C)\u001b[0m\n\u001b[0;32m     77\u001b[0m bracket_term1 \u001b[38;5;241m=\u001b[39m (CT\u001b[38;5;129m@theta\u001b[39m\u001b[38;5;129m@C\u001b[39m)\n\u001b[0;32m     78\u001b[0m bracket_term3 \u001b[38;5;241m=\u001b[39m (CT\u001b[38;5;129m@A\u001b[39m\u001b[38;5;129m@C\u001b[39m)\n\u001b[1;32m---> 79\u001b[0m bracket_term2 \u001b[38;5;241m=\u001b[39m \u001b[43mbracket_term2fun\u001b[49m\u001b[43m(\u001b[49m\u001b[43mC\u001b[49m\u001b[43m,\u001b[49m\u001b[43mCT\u001b[49m\u001b[43m,\u001b[49m\u001b[43mtheta\u001b[49m\u001b[43m)\u001b[49m \n\u001b[0;32m     80\u001b[0m bracket_term \u001b[38;5;241m=\u001b[39m bracket_term3 \u001b[38;5;241m-\u001b[39m bracket_term2             \u001b[38;5;66;03m# bracket term (CT*A*C - U*lambda*UT)\u001b[39;00m\n\u001b[0;32m     81\u001b[0m t22 \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m2\u001b[39m\u001b[38;5;241m*\u001b[39m(theta\u001b[38;5;129m@C\u001b[39m)                                      \u001b[38;5;66;03m# Check for multiplication of gamma\u001b[39;00m\n",
      "Cell \u001b[1;32mIn[34], line 31\u001b[0m, in \u001b[0;36mexperiment_structure.<locals>.bracket_term2fun\u001b[1;34m(C, CT, theta)\u001b[0m\n\u001b[0;32m     27\u001b[0m   X \u001b[38;5;241m=\u001b[39m X  \n\u001b[0;32m     28\u001b[0m   ones \u001b[38;5;241m=\u001b[39m ones  \n\u001b[1;32m---> 31\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mbracket_term2fun\u001b[39m(C,CT,theta):\n\u001b[0;32m     32\u001b[0m     \u001b[38;5;66;03m# U  = update_V(C,theta).double()\u001b[39;00m\n\u001b[0;32m     33\u001b[0m     U \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mstack(update_V(C, theta))\u001b[38;5;241m.\u001b[39mdouble()\n\u001b[0;32m     34\u001b[0m     UT\u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mtranspose(U,\u001b[38;5;241m0\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n",
      "\u001b[1;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "#RUN FROM alpha 10 ......11sep_6pm\n",
    "for alpha_param in [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.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              acc = get_accu(C_test,L_test,X_t_test)\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "pqDLVv1Wn9RD",
   "metadata": {
    "id": "pqDLVv1Wn9RD"
   },
   "outputs": [],
   "source": [
    "highest_accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "e8fe6add",
   "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_44964\\1999241371.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_44964\\1999241371.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_44964\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:18<00:00, 13.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3919\n",
      "Accuracy = 0.815195303680289 100 0.1 0.001\n",
      "Average accuracy = 81.51953036802891 +/- 0.0\n",
      "Params =  100 0.1 0.001\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [100]:\n",
    "  for beta_param in [0.1]:\n",
    "      for gamma_param in [0.001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(1):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              acc = get_accu(C_test,L_test,X_t_test)\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "ac5efdbc",
   "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_44964\\1999241371.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_44964\\1999241371.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_44964\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [01:54<00:00, 11.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3860\n",
      "Accuracy = 0.7695303680289004 100 0.1 0.001\n",
      "Average accuracy = 76.95303680289004 +/- 0.0\n",
      "Params =  100 0.1 0.001\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [100]:\n",
    "  for beta_param in [0.1]:\n",
    "      for gamma_param in [0.001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(1):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              acc = get_accu_gat(C_test,L_test,X_t_test)\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "7b26c255",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.nn import Linear\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.nn import APPNP\n",
    "\n",
    "class APPNPNet(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(APPNPNet, self).__init__()\n",
    "        self.lin1 = Linear(X.shape[1], 128)\n",
    "        self.lin2 = Linear(128,NO_OF_CLASSES)\n",
    "        self.prop1 = APPNP(16, 0.1)\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.lin1.reset_parameters()\n",
    "        self.lin2.reset_parameters()\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = F.relu(self.lin1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.lin2(x)\n",
    "        x = self.prop1(x, edge_index)\n",
    "\n",
    "        return F.log_softmax(x, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "a9ed98ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accu_app(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "        model=APPNPNet().to(device)\n",
    "        lr=0.01\n",
    "        decay=0.0001\n",
    "        features_= features.cpu().detach().numpy()\n",
    "        try:\n",
    "          X=np.array(features_.todense())\n",
    "        except:\n",
    "          X = np.array(features_)\n",
    "        #print(\"X:\",X.shape)\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=decay)\n",
    "        # criterion=torch.nn.CrossEntropyLoss()\n",
    "        x=sample(range(0, int(k)), k)\n",
    "      \n",
    "        from datetime import datetime\n",
    "        Xt=P@X\n",
    "        # Xt=X_t_0\n",
    "        def train():\n",
    "            model.train()\n",
    "            optimizer.zero_grad()\n",
    "            out = model(torch.Tensor(Xt).to(device),edge_index_coarsen2)\n",
    "            loss = F.nll_loss(out[x], labels_coarse[x])\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            return loss\n",
    "        now1 = datetime.now()\n",
    "        losses=[]\n",
    "        for epoch in range(100):\n",
    "            loss=train()\n",
    "            losses.append(loss)\n",
    "            if(epoch%100==0):\n",
    "                print(f'Epoch: {epoch:03d},loss: {loss:.4f}')\n",
    "        now2 = datetime.now()        \n",
    "        pred=model(torch.Tensor(Xt).to(device),edge_index_coarsen2).argmax(dim=1)        \n",
    "        def train_accuracy():\n",
    "            model.eval()\n",
    "            correct = (pred[x] == labels_coarse[x]).sum()\n",
    "            acc = int(correct) /len(x)\n",
    "            return acc\n",
    "    \n",
    "        t+=[(now2-now1).total_seconds()]\n",
    "\n",
    "        zz=sample(range(0, int(NO_OF_NODES)), NO_OF_NODES)\n",
    "        adj_ = adj.cpu().detach().numpy()\n",
    "        Wc=sparse.csr_matrix(adj_)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_coarsen).argmax(dim=1)\n",
    "        pred=np.array(pred)\n",
    "        correct =(pred[zz]==labels[zz]).sum()\n",
    "        acc = int(correct) /NO_OF_NODES\n",
    "        return acc\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "0421339d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3848\n"
     ]
    }
   ],
   "source": [
    "acc = get_accu_app(C_test,L_test,X_t_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "55c2278a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8090426732896816\n"
     ]
    }
   ],
   "source": [
    "print(acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "17a821a3",
   "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_44964\\1999241371.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_44964\\1999241371.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_44964\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:39<00:00, 15.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.4007\n",
      "Accuracy = 0.7803115827500564 100 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [02:31<00:00, 15.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.3947\n",
      "Accuracy = 0.7981485662677805 100 0.1 0.001\n",
      "Average accuracy = 78.92300745089184 +/- 0.8918491758862057\n",
      "Params =  100 0.1 0.001\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [100]:\n",
    "  for beta_param in [0.1]:\n",
    "      for gamma_param in [0.001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(2):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "              C_t_0 = C_0.T\n",
    "              L = theta\n",
    "              pseudo_C = torch.linalg.pinv(C_0)\n",
    "              X_t_0 = pseudo_C@X\n",
    "              C_test = C_0.cpu().detach().numpy()\n",
    "              X_t_test = X_t_0.cpu().detach().numpy()\n",
    "              L_test = L.cpu().detach().numpy() \n",
    "              acc = get_accu_app(C_test,L_test,X_t_test)\n",
    "              av.append(acc)\n",
    "              if highest_accuracy<acc:\n",
    "                highest_accuracy=acc\n",
    "                print(\"Accuracy = \" + str(acc) + \" \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))\n",
    "        print(\"Average accuracy = \" + str(np.mean(av)*100)  + \" +/- \" + str(np.std(av)*100))\n",
    "        print(\"Params =  \" + str(alpha_param)+\" \" + str(beta_param)+\" \"+str(gamma_param))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0028407",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "FN7Cp3UQoMKv",
   "metadata": {
    "id": "FN7Cp3UQoMKv"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvgAAAK9CAYAAABRtxg8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABFdElEQVR4nO3de5hVZdk4/nsGYUZEPISAEIriuRQUhNAUzVFM1HjLRDtwyBRNPFEepgzE06QmooLHQrTkK2oek0jF0FejVJQ3pRw0QXqVQdEARQVl9u8Pf87rxLgcxmGvWYvP57r2dTGLtddz7z37WnOve9/Ps0oKhUIhAACAXChNOwAAAKD5SPABACBHJPgAAJAjEnwAAMgRCT4AAOSIBB8AAHJEgg8AADkiwQcAgByR4AMAQI5I8IHc+fDDD+Oss86Kbt26RWlpaQwePDjtkD7TAQccEAcccECTnjt8+PDo3r17s8bzn6ZMmRIlJSWxcOHCxP3OO++8KCkpadIY3bt3j8MPP7xJz/00JSUlcd555zXrMQFaOgk+tCAfJ1FPP/10g/9/wAEHxJe//OX1GsP06dMznxBNnjw5LrvssjjqqKPi5ptvjjPOOCPtkACgaDZKOwCgZZk+fXpMmjQp00n+I488El27do0rrrgi7VAa7cEHH2zyc2+88caora1txmgAyDIVfCB3Xn/99dh8882b7Xi1tbXx/vvvN9vxPundd9+NiIg2bdpEmzZtmnSM1q1bR1lZWXOGBUCGSfAhB377299G7969Y+ONN44tt9wyjjnmmPjXv/5Vb5///u//jm9/+9uxzTbbRFlZWXTr1i3OOOOMeO+99+r2GT58eEyaNCkiPupd/vgREbFw4cIoKSmJX/7ylzFp0qTYfvvto23btnHIIYfEv/71rygUCnHBBRfEF7/4xdh4443jG9/4Rrz11lv1Yrj33ntj0KBB0aVLlygrK4sePXrEBRdcEGvWrKm338etSHPmzIl99tknNt5449huu+3iuuuuS3wfPo7xT3/6U8ybN68u/lmzZkVExMqVK+PHP/5xdOvWLcrKymLnnXeOX/7yl1EoFOodp6SkJEaNGhW33nprfOlLX4qysrKYMWNG4tjXXHNN3b5dunSJk08+OZYtW/apr2v//fePtm3bxk9/+tO6//vPHvxXXnkljjzyyNhkk02iY8eOccYZZ8Qf//jHeq8pYu0e/E/+rm644Ybo0aNHlJWVxd577x1PPfVUvTH+9re/xfDhw2P77beP8vLy6Ny5c/zgBz+IN998M/H1roubbropvva1r0XHjh2jrKwsdtttt7j22ms/df8HH3wwevXqFeXl5bHbbrvFXXfdtdY+y5Yti9NPP73ud7nDDjvEJZdc8pnfZLz99ttx+umnR/fu3aOsrCw6duwYBx98cDzzzDOf+3UCtBRadKAFWr58eSxdunSt7R988MFa2y666KL4+c9/HkcffXT88Ic/jDfeeCOuvvrq2H///ePZZ5+tq2Tfcccd8e6778ZJJ50UX/jCF+LJJ5+Mq6++Ov73f/837rjjjoiIGDlyZLz22mvx0EMPxW9+85sGY7v11ltj9erVccopp8Rbb70Vl156aRx99NHxta99LWbNmhVnn312vPTSS3H11VfHT37yk5g8eXLdc6dMmRLt2rWL0aNHR7t27eKRRx6JMWPGxIoVK+Kyyy6rN86///3vOOyww+Loo4+OY489Nm6//fY46aSTok2bNvGDH/ygwdi22mqr+M1vfhMXXXRRvPPOO1FVVRUREbvuumsUCoU48sgj409/+lMcd9xx0atXr/jjH/8YZ555Zrz66qtrtfM88sgjcfvtt8eoUaOiQ4cOiZNYzzvvvBg3blxUVFTESSedFNXV1XHttdfGU089FU888US0bt26bt8333wzvv71r8cxxxwT3/ve96JTp04NHnPlypXxta99LRYvXhynnXZadO7cOaZOnRp/+tOfPjWO/zR16tR4++23Y+TIkVFSUhKXXnppfPOb34yXX365LqaHHnooXn755RgxYkR07tw55s2bFzfccEPMmzcv/vKXvzR5wuwnXXvttfGlL30pjjzyyNhoo43i/vvvjx/96EdRW1sbJ598cr19X3zxxRgyZEiceOKJMWzYsLjpppvi29/+dsyYMSMOPvjgiPjoW48BAwbEq6++GiNHjoxtttkm/vznP0dlZWUsXrw4JkyY8KmxnHjiiXHnnXfGqFGjYrfddos333wzHn/88fjHP/4Re+211+d+rQAtQgFoMW666aZCRCQ+vvSlL9Xtv3DhwkKrVq0KF110Ub3jPPfcc4WNNtqo3vZ33313rfGqqqoKJSUlhVdeeaVu28knn1xo6NSwYMGCQkQUttpqq8KyZcvqtldWVhYiotCzZ8/CBx98ULf92GOPLbRp06bw/vvvJ8YwcuTIQtu2bevtN2DAgEJEFC6//PK6batWrSr06tWr0LFjx8Lq1avXfvM+YcCAAfXep0KhULjnnnsKEVG48MIL620/6qijCiUlJYWXXnqpbltEFEpLSwvz5s1LHKdQKBRef/31Qps2bQqHHHJIYc2aNXXbJ06cWIiIwuTJk9d6Xdddd12DMQ8YMKDu58svv7wQEYV77rmnbtt7771X2GWXXQoRUfjTn/5Ut33YsGGFbbfdtu7nj39XX/jCFwpvvfVW3fZ77723EBGF+++/v25bQ7+T//f//l8hIgqPPfZY3baPP5sLFixIfD/Gjh271uenoTEGDhxY2H777ett23bbbQsRUfjd735Xt2358uWFrbfeurDnnnvWbbvgggsKm2yySWH+/Pn1nn/OOecUWrVqVVi0aFHdtogojB07tu7nzTbbrHDyyScnvgaArNOiAy3QpEmT4qGHHlrrsccee9Tb76677ora2to4+uijY+nSpXWPzp07x4477liv2rvxxhvX/XvlypWxdOnS2GeffaJQKMSzzz7b6Ni+/e1vx2abbVb3c79+/SIi4nvf+15stNFG9bavXr06Xn311QZjePvtt2Pp0qWx3377xbvvvhsvvPBCvXE22mijGDlyZN3Pbdq0iZEjR8brr78ec+bMaXS8H5s+fXq0atUqTj311Hrbf/zjH0ehUIg//OEP9bYPGDAgdtttt8887sMPPxyrV6+O008/PUpL/++Uevzxx0f79u3jgQceqLd/WVlZjBgx4jOPO2PGjOjatWsceeSRddvKy8vj+OOP/8znfmzIkCGxxRZb1P283377RUTEyy+/XLftk7+T999/P5YuXRpf+cpXIiKarW3lk2N8/O3UgAED4uWXX47ly5fX27dLly7xX//1X3U/t2/fPoYOHRrPPvts1NTURMRH30btt99+scUWW9T73FdUVMSaNWviscce+9RYNt988/jrX/8ar732WrO8NoCWSIsOtEB9+/aNPn36rLX944TmYy+++GIUCoXYcccdGzzOJ1tDFi1aFGPGjIn77rsv/v3vf9fb7z+TrCTbbLNNvZ8/Tva7devW4PZPjjVv3rw499xz45FHHokVK1YkxtClS5fYZJNN6m3baaedIuKjHvOPk9DGeuWVV6JLly6x6aab1tu+66671v3/J2233XaNPm5ExM4771xve5s2bWL77bdf67hdu3Zt1GTaV155JXr06LFWi8wOO+zQqLgi1v5dfZzsf/J38tZbb8W4cePitttui9dff73e/uvyuUjyxBNPxNixY2P27Nl1k4o/OcYnLxh32GGHtV7zJ3/vnTt3jhdffDH+9re/xVZbbdXgeP/5Oj7p0ksvjWHDhkW3bt2id+/ecdhhh8XQoUNj++23b+rLA2hxJPiQYbW1tVFSUhJ/+MMfolWrVmv9f7t27SIiYs2aNXHwwQfHW2+9FWeffXbssssusckmm8Srr74aw4cPX6clFhsaJ2l74f+fwLps2bIYMGBAtG/fPs4///zo0aNHlJeXxzPPPBNnn312i1vm8ZNV5ywctyGf9TuJiDj66KPjz3/+c5x55pnRq1evaNeuXdTW1sahhx7aLL+Tf/7zn3HQQQfFLrvsEuPHj49u3bpFmzZtYvr06XHFFVc0aYza2to4+OCD46yzzmrw/z++IGjI0UcfHfvtt1/cfffd8eCDD8Zll10Wl1xySdx1113x9a9/fZ1jAWiJJPiQYT169IhCoRDbbbddYlLz3HPPxfz58+Pmm2+OoUOH1m1/6KGH1tq3OSZVNmTWrFnx5ptvxl133RX7779/3fYFCxY0uP9rr70WK1eurFfFnz9/fkREk+7auu2228bDDz8cb7/9dr0q/setQdtuu+06H/OTz6uurq5XBV69enUsWLAgKioqmnzcv//971EoFOr9Tl566aUmHa8h//73v2PmzJkxbty4GDNmTN32F198sdnGuP/++2PVqlVx33331ftG4dMmC7/00ktrveb//L336NEj3nnnnSa/t1tvvXX86Ec/ih/96Efx+uuvx1577RUXXXSRBB/IDT34kGHf/OY3o1WrVjFu3Li1lnosFAp1Sx1+XMn95D6FQiGuvPLKtY75cUL9n0s8fl4NxbB69eq45pprGtz/ww8/jOuvv77evtdff31stdVW0bt373Ue/7DDDos1a9bExIkT622/4ooroqSkpMnJXUVFRbRp0yauuuqqeq/t17/+dSxfvjwGDRrUpOMOHDgwXn311bjvvvvqtr3//vtx4403Nul4DWnodxIRiavQNMcYy5cvj5tuuqnB/V977bW4++67635esWJF3HLLLdGrV6/o3LlzRHxUhZ89e3b88Y9/XOv5y5Ytiw8//LDBY69Zs2attqOOHTtGly5dYtWqVev2wgBaMBV8yLAePXrEhRdeGJWVlbFw4cIYPHhwbLrpprFgwYK4++6744QTToif/OQnscsuu0SPHj3iJz/5Sbz66qvRvn37+N3vfrdWL35E1CXPp556agwcODBatWoVxxxzzOeOdZ999oktttgihg0bFqeeemqUlJTEb37zm7WSy4916dIlLrnkkli4cGHstNNOMW3atJg7d27ccMMN9eYWNNYRRxwRBx54YPzsZz+LhQsXRs+ePePBBx+Me++9N04//fTo0aNHk17XVlttFZWVlTFu3Lg49NBD48gjj4zq6uq45pprYu+9947vfe97TTruyJEjY+LEiXHsscfGaaedFltvvXXceuutUV5eHhHN801L+/btY//9949LL700Pvjgg+jatWs8+OCDn/qtSlMccsgh0aZNmzjiiCNi5MiR8c4778SNN94YHTt2jMWLF6+1/0477RTHHXdcPPXUU9GpU6eYPHlyLFmypN4FwZlnnhn33XdfHH744TF8+PDo3bt3rFy5Mp577rm48847Y+HChdGhQ4e1jv3222/HF7/4xTjqqKOiZ8+e0a5du3j44Yfjqaeeissvv7zZXjNA2iT4kHHnnHNO7LTTTnHFFVfEuHHjIuKjCa+HHHJI3QosrVu3jvvvvz9OPfXUqKqqivLy8viv//qvGDVqVPTs2bPe8b75zW/GKaecErfddlv89re/jUKh0CwJ/he+8IX4/e9/Hz/+8Y/j3HPPjS222CK+973vxUEHHRQDBw5ca/8tttgibr755jjllFPixhtvjE6dOsXEiRPXaRWZTyotLY377rsvxowZE9OmTYubbropunfvHpdddln8+Mc//lyv7bzzzoutttoqJk6cGGeccUZsueWWccIJJ8TFF1/cpIuRiKi7T8App5wSV155ZbRr1y6GDh0a++yzT3zrW9+qS/Q/r6lTp8Ypp5wSkyZNikKhEIccckj84Q9/iC5dujTL8Xfeeee4884749xzz42f/OQn0blz5zjppJNiq622avB+BjvuuGNcffXVceaZZ0Z1dXVst912MW3atHqfkbZt28ajjz4aF198cdxxxx1xyy23RPv27WOnnXaKcePG1Zu0+0lt27aNH/3oR/Hggw/WrUC1ww47xDXXXBMnnXRSs7xegJagpPBp5TOAlBxwwAGxdOnSeP7559MOpcWZMGFCnHHGGfG///u/0bVr17TDAaAF0oMP0EK999579X5+//334/rrr48dd9xRcg/Ap9KiA9BCffOb34xtttkmevXqFcuXL4/f/va38cILL8Stt96admgAtGASfIAWauDAgfGrX/0qbr311lizZk3stttucdttt8WQIUPSDg2AFkwPPgAArAePPfZYXHbZZTFnzpxYvHhx3H333TF48ODE58yaNStGjx4d8+bNi27dusW5554bw4cPX6dx9eADAMB6sHLlyujZs2dMmjSpUfsvWLAgBg0aFAceeGDMnTs3Tj/99PjhD3/Y4H0/kqjgAwDAelZSUvKZFfyzzz47HnjggXqryB1zzDGxbNmymDFjRqPHUsEHAIBGWrVqVaxYsaLeo7nuhj179uyoqKiot23gwIExe/bsdTpOapNsH2i9c1pDs4GpOvSGtEMAgEx6/P4BaYfQoDTzyKd+dmzdjSU/Nnbs2DjvvPM+97FramqiU6dO9bZ16tQpVqxYEe+9915svPHGjTqOVXQAAKCRKisrY/To0fW2lZWVpRRNwyT4AABkSknrktTGLisrW28JfefOnWPJkiX1ti1ZsiTat2/f6Op9RIoJvrYJiqVyxglph8AGwnkNgM+jf//+MX369HrbHnrooejfv/86HSe1BF/SRbFIugCANLzzzjvx0ksv1f28YMGCmDt3bmy55ZaxzTbbRGVlZbz66qtxyy23RETEiSeeGBMnToyzzjorfvCDH8QjjzwSt99+ezzwwAPrNK4WHQAAMqV0o/RadNbF008/HQceeGDdzx/37g8bNiymTJkSixcvjkWLFtX9/3bbbRcPPPBAnHHGGXHllVfGF7/4xfjVr34VAwcOXKdxJfgAALAeHHDAAZF0y6kpU6Y0+Jxnn332c40rwQcAIFNKWruVUxLvDgAA5IgKPgAAmZKVHvy0qOADAECOSPABACBHtOgAAJApad7JNgtU8AEAIEdU8AEAyBSTbJOlluBXHXpDWkMDQKZVzjgh7RDYYFSnHQBNUFJIur3WevRA653TGJYNkItJAGiax+8fkHYIDXqk+x6pjf21hX9LbezGUsEHgIxRwad4WmYF3yTbZHrwAZqJpItiUSSjWAalHQBNklqC7w8hxeIPIcXiswZQHCbZJrNMJgAA5IgWHQAAMqWklQp+EpNsASBjtLlSPC1zki3JVPDJPX8IKRaFC4rFZ41iMck2m0yyJff8IQSAfCnVopPIJFsAAMgRLToAAGRKSakKfhKTbAEgY7S5Ujwm2WZRSaFQKKQx8AOtd05jWDZALiYBoGkev39A2iE06Ik9e6c29r7Pzklt7MbSogMAQKaUtDKNNIl3BwAAckQPPrmnV5VicV4DKA7LZCZTwQcAgBxxoytyT1UVAPLFMpnJtOgAQMYoklE8lsnMIstkknsuJgGgaVrqMpl/7d8vtbH7zf5ramM3lgo+uafSRbE4rwEUh0m2yayDT+5JuoC8UbigeLToZJEWHXJPgg8ATdNSW3SeHtA/tbH7PDo7tbEbyzKZAACQIxJ8AADIEZNsASBj9OBTPC2zB7+kVI06iRtdkXsuJoG8cV6jWAalHQBNYhUdAAAyxZ1sk2nRAWgmvpmkWPwNBZJo0SH3/CGkWHzWAIrDja6SmaEAAAA5IsEHAIAcMckWAIBMMck2mQo+AADkiAo+AACZ4kZXybw7AACQIxJ8AADIES06AABkikm2yVTwAQAgR1TwAQDIFHeyTaaCDwAAOaKCDwBApujBT6aCDwAAOSLBBwCAHNGiAwBApriTbTLvDgAA5IgKPgAAmWKSbTIVfAAAyBEJPgAA5IgWHQAAMkWLTjIVfAAAyBEVfAAAMkUFP5kKPgAA5IgEHwAAciS1Fp2qQ29Ia2g2MJUzTkg7BDYQzmsAxeFOtslSS/AlXRSLpAsA2JCYZAsAQKaUtjLJNonvNwAAIEdU8AEAyBTLZCZTwQcAgByR4AMAQI5YJhMAMsZKdBRPddoBNMgymcksk0nuuZgE8sZ5jWIZlHYANIlJtgAAZIpJtsl8vwEAADkiwQcAgBzRogMAQKZo0Ummgg8AADmigg8AQKZYJjOZdwcAAHLEja4AIGPcS4biaak3utKDn8SNrsg9F5NA3jivUSxudJVNWnQAACBHTLIFACBTTLJN5t0BAIAcUcEHACBbSkyyTWIVHYBmYvEAisXfUCCJVXTIPX8IKRafNQBaAhV8AMgYRTKKxzr4WaSCT+65mATyxnmNYrEOfjaZZAsAQKZYJjOZdwcAAHJEDz4AZIw2V4pHD34W6cEn91xMAnnjvEax6MHPJi06AACQIybZAgCQKSbZJvPuAABAjqjgAwCQKSbZJlPBBwCAHLFMJgBkjJXoKJ6WuUwmySyTSe65mATyxnmNYmmpy2Rq0Ummgg8AGaNIRvGo4GeRCj6552ISyBvnNYqlpVbwwzKZibw7AACQI5bJBAAgU0pK9OAn0YMPABmjzZXi0YOfRXrwyT0Xk0DeOK9RLC22B59EWnQAAMiUEpNsE3l3AAAgR1TwAQDIFDe6SmaSLQBkjHlsFI9Jtlmkgg/QTCRdFIsiGcVikm02SfDJPUkXxSLpAigSk2wTSfDJPUkXkDcKFxSPFp3mMGnSpLjsssuipqYmevbsGVdffXX07dv3U/efMGFCXHvttbFo0aLo0KFDHHXUUVFVVRXl5eWNGs86+OSeBB/IG+c1iqWltuhkaZLttGnTYvTo0XHddddFv379YsKECTFw4MCorq6Ojh07rrX/1KlT45xzzonJkyfHPvvsE/Pnz4/hw4dHSUlJjB8/vlFj+n4DAADWk/Hjx8fxxx8fI0aMiN122y2uu+66aNu2bUyePLnB/f/85z/HvvvuG9/5zneie/fuccghh8Sxxx4bTz75ZKPHlOADAJApJSWlqT1WrVoVK1asqPdYtWpVg3GuXr065syZExUVFXXbSktLo6KiImbPnt3gc/bZZ5+YM2dOXUL/8ssvx/Tp0+Owww5r9PsjwQcAgEaqqqqKzTbbrN6jqqqqwX2XLl0aa9asiU6dOtXb3qlTp6ipqWnwOd/5znfi/PPPj69+9avRunXr6NGjRxxwwAHx05/+tNExSvABAKCRKisrY/ny5fUelZWVzXb8WbNmxcUXXxzXXHNNPPPMM3HXXXfFAw88EBdccEGjj+FGV+SeCd0Ui/MaQJGkOMm2rKwsysrKGrVvhw4dolWrVrFkyZJ625csWRKdO3du8Dk///nP4/vf/3788Ic/jIiI3XffPVauXBknnHBC/OxnP4vSRiwRahUdck/SBQCkoU2bNtG7d++YOXNmDB48OCIiamtrY+bMmTFq1KgGn/Puu++ulcS3atUqIiIKhUKjxrUOPgAAmVKSoRtdjR49OoYNGxZ9+vSJvn37xoQJE2LlypUxYsSIiIgYOnRodO3ata6P/4gjjojx48fHnnvuGf369YuXXnopfv7zn8cRRxxRl+h/Fgk+AACsJ0OGDIk33ngjxowZEzU1NdGrV6+YMWNG3cTbRYsW1avYn3vuuVFSUhLnnntuvPrqq7HVVlvFEUccERdddFGjxywpNLbW38y+esSjaQwLAJmnzZViGfRBy7yT7bJLGm5vKYbNz56Y2tiNpYIPAECmZOlOtmnITgMTAADwmVTwAQDIlhI16iSWyST3LJMJ5I3zGsUyKO0AaBIVfAAAMkUPfjLfbwAAQI5I8AEAIEdSa9HRPwgATWMeG8XTMtfBjwzdyTYNJtmSey4mgbxxXqNYTLLNJpNsAQDIlJISk2yT+H4DAAByRIIPAAA5okUHAIBsMck2kXcHAAByRAUfAIBMcSfbZCr4AACQIxJ8AADIES06AABkS4kadZLUEnx34QOApnE3eIqnOu0AaILUEnwnJ4rFxSSQN85rFMugtAP4NCbZJvL9BgAA5IgefAAAMqVED34iPfjknnYwisV5DYCWQA8+uSfpAgA2JFp0AADIFpNsE2lgAgCAHFHBBwAgU0pK1aiTeHcAACBHJPgAAJAjWnQAAMiWEpNsk6jgAwBAjqjgAwCQLSbZJnInWwDIGDeLpHiq0w6AJnAnW3LPxSSQN85rFMugtAP4NHrwE/l+AwAAckSLDgBkjG/BKR4tOlmkRYfcczEJ5I3zGsXSUlt03Mk2mXcHAAByxDKZAABkS4kadRI9+ACQMdpcKR49+FmkB5/cczEJ5I3zGsXSUnvwSaZFBwCAbCm1Dn4SDUwAAJAjKvgAAGRKiUm2iUyyBYCMMY+N4jHJNotMsiX3XEwCeeO8RrG02Em2evAT+X4DAAByRIIPAAA5YpItAADZYpJtIu8OAADkiAo+AADZUmKSbRIVfAAAyBEJPgAA5IgWHQAAsqVUjTqJdwcAAHJEBR8AgGyxTGYi7w4AAOSICj4AANlSapnMJCr4AACQIxJ8AADIES06AABki0m2ibw7AACQIyr4AABkS4lJtklU8AEAIEdSq+BXHXpDWkMDQKZVzjgh7RDYYFSnHQBNkFqC7+REsbiYBPLGeY1iGZR2AJ+mVBNKEhV8cs/FJMXivAZAS6CCT+5JugAgZ0yyTeT7DQAAyBHLZAIAkC1udJXIuwMAADkiwQcAgBzRogMAQLZYJjORdwcAAHJEBR8AgGyxTGYiFXwAAMgRCT4AAOSIFh0AALLFOviJvDsAAJAjKvgAAGSLSbaJVPABACBHUqvgVx16Q1pDA0CmVc44Ie0Q2GBUpx1Aw9zoKlFJoVAopDHwA613TmNYNkAuJgGgaR6/f0DaITTo/Zm3pDZ2+UFDUxu7sVz+AABAjphkCwBAphRMsk2kgg8AADmigg8AQLa40VUiq+iQe1aboFic1wBoCVTwyT1JF5A3ChcUTwtdJpNElskk9yT4ANA0LXWZzPdm/b/Uxt74gGNTG7uxNDABAECOaNEBACBTLJOZTAUfAAByRIIPAAA5okUHAIBssQ5+Iu8OAADkiAo+AADZYpJtIhV8AADIERV8AACypVSNOol3BwAAckSCDwAAOaJFBwCATHEn22Qq+AAAkCMq+AAAZIsbXSXy7gAAQI5I8AEAIEe06AAAkCkFLTqJvDsAAJAjKvgAAGSLZTITpZbgVx16Q1pDA0CmVc44Ie0Q2GBUpx0ATVBSKBQKaQz8QOud0xiWDZCLSQBomsfvH5B2CA16+8kHUht7076DUhu7sfTgAwBAjkjwAQBgPZo0aVJ07949ysvLo1+/fvHkk08m7r9s2bI4+eSTY+utt46ysrLYaaedYvr06Y0ezyRbAACyJUOTbKdNmxajR4+O6667Lvr16xcTJkyIgQMHRnV1dXTs2HGt/VevXh0HH3xwdOzYMe68887o2rVrvPLKK7H55ps3ekwJPgAArCfjx4+P448/PkaMGBEREdddd1088MADMXny5DjnnHPW2n/y5Mnx1ltvxZ///Odo3bp1RER07959ncbUogMAQLaUlKb2WLVqVaxYsaLeY9WqVQ2GuXr16pgzZ05UVFTUbSstLY2KioqYPXt2g8+57777on///nHyySdHp06d4stf/nJcfPHFsWbNmka/PRJ8AABopKqqqthss83qPaqqqhrcd+nSpbFmzZro1KlTve2dOnWKmpqaBp/z8ssvx5133hlr1qyJ6dOnx89//vO4/PLL48ILL2x0jFp0AACgkSorK2P06NH1tpWVlTXb8Wtra6Njx45xww03RKtWraJ3797x6quvxmWXXRZjx45t1DHc6Ircc0MYisV5DaA4CilOsi0rK2t0Qt+hQ4do1apVLFmypN72JUuWROfOnRt8ztZbbx2tW7eOVq1a1W3bddddo6amJlavXh1t2rT5zHFTS/AlXRSLpAsASEObNm2id+/eMXPmzBg8eHBEfFShnzlzZowaNarB5+y7774xderUqK2tjdLSj7rp58+fH1tvvXWjkvsIPfgAAGRNipNs19Xo0aPjxhtvjJtvvjn+8Y9/xEknnRQrV66sW1Vn6NChUVlZWbf/SSedFG+99VacdtppMX/+/HjggQfi4osvjpNPPrnRY+rBBwCA9WTIkCHxxhtvxJgxY6KmpiZ69eoVM2bMqJt4u2jRorpKfUREt27d4o9//GOcccYZsccee0TXrl3jtNNOi7PPPrvRY5YUCoVCs7+SRnig9c5pDMsGSIsOADTN4/cPSDuEBi1/5uHUxt5sr4rP3illWnQAACBHJPgAAJAjevABAMiUQhMmu25IvDsAAJAjKvgAAGSLCn4i7w4AAOSIBB8AAHJEiw4AAJlSKClJO4QWTQUfAAByRAUfAIBMsUxmMu8OAADkiAo+AADZogc/kQo+AADkiAQfAAByRIsOAACZYpJtMu8OAADkSGoV/KpDb0hraDYwlTNOSDsENhDOawDFUQiTbJOkluBLuigWSRcAsCFRwSf3XExSLM5rALQEKvjknqQLAPLFJNtk3h0AAMgRy2QCAJAt7mSbSAUfAAByRAUfAIBMKahRJ/LuAABAjkjwAQAgR6yDT+5ZkpVicV4DKI6CSbaJrINP7km6AIANiUm2AABkihtdJdOiAwAZ41twiqc67QBogpJCoVBIY+AHWu+cxrBsgFxMAkDTPH7/gLRDaFDNC8+mNnbnXfZMbezGUsEHgIxRwad4WmYFvxAm2SZRwSf3XEwCQNO01Ar+4hfmpjb21rv0Sm3sxlLBB4CMUcGneFpoBd8k20Qq+OSei0kAaJqWWsF/rfpvqY3dZec9Uhu7sVTwASBjVPApnpZawdeDn0QFn9xzMQkATdNSK/ivzn8utbG77rR7amM3VpMamJ555pl47rn/e2PvvffeGDx4cPz0pz+N1atXN1twAADAumlSgj9y5MiYP39+RES8/PLLccwxx0Tbtm3jjjvuiLPOOqtZAwQAgE8qRElqjyxoUoI/f/786NWrV0RE3HHHHbH//vvH1KlTY8qUKfG73/2uOeMDAADWQZMm2RYKhaitrY2IiIcffjgOP/zwiIjo1q1bLF26tPmiAwCA/2CZzGRNSvD79OkTF154YVRUVMSjjz4a1157bURELFiwIDp16tSoY5j4CABNYxUdiqdlrqJDsiatovO3v/0tvvvd78aiRYti9OjRMXbs2IiIOOWUU+LNN9+MqVOnfuYxrKJDsbiYBICmaamr6Pzrxb+nNna3HXdLbezGatZlMt9///1o1apVtG7d+jP3/eoRjzbXsJBIpYticTEJ5E1LTfAXvfiP1MbeZsddUxu7sZp8o6tly5bFnXfeGf/85z/jzDPPjC233DL+/ve/R6dOnaJr167NGSN8LpIuIG8ULigeLTpZ1OQWnYMOOig233zzWLhwYVRXV8f2228f5557bixatChuueWWzzyGFh2KRYIPAE3TUiv4r7yU3oXHtju0/By2SVOQR48eHSNGjIgXX3wxysvL67Yfdthh8dhjjzVbcAAAwLppUovOU089Fddff/1a27t27Ro1NTWNOoaqKsXiq2yKxXkNgJagSQl+WVlZrFixYq3t8+fPj6222qpRx5B0USySLgDIl6zcUTYtTWrROfLII+P888+PDz74ICIiSkpKYtGiRXH22WfHt771rWYNEAAAaLwmTbJdvnx5HHXUUfH000/H22+/HV26dImampro379/TJ8+PTbZZJPPPIZlMikW3xZRLL4tAvKmpU6yXfDPl1Ibe7seO6Q2dmN9rnXwH3/88fjb3/4W77zzTuy1115RUVHR6OdaRYdikXQBQNNI8NeWhQS/yevgR0R89atfja9+9avNFQsAAHwmPfjJGp3gX3XVVY0+6KmnntqkYAAAgM+n0Qn+FVdcUe/nN954I959993YfPPNI+KjO9u2bds2OnbsKMEHAICUNDrBX7BgQd2/p06dGtdcc038+te/jp13/qiXvrq6Oo4//vgYOXJko46nLxrIGxO6KRZ/Q9nQFUq06CRp0iTbHj16xJ133hl77rlnve1z5syJo446qt7FwKcxyZZi8YcQAJqmpU6y/efLL6c2do/tt09t7MZq0iTbxYsXx4cffrjW9jVr1sSSJUs+d1AAAPBpCgUV/CRNutHVQQcdFCNHjoxnnnmmbtucOXPipJNOWqelMgEAgObVpAR/8uTJ0blz5+jTp0+UlZVFWVlZ9O3bNzp16hS/+tWvmjtGAACgkT7Xja7mz58f//jHP6KkpCR22WWX2GmnnRr9XHeyBYCmMaGbYhn0QXXaITToxX++ktrYO/bYNrWxG+tzJfgRER8/vWQdZzObZEuxmGQLAE3TUifZSvCTNalFJyLilltuid133z023njj2HjjjWOPPfaI3/zmN80ZGwAArKUQJak9sqBJq+iMHz8+fv7zn8eoUaNi3333jYiIxx9/PE488cRYunRpnHHGGc0aJAAA0DhNSvCvvvrquPbaa2Po0KF124488sj40pe+FOedd54EHwCA9SYrlfS0NKlFZ/HixbHPPvustX2fffaJxYsXf+6gAACApmlSgr/DDjvE7bffvtb2adOmxY477vi5gwIAAJqmSS0648aNiyFDhsRjjz1W14P/xBNPxMyZMxtM/AEAoLlo0UnWpAT/W9/6Vvz1r3+N8ePHxz333BMREbvuums8+eSTseeeezbqGJYupFisF02xOK8B0BJ87nXwm8o6+BSLpAsAmqalroP/j3++mtrYu/bomtrYjbVOFfzS0tLPvKFVSUlJfPjhh58rKAAAoGnWKcG/++67P/X/Zs+eHVdddVXU1tZ+7qAAAICmWacE/xvf+MZa26qrq+Occ86J+++/P7773e/G+eef32zBAQDAfyoUTLJN0qRlMiMiXnvttTj++ONj9913jw8//DDmzp0bN998c2y77bbNGR8AALAO1nkVneXLl8fFF18cV199dfTq1StmzpwZ++233zoPbOIjADSN1cEonuq0A2iQZTKTrdMqOpdeemlccskl0blz57j44osbbNlpLKvoUCwuJgGgaVrqKjrzXlqc2thf2mHr1MZurHWq4J9zzjmx8cYbxw477BA333xz3HzzzQ3ud9dddzVLcAAA8J9U8JOtU4I/dOjQz1wmEwAASM86JfhTpkxZT2EAAADNYZ0n2QIAQJq06CRr8jKZAABAy6OCDwBAprjRVbLUEnxLFwJ5Y21yisXfUCCJCj5AM5F0USwuJimelnmjK5JJ8Mk9fwgpFgk+xeKzRrEMSjuAT1Frkm0iCT655w8hxeJikmJxXgOSlBQKhUIaAz/Qeuc0hmUD5A8hADTN4/cPSDuEBj374tLUxt5zxw6pjd1YJtkCNBMVfIrF31AgiRYdAAAyxTKZybTokHsqXQDQNC21ReeZ+W+mNvZeO30htbEby51sAQAgR7ToAACQKQXLZCYyyRYAMsaEborHja6ySAUfAIBMMck2mQSf3FPpolh8M0mx+KxRLC31TrYkSy3Bl3RRLP4QAgAbEj34AJAximQUT8vswTfJNpl18Mk9F5MA0DQtdR38p6qXpTb23jtvntrYjaWCT+6pdFEszmsAxWGSbTI3ugIAgBwxyZbcU1UFgHypTTuAFk6LDgBkjCIZxdMyJ9mSTIsOAADkiBtdkXsqXRSLbyYpFp81iqWl3ujKJNtkKvgAAJAjKvgAAGSKG10lU8EHAIAckeADAECOaNEBACBTTLJNpoIPAAA5ooIPAECmmGSbTAUfAAByRIIPAECm1BbSezTFpEmTonv37lFeXh79+vWLJ598slHPu+2226KkpCQGDx68TuNJ8AEAYD2ZNm1ajB49OsaOHRvPPPNM9OzZMwYOHBivv/564vMWLlwYP/nJT2K//fZb5zEl+AAAsJ6MHz8+jj/++BgxYkTstttucd1110Xbtm1j8uTJn/qcNWvWxHe/+90YN25cbL/99us8pgQfAIBMKURJao9Vq1bFihUr6j1WrVrVYJyrV6+OOXPmREVFRd220tLSqKioiNmzZ3/q6zv//POjY8eOcdxxxzXp/ZHgAwBAI1VVVcVmm21W71FVVdXgvkuXLo01a9ZEp06d6m3v1KlT1NTUNPicxx9/PH7961/HjTfe2OQYLZMJAECmpHmjq8rKyhg9enS9bWVlZc1y7Lfffju+//3vx4033hgdOnRo8nEk+AAA0EhlZWWNTug7dOgQrVq1iiVLltTbvmTJkujcufNa+//zn/+MhQsXxhFHHFG3rba2NiIiNtpoo6iuro4ePXp85rhadAAAYD1o06ZN9O7dO2bOnFm3rba2NmbOnBn9+/dfa/9ddtklnnvuuZg7d27d48gjj4wDDzww5s6dG926dWvUuCr4AABkSqGJ69GnYfTo0TFs2LDo06dP9O3bNyZMmBArV66MESNGRETE0KFDo2vXrlFVVRXl5eXx5S9/ud7zN99884iItbYnkeADAMB6MmTIkHjjjTdizJgxUVNTE7169YoZM2bUTbxdtGhRlJY2b1ONBB8AgEypjfQm2TbFqFGjYtSoUQ3+36xZsxKfO2XKlHUeTw8+AADkiAQfAAByRIsOuVd16A1phwDQrCpnnJB2CGwwqtMOoEFproOfBRJ8cs8fQorFxSTF4rNGsQxKOwCaRIIPAECmZGmZzDTowQcAgBxRwQcAIFMKGVsms9hU8AEAIEck+AAAkCNadAAAyJRak2wTqeADAECOqOADAJApbnSVTAUfAAByRIIPAAA5okUHAIBMcSfbZCr4AACQIyr4AABkSq072SZSwQcAgBxRwQcAIFP04CdTwQcAgBxRwSf3qg69Ie0QAJpV5YwT0g6BDUZ12gHQBBJ8cs8fQorFxSTF4rNGsQxKO4BP4U62ybToAABAjqjgAwCQKbUm2SZSwQcAgByR4AMAQI5o0QEAIFOsg59MBR8AAHJEBZ/cs5wckDeW/6V4WuY6+IWwTGYSCT655w8hxeJikmLxWaNYWuo6+CST4AMAkCmWyUymBx8AAHJEBZ/c81U2xaIdjGJxXgOSSPDJPUkXxSLpAigOy2Qm06IDAAA5ooIPAECmqOAnU8EHAIAckeADAECOaNEBACBTagvuZJtEBR8AAHJEBR8AgEwxyTaZCj4AAOSICj4AAJmigp9MBR8AAHJEgg8AADmiRQcAgEyp1aKTSAUfAAByRAUfAIBMKbjRVSIVfAAAyBEJPgAA5IgWHQAAMsU6+MlU8AEAIEdU8AEAyBTLZCZTwQcAgBxRwQcAIFP04CdTwQcAgByR4AMAQI5o0QEAIFO06CRTwQcAgBxRwQcAIFMsk5lMBR8AAHJEgg8AADmiRQcAgEwxyTaZCj4AAOSICj4AAJlSW5t2BC2bCj4AAOSICj65V3XoDWmHANCsKmeckHYIbDCq0w6gQXrwk0nwyT1/CCkWF5MUi88axTIo7QBoEi06AACQIyr4AABkihadZCr4AACQIyr4AABkSq0KfiIVfAAAyBEJPgAA5IgWHXLPcnIUiyVZKRbnNTZ0hVRn2ZakOHbjSPDJPUkXxSLpAqAlkOADAJAplslMpgcfAAByRIIPAAA5okUHAIBMqa1NO4KWTQUfAAByRAUfAIBMMck2mQo+AADkiAo+AACZUquCn0gFHwAAckSCDwAAOaJFBwCATDHJNpkKPgAA5IgKPgAAmVJIdZZtSYpjN44KPgAA5IgEHwAAckSLDgAAmWId/GQq+AAAkCMq+AAAZIplMpOp4AMAQI6o4AMAkCm1mvATqeADAECOSPABACBHtOgAAJApJtkmU8EHAIAcUcEHACBTVPCTqeADAECOSPABACBHtOgAAJAptXp0Eknwyb2qQ29IOwSAZlU544S0Q2CDUZ12ADSBBB8AgEwp1KYdQcsmwSf3VLooFt8WUSw+axTLoLQDoEkk+AAAZEpBD34iq+gAAECOSPABACBHtOgAAJAptSbZJlLBBwCAHFHBBwAgU0yyTSbBJ/csJ0exWJKVYnFeg2yZNGlSXHbZZVFTUxM9e/aMq6++Ovr27dvgvjfeeGPccsst8fzzz0dERO/evePiiy/+1P0bIsEn9yRdFIukC4D/NG3atBg9enRcd9110a9fv5gwYUIMHDgwqquro2PHjmvtP2vWrDj22GNjn332ifLy8rjkkkvikEMOiXnz5kXXrl0bNWZJIaXvOL56xKNpDAsAmadwQbEM+qA67RAadO6U1amNfeHwNuu0f79+/WLvvfeOiRMnRkREbW1tdOvWLU455ZQ455xzPvP5a9asiS222CImTpwYQ4cObdSYJtkCAEAjrVq1KlasWFHvsWrVqgb3Xb16dcyZMycqKirqtpWWlkZFRUXMnj27UeO9++678cEHH8SWW27Z6Bgl+AAAZEqhtpDao6qqKjbbbLN6j6qqqgbjXLp0aaxZsyY6depUb3unTp2ipqamUa/17LPPji5dutS7SPgsevDJPV9lUyx68CkWnzWKZVDaAbRAlZWVMXr06HrbysrK1stYv/jFL+K2226LWbNmRXl5eaOfJ8EHACBT0lwls6ysrNEJfYcOHaJVq1axZMmSetuXLFkSnTt3TnzuL3/5y/jFL34RDz/8cOyxxx7rFKMWHQAAWA/atGkTvXv3jpkzZ9Ztq62tjZkzZ0b//v0/9XmXXnppXHDBBTFjxozo06fPOo+rgg8AAOvJ6NGjY9iwYdGnT5/o27dvTJgwIVauXBkjRoyIiIihQ4dG165d6/r4L7nkkhgzZkxMnTo1unfvXter365du2jXrl2jxpTgAwCQKbW12bmT7ZAhQ+KNN96IMWPGRE1NTfTq1StmzJhRN/F20aJFUVr6f0011157baxevTqOOuqoescZO3ZsnHfeeY0a0zr4AJAxFg+gWFrqOvjn3Ph+amP/4vjGT3ZNiwo+uecPIcViZROKxWeNYmmpq+ikVJ/ODJNsAQAgRyT4AACQI1p0AADIlEJt2hG0bCr4AACQIyr4AABkSq1Jtokk+OSe1SaAvLE6GMXTMpfJJJkEHwCATLFMZjI9+AAAkCMq+ADNRNsExaL1kGJpqTe6IpkEHwCATKmt1aKTRIJP7qmqUiyqqgC0BBJ8AAAyxRzbZCbZAgBAjqjgk3vaJigW7WAUi/MakESCT+5JuigWSRdAcRRMsk2kRQcAAHJEBZ/cU1UF8sY3kxRPddoBNKjWLNtEEnxyzx9CisXFJMXis0axuNFVNknwAQDIFD34yfTgAwBAjkjwAQAgR7ToAACQKVp0kknwyT2T0SgWE7opFuc1IIkEn9yTdFEski6A4lDAT6YHHwAAckSCDwAAOaJFBwCATDHJNpkKPgAA5IgKPgAAmVIoqOAnUcEHAIAckeADAECOaNEh96xNTrG45wLF4rzGhq7WJNtEEnxyT9JFsUi6AGgJJPgAAGSKSbbJ9OADAECOqOADAJApbnSVTAUfAAByRAWf3DPxkWIxoZticV4DkkjwyT1JF8Ui6QIoDi06yST45J6ki2JxMUmxOK8BSST4AABkSq1lMhNJ8Mk9VVWKRVUVgJbAKjoAAJAjKvgAAGSKSbbJVPABACBHVPDJPX3RFIv5HhSL8xobuoJJtokk+OSepItikXQB0BJI8AEAyJRaPfiJJPjknqoqxeLbIorFeQ1IYpItAADkiAo+AACZYpnMZCr4AACQIyr4AABkimUyk6ngAwBAjkjwAQAgR7ToAACQKYXa2rRDaNFU8AEAIEdU8AEAyBR3sk2mgg8AADmigg8AQKZYJjOZCj4AAOSIBB8AAHJEiw4AAJlSMMk2kQo+AADkiAo+AACZooKfTAUfAAByRIIPAAA5okUHAIBMqS3Uph1Ci6aCDwAAOaKCDwBApphkm0wFHwAAckQFHwCATFHBT6aCDwAAOSLBBwCAHNGiAwBAphQKWnSSSPABmknVoTekHQIbiMoZJ6QdAhuM6rQDoAkk+ADNRNJFsbiYpFgGpR3Ap6itdaOrJHrwAQAgRyT4AACQI1p0AADIFOvgJ1PBBwCAHFHBBwAgUwoFk2yTqOADAECOqOADAJApevCTqeADAECOSPABACBHtOgAAJApWnSSqeADAECOqOADAJAptZbJTKSCDwAAOSLBBwCAHNGiAwBApphkm0wFHwAAckQFHwCATCnUmmSbRIIP0EyqDr0h7RDYQFTOOCHtENhgVKcdAE0gwQdoJpIuisXFJMUyKO0APoUe/GR68AEAIEck+AAAkCNadAAAyJSCO9kmkuADNBN90RSL+R4Uj0m2WSTBBwAgU2pNsk2kBx8AAHJEgg8AADmiRQcAgExxJ9tkKvgAAJAjKvgAAGSKO9kmU8EHAIAckeADAECOaNEBACBT3Mk2mQo+AADkiAo+AACZYpJtMhV8AABYjyZNmhTdu3eP8vLy6NevXzz55JOJ+99xxx2xyy67RHl5eey+++4xffr0dRpPgg8AQKYUamtTe6yradOmxejRo2Ps2LHxzDPPRM+ePWPgwIHx+uuvN7j/n//85zj22GPjuOOOi2effTYGDx4cgwcPjueff77RY0rwAQBgPRk/fnwcf/zxMWLEiNhtt93iuuuui7Zt28bkyZMb3P/KK6+MQw89NM4888zYdddd44ILLoi99torJk6c2OgxJfgAANBIq1atihUrVtR7rFq1qsF9V69eHXPmzImKioq6baWlpVFRURGzZ89u8DmzZ8+ut39ExMCBAz91/4akNsn28fsHpDV0Jq1atSqqqqqisrIyysrK0g6HHPNZo1h81j6P6rQDyBSftfxJM48877zzYty4cfW2jR07Ns4777y19l26dGmsWbMmOnXqVG97p06d4oUXXmjw+DU1NQ3uX1NT0+gYVfAzYtWqVTFu3LhPvUKE5uKzRrH4rFEsPms0p8rKyli+fHm9R2VlZdph1WOZTAAAaKSysrJGfxPUoUOHaNWqVSxZsqTe9iVLlkTnzp0bfE7nzp3Xaf+GqOADAMB60KZNm+jdu3fMnDmzblttbW3MnDkz+vfv3+Bz+vfvX2//iIiHHnroU/dviAo+AACsJ6NHj45hw4ZFnz59om/fvjFhwoRYuXJljBgxIiIihg4dGl27do2qqqqIiDjttNNiwIABcfnll8egQYPitttui6effjpuuOGGRo8pwc+IsrKyGDt2rMlBrHc+axSLzxrF4rNGmoYMGRJvvPFGjBkzJmpqaqJXr14xY8aMuom0ixYtitLS/2uq2WeffWLq1Klx7rnnxk9/+tPYcccd45577okvf/nLjR6zpFAouNcvAADkhB58AADIEQk+AADkiAQfAAByRIIPAAA5IsHPiEmTJkX37t2jvLw8+vXrF08++WTaIZEzjz32WBxxxBHRpUuXKCkpiXvuuSftkMipqqqq2HvvvWPTTTeNjh07xuDBg6O6ujrtsMiha6+9NvbYY49o3759tG/fPvr37x9/+MMf0g4L1jsJfgZMmzYtRo8eHWPHjo1nnnkmevbsGQMHDozXX3897dDIkZUrV0bPnj1j0qRJaYdCzj366KNx8sknx1/+8pd46KGH4oMPPohDDjkkVq5cmXZo5MwXv/jF+MUvfhFz5syJp59+Or72ta/FN77xjZg3b17aocF6ZZnMDOjXr1/svffeMXHixIj46A5o3bp1i1NOOSXOOeeclKMjj0pKSuLuu++OwYMHpx0KG4A33ngjOnbsGI8++mjsv//+aYdDzm255ZZx2WWXxXHHHZd2KLDeqOC3cKtXr445c+ZERUVF3bbS0tKoqKiI2bNnpxgZQPNYvnx5RHyUeMH6smbNmrjtttti5cqV0b9//7TDgfXKnWxbuKVLl8aaNWvq7nb2sU6dOsULL7yQUlQAzaO2tjZOP/302HfffdfpLo3QWM8991z0798/3n///WjXrl3cfffdsdtuu6UdFqxXEnwAUnPyySfH888/H48//njaoZBTO++8c8ydOzeWL18ed955ZwwbNiweffRRST65JsFv4Tp06BCtWrWKJUuW1Nu+ZMmS6Ny5c0pRAXx+o0aNit///vfx2GOPxRe/+MW0wyGn2rRpEzvssENERPTu3TueeuqpuPLKK+P6669POTJYf/Tgt3Bt2rSJ3r17x8yZM+u21dbWxsyZM/UQAplUKBRi1KhRcffdd8cjjzwS2223XdohsQGpra2NVatWpR0GrFcq+BkwevToGDZsWPTp0yf69u0bEyZMiJUrV8aIESPSDo0ceeedd+Kll16q+3nBggUxd+7c2HLLLWObbbZJMTLy5uSTT46pU6fGvffeG5tuumnU1NRERMRmm20WG2+8ccrRkSeVlZXx9a9/PbbZZpt4++23Y+rUqTFr1qz44x//mHZosF5ZJjMjJk6cGJdddlnU1NREr1694qqrrop+/fqlHRY5MmvWrDjwwAPX2j5s2LCYMmVK8QMit0pKShrcftNNN8Xw4cOLGwy5dtxxx8XMmTNj8eLFsdlmm8Uee+wRZ599dhx88MFphwbrlQQfAAByRA8+AADkiAQfAAByRIIPAAA5IsEHAIAckeADAECOSPABACBHJPgAAJAjEnwAAMgRCT7AOpoyZUpsvvnmn/s4JSUlcc8993zu4wDAJ0nwgQ3S8OHDY/DgwWmHAQDNToIPAAA5IsEH+A/jx4+P3XffPTbZZJPo1q1b/OhHP4p33nlnrf3uueee2HHHHaO8vDwGDhwY//rXv+r9/7333ht77bVXlJeXx/bbbx/jxo2LDz/8sMExV69eHaNGjYqtt946ysvLY9ttt42qqqr18voAyDcJPsB/KC0tjauuuirmzZsXN998czzyyCNx1lln1dvn3XffjYsuuihuueWWeOKJJ2LZsmVxzDHH1P3/f//3f8fQoUPjtNNOi7///e9x/fXXx5QpU+Kiiy5qcMyrrroq7rvvvrj99tujuro6br311ujevfv6fJkA5FRJoVAopB0EQLENHz48li1b1qhJrnfeeWeceOKJsXTp0oj4aJLtiBEj4i9/+Uv069cvIiJeeOGF2HXXXeOvf/1r9O3bNyoqKuKggw6KysrKuuP89re/jbPOOitee+21iPhoku3dd98dgwcPjlNPPTXmzZsXDz/8cJSUlDT/CwZgg6GCD/AfHn744TjooIOia9eusemmm8b3v//9ePPNN+Pdd9+t22ejjTaKvffeu+7nXXbZJTbffPP4xz/+ERER//M//xPnn39+tGvXru5x/PHHx+LFi+sd52PDhw+PuXPnxs477xynnnpqPPjgg+v/hQKQSxJ8gE9YuHBhHH744bHHHnvE7373u5gzZ05MmjQpIj7qk2+sd955J8aNGxdz586tezz33HPx4osvRnl5+Vr777XXXrFgwYK44IIL4r333oujjz46jjrqqGZ7XQBsODZKOwCAlmTOnDlRW1sbl19+eZSWflQDuf3229fa78MPP4ynn346+vbtGxER1dXVsWzZsth1110j4qOEvbq6OnbYYYdGj92+ffsYMmRIDBkyJI466qg49NBD46233oott9yyGV4ZABsKCT6wwVq+fHnMnTu33rYOHTrEBx98EFdffXUcccQR8cQTT8R111231nNbt24dp5xySlx11VWx0UYbxahRo+IrX/lKXcI/ZsyYOPzww2ObbbaJo446KkpLS+N//ud/4vnnn48LL7xwreONHz8+tt5669hzzz2jtLQ07rjjjujcuXOz3FALgA2LFh1ggzVr1qzYc8896z1+85vfxPjx4+OSSy6JL3/5y3Hrrbc2uFxl27Zt4+yzz47vfOc7se+++0a7du1i2rRpdf8/cODA+P3vfx8PPvhg7L333vGVr3wlrrjiith2220bjGXTTTeNSy+9NPr06RN77713LFy4MKZPn173LQIANJZVdAAAIEeUhgAAIEck+AAAkCMSfAAAyBEJPgAA5IgEHwAAckSCDwAAOSLBBwCAHJHgAwBAjkjwAQAgRyT4AACQIxJ8AADIkf8PG6hnmq/B/XkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAv0AAAK9CAYAAAC3ntN4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABTuklEQVR4nO3deXxU5fn///dMyMbeaBaCgBCVRVEsIODCIkjArQiUYl1AESnfBCq4IFYFREyVuqEo+rEVVPhYQJaWuoGIigIqFhcQBApalYCAYSdkZs7vD3/MhyFBc0K4T+Y+r+fjkcfDnEzm3Anj5DrXua7rDjiO4wgAAACAtYJeLwAAAADAiUXQDwAAAFiOoB8AAACwHEE/AAAAYDmCfgAAAMByBP0AAACA5Qj6AQAAAMsR9AMAAACWI+gHAAAALEfQD+C4hEIh3XHHHWrQoIGCwaB69ep1Qs/XuXNnde7c2fX3bd68WYFAQH/5y18qbS1LlixRIBDQkiVLKu05y+P1119Xq1atlJKSokAgoKKiIqPnx//x6jUAAG4R9MO3pk6dqkAgoI8//rjMr3fu3FlnnXXWCV3Dq6++qrFjx57Qc5xof/vb3zRx4kT17dtX06ZN04gRI7xektV27Nihfv36KTU1VZMnT9aLL76oGjVq6IEHHtC8efO8Xh4AoIqq5vUCAD979dVXNXny5LgO/BcvXqz69evr0Ucf9XopvvDRRx9pz549Gj9+vLp16xY9/sADD6hv374n/E4LYnXs2FEHDhxQUlKS10sBgJ9Fph/Acdm2bZvq1q1bac8XiUR08ODBSns+22zbtk2SKvV3fiwHDx5UJBI54ec5Xvv37/fs3MFgUCkpKQoG+XMKoGrjXQpw6aWXXlLr1q2VmpqqtLQ09e/fX//9739jHvPee+/pt7/9rRo2bKjk5GQ1aNBAI0aM0IEDB6KPGThwoCZPnixJCgQC0Q8ptv588uTJatKkiapXr67u3bvrv//9rxzH0fjx43XKKacoNTVVv/nNb7Rz586YNcyfP1+XXXaZsrOzlZycrJycHI0fP17hcDjmcYfLmFauXKnzzz9fqampaty4saZMmfKzv4fDa3z77be1evXq6PoP1zbv27dPt956qxo0aKDk5GQ1bdpUf/nLX+Q4TszzBAIB5efna/r06TrzzDOVnJys119/vdz/HocOHdK9996r1q1bq06dOqpRo4Yuuugivf3228f8nkcffVSNGjVSamqqOnXqpC+++KLUY9auXau+ffsqLS1NKSkpatOmjf7xj3/84nrWr1+vPn36KCsrSykpKTrllFPUv39/7dq162e/rzyvmc6dO2vAgAGSpLZt2yoQCGjgwIEKBALat2+fpk2bFv13GDhwYPT7vvvuO914443KzMxUcnKyzjzzTP3tb3+LOf/h2vSXX35Zd999t+rXr6/q1atr9+7dx1xzJBLR448/rpYtWyolJUXp6enq0aNHTMlcKBTS+PHjlZOTo+TkZJ166qm66667VFxcHPNcFXm9duzYUdWrV9ddd90lSfr444+Vm5urk08+Ofo6vvHGG0ut+bHHHtOZZ56plJQUZWZmasiQIfrxxx9jHnfqqafq8ssv19KlS3XeeecpJSVFTZo00QsvvFDm7+3Imv7Da1yzZo26dOmi6tWrq379+nrooYdK/Q6//vprXXnllapRo4YyMjI0YsQIvfHGG/QJAKh0lPfA93bt2qXt27eXOl5SUlLq2IQJE3TPPfeoX79+uummm/TDDz/oiSeeUMeOHfXvf/87mn2dNWuW9u/fr6FDh+qkk07Shx9+qCeeeELffvutZs2aJUkaMmSIvv/+ey1cuFAvvvhimWubPn26Dh06pGHDhmnnzp166KGH1K9fP1188cVasmSJRo0apQ0bNuiJJ57QbbfdFhPITZ06VTVr1tTIkSNVs2ZNLV68WPfee692796tiRMnxpznxx9/1KWXXqp+/frp6quv1syZMzV06FAlJSWVCpoOS09P14svvqgJEyZo7969KigokCQ1b95cjuPoyiuv1Ntvv61BgwapVatWeuONN3T77bfru+++K1UKtHjxYs2cOVP5+fk6+eSTdeqpp5b9j1WG3bt367nnntPVV1+twYMHa8+ePfrrX/+q3Nxcffjhh2rVqlXM41944QXt2bNHeXl5OnjwoB5//HFdfPHF+vzzz5WZmSlJWr16tS644ALVr19fd955p2rUqKGZM2eqV69eeuWVV3TVVVeVuZZDhw4pNzdXxcXFGjZsmLKysvTdd99pwYIFKioqUp06dY75c5TnNfOnP/1JTZs21bPPPqv77rtPjRs3Vk5Ojrp166abbrpJ5513nm6++WZJUk5OjiRp69atat++ffTiKj09Xa+99poGDRqk3bt3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XHGFunTpoj/96U/avHmzzjnnHL355puaP3++brnllug4ycpw+eWXa86cObrqqqt02WWXadOmTZoyZYpatGihvXv3lnr8aaedpgsvvFBDhw5VcXGxHnvsMZ100km64447oo+ZPHmyLrzwQrVs2VKDBw9WkyZNtHXrVi1btkzffvutPv300zLXsnjxYuXn5+u3v/2tzjjjDIVCIb344ovR4PtY3LxmjqV169ZatGiRHnnkEWVnZ6tx48Zq166d/vznP+vtt99Wu3btNHjwYLVo0UI7d+7UJ598okWLFpXa36G8unTpouuuu06TJk3S+vXr1aNHD0UiEb333nvq0qWL8vPzdc4552jAgAF69tlnoyU8H374oaZNm6ZevXqpS5cukty/Xssybdo0PfXUU7rqqquUk5OjPXv26H/+539Uu3bt6MVHp06dNGTIEBUUFGjVqlXq3r27EhMTtX79es2aNUuPP/64+vbtW6HfR0UMGTJETz75pK6++mr98Y9/VL169TR9+nSlpKRIOnF3AgH4lKkxQUBVc6zRh4eVNYrScRznlVdecS688EKnRo0aTo0aNZxmzZo5eXl5zrp166KPWbNmjdOtWzenZs2azsknn+wMHjzY+fTTTx1JzvPPPx99XCgUcoYNG+akp6c7gUAgOr7z8HjJiRMnxpz78HjAo0dClvWzvP/++0779u2d1NRUJzs727njjjucN954o8zxgmeeeabz8ccfOx06dHBSUlKcRo0aOU8++WS5fo/H+j3t2bPHGTFihJOdne0kJiY6p59+ujNx4sToOMfDJDl5eXnlOtfh8x05sjMSiTgPPPCA06hRIyc5Odk599xznQULFjgDBgxwGjVqFH3ckb/Thx9+2GnQoIGTnJzsXHTRRc6nn35a6jwbN250rr/+eicrK8tJTEx06tev71x++eXO7Nmzo485elzjf/7zH+fGG290cnJynJSUFCctLc3p0qWLs2jRol/8ucr7mjnW63bt2rVOx44dndTUVEdSzPjOrVu3Onl5eU6DBg2cxMREJysry+natavz7LPPlvpZ3IwbDYVCzsSJE51mzZo5SUlJTnp6utOzZ09n5cqV0ceUlJQ448aNcxo3buwkJiY6DRo0cEaPHh0zhtNx3L9ej/bJJ584V199tdOwYUMnOTnZycjIcC6//HLn448/LvXYZ5991mndurWT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GAxq0qRJWr16taZNm6bFixfrjjvuiHnM/v37NWHCBL3wwgt6//33VVRUpP79+0e//t577+n666/XH//4R61Zs0bPPPOMpk6dqgkTJpR5zkmTJukf//iHZs6cqXXr1mn69Ok69dRTT+SPCQDwkYDjOI7XiwAA0wYOHKiioqJyNdLOnj1bf/jDH7R9+3ZJPzXy3nDDDVq+fLnatWsnSVq7dq2aN2+uFStW6LzzzlO3bt3UtWtXjR49Ovo8L730ku644w59//33kn5q5J07d6569eql4cOHa/Xq1Vq0aJECgUDl/8AAAF8j0w8AR1m0aJG6du2q+vXrq1atWrruuuu0Y8cO7d+/P/qYatWqqW3bttHPmzVrprp16+rLL7+UJH366ae67777VLNmzejH4MGDtWXLlpjnOWzgwIFatWqVmjZtquHDh+vNN9888T8oAMA3CPoB4AibN2/W5ZdfrrPPPluvvPKKVq5cqcmTJ0v6qe6+vPbu3atx48Zp1apV0Y/PP/9c69evV0pKSqnH//rXv9amTZs0fvx4HThwQP369VPfvn0r7ecCAPhbNa8XAABVycqVKxWJRPTwww8rGPwpLzJz5sxSjwuFQvr444913nnnSZLWrVunoqIiNW/eXNJPQfy6det02mmnlfvctWvX1u9+9zv97ne/U9++fdWjRw/t3LlTaWlplfCTAQD8jKAfgG/t2rVLq1atijl28sknq6SkRE888YSuuOIKvf/++5oyZUqp701MTNSwYcM0adIkVatWTfn5+Wrfvn30IuDee+/V5ZdfroYNG6pv374KBoP69NNP9cUXX+j+++8v9XyPPPKI6tWrp3PPPVfBYFCzZs1SVlZWpWwCBgAA5T0AfGvJkiU699xzYz5efPFFPfLII3rwwQd11llnafr06WWOzqxevbpGjRql3//+97rgggtUs2ZN/f3vf49+PTc3VwsWLNCbb76ptm3bqn379nr00UfVqFGjMtdSq1YtPfTQQ2rTpo3atm2rzZs369VXX43ebQAA4HgwvQcAAACwHCkkAAAAwHIE/QAAAIDlCPoBAAAAyxH0AwAAAJYj6AcAAAAsR9APAAAAWI6gHwAAALAcQT8AAABgOYJ+AAAAwHIE/QAAAIDlCPoBAAAAy/1/p0q4jt0OYogAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_nodes = len(labels)\n",
    "num_labels = len(set(labels))\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((num_nodes, num_labels))\n",
    "\n",
    "# Fill in the one-hot encoded values\n",
    "for node_idx, label_idx in enumerate(labels):\n",
    "    Y[node_idx, label_idx] = 1\n",
    "C_t_0=C_0.T\n",
    "Phi = C_t_0@Y \n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 8))\n",
    "sns.heatmap(Y, cmap=\"coolwarm\", cbar=True, xticklabels=True, yticklabels=False)\n",
    "plt.xlabel(\"Labels\")\n",
    "plt.ylabel(\"Nodes\")\n",
    "plt.title(\"Heatmap for original labels\")\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 8))\n",
    "sns.heatmap(Phi, cmap=\"coolwarm\", cbar=True, xticklabels=True, yticklabels=False)\n",
    "plt.xlabel(\"Labels\")\n",
    "plt.ylabel(\"Nodes\")\n",
    "plt.title(\"Heatmap for labels after coarsening\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "588acbe7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hm= sns.heatmap(data = Phi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "b1ae1b34",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjsAAAHHCAYAAABZbpmkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABGzklEQVR4nO3deXRN9/7/8ddJIoOQRJDpmtJWScxFI7QoqSDa+kr5alWjXFpNtGi19BpK1dTWVCrVr4vfRasTVYoSYyumGIqW24GLkoSSHKEy7t8fVs7taYIkEid2n4+19lrO5/PZe7/3OeG87P3ZOxbDMAwBAACYlJOjCwAAAChLhB0AAGBqhB0AAGBqhB0AAGBqhB0AAGBqhB0AAGBqhB0AAGBqhB0AAGBqhB0AAGBqhB2gmE6cOCGLxaJFixY5upQCXn/9dVksFkeXAQDlCmEHt2zRokWyWCy2xd3dXUFBQYqMjNTs2bN16dKlAuvkfynnL05OTgoMDFS3bt20c+dOu7H54eLtt9++YR116tSx26afn58efPBBrVix4qbHUJx6HO3KlSt6/fXXtWXLliKNnzRpklauXFlm9eTm5iooKEgWi0Vr164ts/3g5jZu3KiHHnpI1apVk4+Pj+6//37961//KnTsggULFBISInd3d9WtW1fvvvtukfbRr18/u78rf15+/fVX29js7GyNHz9ed911l9zc3HTXXXdp4sSJysnJKZXjvd127NihBx54QBUrVlRAQIBeeOEFZWRkFGndefPmqWfPnqpVq5YsFov69etXtsXCjoujC4B5TJgwQcHBwcrOzlZycrK2bNmioUOHavr06Vq1apUaN25cYJ158+apUqVKysvL06lTp/TBBx+obdu22r17t5o2bVrsGpo2baqXXnpJknTmzBm9//776tGjh+bNm6fnnnvupusXpZ7atWvr999/V4UKFYpdX2m4cuWKxo8fL0lq3769Xd/o0aM1cuRIu7ZJkybp8ccfV/fu3cuknk2bNuns2bOqU6eOli5dqi5dupTJfnBjq1atUvfu3RUeHm4L7x9//LGefvppnT9/XsOGDbONff/99/Xcc88pOjpaw4cP1/bt2/XCCy/oypUrevXVV2+4n2effVYRERF2bYZh6LnnnlOdOnX0t7/9zdb+1FNP6ZNPPlH//v3VokUL7dy5U2PGjNHJkyc1f/780n0DytiBAwfUsWNHhYSEaPr06Tp9+rTefvtt/fjjj0UK+VOnTtWlS5d0//336+zZs7ehYtgxgFu0cOFCQ5KxZ8+eAn0JCQmGh4eHUbt2bePKlSu29nHjxhmSjHPnztmNP3z4sCHJeO2112xtx48fNyQZb7311g3rqF27thEVFWXXdvbsWcPT09O49957b7hucepxlNzcXOP33383zp07Z0gyxo0bV6T1PD09jZiYmDKr6+mnnzbuu+8+Y9asWYanp6eRkZFRZvu6FdnZ2UZmZqajyygzDz/8sBEUFGRcvXrV1padnW3cfffdRuPGjW1tV65cMapWrVrg70qfPn0MT09P48KFC8Xe9/bt2w1Jxptvvmlr2717tyHJGDNmjN3Yl156ybBYLMbBgweLvZ9bcfny5Vtav0uXLkZgYKCRnp5ua/vggw8MScb69etvuv6JEyeMvLw8wzDK/u8kCuIyFspUhw4dNGbMGP3nP//RkiVLbjo+ICBAkuTiUjonHQMCAhQSEqLjx4+XeP0/11PYnJ1+/fqpUqVK+uWXXxQZGSlPT08FBQVpwoQJMgzDbptvv/22WrdurapVq8rDw0PNmzfXp59+WmDfFotFcXFxWrp0qRo0aCA3NzfFx8erevXqkqTx48fbLh28/vrrkgrO2bFYLLp8+bIWL15sG/vH0+e//vqr+vfvL39/f7m5ualBgwb65z//WeT35/fff9eKFSvUu3dv9erVS7///ru++OKLQseuXbtW7dq1U+XKleXl5aWWLVtq2bJldmN27dqlrl27qkqVKvL09FTjxo01a9YsW3/79u0LnM2Srr3/derUsb3+46XPmTNn6u6775abm5u+//57ZWVlaezYsWrevLm8vb3l6empBx98UJs3by6w3by8PM2aNUuNGjWSu7u7qlevrs6dO2vv3r2SpHbt2qlJkyaFHm+9evUUGRl5s7ew1FitVlWpUkVubm62NhcXF1WrVk0eHh62ts2bN+u3337T888/b7d+bGysLl++rDVr1hR738uWLZPFYtGTTz5pa9u+fbskqXfv3nZje/fuLcMwtHz58mLvJ9/Nfpbat2+vhg0bKikpSW3btlXFihX12muvlXh/VqtVGzZs0FNPPSUvLy9b+9NPP61KlSrp448/vuk2ateuzXw6B+IyFspc37599dprr+nrr7/WwIED7fouXLgg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tzw8PBxcHUpq1KhR6tKli2rVqqVLly5p2bJl2rJli9avX+/o0u443HqOQs2ZM0dvvfWWkpOT1bRpU82ePVthYWGOLgu3YMuWLXrooYcKtMfExGjRokW3vyCUGovFUmj7woUL1a9fv9tbDErNgAEDlJCQoLNnz8rb21uNGzfWq6++qocfftjRpd1xCDsAAMDUmLMDAABMjbADAABMjbADAABMjbADAABMjbADAABMjbADAABMjbADAABMjbADwGFOnDghi8WiAwcOOLoUm6NHj6pVq1Zyd3dX06ZNHV0OgFJA2AH+wvr16yeLxaIpU6bYta9cufK6T+U1u3HjxsnT01PHjh2z+x1x+bZs2SKLxXLdpbCnVANwLMIO8Bfn7u6uqVOn6uLFi44updRkZWWVeN2ff/5ZDzzwgGrXrq2qVasW6G/durXOnj1bYHn//fdlsVj0/PPPO6RuANdH2AH+4iIiIhQQEKDJkydfd8zrr79e4JLOzJkzVadOHdvrfv36qXv37po0aZL8/f3l4+OjCRMmKCcnRyNGjJCvr69q1KihhQsXFtj+0aNH1bp1a7m7u6thw4baunWrXf/hw4fVpUsXVapUSf7+/urbt6/Onz9v62/fvr3i4uI0dOhQVatWTZGRkYUeR15eniZMmKAaNWrIzc1NTZs21bp162z9FotFSUlJmjBhgiwWi15//fUC23B1dVVAQIDdcvHiRb388st67bXX1LNnz1uue+vWrbr//vvl5uamwMBAjRw5Ujk5Obb1Pv30UzVq1EgeHh6qWrWqIiIidPny5UKPGQBhB/jLc3Z21qRJk/Tuu+/q9OnTt7StTZs26cyZM9q2bZumT5+ucePGqVu3bqpSpYp27dql5557Ts8++2yB/YwYMUIvvfSS9u/fr/DwcD3yyCP67bffJElpaWnq0KGDmjVrpr1792rdunVKSUlRr1697LaxePFiubq66ttvv1V8fHyh9c2aNUvvvPOO3n77bX333XeKjIzUo48+qh9//FGSdPbsWTVo0EAvvfSSzp49q5dffvmmx5yWlqbHHntM7du31xtvvGHXXpK6f/31V3Xt2lUtW7bUwYMHNW/ePC1YsEATJ0601fjEE0+of//++uGHH7Rlyxb16NFD/JpD4AYMAH9ZMTExxmOPPWYYhmG0atXK6N+/v2EYhrFixQrjj/88jBs3zmjSpIndujNmzDBq165tt63atWsbubm5trZ69eoZDz74oO11Tk6O4enpaXz44YeGYRjG8ePHDUnGlClTbGOys7ONGjVqGFOnTjUMwzDeeOMNo1OnTnb7PnXqlCHJOHbsmGEYhtGuXTujWbNmNz3eoKAg480337Rra9mypfH888/bXjdp0sQYN27cTbdlGIaRm5trdOnSxQgJCTGsVqtdX0nrfu2114x69eoZeXl5tra5c+calSpVMnJzc42kpCRDknHixIki1QjAMDizA0CSNHXqVC1evFg//PBDibfRoEEDOTn9958Vf39/NWrUyPba2dlZVatWVWpqqt164eHhtj+7uLioRYsWtjoOHjyozZs3q1KlSralfv36kq7Nr8nXvHnzG9ZmtVp15swZtWnTxq69TZs2JT7m1157TYmJifriiy9UuXJlu76S1v3DDz8oPDzcboJ4mzZtlJGRodOnT6tJkybq2LGjGjVqpJ49e+qDDz4w1XwroCy4OLoAAOVD27ZtFRkZqVGjRqlfv352fU5OTgUuk2RnZxfYRoUKFexeWyyWQtvy8vKKXFdGRoYeeeQRTZ06tUBfYGCg7c+enp5F3mZp+Oijj/T2229rzZo1qlu3boH+sqrb2dlZGzZs0I4dO/T111/r3Xff1T/+8Q/t2rVLwcHBxT8Q4C+AMzsAbKZMmaIvv/xSiYmJdu3Vq1dXcnKyXeApzWfj7Ny50/bnnJwcJSUlKSQkRJJ033336ciRI6pTp47uueceu6U4QcHLy0tBQUH69ttv7dq//fZbhYaGFqveAwcOaMCAAZoyZcp1J0OXtO6QkBAlJibavdfffvutKleurBo1aki6FhjbtGmj8ePHa//+/XJ1ddWKFSuKdQzAXwlhB4BNo0aN1KdPH82ePduuvX379jp37pymTZumn3/+WXPnztXatWtLbb9z587VihUrdPToUcXGxurixYvq37+/JCk2NlYXLlzQE088oT179ujnn3/W+vXr9cwzzyg3N7dY+xkxYoSmTp2q5cuX69ixYxo5cqQOHDigF198scjbOH/+vLp376727dvrqaeeUnJyst1y7ty5W6r7+eef16lTpzRkyBAdPXpUX3zxhcaNG6fhw4fLyclJu3bt0qRJk7R3716dPHlSn3/+uc6dO2cLhwAKIuwAsDNhwoQCl5lCQkL03nvvae7cuWrSpIl2795dpDuVimrKlCmaMmWKmjRpom+++UarVq1StWrVJMl2NiY3N1edOnVSo0aNNHToUPn4+NjNDyqKF154QcOHD9dLL72kRo0aad26dVq1alWhl6GuZ82aNfrPf/6jr776SoGBgQWWli1b3lLdf/vb3/TVV19p9+7datKkiZ577jkNGDBAo0ePlnTtDNW2bdvUtWtX3XvvvRo9erTeeecddenSpVjvBfBXYjH+fCEeAADARDizAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATI2wAwAATO3/A9KXCSCL87HxAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from collections import Counter\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((NO_OF_NODES, NO_OF_CLASSES))\n",
    "\n",
    "# Fill in the one-hot encoded values\n",
    "for node_idx, label_idx in enumerate(labels):\n",
    "    Y[node_idx, label_idx] = 1\n",
    "    \n",
    "    \n",
    "Phi = C_t_0@Y\n",
    "Phi[Phi<3]=0\n",
    "Phi = Phi.detach().cpu().numpy()\n",
    "# Generate a sample num_zeros_per_row array with shape (998, 6)\n",
    "# num_zeros_per_row = np.random.randint(0, 6, size=(998, 6))  # Replace with your actual data\n",
    "num_zeros_per_row = np.sum(Phi == 0, axis=1)\n",
    "\n",
    "filtered_counts = [count for count in num_zeros_per_row if count <= 3]\n",
    "counts = Counter(filtered_counts)\n",
    "\n",
    "# Create a bar plot\n",
    "plt.bar(counts.keys(), counts.values())\n",
    "plt.xlabel(\"Number of Zeros\")\n",
    "plt.ylabel(\"Count\")\n",
    "plt.xticks(range(4))\n",
    "plt.title(\"DBLP Bipartite Accuracy = 80.79, cr=0.1\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "426a2042",
   "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
}
