{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3f80e3a6",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 53
    },
    "id": "3f80e3a6",
    "outputId": "b9aae7ce-81c2-4d10-9e74-0357fe243212"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_50892\\1413303913.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": [
    "\n",
    "\n",
    "# !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": "36dfef07-43ca-4966-806d-d1fa7a4cc805"
   },
   "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_50892\\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\\\\CiteSeer'"
      ]
     },
     "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": "c5bb0b93-ee39-411a-e418-93ca31a0dc9b"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'C:\\\\Users\\\\Sandeep\\\\Downloads\\\\Subhanu_ RESULTS\\\\FGC\\\\Experiment Bipartite\\\\CiteSeer\\\\CiteSeer'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "\n",
    "dataset = os.path.join(os.getcwd(),'CiteSeer')\n",
    "dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "067c3d06",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "067c3d06",
    "outputId": "1083fdfa-ea4a-4056-bf77-e9c79158b840"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dataset: CiteSeer\n",
      "num_nodes: 3327\n",
      "num_edges: 9104\n",
      "num_classes: 6\n",
      "num_features: 3703\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "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 = ['CiteSeer']\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": "18568f4f-8ac0-4136-ca24-08468b576958"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data(x=[3327, 3703], edge_index=[2, 9104], y=[3327], train_mask=[3327], val_mask=[3327], test_mask=[3327])\n",
      "torch.Size([3327, 3703]) torch.Size([3327, 3327])\n",
      "torch.Size([3327, 3703]) torch.Size([3327, 3327])\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "# from torch_geometric.datasets import Planetoid\n",
    "from torch_geometric.utils import to_dense_adj\n",
    "\n",
    "# # dataset = NELL(root='/nell')\n",
    "k_ = dataset.num_classes\n",
    "\n",
    "# dataset= Planetoid(root=dataset, name='Cora')\n",
    "print(dataset[0])\n",
    "adj = to_dense_adj(dataset[0].edge_index)\n",
    "adj = adj[0]\n",
    "labels = dataset[0].y\n",
    "labels = labels.numpy()\n",
    "\n",
    "X = dataset[0].x\n",
    "X = X.to_dense()\n",
    "N = X.shape[0]\n",
    "NO_OF_CLASSES =  len(set(np.array(dataset[0].y)))\n",
    "\n",
    "print(X.shape, adj.shape)\n",
    "\n",
    "nn = int(1*N)\n",
    "X = X[:nn,:]\n",
    "adj = adj[:nn,:nn]\n",
    "A = adj[:nn,:nn]\n",
    "AT= torch.transpose(A,0,1)\n",
    "labels = labels[:nn]\n",
    "print(X.shape,adj.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "475846d5",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "475846d5",
    "outputId": "70c6c67d-d4c7-45fe-f3a2-53e54262dddf"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3327, 3703])"
      ]
     },
     "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": "8d413279-27b9-4afe-c6fe-8ad450ddc009"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3327, 3327])\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": "edcc8133-d384-43ea-d901-72953ae4d844"
   },
   "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": "194802f6-ea33-40cf-b7f1-1d0b8d2b652a"
   },
   "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": "9cb962b8-b68a-4a3e-ae67-53c09adc6487"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6 3327\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": "181ac6ce-004a-43b6-dc06-46016a2ae9b7"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "## Delete later\n",
    "features.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b33c30e2",
   "metadata": {
    "id": "b33c30e2"
   },
   "outputs": [],
   "source": [
    "def convertScipyToTensor(coo):\n",
    "  try:\n",
    "    coo = coo.tocoo()\n",
    "  except:\n",
    "    coo = coo\n",
    "  values = coo.data\n",
    "  indices = np.vstack((coo.row, coo.col))\n",
    "\n",
    "  i = torch.LongTensor(indices)\n",
    "  v = torch.FloatTensor(values)\n",
    "  shape = coo.shape\n",
    "\n",
    "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b7f9d72b",
   "metadata": {
    "id": "b7f9d72b"
   },
   "outputs": [],
   "source": [
    "from scipy.sparse import random\n",
    "from scipy.sparse.linalg import norm\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "p = X.shape[0]\n",
    "k = int(p*0.1)\n",
    "n = X.shape[1]\n",
    "lr = 1e-5\n",
    "thresh = 1e-10\n",
    "\n",
    "from scipy.sparse import random\n",
    "from scipy.stats import rv_continuous\n",
    "class CustomDistribution(rv_continuous):\n",
    "    def _rvs(self,  size=None, random_state=None):\n",
    "        return random_state.standard_normal(size)\n",
    "temp = CustomDistribution(seed=1)\n",
    "temp2 = temp()  # get a frozen version of the distribution\n",
    "C = random(p, k, density=0.25, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "eecc9adb",
   "metadata": {
    "id": "eecc9adb"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch_geometric.nn import GCNConv\n",
    "\n",
    "\n",
    "class Net(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Net, self).__init__()\n",
    "        self.conv1 = GCNConv(X.shape[1], 64)\n",
    "        self.conv2 = GCNConv(64, NO_OF_CLASSES)\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.conv1.reset_parameters()\n",
    "        self.conv2.reset_parameters()\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "        x = self.conv1(x, edge_index)\n",
    "        x = F.relu(x)\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return F.log_softmax(x, dim=1)\n",
    "    \n",
    "    \n",
    "####### NO output layer is written\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "1c5a519a",
   "metadata": {
    "id": "1c5a519a"
   },
   "outputs": [],
   "source": [
    "def get_accu(C_0,L,X_t_0):\n",
    "    global labels, NO_OF_CLASSES,k\n",
    "    t=[]\n",
    "    for i in [1]: \n",
    "        C_0_new=np.zeros(C_0.shape)\n",
    "        for i in range(C_0.shape[0]):\n",
    "            C_0_new[i][np.argmax(C_0[i])]=1\n",
    "        # print(C_0_new)\n",
    "        # C_0_new=C_0\n",
    "        from scipy import sparse\n",
    "        #Lc=C_0.T@L@C_0\n",
    "        Lc=C_0_new.T@L@C_0_new\n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        # device = torch.device('cpu')\n",
    "        device = '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_original = torch.stack([row, col], dim=0)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        pred=model(torch.Tensor(X),edge_index_original).argmax(dim=1)\n",
    "        pred = pred.cpu().detach().numpy()\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": 143,
   "id": "556afd48",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "556afd48",
    "outputId": "74fb6a74-035c-421d-bd91-b4a480f9a291"
   },
   "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_29644\\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_29644\\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_29644\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Accuracy = 0.21430718364893298 1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.235347159603247 +/- 0.19537120529005136\n",
      "Params =  1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 21.37060414788097 +/- 0.030057108506161\n",
      "Params =  1000 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.265404268109407 +/- 0.13525698827772797\n",
      "Params =  1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Accuracy = 0.2146077547339946 1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.4307183648933 +/- 0.03005710850616239\n",
      "Params =  1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.4307183648933 +/- 0.0\n",
      "Params =  1000 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 21.235347159603247 +/- 0.015028554253079807\n",
      "Params =  1000 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.190261496844006 +/- 0.06011421701232339\n",
      "Params =  1000 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7968\n",
      "Accuracy = 0.22963630898707543 1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7942\n",
      "Average accuracy = 22.648031259392848 +/- 0.31559963931469676\n",
      "Params =  1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.355575593627893 +/- 0.07514277126540458\n",
      "Params =  1000 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.29546137661557 +/- 0.0751427712654032\n",
      "Params =  1000 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.220318605350165 +/- 0.39074241058010134\n",
      "Params =  1000 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.009918845807036 +/- 0.030057108506161\n",
      "Params =  1000 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.400661256387135 +/- 0.15028554253080917\n",
      "Params =  1000 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.32551848512173 +/- 0.015028554253081194\n",
      "Params =  1000 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.235347159603247 +/- 0.07514277126540458\n",
      "Params =  1000 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7932\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Accuracy = 0.25849113315299066 1000 100 0.0001\n",
      "Average accuracy = 24.0156296964232 +/- 1.8334836188758628\n",
      "Params =  1000 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.415689810640217 +/- 0.10519987977156559\n",
      "Params =  1000 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.385632702134057 +/- 0.015028554253081194\n",
      "Params =  1000 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.205290051097087 +/- 0.25548542230237475\n",
      "Params =  1000 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.265404268109407 +/- 0.13525698827772797\n",
      "Params =  1000 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.400661256387135 +/- 0.12022843402464678\n",
      "Params =  1000 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 21.310489930868652 +/- 0.15028554253080917\n",
      "Params =  1000 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.445746919146377 +/- 0.07514277126540458\n",
      "Params =  1000 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7971\n",
      "Accuracy = 0.616170724376315 1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7977\n",
      "Accuracy = 0.6402164111812444 1000 10 0.0001\n",
      "Average accuracy = 62.81935677787798 +/- 1.2022843402464678\n",
      "Params =  1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.12022843402464678\n",
      "Params =  1000 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.205290051097087 +/- 0.015028554253081194\n",
      "Params =  1000 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.37060414788097 +/- 0.12022843402464678\n",
      "Params =  1000 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.400661256387135 +/- 0.12022843402464678\n",
      "Params =  1000 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.5058611361587 +/- 0.015028554253081194\n",
      "Params =  1000 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.310489930868652 +/- 0.09017132551848439\n",
      "Params =  1000 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "Average accuracy = 15.163811241358582 +/- 6.387135557559362\n",
      "Params =  1000 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7986\n",
      "Average accuracy = 59.16741809437932 +/- 0.4959422903516697\n",
      "Params =  1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.47580402765254 +/- 0.015028554253079807\n",
      "Params =  1000 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7907\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 18.650435828073338 +/- 2.3594830177336936\n",
      "Params =  1000 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.29546137661557 +/- 0.0751427712654032\n",
      "Params =  1000 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.415689810640217 +/- 0.015028554253081194\n",
      "Params =  1000 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 21.4307183648933 +/- 0.03005710850616239\n",
      "Params =  1000 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.235347159603247 +/- 0.1352569882777266\n",
      "Params =  1000 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 27.23174030658251 +/- 7.724676886083559\n",
      "Params =  1000 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7854\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7904\n",
      "Average accuracy = 60.580102194168916 +/- 0.8265704839194477\n",
      "Params =  1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.265404268109407 +/- 0.045085662759242195\n",
      "Params =  1000 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.29546137661557 +/- 0.0751427712654032\n",
      "Params =  1000 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.32551848512173 +/- 0.015028554253081194\n",
      "Params =  1000 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.340547039374812 +/- 0.12022843402464678\n",
      "Params =  1000 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.220318605350165 +/- 0.09017132551848578\n",
      "Params =  1000 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.46077547339946 +/- 0.06011421701232339\n",
      "Params =  1000 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7926\n",
      "Average accuracy = 20.559062218214606 +/- 0.24045686804929356\n",
      "Params =  1000 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7894\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7898\n",
      "Average accuracy = 59.963931469792605 +/- 1.1722272317403082\n",
      "Params =  1000 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.385632702134057 +/- 0.015028554253081194\n",
      "Params =  1000 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.29546137661557 +/- 0.0751427712654032\n",
      "Params =  1000 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.25037571385633 +/- 0.030057108506161\n",
      "Params =  1000 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.030057108506161\n",
      "Params =  1000 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.400661256387135 +/- 0.15028554253080917\n",
      "Params =  1000 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.40066125638714 +/- 0.06011421701232339\n",
      "Params =  1000 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:06<00:00,  1.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 31.394649834685907 +/- 10.535016531409678\n",
      "Params =  1000 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7967\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7964\n",
      "Average accuracy = 61.57198677487226 +/- 0.37571385632702015\n",
      "Params =  1000 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.030057108506161\n",
      "Params =  1000 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:07<00:00,  1.32it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.47580402765254 +/- 0.045085662759242195\n",
      "Params =  1000 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:09<00:00,  1.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.31048993086865 +/- 0.06011421701232339\n",
      "Params =  1000 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.31048993086865 +/- 0.06011421701232339\n",
      "Params =  1000 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.4307183648933 +/- 0.03005710850616239\n",
      "Params =  1000 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:06<00:00,  1.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:07<00:00,  1.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.220318605350165 +/- 0.06011421701232339\n",
      "Params =  1000 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:06<00:00,  1.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:07<00:00,  1.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "Average accuracy = 19.461977757739707 +/- 1.2774271115118738\n",
      "Params =  1000 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7892\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 57.27382025849113 +/- 1.0970844604749008\n",
      "Params =  1000 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.415689810640217 +/- 0.0751427712654032\n",
      "Params =  100 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.235347159603247 +/- 0.045085662759242195\n",
      "Params =  100 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.265404268109407 +/- 0.07514277126540458\n",
      "Params =  100 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:07<00:00,  1.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.47580402765254 +/- 0.07514277126540458\n",
      "Params =  100 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:10<00:00,  1.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.265404268109407 +/- 0.045085662759242195\n",
      "Params =  100 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:07<00:00,  1.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:06<00:00,  1.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.37060414788097 +/- 0.24045686804929356\n",
      "Params =  100 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  2.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:06<00:00,  1.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7899\n",
      "Average accuracy = 22.33243162007815 +/- 0.24045686804929356\n",
      "Params =  100 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7968\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7864\n",
      "Accuracy = 0.6450255485422303 100 1000 0.0001\n",
      "Average accuracy = 62.48872858431018 +/- 2.0138262699128386\n",
      "Params =  100 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:05<00:00,  1.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.385632702134057 +/- 0.13525698827772797\n",
      "Params =  100 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:07<00:00,  1.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.250375713856325 +/- 0.0\n",
      "Params =  100 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:04<00:00,  2.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.310489930868652 +/- 0.0\n",
      "Params =  100 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.340547039374812 +/- 0.030057108506161\n",
      "Params =  100 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.310489930868652 +/- 0.0\n",
      "Params =  100 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.46077547339946 +/- 0.09017132551848578\n",
      "Params =  100 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7895\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7875\n",
      "Average accuracy = 22.31740306582507 +/- 0.4658851818455073\n",
      "Params =  100 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7874\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7860\n",
      "Average accuracy = 61.421701232341455 +/- 0.7063420498947981\n",
      "Params =  100 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.46077547339946 +/- 0.06011421701232339\n",
      "Params =  100 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.4307183648933 +/- 0.09017132551848439\n",
      "Params =  100 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.55094679891794 +/- 0.06011421701232339\n",
      "Params =  100 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.47580402765254 +/- 0.045085662759242195\n",
      "Params =  100 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.09017132551848578\n",
      "Params =  100 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.205290051097084 +/- 0.07514277126540458\n",
      "Params =  100 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 26.450255485422304 +/- 4.388337841899609\n",
      "Params =  100 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7988\n",
      "Average accuracy = 57.61947700631199 +/- 1.1722272317403082\n",
      "Params =  100 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.235347159603247 +/- 0.07514277126540458\n",
      "Params =  100 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 18.34986474301172 +/- 0.19537120529004998\n",
      "Params =  100 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 19.987977156597537 +/- 0.0\n",
      "Params =  100 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 8.040276525398257 +/- 0.10519987977156628\n",
      "Params =  100 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.29546137661557 +/- 0.10519987977156559\n",
      "Params =  100 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 19.401863540727383 +/- 0.34565674782086053\n",
      "Params =  100 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7933\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7936\n",
      "Average accuracy = 61.3014727983168 +/- 0.28554253080853575\n",
      "Params =  100 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7856\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7910\n",
      "Average accuracy = 57.42410580102194 +/- 1.6681695220919779\n",
      "Params =  100 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 7.965133754132853 +/- 0.0\n",
      "Params =  100 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 18.9960925758942 +/- 0.39074241058010273\n",
      "Params =  100 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.13014727983168 +/- 2.614968440036068\n",
      "Params =  100 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "Average accuracy = 19.672377517282836 +/- 0.34565674782085914\n",
      "Params =  100 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 9.122332431620078 +/- 0.25548542230237475\n",
      "Params =  100 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7910\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 15.043582807333934 +/- 5.63570784490532\n",
      "Params =  100 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7890\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7932\n",
      "Average accuracy = 60.76044484520588 +/- 0.10519987977156142\n",
      "Params =  100 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7890\n",
      "Average accuracy = 55.57559362789299 +/- 0.24045686804929356\n",
      "Params =  100 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.91974752028855 +/- 0.5109708446047495\n",
      "Params =  100 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 15.704839194469495 +/- 1.2473700030057113\n",
      "Params =  100 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 14.652840396753831 +/- 6.7177637511271415\n",
      "Params =  100 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 19.431920649233543 +/- 0.10519987977156559\n",
      "Params =  100 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 20.468890892696123 +/- 0.8716561466786898\n",
      "Params =  100 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 27.11151187255786 +/- 5.44033663961527\n",
      "Params =  100 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7950\n",
      "Average accuracy = 60.114217012323415 +/- 0.4809137360985871\n",
      "Params =  100 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7906\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "Average accuracy = 52.810339645326124 +/- 0.2705139765554532\n",
      "Params =  100 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "Average accuracy = 9.212503757138563 +/- 0.04508566275924289\n",
      "Params =  100 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 19.58220619176435 +/- 0.19537120529004998\n",
      "Params =  100 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "Average accuracy = 20.24346257889991 +/- 1.187255785993388\n",
      "Params =  100 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7902\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 15.238954012623985 +/- 0.6011421701232353\n",
      "Params =  100 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 20.859633303276226 +/- 0.36068530207394034\n",
      "Params =  100 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 28.013225127742707 +/- 3.0958821761346553\n",
      "Params =  100 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7930\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7905\n",
      "Average accuracy = 59.31770363691014 +/- 1.2173128944995504\n",
      "Params =  100 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7943\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7944\n",
      "Average accuracy = 54.97445145776976 +/- 1.8034265103697045\n",
      "Params =  100 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7904\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 26.795912233243158 +/- 7.258791704238051\n",
      "Params =  100 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 19.74752028854824 +/- 0.18034265103697017\n",
      "Params =  100 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.28043282236249 +/- 0.09017132551848439\n",
      "Params =  100 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 7.980162308385933 +/- 0.04508566275924289\n",
      "Params =  100 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 19.822663059813646 +/- 1.42771265404268\n",
      "Params =  100 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 43.733092876465285 +/- 2.645025548542229\n",
      "Params =  100 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7895\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7945\n",
      "Average accuracy = 60.760444845205896 +/- 0.6762849413886385\n",
      "Params =  100 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7905\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7968\n",
      "Average accuracy = 57.60444845205891 +/- 1.3675984370303595\n",
      "Params =  100 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.235347159603247 +/- 0.015028554253079807\n",
      "Params =  10 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.25037571385633 +/- 0.18034265103697017\n",
      "Params =  10 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 21.400661256387135 +/- 0.09017132551848439\n",
      "Params =  10 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.415689810640217 +/- 0.015028554253081194\n",
      "Params =  10 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.15028554253080778\n",
      "Params =  10 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7970\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "Average accuracy = 22.302374511571987 +/- 0.18034265103697017\n",
      "Params =  10 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7931\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8034\n",
      "Average accuracy = 23.05380222422603 +/- 0.30057108506161695\n",
      "Params =  10 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7858\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7893\n",
      "Average accuracy = 61.88758641418695 +/- 1.2022843402464678\n",
      "Params =  10 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.355575593627893 +/- 0.015028554253079807\n",
      "Params =  10 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.46077547339946 +/- 0.030057108506161\n",
      "Params =  10 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.31048993086865 +/- 0.06011421701232339\n",
      "Params =  10 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.52088969041178 +/- 0.03005710850616239\n",
      "Params =  10 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.160204388337846 +/- 0.18034265103697017\n",
      "Params =  10 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7988\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 22.437631499849715 +/- 0.4658851818455073\n",
      "Params =  10 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "Accuracy = 0.6582506762849414 10 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7860\n",
      "Accuracy = 0.6642620979861737 10 100 0.001\n",
      "Average accuracy = 66.12563871355576 +/- 0.30057108506161834\n",
      "Params =  10 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7882\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7945\n",
      "Average accuracy = 62.08295761947701 +/- 0.28554253080853575\n",
      "Params =  10 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7931\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 19.987977156597537 +/- 0.15028554253080778\n",
      "Params =  10 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7908\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Average accuracy = 22.37751728283739 +/- 1.0069131349564178\n",
      "Params =  10 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 18.37992185151788 +/- 0.16531409678388898\n",
      "Params =  10 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7949\n",
      "Average accuracy = 19.206492335437332 +/- 0.09017132551848439\n",
      "Params =  10 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7938\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7893\n",
      "Average accuracy = 18.51517883979561 +/- 0.030057108506161\n",
      "Params =  10 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7932\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7943\n",
      "Average accuracy = 24.391343552750225 +/- 3.9224526600541014\n",
      "Params =  10 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7943\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7960\n",
      "Average accuracy = 61.01593026750827 +/- 0.030057108506165164\n",
      "Params =  10 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7904\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7949\n",
      "Average accuracy = 58.91193267207695 +/- 1.1121130147279834\n",
      "Params =  10 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7908\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 26.269912834385334 +/- 0.6311992786293963\n",
      "Params =  10 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 8.025247971145175 +/- 0.09017132551848508\n",
      "Params =  10 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7910\n",
      "Average accuracy = 36.20378719567178 +/- 0.37571385632702015\n",
      "Params =  10 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 38.262699128343854 +/- 0.8415990381725275\n",
      "Params =  10 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 20.42380522993688 +/- 0.10519987977156559\n",
      "Params =  10 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7902\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7879\n",
      "Average accuracy = 37.64652840396754 +/- 0.9768560264502568\n",
      "Params =  10 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7848\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7938\n",
      "Average accuracy = 58.385933273219116 +/- 1.5178839795611632\n",
      "Params =  10 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7937\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7775\n",
      "Average accuracy = 55.09467989179442 +/- 1.5028554253080861\n",
      "Params =  10 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 32.626991283438535 +/- 5.305079651337541\n",
      "Params =  10 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 41.88458070333634 +/- 0.31559963931469814\n",
      "Params =  10 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7894\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 25.38322813345356 +/- 0.5259993988578293\n",
      "Params =  10 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7910\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7900\n",
      "Average accuracy = 24.872257288848814 +/- 1.157198677487227\n",
      "Params =  10 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 44.033663961526905 +/- 4.899308686504359\n",
      "Params =  10 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7983\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8026\n",
      "Average accuracy = 57.16862037871957 +/- 1.1722272317403082\n",
      "Params =  10 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7863\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8036\n",
      "Average accuracy = 52.99068229636309 +/- 3.0057108506161723\n",
      "Params =  10 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7932\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "Average accuracy = 57.06342049894799 +/- 1.0069131349564164\n",
      "Params =  10 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7934\n",
      "Average accuracy = 32.53681995792005 +/- 10.204388337841898\n",
      "Params =  10 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7899\n",
      "Average accuracy = 39.69041178238653 +/- 0.1051998797715642\n",
      "Params =  10 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7908\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Average accuracy = 37.69161406672678 +/- 3.1259392846408165\n",
      "Params =  10 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7908\n",
      "Average accuracy = 47.234746017433125 +/- 1.4577697625488413\n",
      "Params =  10 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 42.07995190862639 +/- 6.281935677787798\n",
      "Params =  10 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7898\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 58.400961827472194 +/- 0.5710850616170715\n",
      "Params =  10 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7808\n",
      "Average accuracy = 57.123534715960325 +/- 1.577998196573488\n",
      "Params =  10 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 57.51427712654043 +/- 2.7502254283137963\n",
      "Params =  10 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 18.966035467388036 +/- 0.18034265103697017\n",
      "Params =  10 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 24.6468289750526 +/- 2.3745115719867744\n",
      "Params =  10 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 19.236549443943492 +/- 1.4727983168019239\n",
      "Params =  10 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 24.391343552750225 +/- 1.3675984370303569\n",
      "Params =  10 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7902\n",
      "Average accuracy = 53.62188157499248 +/- 8.44604749023144\n",
      "Params =  10 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7895\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 59.66336038473099 +/- 1.2623985572587926\n",
      "Params =  10 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7958\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7974\n",
      "Average accuracy = 52.629996994289144 +/- 1.8935978358881889\n",
      "Params =  10 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8015\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7886\n",
      "Average accuracy = 53.96753832281333 +/- 0.916741809437932\n",
      "Params =  10 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7930\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "Average accuracy = 38.90892696122633 +/- 6.32702134054704\n",
      "Params =  10 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 21.611061015930268 +/- 2.885482416591524\n",
      "Params =  10 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 17.493237150586115 +/- 3.937481214307184\n",
      "Params =  10 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 21.235347159603247 +/- 0.9768560264502568\n",
      "Params =  10 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7947\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 60.11421701232342 +/- 3.1559963931469817\n",
      "Params =  10 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7864\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7861\n",
      "Average accuracy = 60.95581605049594 +/- 1.5329125338142513\n",
      "Params =  10 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7862\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7954\n",
      "Average accuracy = 56.37210700330628 +/- 0.015028554253082582\n",
      "Params =  10 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7880\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "Average accuracy = 55.72587917042381 +/- 2.013826269912833\n",
      "Params =  10 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.340547039374812 +/- 0.0\n",
      "Params =  1 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.340547039374812 +/- 0.06011421701232339\n",
      "Params =  1 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.32551848512173 +/- 0.07514277126540458\n",
      "Params =  1 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.32551848512173 +/- 0.015028554253081194\n",
      "Params =  1 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7897\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7943\n",
      "Average accuracy = 22.061917643522694 +/- 0.21039975954313256\n",
      "Params =  1 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7893\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7999\n",
      "Average accuracy = 23.459573189059213 +/- 0.616170724376315\n",
      "Params =  1 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7945\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Average accuracy = 23.459573189059213 +/- 0.13525698827772797\n",
      "Params =  1 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7848\n",
      "Average accuracy = 63.84129846708746 +/- 1.6230838593327357\n",
      "Params =  1 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 21.385632702134057 +/- 0.07514277126540458\n",
      "Params =  1 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.415689810640217 +/- 0.0751427712654032\n",
      "Params =  1 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.400661256387135 +/- 0.03005710850616239\n",
      "Params =  1 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.29546137661557 +/- 0.13525698827772797\n",
      "Params =  1 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7901\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "Average accuracy = 22.076946197775772 +/- 0.40577096483318253\n",
      "Params =  1 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7961\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7948\n",
      "Average accuracy = 23.53471596032462 +/- 0.0\n",
      "Params =  1 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7875\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7960\n",
      "Average accuracy = 61.136158701532906 +/- 0.9918845807033339\n",
      "Params =  1 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7982\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 59.978960024045676 +/- 1.5178839795611687\n",
      "Params =  1 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7906\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7897\n",
      "Average accuracy = 19.507063420498948 +/- 0.6612563871355572\n",
      "Params =  1 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7938\n",
      "Average accuracy = 33.45356176735798 +/- 0.33062819356777795\n",
      "Params =  1 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7938\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 24.36128644424406 +/- 0.6762849413886385\n",
      "Params =  1 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7896\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "Average accuracy = 39.81064021641118 +/- 0.4959422903516697\n",
      "Params =  1 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7937\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7940\n",
      "Average accuracy = 32.131048993086864 +/- 3.2161106101593036\n",
      "Params =  1 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7958\n",
      "Accuracy = 0.6669672377517283 1 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7942\n",
      "Average accuracy = 64.66786895100691 +/- 2.0288548241659154\n",
      "Params =  1 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7955\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "Average accuracy = 61.24135858130448 +/- 0.25548542230237614\n",
      "Params =  1 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7947\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7933\n",
      "Average accuracy = 56.82296363089871 +/- 2.179140366696725\n",
      "Params =  1 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 41.46378118425007 +/- 8.61136158701533\n",
      "Params =  1 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "Average accuracy = 44.96543432521791 +/- 0.9918845807033366\n",
      "Params =  1 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 46.227832882476704 +/- 8.866847009317702\n",
      "Params =  1 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "Average accuracy = 43.01172227231741 +/- 3.997595431319506\n",
      "Params =  1 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7982\n",
      "Accuracy = 0.6847009317703637 1 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Accuracy = 0.6871055004508566 1 1 0.1\n",
      "Average accuracy = 68.59032161106103 +/- 0.120228434024644\n",
      "Params =  1 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7894\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7938\n",
      "Average accuracy = 57.889990982867445 +/- 2.4045686804929356\n",
      "Params =  1 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7839\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7888\n",
      "Average accuracy = 51.638112413585816 +/- 3.9374812143071813\n",
      "Params =  1 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7892\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7981\n",
      "Average accuracy = 51.412684099789594 +/- 2.5097685602645\n",
      "Params =  1 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7937\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "Average accuracy = 41.959723474601745 +/- 21.85151788397956\n",
      "Params =  1 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7934\n",
      "Average accuracy = 64.53261196272919 +/- 0.3606853020739431\n",
      "Params =  1 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7843\n",
      "Average accuracy = 45.626690712353465 +/- 21.941689209498048\n",
      "Params =  1 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7900\n",
      "Average accuracy = 63.30027051397656 +/- 0.4809137360985871\n",
      "Params =  1 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  3.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8000\n",
      "Average accuracy = 60.89570183348363 +/- 0.6311992786293963\n",
      "Params =  1 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7930\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7951\n",
      "Average accuracy = 53.937481214307184 +/- 3.1710249474000585\n",
      "Params =  1 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7972\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7908\n",
      "Average accuracy = 54.839194469492035 +/- 1.0069131349564164\n",
      "Params =  1 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7825\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7904\n",
      "Average accuracy = 57.363991584009625 +/- 1.24737000300571\n",
      "Params =  1 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.97it/s]\n"
     ]
    },
    {
     "ename": "_LinAlgError",
     "evalue": "linalg.svd: The algorithm failed to converge because the input matrix is ill-conditioned or has too many repeated singular values (error code: 1).",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31m_LinAlgError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[143], line 25\u001b[0m\n\u001b[0;32m     23\u001b[0m               L \u001b[38;5;241m=\u001b[39m theta\n\u001b[0;32m     24\u001b[0m \u001b[38;5;66;03m#               L=L.cuda()\u001b[39;00m\n\u001b[1;32m---> 25\u001b[0m               pseudo_C \u001b[38;5;241m=\u001b[39m \u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlinalg\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mpinv\u001b[49m\u001b[43m(\u001b[49m\u001b[43mC_0\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     26\u001b[0m               X_t_0 \u001b[38;5;241m=\u001b[39m pseudo_C\u001b[38;5;129m@X\u001b[39m\n\u001b[0;32m     27\u001b[0m               C_test \u001b[38;5;241m=\u001b[39m C_0\u001b[38;5;241m.\u001b[39mcpu()\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mnumpy()\n",
      "\u001b[1;31m_LinAlgError\u001b[0m: linalg.svd: The algorithm failed to converge because the input matrix is ill-conditioned or has too many repeated singular values (error code: 1)."
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pylab as plt\n",
    "        # sns.heatmap(C_0.T@C_0)\n",
    "        \n",
    "        \n",
    "highest_accuracy=0\n",
    "lambda_param = 0.001\n",
    "#0.0001,0.0001,10,0.0001\n",
    "for alpha_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "  for beta_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "      for gamma_param in [1000,100,10,1,0.1,0.01,0.001,0.0001]:\n",
    "            \n",
    "        av = []\n",
    "        for _ in range(2):\n",
    "            avg_accuracy_all=[]\n",
    "#             X=X.cuda()\n",
    "            for _ in range(1):\n",
    "              C = random(p, k, density=0.15, random_state=1, data_rvs=temp2.rvs)\n",
    "#               A = A.cuda()\n",
    "#               theta = theta.cuda()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "#               C_0 = C_0.cuda()\n",
    "              L = theta\n",
    "#               L=L.cuda()\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": 144,
   "id": "VYrR83c2grMy",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "VYrR83c2grMy",
    "outputId": "c388488b-8d14-4705-c421-7cee6dbae62b"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "68.71055004508565"
      ]
     },
     "execution_count": 144,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "highest_accuracy*100  #Params =  1 1 0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "598c5a60",
   "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": 18,
   "id": "ab38b56f",
   "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": 22,
   "id": "ea48aefe",
   "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",
    "        # Lc=C_0_new.T@L@C_0_new\n",
    "        en_mat = Lc\n",
    "        print(\"L:\", Lc.shape)\n",
    "     \n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        model=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": 23,
   "id": "9623670e",
   "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",
    "        # Lc=C_0_new.T@L@C_0_new\n",
    "        en_mat = Lc\n",
    "        print(\"L:\", Lc.shape)\n",
    "       \n",
    "        # print(\"L:\", Lc.shape)\n",
    "        # Lc=L_new\n",
    "        #print(Lc)\n",
    "        Wc=(-1*Lc)*(1-np.eye(Lc.shape[0]))\n",
    "        # print(\"W:\", Wc.shape)\n",
    "        Wc[Wc<0.1]=0\n",
    "        Wc=sparse.csr_matrix(Wc)\n",
    "        Wc = Wc.tocoo()\n",
    "        row = torch.from_numpy(Wc.row).to(torch.long)\n",
    "        col = torch.from_numpy(Wc.col).to(torch.long)\n",
    "        edge_index_coarsen2 = torch.stack([row, col], dim=0)\n",
    "        #print(\"edgecoarsen:\", edge_index_coarsen2.shape)\n",
    "        edge_weight = torch.from_numpy(Wc.data)\n",
    "        #print(\"edgeweight:\", edge_weight.shape)\n",
    "        def one_hot(x, class_count):\n",
    "            return torch.eye(class_count)[x, :]\n",
    "\n",
    "        device = torch.device('cpu')\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        labels=labels\n",
    "        Y = labels\n",
    "        #print(\"Y:\", Y.shape)\n",
    "        Y = one_hot(Y,NO_OF_CLASSES)\n",
    "        # NO_OF_CLASSES=Y.shape[1]\n",
    "        P=np.linalg.pinv(C_0_new)\n",
    "        labels_coarse = torch.argmax(torch.sparse.mm(torch.Tensor(P).double() , Y.double()).double() , 1)\n",
    "        #print(\"Lables:\", labels_coarse.shape)\n",
    "\n",
    "        #torch.Tensor(C2)@X\n",
    "        Wc=Wc.toarray()\n",
    "        #Wc[Wc<0.01]=0\n",
    "        C2=np.linalg.pinv(C_0_new)\n",
    "#         device = torch.device(' ' if torch. .is_available() else 'cpu')\n",
    "        model=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": 25,
   "id": "ccf78b6b",
   "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_50892\\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_50892\\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_50892\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (332, 332)\n",
      "Epoch: 000,loss: 1.7928\n",
      "Accuracy = 0.6498346859032161 1 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (332, 332)\n",
      "Epoch: 000,loss: 1.7946\n",
      "Accuracy = 0.6792906522392546 1 1 0.1\n",
      "Average accuracy APPNPNET= 66.45626690712353 +/- 1.472798316801921\n",
      "Params =  1 1 0.1\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 [1]:\n",
    "  for beta_param in [1]:\n",
    "      for gamma_param in [0.1]:\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",
    "#               A = A.cuda()\n",
    "#               theta = theta.cuda()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "#               C_0 = C_0.cuda()\n",
    "              L = theta\n",
    "#               L=L.cuda()\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 APPNPNET= \" + 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": 27,
   "id": "beb43355",
   "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_50892\\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_50892\\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_50892\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (332, 332)\n",
      "Epoch: 000,loss: 1.7922\n",
      "Accuracy = 0.6678689510069131 1 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L: (332, 332)\n",
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 63.79621280432822 +/- 2.9906822963630897\n",
      "Params =  1 1 0.1\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 [1]:\n",
    "  for beta_param in [1]:\n",
    "      for gamma_param in [0.1]:\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",
    "#               A = A.cuda()\n",
    "#               theta = theta.cuda()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "#               C_0 = C_0.cuda()\n",
    "              L = theta\n",
    "#               L=L.cuda()\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": null,
   "id": "ab220098",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccedca60",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5202cb3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b73cfbd9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "101e059b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af238895",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "1b6c9f28",
   "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_29644\\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_29644\\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_29644\\1999241371.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:03<00:00,  2.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7944\n",
      "Accuracy = 0.6837992185151789 1 1 0.1\n",
      "Average accuracy = 68.37992185151789 +/- 0.0\n",
      "Params =  1 1 0.1\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 [1]:\n",
    "  for beta_param in [1]:\n",
    "      for gamma_param in [0.1]:\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",
    "#               A = A.cuda()\n",
    "#               theta = theta.cuda()\n",
    "              C_0 = experiment_structure(alpha_param,lambda_param,beta_param,gamma_param,C,theta,X,A)\n",
    "#               C_0 = C_0.cuda()\n",
    "              L = theta\n",
    "#               L=L.cuda()\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": 149,
   "id": "pqDLVv1Wn9RD",
   "metadata": {
    "id": "pqDLVv1Wn9RD"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvgAAAK9CAYAAABRtxg8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABRwklEQVR4nO3deXwV1f3/8fdNJIkKiAhJJLLIIogLUTbBKi7RqIhSS0VcWGopKuASF0hFIG4RqRgFFLVF3KggFVxQXFC0KrYYSqu0RBAQiwSJFpCgieTe3x/+uF+uE4bkcs18ZvJ6Ph55PGS4984J48y8z+eecyYUiUQiAgAAABAISV43AAAAAEDiEPABAACAACHgAwAAAAFCwAcAAAAChIAPAAAABAgBHwAAAAgQAj4AAAAQIAR8AAAAIEAI+AAAAECAEPABBM6uXbt0yy23qGXLlkpKSlL//v29btI+nXbaaTrttNPieu/QoUPVpk2bhLbnp2bNmqVQKKT169e7vm7ixIkKhUJx7aNNmzY6//zz43rv3oRCIU2cODGhnwkA1hHwAUN2h6iPPvqo2r8/7bTTdOyxx/6sbXjllVd8H4hmzpypyZMna8CAAXriiSd0ww03eN0kAADqzAFeNwCALa+88oqmT5/u65D/1ltvKSsrS/fff7/XTamx119/Pe73PvbYYwqHwwlsDQDAz6jgAwicr776Sk2aNEnY54XDYX3//fcJ+7w97dy5U5KUkpKilJSUuD6jQYMGSk1NTWSzAAA+RsAHAuDpp59W165ddeCBB6pp06a65JJL9MUXX8S85q9//at+/etfq1WrVkpNTVXLli11ww036Lvvvou+ZujQoZo+fbqkH8cu7/6RpPXr1ysUCukPf/iDpk+frrZt2+qggw7S2WefrS+++EKRSER33HGHjjjiCB144IG68MIL9c0338S04YUXXlDfvn3VokULpaamql27drrjjjtUVVUV87rdQ5GKi4vVu3dvHXjggTryyCM1Y8YM13+H3W18++23tXLlymj7lyxZIkkqLy/XjTfeqJYtWyo1NVUdO3bUH/7wB0UikZjPCYVCGjVqlJ555hkdc8wxSk1N1aJFi1z3/dBDD0Vf26JFC40cOVJbt27d6+916qmn6qCDDtLvf//76N/9dAz+559/rgsuuEAHH3yw0tPTdcMNN+i1116L+Z0k5xj8PY/Vo48+qnbt2ik1NVXdu3fXsmXLYvbxr3/9S0OHDlXbtm2VlpamzMxM/eY3v9HXX3/t+vvWxuOPP64zzjhD6enpSk1NVefOnfXwww/v9fWvv/66srOzlZaWps6dO+v55593vGbr1q26/vrro8eyffv2mjRp0j6/yfj22291/fXXq02bNkpNTVV6errOOussLV++fL9/TwCwgiE6gEHbtm1TWVmZY/sPP/zg2HbXXXfptttu08UXX6zf/va32rJli6ZOnapTTz1V//jHP6KV7Oeee047d+7U1VdfrcMOO0x///vfNXXqVP33v//Vc889J0kaMWKEvvzyS73xxht66qmnqm3bM888o8rKSo0ePVrffPON7r33Xl188cU644wztGTJEo0ZM0Zr1qzR1KlTddNNN2nmzJnR986aNUsNGzZUXl6eGjZsqLfeekvjx4/X9u3bNXny5Jj9/O9//9N5552niy++WIMGDdLcuXN19dVXKyUlRb/5zW+qbVvz5s311FNP6a677tKOHTtUWFgoSTr66KMViUR0wQUX6O2339aVV16p7Oxsvfbaa7r55pu1ceNGx3Cet956S3PnztWoUaPUrFkz10msEydOVEFBgXJycnT11VerpKREDz/8sJYtW6b3339fDRo0iL7266+/1rnnnqtLLrlEl19+uTIyMqr9zPLycp1xxhnatGmTrrvuOmVmZmr27Nl6++2399qOn5o9e7a+/fZbjRgxQqFQSPfee68uuugirV27NtqmN954Q2vXrtWwYcOUmZmplStX6tFHH9XKlSv14Ycfxj1hdk8PP/ywjjnmGF1wwQU64IAD9NJLL+maa65ROBzWyJEjY167evVqDRw4UFdddZWGDBmixx9/XL/+9a+1aNEinXXWWZJ+/NajT58+2rhxo0aMGKFWrVrpgw8+UH5+vjZt2qSioqK9tuWqq67SvHnzNGrUKHXu3Flff/213nvvPf3nP//RiSeeuN+/KwCYEAFgxuOPPx6R5PpzzDHHRF+/fv36SHJycuSuu+6K+ZyPP/44csABB8Rs37lzp2N/hYWFkVAoFPn888+j20aOHBmp7tKwbt26iKRI8+bNI1u3bo1uz8/Pj0iKdOnSJfLDDz9Etw8aNCiSkpIS+f77713bMGLEiMhBBx0U87o+ffpEJEXuu+++6LaKiopIdnZ2JD09PVJZWen8x9tDnz59Yv6dIpFIZMGCBRFJkTvvvDNm+4ABAyKhUCiyZs2a6DZJkaSkpMjKlStd9xOJRCJfffVVJCUlJXL22WdHqqqqotunTZsWkRSZOXOm4/eaMWNGtW3u06dP9M/33XdfRFJkwYIF0W3fffddpFOnThFJkbfffju6fciQIZHWrVtH/7z7WB122GGRb775Jrr9hRdeiEiKvPTSS9Ft1R2TP//5zxFJkXfffTe6bff/m+vWrXP995gwYYLj/5/q9pGbmxtp27ZtzLbWrVtHJEX+8pe/RLdt27Ytcvjhh0dOOOGE6LY77rgjcvDBB0c+/fTTmPePHTs2kpycHNmwYUN0m6TIhAkTon8+5JBDIiNHjnT9HQDA7xiiAxg0ffp0vfHGG46f448/PuZ1zz//vMLhsC6++GKVlZVFfzIzM9WhQ4eYau+BBx4Y/e/y8nKVlZWpd+/eikQi+sc//lHjtv3617/WIYccEv1zz549JUmXX365DjjggJjtlZWV2rhxY7Vt+Pbbb1VWVqZTTjlFO3fu1KpVq2L2c8ABB2jEiBHRP6ekpGjEiBH66quvVFxcXOP27vbKK68oOTlZ1157bcz2G2+8UZFIRK+++mrM9j59+qhz5877/Nw333xTlZWVuv7665WU9H+X1OHDh6tx48ZauHBhzOtTU1M1bNiwfX7uokWLlJWVpQsuuCC6LS0tTcOHD9/ne3cbOHCgDj300OifTznlFEnS2rVro9v2PCbff/+9ysrKdNJJJ0lSwoat7LmP3d9O9enTR2vXrtW2bdtiXtuiRQv98pe/jP65cePGGjx4sP7xj3+otLRU0o/fRp1yyik69NBDY/6/z8nJUVVVld599929tqVJkyb629/+pi+//DIhvxsAWMQQHcCgHj16qFu3bo7tuwPNbqtXr1YkElGHDh2q/Zw9h4Zs2LBB48eP14svvqj//e9/Ma/7achy06pVq5g/7w77LVu2rHb7nvtauXKlxo0bp7feekvbt293bUOLFi108MEHx2w76qijJP04xnx3CK2pzz//XC1atFCjRo1ith999NHRv9/TkUceWePPlaSOHTvGbE9JSVHbtm0dn5uVlVWjybSff/652rVr5xgi0759+xq1S3Ieq91hf89j8s0336igoEDPPvusvvrqq5jX1+b/Czfvv/++JkyYoKVLl0YnFe+5jz07jO3bt3f8znse98zMTK1evVr/+te/1Lx582r399PfY0/33nuvhgwZopYtW6pr164677zzNHjwYLVt2zbeXw8AzCHgAz4WDocVCoX06quvKjk52fH3DRs2lCRVVVXprLPO0jfffKMxY8aoU6dOOvjgg7Vx40YNHTq0VkssVrcft+2R/z+BdevWrerTp48aN26s22+/Xe3atVNaWpqWL1+uMWPGmFvmcc+qsx8+tzr7OiaSdPHFF+uDDz7QzTffrOzsbDVs2FDhcFjnnHNOQo7JZ599pjPPPFOdOnXSlClT1LJlS6WkpOiVV17R/fffH9c+wuGwzjrrLN1yyy3V/v3uDkF1Lr74Yp1yyimaP3++Xn/9dU2ePFmTJk3S888/r3PPPbfWbQEAiwj4gI+1a9dOkUhERx55pGuo+fjjj/Xpp5/qiSee0ODBg6Pb33jjDcdrEzGpsjpLlizR119/reeff16nnnpqdPu6deuqff2XX36p8vLymCr+p59+KklxPbW1devWevPNN/Xtt9/GVPF3Dw1q3bp1rT9zz/eVlJTEVIErKyu1bt065eTkxP25//73vxWJRGKOyZo1a+L6vOr873//0+LFi1VQUKDx48dHt69evTph+3jppZdUUVGhF198MeYbhb1NFl6zZo3jd/7pcW/Xrp127NgR97/t4YcfrmuuuUbXXHONvvrqK5144om66667CPgAAoMx+ICPXXTRRUpOTlZBQYFjqcdIJBJd6nB3JXfP10QiET3wwAOOz9wdqH+6xOP+qq4NlZWVeuihh6p9/a5du/TII4/EvPaRRx5R8+bN1bVr11rv/7zzzlNVVZWmTZsWs/3+++9XKBSKO9zl5OQoJSVFDz74YMzv9qc//Unbtm1T37594/rc3Nxcbdy4US+++GJ02/fff6/HHnssrs+rTnXHRJLrKjSJ2Me2bdv0+OOPV/v6L7/8UvPnz4/+efv27XryySeVnZ2tzMxMST9W4ZcuXarXXnvN8f6tW7dq165d1X52VVWVY9hRenq6WrRooYqKitr9YgBgGBV8wMfatWunO++8U/n5+Vq/fr369++vRo0aad26dZo/f75+97vf6aabblKnTp3Url073XTTTdq4caMaN26sv/zlL46x+JKi4fnaa69Vbm6ukpOTdckll+x3W3v37q1DDz1UQ4YM0bXXXqtQKKSnnnrKES53a9GihSZNmqT169frqKOO0pw5c7RixQo9+uijMXMLaqpfv346/fTTdeutt2r9+vXq0qWLXn/9db3wwgu6/vrr1a5du7h+r+bNmys/P18FBQU655xzdMEFF6ikpEQPPfSQunfvrssvvzyuzx0xYoSmTZumQYMG6brrrtPhhx+uZ555RmlpaZIS801L48aNdeqpp+ree+/VDz/8oKysLL3++ut7/VYlHmeffbZSUlLUr18/jRgxQjt27NBjjz2m9PR0bdq0yfH6o446SldeeaWWLVumjIwMzZw5U5s3b47pENx888168cUXdf7552vo0KHq2rWrysvL9fHHH2vevHlav369mjVr5vjsb7/9VkcccYQGDBigLl26qGHDhnrzzTe1bNky3XfffQn7nQHAawR8wOfGjh2ro446Svfff78KCgok/Tjh9eyzz46uwNKgQQO99NJLuvbaa1VYWKi0tDT98pe/1KhRo9SlS5eYz7vooos0evRoPfvss3r66acViUQSEvAPO+wwvfzyy7rxxhs1btw4HXroobr88st15plnKjc31/H6Qw89VE888YRGjx6txx57TBkZGZo2bVqtVpHZU1JSkl588UWNHz9ec+bM0eOPP642bdpo8uTJuvHGG/frd5s4caKaN2+uadOm6YYbblDTpk31u9/9TnfffXdcnRFJ0ecEjB49Wg888IAaNmyowYMHq3fv3vrVr34VDfr7a/bs2Ro9erSmT5+uSCSis88+W6+++qpatGiRkM/v2LGj5s2bp3Hjxummm25SZmamrr76ajVv3rza5xl06NBBU6dO1c0336ySkhIdeeSRmjNnTsz/IwcddJDeeecd3X333Xruuef05JNPqnHjxjrqqKNUUFAQM2l3TwcddJCuueYavf7669EVqNq3b6+HHnpIV199dUJ+XwCwIBTZW/kMADxy2mmnqaysTJ988onXTTGnqKhIN9xwg/773/8qKyvL6+YAAAxiDD4AGPXdd9/F/Pn777/XI488og4dOhDuAQB7xRAdADDqoosuUqtWrZSdna1t27bp6aef1qpVq/TMM8943TQAgGEEfAAwKjc3V3/84x/1zDPPqKqqSp07d9azzz6rgQMHet00AIBhjMEHAAAAfgbvvvuuJk+erOLiYm3atEnz589X//79Xd+zZMkS5eXlaeXKlWrZsqXGjRunoUOH1mq/jMEH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53Tbbbdp/fr16tChgyZNmqTzzjuvxvvzLOBzsQUA1BWKSnaRBxAPPz3oas6cOcrLy9OMGTPUs2dPFRUVKTc3VyUlJUpPT3e8/oMPPtCgQYNUWFio888/X7Nnz1b//v21fPlyHXvssTXaZygSiXjyHccv+r3jxW5RA9wI7eJGCACoS++91MfrJlTLyxxZ23+Tnj17qnv37po2bZokKRwOq2XLlho9erTGjh3reP3AgQNVXl6ul19+ObrtpJNOUnZ2tmbMmFGjfTLJFgAAAKihiooKbd++PeanoqKi2tdWVlaquLhYOTk50W1JSUnKycnR0qVLq33P0qVLY14vSbm5uXt9fXU8G6JjtUdYWxUVFSosLFR+fr5SU1O9bk6CBGfN26AdH6uTneIRtGMTJBwb2zg+dnFs6o6XOXLixIkqKCiI2TZhwgRNnDjR8dqysjJVVVUpIyMjZntGRoZWrVpV7eeXlpZW+/rS0tIat5EK/n6qqKhQQUHBXntu8BbHxy6OjV0cG9s4PnZxbOqH/Px8bdu2LeYnPz/f62bFYJlMAAAAoIZSU1Nr/A1Ns2bNlJycrM2bN8ds37x5szIzM6t9T2ZmZq1eXx0q+AAAAMDPICUlRV27dtXixYuj28LhsBYvXqxevXpV+55evXrFvF6S3njjjb2+vjpU8AEAAICfSV5enoYMGaJu3bqpR48eKioqUnl5uYYNGyZJGjx4sLKyslRYWChJuu6669SnTx/dd9996tu3r5599ll99NFHevTRmq+kR8DfT6mpqZowYQKTaYzi+NjFsbGLY2Mbx8cujg2qM3DgQG3ZskXjx49XaWmpsrOztWjRouhE2g0bNigp6f8G1fTu3VuzZ8/WuHHj9Pvf/14dOnTQggULarwGvuThOvgAAAAAEo8x+AAAAECAEPABAACAACHgAwAAAAFCwAcAAAAChIC/n6ZPn642bdooLS1NPXv21N///nevmwRJ7777rvr166cWLVooFAppwYIFXjcJ/19hYaG6d++uRo0aKT09Xf3791dJSYnXzYKkhx9+WMcff7waN26sxo0bq1evXnr11Ve9bhaqcc899ygUCun666/3uimQNHHiRIVCoZifTp06ed0s1GME/P0wZ84c5eXlacKECVq+fLm6dOmi3NxcffXVV143rd4rLy9Xly5dNH36dK+bgp945513NHLkSH344Yd644039MMPP+jss89WeXm5102r94444gjdc889Ki4u1kcffaQzzjhDF154oVauXOl107CHZcuW6ZFHHtHxxx/vdVOwh2OOOUabNm2K/rz33nteNwn1GMtk7oeePXuqe/fumjZtmqQfn0zWsmVLjR49WmPHjvW4ddgtFApp/vz56t+/v9dNQTW2bNmi9PR0vfPOOzr11FO9bg5+omnTppo8ebKuvPJKr5sCSTt27NCJJ56ohx56SHfeeaeys7NVVFTkdbPqvYkTJ2rBggVasWKF100BJFHBj1tlZaWKi4uVk5MT3ZaUlKScnBwtXbrUw5YB/rJt2zZJPwZJ2FFVVaVnn31W5eXltXo8On5eI0eOVN++fWPuPbBh9erVatGihdq2bavLLrtMGzZs8LpJqMd4km2cysrKVFVVFX0K2W4ZGRlatWqVR60C/CUcDuv666/XySefXKsn9OHn8/HHH6tXr176/vvv1bBhQ82fP1+dO3f2ulmQ9Oyzz2r58uVatmyZ103BT/Ts2VOzZs1Sx44dtWnTJhUUFOiUU07RJ598okaNGnndPNRDBHwAnhk5cqQ++eQTxqoa0rFjR61YsULbtm3TvHnzNGTIEL3zzjuEfI998cUXuu666/TGG28oLS3N6+bgJ84999zofx9//PHq2bOnWrdurblz5zK8DZ4g4MepWbNmSk5O1ubNm2O2b968WZmZmR61CvCPUaNG6eWXX9a7776rI444wuvm4P9LSUlR+/btJUldu3bVsmXL9MADD+iRRx7xuGX1W3Fxsb766iudeOKJ0W1VVVV69913NW3aNFVUVCg5OdnDFmJPTZo00VFHHaU1a9Z43RTUU4zBj1NKSoq6du2qxYsXR7eFw2EtXryY8aqAi0gkolGjRmn+/Pl66623dOSRR3rdJLgIh8OqqKjwuhn13plnnqmPP/5YK1asiP5069ZNl112mVasWEG4N2bHjh367LPPdPjhh3vdFNRTVPD3Q15enoYMGaJu3bqpR48eKioqUnl5uYYNG+Z10+q9HTt2xFRO1q1bpxUrVqhp06Zq1aqVhy3DyJEjNXv2bL3wwgtq1KiRSktLJUmHHHKIDjzwQI9bV7/l5+fr3HPPVatWrfTtt99q9uzZWrJkiV577TWvm1bvNWrUyDFP5eCDD9Zhhx3G/BUDbrrpJvXr10+tW7fWl19+qQkTJig5OVmDBg3yummopwj4+2HgwIHasmWLxo8fr9LSUmVnZ2vRokWOibeoex999JFOP/306J/z8vIkSUOGDNGsWbM8ahWkHx+mJEmnnXZazPbHH39cQ4cOrfsGIeqrr77S4MGDtWnTJh1yyCE6/vjj9dprr+mss87yummAaf/97381aNAgff3112revLl+8Ytf6MMPP1Tz5s29bhrqKdbBBwAAAAKEMfgAAABAgBDwAQAAgAAh4AMAAAABQsAHAAAAAoSADwAAAAQIAR8AAAAIEAI+AAAAECAEfAAAACBACPgAUEuzZs1SkyZN9vtzQqGQFixYsN+fAwDAngj4AOqloUOHqn///l43AwCAhCPgAwAAAAFCwAeAn5gyZYqOO+44HXzwwWrZsqWuueYa7dixw/G6BQsWqEOHDkpLS1Nubq6++OKLmL9/4YUXdOKJJyotLU1t27ZVQUGBdu3aVe0+KysrNWrUKB1++OFKS0tT69atVVhY+LP8fgCAYCPgA8BPJCUl6cEHH9TKlSv1xBNP6K233tItt9wS85qdO3fqrrvu0pNPPqn3339fW7du1SWXXBL9+7/+9a8aPHiwrrvuOv373//WI488olmzZumuu+6qdp8PPvigXnzxRc2dO1clJSV65pln1KZNm5/z1wQABFQoEolEvG4EANS1oUOHauvWrTWa5Dpv3jxdddVVKisrk/TjJNthw4bpww8/VM+ePSVJq1at0tFHH62//e1v6tGjh3JycnTmmWcqPz8/+jlPP/20brnlFn355ZeSfpxkO3/+fPXv31/XXnutVq5cqTfffFOhUCjxvzAAoN6ggg8AP/Hmm2/qzDPPVFZWlho1aqQrrrhCX3/9tXbu3Bl9zQEHHKDu3btH/9ypUyc1adJE//nPfyRJ//znP3X77berYcOG0Z/hw4dr06ZNMZ+z29ChQ7VixQp17NhR1157rV5//fWf/xcFAAQSAR8A9rB+/Xqdf/75Ov744/WXv/xFxcXFmj59uqQfx8nX1I4dO1RQUKAVK1ZEfz7++GOtXr1aaWlpjtefeOKJWrdune644w599913uvjiizVgwICE/V4AgPrjAK8bAACWFBcXKxwO67777lNS0o81kLlz5zpet2vXLn300Ufq0aOHJKmkpERbt27V0UcfLenHwF5SUqL27dvXeN+NGzfWwIEDNXDgQA0YMEDnnHOOvvnmGzVt2jQBvxkAoL4g4AOot7Zt26YVK1bEbGvWrJl++OEHTZ06Vf369dP777+vGTNmON7boEEDjR49Wg8++KAOOOAAjRo1SieddFI08I8fP17nn3++WrVqpQEDBigpKUn//Oc/9cknn+jOO+90fN6UKVN0+OGH64QTTlBSUpKee+45ZWZmJuSBWgCA+oUhOgDqrSVLluiEE06I+Xnqqac0ZcoUTZo0Sccee6yeeeaZaperPOiggzRmzBhdeumlOvnkk9WwYUPNmTMn+ve5ubl6+eWX9frrr6t79+466aSTdP/996t169bVtqVRo0a699571a1bN3Xv3l3r16/XK6+8Ev0WAQCAmmIVHQAAACBAKA0BAAAAAULABwAAAAKEgA8AAAAECAEfAAAACBACPgAAABAgBHwAAAAgQAj4AAAAQIAQ8AEAAIAAIeADAAAAAULABwAAAAKEgA8AAAAEyP8D4eL4C8QgTToAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAv0AAAK9CAYAAAC3ntN4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABXrElEQVR4nO3deXgUVdr38V93lk4IEEQhAQRkE1xQFAVZFBXGuKEojOKDIygijwMi4MqMG24ZdQREcZtFUOFxUASXURgFBXUAFcVxBVRwQRYBQ0iAbF3vHw790nQ6STVNzqnK93NduS6oVHfd6e7qvvuu+5wTcBzHEQAAAADfCpoOAAAAAMCBRdIPAAAA+BxJPwAAAOBzJP0AAACAz5H0AwAAAD5H0g8AAAD4HEk/AAAA4HMk/QAAAIDPkfQDAAAAPkfSD2C/lJeX68Ybb1TLli0VDAY1YMCAA3q8U089Vaeeeqrr261bt06BQEB//vOfkxbL22+/rUAgoLfffjtp91kT8+fPV5cuXZSRkaFAIKCCgoJaPT7+P1OvAQBwi6Qfddb06dMVCAT04YcfVvr7U089VUcfffQBjeG1117THXfccUCPcaD9/e9/1wMPPKBBgwZpxowZGjdunOmQfG3r1q266KKLlJmZqWnTpumZZ55RVlaW7r33Xs2bN890eAAAS6WaDgCoy1577TVNmzbN04n/okWL1KJFC02ePNl0KHXCBx98oB07duiuu+5Sv379ItvvvfdeDRo06IBfaUG0U045Rbt27VJ6errpUACgSlT6AeyXzZs3q1GjRkm7v3A4rN27dyft/vxm8+bNkpTUxzye3bt3KxwOH/Dj7K+dO3caO3YwGFRGRoaCQT5OAdiNdynApWeffVZdu3ZVZmamGjdurMGDB+uHH36I2uedd97Rb3/7W7Vq1UqhUEgtW7bUuHHjtGvXrsg+w4YN07Rp0yRJgUAg8iNF959PmzZNbdu2Vb169XTGGWfohx9+kOM4uuuuu3TooYcqMzNT559/vrZt2xYVw0svvaRzzjlHzZs3VygUUrt27XTXXXepoqIiar89bUwrVqxQz549lZmZqTZt2ujxxx+v8nHYE+Nbb72lzz//PBL/nt7m4uJiXXfddWrZsqVCoZA6duyoP//5z3IcJ+p+AoGARo8erZkzZ+qoo45SKBTS/Pnza/x8lJaW6rbbblPXrl2VnZ2trKwsnXzyyXrrrbfi3mby5Mlq3bq1MjMz1adPH3322Wcx+3z11VcaNGiQGjdurIyMDJ1wwgl6+eWXq41nzZo1GjhwoHJzc5WRkaFDDz1UgwcP1vbt26u8XU1eM6eeeqqGDh0qSTrxxBMVCAQ0bNgwBQIBFRcXa8aMGZHnYdiwYZHbrV+/XldccYVycnIUCoV01FFH6e9//3vU8ff0pj/33HO65ZZb1KJFC9WrV0+FhYVxYw6Hw3rooYfUuXNnZWRkqEmTJjrzzDOjWubKy8t11113qV27dgqFQjrssMP0hz/8QSUlJVH3lcjr9ZRTTlG9evX0hz/8QZL04YcfKi8vT4ccckjkdXzFFVfExDxlyhQdddRRysjIUE5OjkaOHKlffvklar/DDjtM5557rt59911169ZNGRkZatu2rZ5++ulKH7e9e/r3xPjFF1/otNNOU7169dSiRQvdf//9MY/hd999p/POO09ZWVlq2rSpxo0bpwULFjBOAEDS0d6DOm/79u3asmVLzPaysrKYbffcc49uvfVWXXTRRbryyiv1888/6+GHH9Ypp5yijz/+OFJ9ff7557Vz505dffXVOvjgg/X+++/r4Ycf1o8//qjnn39ekjRy5Ej99NNPeuONN/TMM89UGtvMmTNVWlqqa665Rtu2bdP999+viy66SKeffrrefvtt3XTTTfr666/18MMP6/rrr49K5KZPn6769etr/Pjxql+/vhYtWqTbbrtNhYWFeuCBB6KO88svv+jss8/WRRddpEsuuUSzZ8/W1VdfrfT09JikaY8mTZromWee0T333KOioiLl5+dLko444gg5jqPzzjtPb731loYPH64uXbpowYIFuuGGG7R+/fqYVqBFixZp9uzZGj16tA455BAddthhlT9ZlSgsLNRf//pXXXLJJRoxYoR27Nihv/3tb8rLy9P777+vLl26RO3/9NNPa8eOHRo1apR2796thx56SKeffro+/fRT5eTkSJI+//xz9erVSy1atNDNN9+srKwszZ49WwMGDNCcOXN0wQUXVBpLaWmp8vLyVFJSomuuuUa5ublav369Xn31VRUUFCg7Ozvu31GT18wf//hHdezYUU8++aTuvPNOtWnTRu3atVO/fv105ZVXqlu3brrqqqskSe3atZMkbdq0SSeddFLky1WTJk30+uuva/jw4SosLNTYsWOj4rjrrruUnp6u66+/XiUlJVW2rQwfPlzTp0/XWWedpSuvvFLl5eV65513tGzZMp1wwgmSpCuvvFIzZszQoEGDdN1112n58uXKz8/Xl19+qblz50buy83rdevWrTrrrLM0ePBgXXrppcrJydHmzZt1xhlnqEmTJrr55pvVqFEjrVu3Ti+++GLUbUeOHKnp06fr8ssv15gxY7R27Vo98sgj+vjjj/Xee+8pLS0tsu/XX3+tQYMGafjw4Ro6dKj+/ve/a9iwYeratauOOuqouI+L9Os5deaZZ+rCCy/URRddpBdeeEE33XSTOnfurLPOOkvSr1+MTz/9dG3YsEHXXnutcnNzNWvWrCq/sAJAwhygjnrqqaccSVX+HHXUUZH9161b56SkpDj33HNP1P18+umnTmpqatT2nTt3xhwvPz/fCQQCznfffRfZNmrUKKey03Dt2rWOJKdJkyZOQUFBZPuECRMcSc6xxx7rlJWVRbZfcsklTnp6urN79+4qYxg5cqRTr169qP369OnjSHIefPDByLaSkhKnS5cuTtOmTZ3S0tLYB28vffr0iXqcHMdx5s2b50hy7r777qjtgwYNcgKBgPP1119HtklygsGg8/nnn1d5nL2P16dPn8j/y8vLnZKSkqh9fvnlFycnJ8e54oorItv2PKaZmZnOjz/+GNm+fPlyR5Izbty4yLa+ffs6nTt3jnqcwuGw07NnT6dDhw6RbW+99ZYjyXnrrbccx3Gcjz/+2JHkPP/88zX6W/ZW09fMntftBx98ELVvVlaWM3To0Jj7GD58uNOsWTNny5YtUdsHDx7sZGdnR467529p27ZtpbHsa9GiRY4kZ8yYMTG/C4fDjuM4zsqVKx1JzpVXXhn1++uvv96R5CxatCiyze3r9fHHH4/ad+7cuZU+Lnt75513HEnOzJkzo7bPnz8/Znvr1q0dSc6SJUsi2zZv3uyEQiHnuuuui2zb9zWwd4xPP/10ZFtJSYmTm5vrDBw4MLLtwQcfdCQ58+bNi2zbtWuX06lTp5j7BID9RXsP6rxp06bpjTfeiPk55phjovZ78cUXFQ6HddFFF2nLli2Rn9zcXHXo0CGqOpeZmRn5d3FxsbZs2aKePXvKcRx9/PHHNY7tt7/9bVR1uHv37pKkSy+9VKmpqVHbS0tLtX79+kpj2LFjh7Zs2aKTTz5ZO3fu1FdffRV1nNTUVI0cOTLy//T0dI0cOVKbN2/WihUrahzvHq+99ppSUlI0ZsyYqO3XXXedHMfR66+/HrW9T58+OvLII10fR5JSUlIi1ehwOKxt27apvLxcJ5xwgj766KOY/QcMGKAWLVpE/t+tWzd1795dr732miRp27ZtWrRokS666KLI47ZlyxZt3bpVeXl5WrNmTdTjvLc9z9WCBQtc95kn6zWzN8dxNGfOHPXv31+O40S9bvPy8rR9+/aYx2jo0KFRscQzZ84cBQIB3X777TG/29OmtucxHT9+fNTvr7vuOknSP//5z8g2N6/XUCikyy+/PGrbnqtsr776aqVX6aRfr6ZkZ2frN7/5TdRj0bVrV9WvXz+mwn7kkUfq5JNPjvy/SZMm6tixo7799ttK739v9evX16WXXhr5f3p6urp16xZ12/nz56tFixY677zzItsyMjI0YsSIau8fANyivQd1Xrdu3SKtCHs76KCDotp+1qxZI8dx1KFDh0rvZ++2gO+//1633XabXn755Zhe4ep6u/fWqlWrqP/vSSpbtmxZ6fa9j/X555/rlltu0aJFi2L6sveNoXnz5srKyoradvjhh0v6tXf/pJNOqnHM0q99ys2bN1eDBg2ith9xxBGR3++tTZs2ru5/XzNmzNCDDz6or776Kirhq+x+K3v+Dj/8cM2ePVvSry0djuPo1ltv1a233lrp8TZv3hz1xWHv440fP16TJk3SzJkzdfLJJ+u8887TpZdeWmVrj5S818zefv75ZxUUFOjJJ5/Uk08+Gfdv2fdvqIlvvvlGzZs3V+PGjePu89133ykYDKp9+/ZR23Nzc9WoUaOo14Gb12uLFi1i2o769OmjgQMHauLEiZo8ebJOPfVUDRgwQP/zP/+jUCgk6ddzePv27WratGml8e77WOx7/km/vi/s+/xU5tBDD418+dn7tv/5z38i///uu+/Url27mP32fbwAIBlI+oEaCofDCgQCev3115WSkhLz+/r160uSKioq9Jvf/Ebbtm3TTTfdpE6dOikrK0vr16/XsGHDXM2GUtlxqtru/HeQbEFBgfr06aOGDRvqzjvvVLt27ZSRkaGPPvpIN910k3UzstSkshzPs88+q2HDhmnAgAG64YYb1LRpU6WkpCg/P1/ffPON6/vb89hcf/31ysvLq3SfqpKyBx98UMOGDdNLL72kf/3rXxozZozy8/O1bNkyHXrooZXeJpmvmcr+lksvvTQyAHhf+17R2p/nIp59k9p9uX29VhZjIBDQCy+8oGXLlumVV17RggULdMUVV+jBBx/UsmXLVL9+fYXDYTVt2lQzZ86sNI4mTZpE/b+686wq+3NbADgQSPqBGmrXrp0cx1GbNm0iVfDKfPrpp1q9erVmzJihyy67LLL9jTfeiNm3umQoUW+//ba2bt2qF198Uaecckpk+9q1ayvd/6efflJxcXFUtX/16tWS5GpQ7R6tW7fWm2++qR07dkRV+/e0abRu3dr1fcbzwgsvqG3btnrxxRejHs/K2k6kX6u9+1q9enXk72zbtq2kX6/c7D0PvhudO3dW586ddcstt+jf//63evXqpccff1x33313pfu7ec3EU9lrqUmTJmrQoIEqKioS/lviadeunRYsWKBt27bFrfa3bt1a4XBYa9asiVzlkX4dXFxQUBB5Hbh9vVblpJNO0kknnaR77rlHs2bN0pAhQ/Tcc8/pyiuvVLt27fTmm2+qV69eB+TLjVutW7fWF198Icdxop6/r7/+2mBUAPyKnn6ghi688EKlpKRo4sSJMdU6x3G0detWSf+/wrf3Po7j6KGHHoq5zz1JdkFBQVJjrSyG0tJSPfroo5XuX15erieeeCJq3yeeeEJNmjRR165dXR//7LPPVkVFhR555JGo7ZMnT1YgEIjMXpIMlf2ty5cv19KlSyvdf968eVE9+e+//76WL18eialp06Y69dRT9cQTT2jDhg0xt//555/jxlJYWKjy8vKobZ07d1YwGIyZorK6vyHeayaerKysmNdRSkqKBg4cqDlz5lQ6LWlVf0t1Bg4cKMdxNHHixJjf7fk7zj77bEnSlClTon4/adIkSdI555wTiXPv20lVv14r88svv8Scl3tmbtrz2F900UWqqKjQXXfdFXP78vLypJ+H1cnLy9P69eujpoLdvXu3/vKXv9RqHADqBir9QA21a9dOd999tyZMmKB169ZpwIABatCggdauXau5c+fqqquu0vXXX69OnTqpXbt2uv7667V+/Xo1bNhQc+bMqbQPeE9CPWbMGOXl5SklJUWDBw/e71h79uypgw46SEOHDtWYMWMUCAT0zDPPxG0taN68ue677z6tW7dOhx9+uP7xj39o5cqVevLJJ6PGKtRU//79ddppp+mPf/yj1q1bp2OPPVb/+te/9NJLL2ns2LGR6SST4dxzz9WLL76oCy64QOecc47Wrl2rxx9/XEceeaSKiopi9m/fvr169+6tq6++WiUlJZoyZYoOPvhg3XjjjZF9pk2bpt69e6tz584aMWKE2rZtq02bNmnp0qX68ccf9cknn1Qay6JFizR69Gj99re/1eGHH67y8nI988wzkeQ7HjevmXi6du2qN998U5MmTVLz5s3Vpk0bde/eXX/605/01ltvqXv37hoxYoSOPPJIbdu2TR999JHefPPNmPUdauq0007T7373O02dOlVr1qzRmWeeqXA4rHfeeUennXaaRo8erWOPPVZDhw7Vk08+GWnhef/99zVjxgwNGDBAp512miT3r9fKzJgxQ48++qguuOACtWvXTjt27NBf/vIXNWzYMPLlo0+fPho5cqTy8/O1cuVKnXHGGUpLS9OaNWv0/PPP66GHHtKgQYMSejwSMXLkSD3yyCO65JJLdO2116pZs2aaOXOmMjIyJB24K4EA6qjamiYIsE28qQ/3qGwqSsdxnDlz5ji9e/d2srKynKysLKdTp07OqFGjnFWrVkX2+eKLL5x+/fo59evXdw455BBnxIgRzieffOJIcp566qnIfuXl5c4111zjNGnSxAkEApHpO/dML/nAAw9EHXvP9ID7TglZ2d/y3nvvOSeddJKTmZnpNG/e3LnxxhudBQsWVDq94FFHHeV8+OGHTo8ePZyMjAyndevWziOPPFKjxzHe47Rjxw5n3LhxTvPmzZ20tDSnQ4cOzgMPPBCZznEPSc6oUaNqdKw9x9t7ys5wOOzce++9TuvWrZ1QKOQcd9xxzquvvuoMHTrUad26dWS/vR/TBx980GnZsqUTCoWck08+2fnkk09ijvPNN984l112mZObm+ukpaU5LVq0cM4991znhRdeiOyz73SN3377rXPFFVc47dq1czIyMpzGjRs7p512mvPmm29W+3fV9DUT73X71VdfOaeccoqTmZnpSIqavnPTpk3OqFGjnJYtWzppaWlObm6u07dvX+fJJ5+M+VvcTDdaXl7uPPDAA06nTp2c9PR0p0mTJs5ZZ53lrFixIrJPWVmZM3HiRKdNmzZOWlqa07JlS2fChAlR03A6jvvX674++ugj55JLLnFatWrlhEIhp2nTps65557rfPjhhzH7Pvnkk07Xrl2d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",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_nodes = len(labels)\n",
    "num_labels = len(set(labels))\n",
    "\n",
    "# Initialize the Y matrix with zeros\n",
    "Y = np.zeros((num_nodes, num_labels))\n",
    "\n",
    "# Fill in the one-hot encoded values\n",
    "for node_idx, label_idx in enumerate(labels):\n",
    "    Y[node_idx, label_idx] = 1\n",
    "C_t_0=C_0.T\n",
    "Phi = C_t_0@Y \n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 8))\n",
    "sns.heatmap(Y, cmap=\"coolwarm\", cbar=True, xticklabels=True, yticklabels=False)\n",
    "plt.xlabel(\"Labels\")\n",
    "plt.ylabel(\"Nodes\")\n",
    "plt.title(\"Heatmap for original labels\")\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 8))\n",
    "sns.heatmap(Phi, cmap=\"coolwarm\", cbar=True, xticklabels=True, yticklabels=False)\n",
    "plt.xlabel(\"Labels\")\n",
    "plt.ylabel(\"Nodes\")\n",
    "plt.title(\"Heatmap for labels after coarsening\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "063541db",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hm= sns.heatmap(data = Phi)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48af3559",
   "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
}
