{
 "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_36796\\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_36796\\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.3)\n",
    "n = X.shape[1]\n",
    "lr = 1e-5\n",
    "thresh = 1e-10\n",
    "\n",
    "from scipy.sparse import random\n",
    "from scipy.stats import rv_continuous\n",
    "class CustomDistribution(rv_continuous):\n",
    "    def _rvs(self,  size=None, random_state=None):\n",
    "        return random_state.standard_normal(size)\n",
    "temp = CustomDistribution(seed=1)\n",
    "temp2 = temp()  # get a frozen version of the distribution\n",
    "C = random(p, k, density=0.25, random_state=1, data_rvs=temp2.rvs)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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.3)\n",
    "      n = X.shape[1]\n",
    "      ones = csr_matrix(np.ones((k,k)))\n",
    "      ones = convertScipyToTensor(ones)  \n",
    "      ones = ones.to_dense()\n",
    "      \n",
    "      try:\n",
    "        C = convertScipyToTensor(C)\n",
    "        C = C.to_dense()\n",
    "      except:\n",
    "        C=C\n",
    "      try:\n",
    "        theta = convertScipyToTensor(theta)\n",
    "      except:\n",
    "        theta = theta\n",
    "      try:\n",
    "        X = convertScipyToTensor(X)\n",
    "        X = X.to_dense()\n",
    "      except:\n",
    "        X = X\n",
    "      if(torch.cuda.is_available()):\n",
    "        print(\"GPU is available\")\n",
    "        C = C  \n",
    "        theta = theta  \n",
    "        X = X  \n",
    "        ones = ones  \n",
    "      \n",
    "        \n",
    "      def bracket_term2fun(C,CT,theta):\n",
    "          # U  = update_V(C,theta).double()\n",
    "          U = torch.stack(update_V(C, theta)).double()\n",
    "          UT= torch.transpose(U,0,1)\n",
    "          Lw = (CT @theta @C).double()\n",
    "          lb= 1e-5\n",
    "          ub = 1e+4\n",
    "          beta = 0.5 \n",
    "          lambda_ =  laplacian_lambda_update(lb, ub, beta, U, Lw, k_,C)   \n",
    "          lambda_matrix =  torch.diag(lambda_,0)  \n",
    "          # print(lambda_matrix)\n",
    "          # print(f'Shape of U is: {U.shape}')\n",
    "          # print(f'Shape of lambda: {}')\n",
    "          # print(f'Shape of lambda_matrix is: {lambda_matrix.shape}')\n",
    "          return UT@lambda_matrix@U\n",
    "        \n",
    "      def update_V(C,theta):\n",
    "            \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        product = CT @ A @ C               \n",
    "        matrix = torch.tensor(product)         \n",
    "        eigenvalues, eigenvectors = torch.linalg.eig(product)\n",
    "\n",
    "        # select non-zero eigenvalues and eigenvectors\n",
    "        non_zero_eigenvalues = []\n",
    "        non_zero_eigenvectors = []\n",
    "          \n",
    "        # for i in range(matrix.shape[0]):\n",
    "        #     if matrix[i, i] != 0:\n",
    "        #         non_zero_eigenvalues.append(eigenvalues[i])\n",
    "        #         non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        # U = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        # return U    \n",
    "\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if eigenvalues[i] != 0:\n",
    "                non_zero_eigenvalues.append(eigenvalues[i])\n",
    "                non_zero_eigenvectors.append(eigenvectors[:, i])\n",
    "        V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
    "        return V \n",
    " \n",
    "\n",
    "      def update_C(C):\n",
    "          CT = torch.transpose(C,0,1)\n",
    "          C.size()\n",
    "          t1 = alpha_param*(C@ones)  \n",
    "          bracket_term1 = (CT@theta@C)\n",
    "          bracket_term3 = (CT@A@C)\n",
    "          bracket_term2 = bracket_term2fun(C,CT,theta) \n",
    "          bracket_term = bracket_term3 - bracket_term2             # bracket term (CT*A*C - U*lambda*UT)\n",
    "          t22 = -2*(theta@C)                                      # Check for multiplication of gamma\n",
    "#           print(t22.type())\n",
    "          t3 = bracket_term1\n",
    "          t7 = bracket_term2\n",
    "          t6 = (CT@A@C)  \n",
    "          t5 = 2* beta_param*(A@C)\n",
    "          t5 = t5.float()\n",
    "          t4 = (1.0/k)\n",
    "          t44 = t4*((torch.ones(k,k)).double())  \n",
    "#           print(t3.device)\n",
    "#           print(t44.device)\n",
    "          t8 = (t3 + t44)  \n",
    "          t9 = torch.pinverse(t8)                  \n",
    "          t9 = t9.float()\n",
    "#           print(t9.type())\n",
    "#           print(t9)x\n",
    "          t10 = (t22@t9)  \n",
    "          t11 = (t6 - t7)  \n",
    "          t11 = t11.float()\n",
    "          t12 = (t5@t11)\n",
    "          t13 = (t1 + t10 +t12)  \n",
    "        \n",
    "          #t2 = beta_param*(theta@C@bracket_term.float())\n",
    "          grad_fc= t13\n",
    "          C_new=C-gamma_param*grad_fc\n",
    "          C_new[C_new<thresh] = thresh\n",
    "          for i in range(len(C_new)):\n",
    "              C_new[i] = C_new[i]/torch.linalg.norm(C_new[i],1)\n",
    "          return C_new        \n",
    "            \n",
    "\n",
    "        \n",
    "        \n",
    "        \n",
    "\n",
    "\n",
    "      #We set c1 = 10−5 and c2 = 10^4 We observed that the experimental performances of the algorithms \n",
    "       #are not sensitive to different values of c1 and c2 as long as they are reasonably small and large,respectively\n",
    "      # K is the number of smallest eigenvalues of the Laplacian matrix that are being ignored while updating the eigenvalues.\n",
    "      def laplacian_lambda_update(lb, ub, beta, U, Lw, k, C):\n",
    "        q = Lw.size(1) - k\n",
    "        # print(f'q is: {q}')\n",
    "        U = U\n",
    "        UT= torch.transpose(U,0,1)\n",
    "        UT = UT.type(torch.float64)\n",
    "        UT = UT\n",
    "        \n",
    "        CT= torch.transpose(C,0,1)\n",
    "        CT = CT.type(torch.float64)\n",
    "        CT = CT\n",
    "        \n",
    "        AC=(A@C).double()\n",
    "        AC = AC\n",
    "        \n",
    "        Af=(CT@AC).double()\n",
    "        Af = Af  \n",
    "        Af.device\n",
    "        U.device\n",
    "        dd = U@Af@UT\n",
    "          \n",
    "        # cc = UT@A@U\n",
    "        \n",
    "        product = dd\n",
    "        matrix = torch.tensor(product)     \n",
    "\n",
    "        non_zero_diag_elements = []\n",
    "        for i in range(matrix.shape[0]):\n",
    "            if matrix[i, i] != 0:\n",
    "                non_zero_diag_elements.append(matrix[i, i])\n",
    "            if len(non_zero_diag_elements) == len(matrix):\n",
    "                break\n",
    "\n",
    "        k = len(non_zero_diag_elements)\n",
    "        e = non_zero_diag_elements\n",
    "        d = torch.diag(torch.tensor(non_zero_diag_elements))\n",
    "#-----------------------------------------------------------------------------------------------------------------------------------------------\n",
    "\n",
    "       # Trial-2                 -########################################\n",
    "\n",
    "        e_bar = torch.tensor([])\n",
    "        if(k%2 == 0):\n",
    "            for i in range(k//2):\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)\n",
    "            \n",
    "        if(k%2 != 0):\n",
    "            for i in range((k+1)//2) :\n",
    "                e_bar = torch.cat((e_bar, ((e[i] - e[k - i - 1]) / 2).unsqueeze(0)), dim=0)       \n",
    "                \n",
    "        lambda_,indices = torch.sort(e_bar, dim=- 1, descending=True)\n",
    "        eps = 1\n",
    "        qq = lambda_.size(0)-1\n",
    "        condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "\n",
    "#                                   (lambda_[1:(q)] - lambda_[0:(q-1)]) >= -eps])\n",
    "        \n",
    "          \n",
    "        if condition.all():\n",
    "            # while(lambda_.size(0) != 135):\n",
    "            #     lambda_ = torch.cat((lambda_, torch.tensor(0).unsqueeze(0)), dim=0)\n",
    "            for i in range(k//2):\n",
    "                lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)\n",
    "            # print(f'Shape of updated lambda1_ is: {lambda_.shape}')\n",
    "            # hm= sns.heatmap(data =lambda_)\n",
    "            # plt.show()\n",
    "            # print(lambda_)\n",
    "            return lambda_\n",
    "        else:\n",
    "            greater_ub = lambda_ > ub\n",
    "            lesser_lb = lambda_ < lb\n",
    "            lambda_[greater_ub] = ub\n",
    "            lambda_[lesser_lb] = lb\n",
    "            condition = torch.stack([(lambda_[qq] - ub) <= eps,\n",
    "                         (lambda_[0] - lb) >= -eps]).all(dim=0)\n",
    "        for i in range(k//2):\n",
    "            lambda_ = torch.cat((lambda_, -lambda_[(k//2)-1-i].unsqueeze(0)), dim=0)            \n",
    "            \n",
    "\n",
    "        print(f'Shape of updated lambda2_ is: {lambda_.shape}')\n",
    "        if condition.all():\n",
    "            return lambda_\n",
    "        else:\n",
    "#           print(lambda_)\n",
    "            raise ValueError(\"eigenvalues are not in increasing order, consider increasing the value of beta\")\n",
    "\n",
    "      for i in tqdm(range(10)): #update C only 21\n",
    "         C = update_C(C)\n",
    "            \n",
    "      return C\n",
    "          "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "556afd48",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "556afd48",
    "outputId": "74fb6a74-035c-421d-bd91-b4a480f9a291"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2387417581.py:13: UserWarning: torch.sparse.SparseTensor(indices, values, shape, *, device=) is deprecated.  Please use torch.sparse_coo_tensor(indices, values, shape, dtype=, device=). (Triggered internally at C:\\cb\\pytorch_1000000000000\\work\\torch\\csrc\\utils\\tensor_new.cpp:607.)\n",
      "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/10 [00:00<?, ?it/s]C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:33: UserWarning: Casting complex values to real discards the imaginary part (Triggered internally at C:\\cb\\pytorch_1000000000000\\work\\aten\\src\\ATen\\native\\Copy.cpp:299.)\n",
      "  U = torch.stack(update_V(C, theta)).double()\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Accuracy = 0.21190261496844004 1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/10 [00:00<?, ?it/s]C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_22812\\2793157037.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:58<00:00,  5.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.1151187255786 +/- 0.07514277126540458\n",
      "Params =  1000 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [01:04<00:00,  6.45s/it]\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:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.91974752028855 +/- 0.03005710850616239\n",
      "Params =  1000 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Accuracy = 0.21370604147880973 1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Accuracy = 0.2146077547339946 1000 1000 10\n",
      "Average accuracy = 21.415689810640217 +/- 0.04508566275924358\n",
      "Params =  1000 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.14517583408476 +/- 0.015028554253081194\n",
      "Params =  1000 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.14517583408476 +/- 0.19537120529005136\n",
      "Params =  1000 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.024947400060114 +/- 0.16531409678388898\n",
      "Params =  1000 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.81454764051698 +/- 0.5560565073639917\n",
      "Params =  1000 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Accuracy = 0.21520889690411782 1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 21.190261496844006 +/- 0.33062819356777795\n",
      "Params =  1000 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.20s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.29546137661557 +/- 0.0751427712654032\n",
      "Params =  1000 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.28s/it]\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:17<00:00,  1.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.070033062819356 +/- 0.30057108506161695\n",
      "Params =  1000 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.709347760745416 +/- 0.30057108506161695\n",
      "Params =  1000 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.1151187255786 +/- 0.07514277126540458\n",
      "Params =  1000 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.03s/it]\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:21<00:00,  2.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.205290051097087 +/- 0.13525698827772797\n",
      "Params =  1000 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.235347159603247 +/- 0.10519987977156697\n",
      "Params =  1000 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.16s/it]\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:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.694319206492334 +/- 0.4658851818455059\n",
      "Params =  1000 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "Accuracy = 0.2185151788397956 1000 100 0.0001\n",
      "Average accuracy = 21.47580402765254 +/- 0.37571385632702015\n",
      "Params =  1000 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.160204388337842 +/- 0.12022843402464678\n",
      "Params =  1000 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.28043282236249 +/- 0.30057108506161695\n",
      "Params =  1000 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.14517583408476 +/- 0.07514277126540458\n",
      "Params =  1000 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.235347159603247 +/- 0.22542831379621375\n",
      "Params =  1000 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.355575593627893 +/- 0.045085662759242195\n",
      "Params =  1000 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.355575593627893 +/- 0.1352569882777266\n",
      "Params =  1000 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.61s/it]\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:21<00:00,  2.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.679290652239253 +/- 0.6913134956417183\n",
      "Params =  1000 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7910\n",
      "Accuracy = 0.6588518184550646 1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7928\n",
      "Accuracy = 0.7183648932972648 1000 10 0.0001\n",
      "Average accuracy = 68.86083558761646 +/- 2.9756537421100124\n",
      "Params =  1000 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.10s/it]\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:20<00:00,  2.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.340547039374812 +/- 0.21039975954313256\n",
      "Params =  1000 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.17s/it]\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:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.385632702134057 +/- 0.07514277126540458\n",
      "Params =  1000 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.32551848512173 +/- 0.015028554253081194\n",
      "Params =  1000 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.15s/it]\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:18<00:00,  1.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.889690411782386 +/- 0.6612563871355572\n",
      "Params =  1000 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.190261496844006 +/- 0.06011421701232339\n",
      "Params =  1000 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.1151187255786 +/- 0.10519987977156697\n",
      "Params =  1000 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 13.345356176735798 +/- 4.749023143973549\n",
      "Params =  1000 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Accuracy = 0.7321911632100991 1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7893\n",
      "Average accuracy = 73.08385933273217 +/- 0.1352569882777266\n",
      "Params =  1000 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.52s/it]\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:28<00:00,  2.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.874661857529304 +/- 0.045085662759242195\n",
      "Params =  1000 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.40s/it]\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:32<00:00,  3.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.12022843402464678\n",
      "Params =  1000 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:30<00:00,  3.09s/it]\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:34<00:00,  3.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.024947400060114 +/- 0.34565674782085914\n",
      "Params =  1000 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:32<00:00,  3.29s/it]\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:31<00:00,  3.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.220318605350165 +/- 0.30057108506161695\n",
      "Params =  1000 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.88s/it]\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:32<00:00,  3.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.889690411782386 +/- 0.39074241058010134\n",
      "Params =  1000 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.72s/it]\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:26<00:00,  2.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.37060414788097 +/- 0.06011421701232339\n",
      "Params =  1000 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.69s/it]\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:26<00:00,  2.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 12.428614367297866 +/- 4.643823264201984\n",
      "Params =  1000 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7890\n",
      "Accuracy = 0.73790201382627 1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7901\n",
      "Accuracy = 0.74721971746318 1000 0.1 0.0001\n",
      "Average accuracy = 74.2560865644725 +/- 0.46588518184550454\n",
      "Params =  1000 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:34<00:00,  3.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.934776074541627 +/- 0.5259993988578306\n",
      "Params =  1000 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 21.911632100991884 +/- 0.4207995190862651\n",
      "Params =  1000 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.220318605350165 +/- 0.030057108506161\n",
      "Params =  1000 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.17523294259092 +/- 0.22542831379621237\n",
      "Params =  1000 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.71s/it]\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:26<00:00,  2.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.709347760745416 +/- 0.7514277126540431\n",
      "Params =  1000 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.27s/it]\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:24<00:00,  2.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.220318605350165 +/- 0.09017132551848578\n",
      "Params =  1000 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.47s/it]\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:27<00:00,  2.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 20.619176435226933 +/- 0.27051397655545456\n",
      "Params =  1000 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7946\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 73.35437330928765 +/- 0.46588518184550454\n",
      "Params =  1000 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.724376314998498 +/- 0.045085662759242195\n",
      "Params =  1000 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.30s/it]\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:20<00:00,  2.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.32551848512173 +/- 0.16531409678388898\n",
      "Params =  1000 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.889690411782386 +/- 0.18034265103697017\n",
      "Params =  1000 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.67s/it]\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:21<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.198376916140667 +/- 1.1421701232341457\n",
      "Params =  1000 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.47s/it]\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:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.40066125638714 +/- 0.06011421701232339\n",
      "Params =  1000 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.30s/it]\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:23<00:00,  2.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.14517583408476 +/- 0.16531409678388898\n",
      "Params =  1000 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.60s/it]\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:25<00:00,  2.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 25.037571385632702 +/- 4.869251577998196\n",
      "Params =  1000 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7880\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "Accuracy = 0.7538322813345356 1000 0.001 0.0001\n",
      "Average accuracy = 74.58671475804029 +/- 0.7965133754132825\n",
      "Params =  1000 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.265404268109407 +/- 0.07514277126540458\n",
      "Params =  1000 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 18.875864141869553 +/- 1.953712052900511\n",
      "Params =  1000 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.17523294259092 +/- 0.04508566275924358\n",
      "Params =  1000 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  2.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.904718966035468 +/- 0.13525698827772797\n",
      "Params =  1000 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.13014727983168 +/- 0.09017132551848578\n",
      "Params =  1000 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.769461977757743 +/- 0.5710850616170728\n",
      "Params =  1000 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.48s/it]\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:27<00:00,  2.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 24.180943793207092 +/- 4.223023745115719\n",
      "Params =  1000 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7908\n",
      "Accuracy = 0.7562368500150286 1000 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7898\n",
      "Average accuracy = 74.79711451758342 +/- 0.8265704839194477\n",
      "Params =  1000 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.055004508566277 +/- 0.31559963931469676\n",
      "Params =  100 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.160204388337842 +/- 0.12022843402464678\n",
      "Params =  100 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.205290051097084 +/- 0.045085662759242195\n",
      "Params =  100 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.355575593627893 +/- 0.1352569882777266\n",
      "Params =  100 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 20.91974752028855 +/- 0.03005710850616239\n",
      "Params =  100 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.550946798917945 +/- 0.03005710850616239\n",
      "Params =  100 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.03s/it]\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:20<00:00,  2.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "Average accuracy = 21.77637511271416 +/- 0.25548542230237475\n",
      "Params =  100 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 10483478528.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "Average accuracy = 42.530808536218814 +/- 25.127742711151193\n",
      "Params =  100 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.29546137661557 +/- 0.04508566275924358\n",
      "Params =  100 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.03s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.25037571385633 +/- 0.06011421701232339\n",
      "Params =  100 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.83s/it]\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:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.220318605350165 +/- 0.24045686804929356\n",
      "Params =  100 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.28043282236249 +/- 0.18034265103697017\n",
      "Params =  100 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.10s/it]\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:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.25037571385633 +/- 0.15028554253080778\n",
      "Params =  100 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.17523294259092 +/- 0.13525698827772797\n",
      "Params =  100 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 21.791403666967234 +/- 0.18034265103697017\n",
      "Params =  100 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.03s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7884\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7882\n",
      "Average accuracy = 73.68500150285541 +/- 0.16531409678389175\n",
      "Params =  100 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.385632702134057 +/- 0.045085662759242195\n",
      "Params =  100 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.13014727983168 +/- 0.030057108506161\n",
      "Params =  100 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.13014727983168 +/- 0.21039975954313256\n",
      "Params =  100 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.32551848512173 +/- 0.045085662759242195\n",
      "Params =  100 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.220318605350165 +/- 0.0\n",
      "Params =  100 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.799519086263903 +/- 0.27051397655545595\n",
      "Params =  100 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7907\n",
      "Average accuracy = 21.611061015930268 +/- 0.6011421701232353\n",
      "Params =  100 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7902\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "Average accuracy = 74.48151487826871 +/- 0.6311992786293963\n",
      "Params =  100 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.265404268109407 +/- 0.045085662759242195\n",
      "Params =  100 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.694319206492334 +/- 0.25548542230237475\n",
      "Params =  100 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.10009017132552 +/- 0.12022843402464678\n",
      "Params =  100 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.190261496844006 +/- 0.15028554253080917\n",
      "Params =  100 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.07s/it]\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:20<00:00,  2.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.039975954313196 +/- 0.18034265103697017\n",
      "Params =  100 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.32s/it]\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:23<00:00,  2.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.31048993086865 +/- 0.18034265103697017\n",
      "Params =  100 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7932\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7935\n",
      "Average accuracy = 69.59723474601743 +/- 1.0970844604749064\n",
      "Params =  100 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7929\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7892\n",
      "Average accuracy = 72.2873459573189 +/- 0.5410279531109063\n",
      "Params =  100 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.45s/it]\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:23<00:00,  2.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.009918845807032 +/- 1.5930267508265705\n",
      "Params =  100 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.35s/it]\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:23<00:00,  2.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.055004508566277 +/- 0.19537120529004998\n",
      "Params =  100 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.48s/it]\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:24<00:00,  2.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.273519687406072 +/- 1.0069131349564164\n",
      "Params =  100 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.31s/it]\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:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 19.957920048091374 +/- 1.2623985572587926\n",
      "Params =  100 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 22.34746017433123 +/- 1.6982266305981375\n",
      "Params =  100 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "Average accuracy = 52.37451157198678 +/- 0.4658851818455101\n",
      "Params =  100 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7934\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 2176879616.0000\n",
      "Average accuracy = 58.896904117823865 +/- 15.76495341148182\n",
      "Params =  100 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7930\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7909\n",
      "Average accuracy = 71.5058611361587 +/- 0.8716561466786898\n",
      "Params =  100 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 19.446949203486625 +/- 0.8115419296663651\n",
      "Params =  100 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 17.73369401863541 +/- 0.42079951908626373\n",
      "Params =  100 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.37s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 34.2200180342651 +/- 13.300270513976553\n",
      "Params =  100 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 19.67237751728284 +/- 1.788397956116622\n",
      "Params =  100 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.56s/it]\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:24<00:00,  2.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 19.88277727682597 +/- 1.217312894499549\n",
      "Params =  100 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 77146431488.0000\n",
      "Average accuracy = 29.681394649834687 +/- 8.551247370003006\n",
      "Params =  100 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.72s/it]\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:16<00:00,  1.68s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 13104557056.0000\n",
      "Average accuracy = 47.640516982266305 +/- 25.247971145175836\n",
      "Params =  100 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7895\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7872\n",
      "Average accuracy = 72.43763149984972 +/- 0.2705139765554587\n",
      "Params =  100 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.53s/it]\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:21<00:00,  2.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 19.206492335437332 +/- 1.833483618875864\n",
      "Params =  100 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.52s/it]\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:23<00:00,  2.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.63420498948001 +/- 0.7363991584009619\n",
      "Params =  100 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 14.848211602043882 +/- 6.7929065223925456\n",
      "Params =  100 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.39374812143072 +/- 0.4658851818455073\n",
      "Params =  100 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.36s/it]\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:22<00:00,  2.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.14517583408476 +/- 0.16531409678388898\n",
      "Params =  100 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 51050434560.0000\n",
      "Average accuracy = 44.198978058310786 +/- 23.06883077847911\n",
      "Params =  100 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7939\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 74.0156296964232 +/- 0.015028554253082582\n",
      "Params =  100 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.77s/it]\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:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Average accuracy = 71.94168920949804 +/- 0.5560565073639945\n",
      "Params =  100 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.97986173730087 +/- 0.27051397655545456\n",
      "Params =  100 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.47s/it]\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:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.17523294259092 +/- 0.28554253080853714\n",
      "Params =  100 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 39.329726480312594 +/- 2.1190261496844\n",
      "Params =  100 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.42s/it]\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:23<00:00,  2.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 16.68169522091975 +/- 8.65644724977457\n",
      "Params =  100 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.48s/it]\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:24<00:00,  2.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 20.979861737300872 +/- 0.36068530207394034\n",
      "Params =  100 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 117243633664.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 43.08686504358281 +/- 14.95341148181545\n",
      "Params =  100 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7933\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 74.4063721070033 +/- 0.46588518184550454\n",
      "Params =  100 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8027\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7881\n",
      "Average accuracy = 72.33243162007815 +/- 0.6762849413886385\n",
      "Params =  100 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.160204388337846 +/- 0.06011421701232339\n",
      "Params =  10 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.80s/it]\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:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.235347159603247 +/- 0.1352569882777266\n",
      "Params =  10 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.355575593627893 +/- 0.19537120529005136\n",
      "Params =  10 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.17523294259092 +/- 0.10519987977156559\n",
      "Params =  10 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.769461977757743 +/- 0.030057108506161\n",
      "Params =  10 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "Average accuracy = 21.701232341448755 +/- 0.24045686804929356\n",
      "Params =  10 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "Average accuracy = 22.963630898707542 +/- 0.030057108506161\n",
      "Params =  10 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7940\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "Average accuracy = 73.56477306883077 +/- 0.22542831379621653\n",
      "Params =  10 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 20.934776074541627 +/- 0.31559963931469676\n",
      "Params =  10 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.355575593627893 +/- 0.16531409678388898\n",
      "Params =  10 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.1151187255786 +/- 0.28554253080853575\n",
      "Params =  10 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.220318605350165 +/- 0.24045686804929356\n",
      "Params =  10 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.070033062819356 +/- 0.09017132551848439\n",
      "Params =  10 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 21.941689209498044 +/- 0.30057108506161695\n",
      "Params =  10 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7957\n",
      "Accuracy = 0.7727682596934174 10 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 74.64682897505259 +/- 2.6299969942891464\n",
      "Params =  10 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7896\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7967\n",
      "Average accuracy = 73.89540126239855 +/- 0.1352569882777266\n",
      "Params =  10 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 9735485440.0000\n",
      "Average accuracy = 35.58761647129546 +/- 18.004207995190864\n",
      "Params =  10 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.10s/it]\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:21<00:00,  2.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 11849516032.0000\n",
      "Average accuracy = 22.302374511571987 +/- 3.757138563270214\n",
      "Params =  10 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 32.86744815148783 +/- 10.414788097385031\n",
      "Params =  10 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.16s/it]\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:22<00:00,  2.26s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 33.58881875563571 +/- 4.553651938683501\n",
      "Params =  10 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.27s/it]\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:21<00:00,  2.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 22.8434024646829 +/- 0.6913134956417197\n",
      "Params =  10 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 42.305380222422606 +/- 0.7063420498948009\n",
      "Params =  10 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7869\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 71.10009017132552 +/- 0.49594229035166415\n",
      "Params =  10 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.83s/it]\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:15<00:00,  1.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8036\n",
      "Average accuracy = 72.54283137962128 +/- 0.045085662759242195\n",
      "Params =  10 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 7317731328.0000\n",
      "Average accuracy = 27.23174030658251 +/- 7.153591824466488\n",
      "Params =  10 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7907\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 26.0595130748422 +/- 1.7132551848512187\n",
      "Params =  10 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7907\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 44.334235046588525 +/- 14.39735497445146\n",
      "Params =  10 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7907\n",
      "Average accuracy = 31.454764051698227 +/- 4.373309287646529\n",
      "Params =  10 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7930\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 38.50315599639315 +/- 13.645927261797416\n",
      "Params =  10 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7926\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.59s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 18465837056.0000\n",
      "Average accuracy = 33.393447550345655 +/- 13.345356176735798\n",
      "Params =  10 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7990\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7950\n",
      "Average accuracy = 71.47580402765254 +/- 0.9918845807033339\n",
      "Params =  10 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.75s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7958\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7931\n",
      "Average accuracy = 71.59603246167718 +/- 0.18034265103696878\n",
      "Params =  10 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "Average accuracy = 26.540426810940787 +/- 2.9155395250976865\n",
      "Params =  10 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 13229545472.0000\n",
      "Average accuracy = 23.09888788698527 +/- 5.695822061917642\n",
      "Params =  10 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 27.607454162909526 +/- 7.078449053201082\n",
      "Params =  10 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 24.10580102194169 +/- 3.6669672377517295\n",
      "Params =  10 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 42.90652239254584 +/- 4.643823264201985\n",
      "Params =  10 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7983\n",
      "Average accuracy = 74.78208596333033 +/- 1.1121130147279834\n",
      "Params =  10 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.97s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7856\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7944\n",
      "Average accuracy = 72.6029455966336 +/- 0.3456567478208606\n",
      "Params =  10 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7948\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.69s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7903\n",
      "Average accuracy = 72.07694619777578 +/- 0.030057108506159613\n",
      "Params =  10 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Average accuracy = 39.074241058010216 +/- 10.9107303877367\n",
      "Params =  10 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7913\n",
      "Average accuracy = 32.16110610159303 +/- 5.290051097084461\n",
      "Params =  10 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.96s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 36.113615870153296 +/- 11.286444244063722\n",
      "Params =  10 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.06s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 61430988800.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 39.46498346859032 +/- 18.665464382326423\n",
      "Params =  10 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.93s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 11037185024.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 25.713856327021347 +/- 2.539825668770665\n",
      "Params =  10 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7930\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7995\n",
      "Average accuracy = 76.60054102795311 +/- 0.5259993988578293\n",
      "Params =  10 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.88s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7993\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7858\n",
      "Average accuracy = 71.20529005109708 +/- 0.5710850616170715\n",
      "Params =  10 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7891\n",
      "Average accuracy = 71.53591824466487 +/- 0.18034265103696878\n",
      "Params =  10 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.03s/it]\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:20<00:00,  2.10s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 45.79200480913736 +/- 13.961526901112114\n",
      "Params =  10 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 20005486592.0000\n",
      "Average accuracy = 21.340547039374812 +/- 0.18034265103697017\n",
      "Params =  10 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.03s/it]\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:28<00:00,  2.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 25.83408476104599 +/- 5.78599338743613\n",
      "Params =  10 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.61s/it]\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:20<00:00,  2.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 36.66967237751728 +/- 7.995190862639015\n",
      "Params =  10 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.68s/it]\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:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 39.29966937180643 +/- 13.300270513976557\n",
      "Params =  10 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7942\n",
      "Average accuracy = 76.87105500450858 +/- 0.28554253080853575\n",
      "Params =  10 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.23s/it]\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:22<00:00,  2.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7903\n",
      "Average accuracy = 71.34054703937481 +/- 0.10519987977156697\n",
      "Params =  10 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.41s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 38011707392.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.20s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7915\n",
      "Average accuracy = 70.7995190862639 +/- 0.16531409678389175\n",
      "Params =  10 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.50s/it]\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:25<00:00,  2.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 69903622144.0000\n",
      "Average accuracy = 35.94830177336941 +/- 15.539525097685605\n",
      "Params =  10 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.23s/it]\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:19<00:00,  1.98s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 31.124135858130447 +/- 1.608055305079653\n",
      "Params =  10 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.62s/it]\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:22<00:00,  2.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 32.26630598136459 +/- 12.789299669371804\n",
      "Params =  10 0.0001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:33<00:00,  3.32s/it]\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:24<00:00,  2.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 9342213120.0000\n",
      "Average accuracy = 26.345055605650735 +/- 6.176735798016231\n",
      "Params =  10 0.0001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:31<00:00,  3.13s/it]\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 [01:02<00:00,  6.24s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "Average accuracy = 49.77457168620379 +/- 1.2022843402464678\n",
      "Params =  10 0.0001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [01:20<00:00,  8.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7946\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [01:00<00:00,  6.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "Accuracy = 0.7757739705440336 10 0.0001 0.01\n",
      "Average accuracy = 76.66065524496544 +/- 0.916741809437932\n",
      "Params =  10 0.0001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7937\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7949\n",
      "Average accuracy = 71.34054703937481 +/- 0.6762849413886385\n",
      "Params =  10 0.0001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7840\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.90s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7860\n",
      "Average accuracy = 71.46077547339947 +/- 0.22542831379621098\n",
      "Params =  10 0.0001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.35s/it]\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:20<00:00,  2.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.190261496844006 +/- 0.15028554253080917\n",
      "Params =  1 1000 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.82s/it]\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:33<00:00,  3.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "Average accuracy = 21.190261496844006 +/- 0.06011421701232339\n",
      "Params =  1 1000 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.42s/it]\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:23<00:00,  2.37s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.085061617072437 +/- 0.19537120529005136\n",
      "Params =  1 1000 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.38s/it]\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:24<00:00,  2.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7917\n",
      "Average accuracy = 21.340547039374812 +/- 0.12022843402464678\n",
      "Params =  1 1000 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.39s/it]\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:26<00:00,  2.64s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 21.896603546738802 +/- 0.10519987977156559\n",
      "Params =  1 1000 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.94s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.30s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7936\n",
      "Average accuracy = 23.79020138262699 +/- 0.16531409678388898\n",
      "Params =  1 1000 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.32s/it]\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:28<00:00,  2.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 34841837568.0000\n",
      "Average accuracy = 39.20949804628795 +/- 20.75443342350466\n",
      "Params =  1 1000 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.18s/it]\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:24<00:00,  2.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7971\n",
      "Average accuracy = 72.85843101893599 +/- 0.5410279531109119\n",
      "Params =  1 1000 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:34<00:00,  3.43s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 12255821824.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:33<00:00,  3.38s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 22.452660054102797 +/- 3.0057108506161723\n",
      "Params =  1 100 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.56s/it]\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:30<00:00,  3.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 59.30267508265705 +/- 6.402164111812442\n",
      "Params =  1 100 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 42078240768.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7919\n",
      "Average accuracy = 40.45686804929366 +/- 11.33152990682296\n",
      "Params =  1 100 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:32<00:00,  3.29s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 35666411520.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 66558345216.0000\n",
      "Average accuracy = 18.199579200480915 +/- 5.545536519386834\n",
      "Params =  1 100 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:34<00:00,  3.50s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 88225193984.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 45178748928.0000\n",
      "Average accuracy = 22.813345356176733 +/- 0.8716561466786885\n",
      "Params =  1 100 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.57s/it]\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:20<00:00,  2.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 6200278528.0000\n",
      "Average accuracy = 43.177036369101295 +/- 19.401863540727383\n",
      "Params =  1 100 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 72.93357379020138 +/- 0.5861136158701541\n",
      "Params =  1 100 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.07s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7912\n",
      "Average accuracy = 73.09888788698527 +/- 0.4508566275924275\n",
      "Params =  1 100 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.57s/it]\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:35<00:00,  3.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7920\n",
      "Average accuracy = 39.314697926059516 +/- 1.9236549443943511\n",
      "Params =  1 10 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 4417168384.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 60029251584.0000\n",
      "Average accuracy = 19.446949203486625 +/- 2.0739404869251574\n",
      "Params =  1 10 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:37<00:00,  3.71s/it]\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:22<00:00,  2.27s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 11206728704.0000\n",
      "Average accuracy = 40.096182747219714 +/- 29.5160805530508\n",
      "Params =  1 10 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:34<00:00,  3.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 5887517184.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:40<00:00,  4.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 44552151040.0000\n",
      "Average accuracy = 18.37992185151788 +/- 1.9086263901412686\n",
      "Params =  1 10 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7916\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 42476548096.0000\n",
      "Average accuracy = 25.293056807935077 +/- 2.329425909227534\n",
      "Params =  1 10 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.84s/it]\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:23<00:00,  2.33s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7885\n",
      "Average accuracy = 72.64803125939285 +/- 0.2705139765554587\n",
      "Params =  1 10 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7953\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:35<00:00,  3.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7911\n",
      "Average accuracy = 72.76825969341749 +/- 0.4207995190862679\n",
      "Params =  1 10 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:31<00:00,  3.18s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7893\n",
      "Average accuracy = 72.04688908926961 +/- 1.232341448752633\n",
      "Params =  1 10 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.52s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 3296389888.0000\n",
      "Average accuracy = 35.85813044785092 +/- 17.162608957018335\n",
      "Params =  1 1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 9458512896.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 110485348352.0000\n",
      "Average accuracy = 24.872257288848814 +/- 0.13525698827772797\n",
      "Params =  1 1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:32<00:00,  3.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 42393956352.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:37<00:00,  3.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 36.489329726480314 +/- 20.709347760745413\n",
      "Params =  1 1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:39<00:00,  3.95s/it]\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:34<00:00,  3.48s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "Average accuracy = 63.66095581605049 +/- 5.199879771565979\n",
      "Params =  1 1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:32<00:00,  3.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7926\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.05s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7955\n",
      "Average accuracy = 75.05259993988578 +/- 0.2705139765554587\n",
      "Params =  1 1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:33<00:00,  3.32s/it]\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:32<00:00,  3.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7871\n",
      "Average accuracy = 72.24226029455967 +/- 0.7063420498947981\n",
      "Params =  1 1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:38<00:00,  3.84s/it]\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:37<00:00,  3.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7926\n",
      "Average accuracy = 71.1151187255786 +/- 0.21039975954313395\n",
      "Params =  1 1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:36<00:00,  3.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7926\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:35<00:00,  3.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7914\n",
      "Average accuracy = 71.14517583408477 +/- 0.21039975954313395\n",
      "Params =  1 1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:37<00:00,  3.71s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 7402113536.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.37s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 9170190336.0000\n",
      "Average accuracy = 20.709347760745416 +/- 0.9918845807033366\n",
      "Params =  1 0.1 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 79049646080.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:32<00:00,  3.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7923\n",
      "Average accuracy = 48.33183047790802 +/- 22.03186053501653\n",
      "Params =  1 0.1 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.21s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7897\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:20<00:00,  2.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7880\n",
      "Average accuracy = 70.19837691614067 +/- 1.3375413285241944\n",
      "Params =  1 0.1 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7993\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.40s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7888\n",
      "Average accuracy = 76.82596934174933 +/- 0.21039975954313395\n",
      "Params =  1 0.1 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7951\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7890\n",
      "Average accuracy = 71.95671776375112 +/- 0.6612563871355615\n",
      "Params =  1 0.1 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.59s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7962\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7931\n",
      "Average accuracy = 71.20529005109708 +/- 0.5410279531109119\n",
      "Params =  1 0.1 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:29<00:00,  2.94s/it]\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:18<00:00,  1.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7967\n",
      "Average accuracy = 71.6711752329426 +/- 1.127141568981066\n",
      "Params =  1 0.1 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.23s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7997\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:29<00:00,  2.99s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7941\n",
      "Average accuracy = 72.31740306582506 +/- 0.42079951908626234\n",
      "Params =  1 0.1 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:31<00:00,  3.19s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7966\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 53935992832.0000\n",
      "Average accuracy = 46.00240456868049 +/- 29.350766456266907\n",
      "Params =  1 0.01 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.70s/it]\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:30<00:00,  3.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7921\n",
      "Average accuracy = 65.41929666366096 +/- 2.9606251878569303\n",
      "Params =  1 0.01 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 18769653760.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:25<00:00,  2.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 67813019648.0000\n",
      "Average accuracy = 26.17974150886685 +/- 2.1941689209498043\n",
      "Params =  1 0.01 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7910\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7866\n",
      "Average accuracy = 75.99939885782987 +/- 0.4959422903516697\n",
      "Params =  1 0.01 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:29<00:00,  2.94s/it]\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:26<00:00,  2.63s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7865\n",
      "Average accuracy = 72.69311692215209 +/- 0.9467989179440917\n",
      "Params =  1 0.01 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:30<00:00,  3.03s/it]\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:25<00:00,  2.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.8024\n",
      "Average accuracy = 69.94289149383829 +/- 0.5710850616170715\n",
      "Params =  1 0.01 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:22<00:00,  2.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7890\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7852\n",
      "Average accuracy = 71.4307183648933 +/- 0.6762849413886385\n",
      "Params =  1 0.01 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7896\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7922\n",
      "Average accuracy = 71.25037571385633 +/- 0.5560565073639889\n",
      "Params =  1 0.01 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.61s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 34839076864.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:23<00:00,  2.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7927\n",
      "Average accuracy = 45.776976254884275 +/- 27.472197174631802\n",
      "Params =  1 0.001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:21<00:00,  2.11s/it]\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:25<00:00,  2.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 31894300672.0000\n",
      "Average accuracy = 50.55605650736399 +/- 22.242260294559664\n",
      "Params =  1 0.001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:28<00:00,  2.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7926\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:26<00:00,  2.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7925\n",
      "Average accuracy = 69.58220619176436 +/- 3.0057108506161723\n",
      "Params =  1 0.001 10\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:24<00:00,  2.50s/it]\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:25<00:00,  2.57s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7948\n",
      "Average accuracy = 77.09648331830479 +/- 0.24045686804929356\n",
      "Params =  1 0.001 1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:27<00:00,  2.78s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7957\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:17<00:00,  1.80s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7968\n",
      "Average accuracy = 72.00180342651036 +/- 1.3375413285241944\n",
      "Params =  1 0.001 0.1\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:14<00:00,  1.49s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.92s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7957\n",
      "Average accuracy = 72.22723174030659 +/- 0.06011421701232478\n",
      "Params =  1 0.001 0.01\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:19<00:00,  1.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7996\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:16<00:00,  1.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7999\n",
      "Average accuracy = 71.14517583408477 +/- 0.8415990381725247\n",
      "Params =  1 0.001 0.001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7918\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.86s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7870\n",
      "Average accuracy = 71.71626089570184 +/- 0.18034265103696878\n",
      "Params =  1 0.001 0.0001\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 38131032064.0000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7940\n",
      "Average accuracy = 47.640516982266305 +/- 23.925458370904725\n",
      "Params =  1 0.0001 1000\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7924\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7933\n",
      "Average accuracy = 65.64472497745717 +/- 5.620679290652242\n",
      "Params =  1 0.0001 100\n",
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:18<00:00,  1.87s/it]\n"
     ]
    },
    {
     "ename": "_LinAlgError",
     "evalue": "linalg.svd: The algorithm failed to converge because the input matrix is ill-conditioned or has too many repeated singular values (error code: 1).",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31m_LinAlgError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[17], 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": 27,
   "id": "VYrR83c2grMy",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "VYrR83c2grMy",
    "outputId": "c388488b-8d14-4705-c421-7cee6dbae62b"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "76.67568379921852"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "highest_accuracy*100  #Params =  1 1 0.1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "864a90ea",
   "metadata": {},
   "source": [
    "### Average accuracy = 77.09648331830479 +/- 0.24045686804929356\n",
    "### Params =  1 0.001 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "1b6c9f28",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_36796\\2387417581.py:13: UserWarning: torch.sparse.SparseTensor(indices, values, shape, *, device=) is deprecated.  Please use torch.sparse_coo_tensor(indices, values, shape, dtype=, device=). (Triggered internally at C:\\cb\\pytorch_1000000000000\\work\\torch\\csrc\\utils\\tensor_new.cpp:607.)\n",
      "  return torch.sparse.FloatTensor(i, v, torch.Size(shape))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GPU is available\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/10 [00:00<?, ?it/s]C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_36796\\2793157037.py:51: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_36796\\2793157037.py:69: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  V = [torch.tensor(eigenvector) for eigenvector in non_zero_eigenvectors]\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_36796\\2793157037.py:33: UserWarning: Casting complex values to real discards the imaginary part (Triggered internally at C:\\cb\\pytorch_1000000000000\\work\\aten\\src\\ATen\\native\\Copy.cpp:299.)\n",
      "  U = torch.stack(update_V(C, theta)).double()\n",
      "C:\\Users\\Sandeep\\AppData\\Local\\Temp\\ipykernel_36796\\2793157037.py:144: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  matrix = torch.tensor(product)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 10/10 [00:15<00:00,  1.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 000,loss: 1.7907\n",
      "Accuracy = 0.7385031559963932 1 0.001 1\n",
      "Average accuracy = 73.85031559963932 +/- 0.0\n",
      "Params =  1 0.001 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 [0.001]:\n",
    "      for gamma_param in [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": 18,
   "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": "iVBORw0KGgoAAAANSUhEUgAAAvQAAAK9CAYAAABLi/iyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABYE0lEQVR4nO3de3wU1f3/8fcm5GaAYDQkgoCACIggigooCiiaUkWpUIRqBUXK1x8XBaxKWwW8FJUqeEHFXgQtfCmgYKtWKiCofEERxaIWRAv1wk1AAkRICDu/P/yy3wyTxOzsknNmeD0fDx8P2Wx2P8nknHmfs+fMRBzHcQQAAAAgkFJMFwAAAADAPwI9AAAAEGAEegAAACDACPQAAABAgBHoAQAAgAAj0AMAAAABRqAHAAAAAoxADwAAAAQYgR4AAAAIMAI9gISUlZXp9ttvV6NGjZSSkqLevXsf1ffr1q2bunXrFvf3bdq0SZFIRL/73e+SVsvSpUsViUS0dOnSpL1mdbz22mtq3769MjMzFYlEtHv37hp9f/wfU38DAFAegR7HrOnTpysSiei9996r8OvdunXTGWeccVRrePXVVzV+/Pij+h5H25/+9CdNmjRJffv21YwZMzRq1CjTJYXazp071a9fP2VlZWnq1Kl6/vnnlZ2drd/+9rdasGCB6fIAAAbUMl0AcCx79dVXNXXq1ECH+iVLlqhhw4aaPHmy6VKOCatWrdLevXt17733qkePHrHHf/vb36pv375H/RMSuF100UXav3+/0tPTTZcC4BjGDD2AhGzfvl316tVL2utFo1EdOHAgaa8XNtu3b5ekpP7OK3PgwAFFo9Gj/j6J+u6774y9d0pKijIzM5WSwukUgDn0QECc/vznP6tDhw7KyspSbm6u+vfvry+//NL1nLfeeks//elP1bhxY2VkZKhRo0YaNWqU9u/fH3vOoEGDNHXqVElSJBKJ/Se513tPnTpVzZo103HHHafLLrtMX375pRzH0b333quTTz5ZWVlZuuqqq7Rr1y5XDS+99JIuv/xyNWjQQBkZGWrevLnuvfdeHTp0yPW8w0uLVq9erfPPP19ZWVlq2rSpnn766Sp/D4drfOONN/Txxx/H6j+8lri4uFhjxoxRo0aNlJGRoZYtW+p3v/udHMdxvU4kEtHw4cM1c+ZMtWnTRhkZGXrttdeqfTxKS0t19913q0OHDsrJyVF2drYuvPBCvfHGG5V+z+TJk9WkSRNlZWWpa9eu+uijjzzPWbdunfr27avc3FxlZmbqnHPO0V//+tcfrGfDhg3q06ePCgoKlJmZqZNPPln9+/dXUVFRld9Xnb+Zbt26aeDAgZKkc889V5FIRIMGDVIkElFxcbFmzJgROw6DBg2Kfd/XX3+tG2+8Ufn5+crIyFCbNm30pz/9yfX+h9eCz549W7/5zW/UsGFDHXfccdqzZ0+lNUejUT366KNq27atMjMzlZeXpx/96EeuZWxlZWW699571bx5c2VkZOiUU07Rr371K5WUlLhey8/f60UXXaTjjjtOv/rVryRJ7733ngoLC3XiiSfG/o5vvPFGT81TpkxRmzZtlJmZqfz8fA0dOlTffvut63mnnHKKrrjiCr399ts677zzlJmZqWbNmum5556r8PdWfg394Ro/+eQTde/eXccdd5waNmyohx56yPM7/M9//qMrr7xS2dnZql+/vkaNGqWFCxeyLh9AXFhyg2NeUVGRduzY4Xn84MGDnsfuv/9+3XXXXerXr59uuukmffPNN3r88cd10UUX6YMPPojNms6dO1ffffedbr75Zp1wwgl699139fjjj+urr77S3LlzJUlDhw7V5s2b9frrr+v555+vsLaZM2eqtLRUI0aM0K5du/TQQw+pX79+uvjii7V06VLdcccd+uyzz/T444/rtttuc4W06dOnq3bt2ho9erRq166tJUuW6O6779aePXs0adIk1/t8++23+vGPf6x+/fppwIABmjNnjm6++Walp6d7AtFheXl5ev7553X//fdr3759mjhxoiSpdevWchxHV155pd544w0NHjxY7du318KFC/XLX/5SX3/9tWd5zpIlSzRnzhwNHz5cJ554ok455ZSKD1YF9uzZoz/84Q8aMGCAhgwZor179+qPf/yjCgsL9e6776p9+/au5z/33HPau3evhg0bpgMHDujRRx/VxRdfrLVr1yo/P1+S9PHHH+uCCy5Qw4YNdeeddyo7O1tz5sxR79699cILL+gnP/lJhbWUlpaqsLBQJSUlGjFihAoKCvT111/r5Zdf1u7du5WTk1Ppz1Gdv5lf//rXatmypZ555hndc889atq0qZo3b64ePXropptu0nnnnadf/OIXkqTmzZtLkrZt26ZOnTrFBk55eXn6+9//rsGDB2vPnj269dZbXXXce++9Sk9P12233aaSkpIql5IMHjxY06dPV8+ePXXTTTeprKxMb731llauXKlzzjlHknTTTTdpxowZ6tu3r8aMGaN33nlHEydO1L/+9S/Nnz8/9lrx/L3u3LlTPXv2VP/+/XXdddcpPz9f27dv12WXXaa8vDzdeeedqlevnjZt2qQXX3zR9b1Dhw7V9OnTdcMNN2jkyJHauHGjnnjiCX3wwQdavny50tLSYs/97LPP1LdvXw0ePFgDBw7Un/70Jw0aNEgdOnRQmzZtKv29SN+3qR/96Ee6+uqr1a9fP82bN0933HGH2rZtq549e0r6ftB78cUXa8uWLbrllltUUFCgWbNmVTkYBYAKOcAx6tlnn3UkVflfmzZtYs/ftGmTk5qa6tx///2u11m7dq1Tq1Yt1+Pfffed5/0mTpzoRCIR5z//+U/ssWHDhjkVNcONGzc6kpy8vDxn9+7dscfHjh3rSHLOPPNM5+DBg7HHBwwY4KSnpzsHDhyosoahQ4c6xx13nOt5Xbt2dSQ5Dz/8cOyxkpISp3379k79+vWd0tJS7y+vnK5du7p+T47jOAsWLHAkOffdd5/r8b59+zqRSMT57LPPYo9JclJSUpyPP/64yvcp/35du3aN/busrMwpKSlxPefbb7918vPznRtvvDH22OHfaVZWlvPVV1/FHn/nnXccSc6oUaNij11yySVO27ZtXb+naDTqnH/++U6LFi1ij73xxhuOJOeNN95wHMdxPvjgA0eSM3fu3Gr9LOVV92/m8N/tqlWrXM/Nzs52Bg4c6HmNwYMHOyeddJKzY8cO1+P9+/d3cnJyYu97+Gdp1qxZhbUcacmSJY4kZ+TIkZ6vRaNRx3EcZ82aNY4k56abbnJ9/bbbbnMkOUuWLIk9Fu/f69NPP+167vz58yv8vZT31ltvOZKcmTNnuh5/7bXXPI83adLEkeS8+eabsce2b9/uZGRkOGPGjIk9duTfQPkan3vuudhjJSUlTkFBgdOnT5/YYw8//LAjyVmwYEHssf379zutWrXyvCYAVIUlNzjmTZ06Va+//rrnv3bt2rme9+KLLyoajapfv37asWNH7L+CggK1aNHCNauWlZUV+//i4mLt2LFD559/vhzH0QcffFDt2n7605+6ZnU7duwoSbruuutUq1Yt1+OlpaX6+uuvK6xh79692rFjhy688EJ99913Wrdunet9atWqpaFDh8b+nZ6erqFDh2r79u1avXp1tes97NVXX1VqaqpGjhzpenzMmDFyHEd///vfXY937dpVp59+etzvI0mpqamxWeRoNKpdu3aprKxM55xzjt5//33P83v37q2GDRvG/n3eeeepY8eOevXVVyVJu3bt0pIlS9SvX7/Y723Hjh3auXOnCgsLtWHDBtfvubzDx2rhwoVxr+tO1t9MeY7j6IUXXlCvXr3kOI7r77awsFBFRUWe39HAgQNdtVTmhRdeUCQS0bhx4zxfO7x07PDvdPTo0a6vjxkzRpL0yiuvxB6L5+81IyNDN9xwg+uxw5+OvfzyyxV+uiZ9/ylITk6OLr30UtfvokOHDqpdu7ZnZvz000/XhRdeGPt3Xl6eWrZsqX//+98Vvn55tWvX1nXXXRf7d3p6us477zzX97722mtq2LChrrzyythjmZmZGjJkyA++PgCUx5IbHPPOO++82PKA8o4//njXUpwNGzbIcRy1aNGiwtcp/1H9F198obvvvlt//etfPWtzf2gtdXmNGzd2/ftwYGzUqFGFj5d/r48//li/+c1vtGTJEs866CNraNCggbKzs12PnXbaaZK+XyvfqVOnatcsfb8uuEGDBqpTp47r8datW8e+Xl7Tpk3jev0jzZgxQw8//LDWrVvnCnMVvW5Fx++0007TnDlzJH2/zMJxHN1111266667Kny/7du3uwYF5d9v9OjReuSRRzRz5kxdeOGFuvLKK3XddddVudxGSt7fTHnffPONdu/erWeeeUbPPPNMpT/LkT9DdXz++edq0KCBcnNzK33Of/7zH6WkpOjUU091PV5QUKB69eq5/g7i+Xtt2LChZylQ165d1adPH02YMEGTJ09Wt27d1Lt3b/3sZz9TRkaGpO/bcFFRkerXr19hvUf+Lo5sf9L3/cKRx6ciJ598cmxgU/57//nPf8b+/Z///EfNmzf3PO/I3xcA/BACPVBN0WhUkUhEf//735Wamur5eu3atSVJhw4d0qWXXqpdu3bpjjvuUKtWrZSdna2vv/5agwYNiuuqIRW9T1WPO/+74XT37t3q2rWr6tatq3vuuUfNmzdXZmam3n//fd1xxx3WXbmkOjPClfnzn/+sQYMGqXfv3vrlL3+p+vXrKzU1VRMnTtTnn38e9+sd/t3cdtttKiwsrPA5VQWuhx9+WIMGDdJLL72kf/zjHxo5cqQmTpyolStX6uSTT67we5L5N1PRz3LdddfFNtMe6chPohI5FpU5MrAeKd6/14pqjEQimjdvnlauXKm//e1vWrhwoW688UY9/PDDWrlypWrXrq1oNKr69etr5syZFdaRl5fn+vcPtbOqJPK9ABAvAj1QTc2bN5fjOGratGls9roia9eu1aeffqoZM2bo+uuvjz3++uuve577Q0HHr6VLl2rnzp168cUXddFFF8Ue37hxY4XP37x5s4qLi12z9J9++qkkxbVB9bAmTZpo0aJF2rt3r2uW/vDSiSZNmsT9mpWZN2+emjVrphdffNH1+6xoKYj0/SztkT799NPYz9msWTNJ33/iUv467/Fo27at2rZtq9/85jf6n//5H11wwQV6+umndd9991X4/Hj+ZipT0d9SXl6e6tSpo0OHDvn+WSrTvHlzLVy4ULt27ap0lr5JkyaKRqPasGFD7NMZ6fuNurt37479HcT791qVTp06qVOnTrr//vs1a9YsXXvttZo9e7ZuuukmNW/eXIsWLdIFF1xwVAYu8WrSpIk++eQTOY7jOn6fffaZwaoABBFr6IFquvrqq5WamqoJEyZ4Ztkcx9HOnTsl/d/MXPnnOI6jRx991POahwP07t27k1prRTWUlpbqySefrPD5ZWVlmjZtmuu506ZNU15enjp06BD3+//4xz/WoUOH9MQTT7genzx5siKRSOwqH8lQ0c/6zjvvaMWKFRU+f8GCBa418O+++67eeeedWE3169dXt27dNG3aNG3ZssXz/d98802ltezZs0dlZWWux9q2bauUlBTPZRp/6Geo7G+mMtnZ2Z6/o9TUVPXp00cvvPBChZfmrOpn+SF9+vSR4ziaMGGC52uHf44f//jHkqQpU6a4vv7II49Iki6//PJYneW/T6r677Ui3377raddHr7C0eHffb9+/XTo0CHde++9nu8vKytLejv8IYWFhfr6669dl0M9cOCAfv/739doHQCCjxl6oJqaN2+u++67T2PHjtWmTZvUu3dv1alTRxs3btT8+fP1i1/8QrfddptatWql5s2b67bbbtPXX3+tunXr6oUXXqhw3e3hsDxy5EgVFhYqNTVV/fv3T7jW888/X8cff7wGDhyokSNHKhKJ6Pnnn6/04/4GDRrowQcf1KZNm3Taaafp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6r777lP79u01ZcoU02Ud88aPH68FCxZozZo1pkvBMYoZep9KS0u1evVq9ejRI/ZYSkqKevTooRUrVhisDAiWoqIiSd8HR9jj0KFDmj17toqLi9W5c2fT5eB/DRs2TJdffrnr3AM7bNiwQQ0aNFCzZs107bXX6osvvjBdEo4htUwXEFQ7duzQoUOHlJ+f73o8Pz9f69atM1QVECzRaFS33nqrLrjgAp1xxhmmy4GktWvXqnPnzjpw4IBq166t+fPn6/TTTzddFiTNnj1b77//vlatWmW6FByhY8eOmj59ulq2bKktW7ZowoQJuvDCC/XRRx+pTp06psvDMYBAD8CYYcOG6aOPPmKtqUVatmypNWvWqKioSPPmzdPAgQO1bNkyQr1hX375pW655Ra9/vrryszMNF0OjtCzZ8/Y/7dr104dO3ZUkyZNNGfOHJaroUYQ6H068cQTlZqaqm3btrke37ZtmwoKCgxVBQTH8OHD9fLLL+vNN9/UySefbLoc/K/09HSdeuqpkqQOHTpo1apVevTRRzVt2jTDlR3bVq9ere3bt+vss8+OPXbo0CG9+eabeuKJJ1RSUqLU1FSDFaK8evXq6bTTTtNnn31muhQcI1hD71N6ero6dOigxYsXxx6LRqNavHgx602BKjiOo+HDh2v+/PlasmSJmjZtarokVCEajaqkpMR0Gce8Sy65RGvXrtWaNWti/51zzjm69tprtWbNGsK8Zfbt26fPP/9cJ510kulScIxghj4Bo0eP1sCBA3XOOefovPPO05QpU1RcXKwbbrjBdGnHvH379rlmRjZu3Kg1a9YoNzdXjRs3NlgZhg0bplmzZumll15SnTp1tHXrVklSTk6OsrKyDFd3bBs7dqx69uypxo0ba+/evZo1a5aWLl2qhQsXmi7tmFenTh3PPpPs7GydcMIJ7D+xwG233aZevXqpSZMm2rx5s8aNG6fU1FQNGDDAdGk4RhDoE3DNNdfom2++0d13362tW7eqffv2eu211zwbZVHz3nvvPXXv3j3279GjR0uSBg4cqOnTpxuqCtL3Ny+SpG7durkef/bZZzVo0KCaLwgx27dv1/XXX68tW7YoJydH7dq108KFC3XppZeaLg2w2ldffaUBAwZo586dysvLU5cuXbRy5Url5eWZLg3HCK5DDwAAAAQYa+gBAACAACPQAwAAAAFGoAcAAAACjEAPAAAABBiBHgAAAAgwAj0AAAAQYAR6AAAAIMAI9AAAAECAEegBIE7Tp09XvXr1En6dSCSiBQsWJPw6AIBjG4EewDFp0KBB6t27t+kyAABIGIEeAAAACDACPQAc4ZFHHlHbtm2VnZ2tRo0a6f/9v/+nffv2eZ63YMECtWjRQpmZmSosLNSXX37p+vpLL72ks88+W5mZmWrWrJkmTJigsrKyCt+ztLRUw4cP10knnaTMzEw1adJEEydOPCo/HwAgXAj0AHCElJQUPfbYY/r44481Y8YMLVmyRLfffrvrOd99953uv/9+Pffcc1q+fLl2796t/v37x77+1ltv6frrr9ctt9yiTz75RNOmTdP06dN1//33V/iejz32mP76179qzpw5Wr9+vWbOnKlTTjnlaP6YAICQiDiO45guAgBq2qBBg7R79+5qbUqdN2+e/uu//ks7duyQ9P2m2BtuuEErV65Ux44dJUnr1q1T69at9c477+i8885Tjx49dMkll2js2LGx1/nzn/+s22+/XZs3b5b0/abY+fPnq3fv3ho5cqQ+/vhjLVq0SJFIJPk/MAAgtJihB4AjLFq0SJdccokaNmyoOnXq6Oc//7l27typ7777LvacWrVq6dxzz439u1WrVqpXr57+9a9/SZI+/PBD3XPPPapdu3bsvyFDhmjLli2u1zls0KBBWrNmjVq2bKmRI0fqH//4x9H/QQEAoUCgB4ByNm3apCuuuELt2rXTCy+8oNWrV2vq1KmSvl/nXl379u3ThAkTtGbNmth/a9eu1YYNG5SZmel5/tlnn62NGzfq3nvv1f79+9WvXz/17ds3aT8XACC8apkuAABssnr1akWjUT388MNKSfl+zmPOnDme55WVlem9997TeeedJ0lav369du/erdatW0v6PqCvX79ep556arXfu27durrmmmt0zTXXqG/fvvrRj36kXbt2KTc3Nwk/GQAgrAj0AI5ZRUVFWrNmjeuxE088UQcPHtTjjz+uXr16afny5Xr66ac935uWlqYRI0boscceU61atTR8+HB16tQpFvDvvvtuXXHFFWrcuLH69u2rlJQUffjhh/roo4903333eV7vkUce0UknnaSzzjpLKSkpmjt3rgoKCpJyAysAQLix5AbAMWvp0qU666yzXP89//zzeuSRR/Tggw/qjDPO0MyZMyu8fORxxx2nO+64Qz/72c90wQUXqHbt2vrLX/4S+3phYaFefvll/eMf/9C5556rTp06afLkyWrSpEmFtdSpU0cPPfSQzjnnHJ177rnatGmTXn311dinBAAAVIar3AAAAAABxtQPAAAAEGAEegAAACDACPQAAABAgBHoAQAAgAAj0AMAAAABRqAHAAAAAoxADwAAAAQYgR4AAAAIMAI9AAAAEGAEegAAACDACPQAAABAgP1/PT8I7lXAPKEAAAAASUVORK5CYII=",
      "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",
    "# Phi[Phi<1]=0\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": 19,
   "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": 22,
   "id": "48af3559",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2ezatStf6zPGmOjoaCPJ7Nu3z6597ty5RpL5/vvv87XcWrVqmUaNGuW7rnuN620/dIRCb+nSpapUqZKaNGmS53kffvhhDRw4UB999JFee+01Va9eXZJs/3722Wfq2bOnIiIiNGHCBP3xxx+aNm2amjVrpl27dqlChQqSpE6dOmnfvn0aMGCAKlSooMTERMXExOj48eO2Prld1r59+9S0aVOVLl1aw4cPl5eXl7766it17NhRCxcu1N/+9je7bXjxxRcVGBioUaNGKSUl5abb/Mcff+js2bOSpOTkZK1cuVKrVq3SiBEjcrXP3nrrLTk5OenVV19VYmKiJk2apPDwcO3evVtFihSRJM2fP19//PGH+vXrp+LFi2vr1q2aPHmyTp48qfnz59st79q1a4qIiFCzZs303nvvqWjRogoJCVFSUpJOnjypiRMnSpK8vb2zref5559XXFycYmJi9Nlnn2U7fdasWerdu7cGDhyoo0ePasqUKdq1a5c2bdp007EaqampWrhwoYYOHSpJ6tq1q3r37q34+HiFhITY+sXFxenBBx/UhQsX9Nxzz6latWo6deqUFixYoD/++EPu7u66dOmSHnroIe3fv1/PPvus6tWrp7Nnz2rJkiU6efKkSpQokavX4Hq///67IiMj1aVLFz3zzDMKDg6WJM2aNUve3t4aMmSIvL29tXbtWo0aNUrJycl2pytjYmLUrl07lSxZUoMGDVJISIj279+vZcuWadCgQercubOioqI0Z84cPfDAA3brnjNnjlq0aKHSpUvnWN/Vq1eVlJSUq20JCAiQs/OtD8WcM2eOJKlbt2437HfmzBnFxMTo6aeflpeX1w37njp1SomJiWrQoEGWaQ8++KBWrFhhe56amqpixYpl6Ve0aFFJ0o4dO3TffffddDuul56ernbt2mnNmjXq0qWLBg0apIsXLyomJkZ79+5V5cqVbX1nzpypK1eu6LnnnpOHh4cCAgIkyfb//mZ8fHzk4eEhSdq1a5e8vLxs74nXb3Pm9GbNmt10mcnJyUpLS9PZs2f16aefau/evXrttddyVQ/Eaax7XVJSkpFkOnTokOt5rj+yY0zOp7EuXrxo/P39Td++fe3a4+PjjZ+fn639/PnzOR4xyeuyjDGmZcuWJjQ01Fy5csXWlpGRYZo0aWJ3WD7zCECzZs1ydSg581Nfdo9+/fqZ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Gn733Xdq2rRpvt5Q58yZo1q1amn06NFZps2YMUNz587VG2+8ocDAQPn6+t40dFeuXPmmfTJPg164cMGu/bfffst13evXr9fvv/+ur7/+2u6eLkePHs1SjyTt3bv3pr9vPXr00Pvvv6+lS5dq5cqVCgwMzDGQX2/z5s165JFHclX30aNHbQP182PJkiW6ePFirgLM3LlzVblyZTVu3DhXyy5durQCAwNtp6Kut3XrVrsjF5m8vLzs3pO+++47FSlSRE2bNs3VOq9XuXJlbdmyRVevXs31DRD/KjOw3czMmTNtd5mvW7eu/v3vf2v//v2qUaOGrc+WLVts0/Pj8uXLMsbo4sWLhJ1c4A7K0CuvvCIvLy/94x//yHLDMOnPw78ffvhhjvNnXoXx1z8uERER8vX11dtvv62rV69mmS/zrql//PGH7ZBupsqVK8vHx8d2+De3ywoKClKLFi00Y8aMbD9BZnen1oKwdOlSSX+Or7iZTz/91O604YIFC3T69GlFRkZKku2TubnuBn/GmBu+Btnx8vLK9VU8Ob2GTz31lNLT0/Xmm29mmefatWtZ+l/vxIkT2rhxo5566il17tw5y6N37946fPiwtmzZImdnZ3Xs2FFLly7N9o9h5r7o1KmTfvrpJy1atCjHPpkBZOPGjbZp6enptpti5kZ2r0FaWpqmTp1q169evXqqWLGiJk2alGVfXD+vJNWuXVu1a9fWv//9by1cuFBdunTJ1SmVzDE7uXnc6piduXPnqmjRotmOibrerl27tH///huO1zpy5IjtNF+mTp06admyZTpx4oStbc2aNfr1119t4+BysnnzZn399dfq06eP/Pz8crE19jp16qSzZ89qypQpWab99bXKSW5fh+tDbIcOHeTm5mb3u2OM0fTp01W6dGm7q2BPnz6tAwcO2L3HZXeq+MKFC1q4cKHKli2b4ylm2OPIDlS5cmXNnTtXTz/9tKpXr253B+XNmzdr/vz5N/wurLp168rFxUUTJkxQUlKSPDw89OijjyooKEjTpk1T9+7dVa9ePXXp0kWBgYE6fvy4li9frqZNm2rKlCn69ddf1bJlSz311FOqUaOGXF1dtWjRIiUkJNjuLurr65urZUlSdHS0mjVrptDQUPXt21eVKlVSQkKCYmNjdfLkSf3000+3tL927typzz//XNKfY53WrFmjhQsXqkmT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SUlJkqSAgABJ0o4dO3T16lWFh4fb+lSrVk3lypVTbGysJCk2NlahoaF2NzOMiIhQcnKy9u3bdwerBwAAhVG+77NT0DIyMjR48GA1bdpUtWrVkiTFx8fL3d1d/v7+dn2Dg4MVHx9v6/PXuzZnPs/s81epqalKTU21PU9OTi6ozQAAAIVMoTmyExUVpb1792revHm3fV3jxo2Tn5+f7VG2bNnbvk4AAOAYhSLs9O/fX8uWLdO6detUpkwZW3tISIjS0tJ04cIFu/4JCQkKCQmx9fnr1VmZzzP7/NWIESOUlJRke5w4caIAtwYAABQmDg07xhj1799fixYt0tq1a1WxYkW76fXr15ebm5vWrFljazt48KCOHz+usLAwSVJYWJj27NmjxMREW5+YmBj5+vqqRo0a2a7Xw8NDvr6+dg8AAGBNDh2zExUVpblz5+qbb76Rj4+PbYyNn5+fihQpIj8/P/Xp00dDhgxRQECAfH19NWDAAIWFhalx48aSpNatW6tGjRrq3r273nnnHcXHx2vkyJGKioqSh4eHIzcPAAAUAg4NO9OmTZMktWjRwq595syZ6tWrlyRp4sSJcnZ2VqdOnZSamqqIiAhNnTrV1tfFxUXLli1Tv379FBYWJi8vL/Xs2VNjx469U5sBAAAKMYeGndzc4sfT01PR0dGKjo7OsU/58uW1YsWKgiwNAABYRKEYoAwAAHC7EHYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClEXYAAIClOTTsbNy4Ue3bt1epUqXk5OSkxYsX2003xmjUqFEqWbKkihQpovDwcB06dMiuz7lz59StWzf5+vrK399fffr00aVLl+7gVgAAgMLMoWEnJSVFderUUXR0dLbT33nnHX300UeaPn26tmzZIi8vL0VEROjKlSu2Pt26ddO+ffsUExOjZcuWaePGjXruuefu1CYAAIBCztWRK4+MjFRkZGS204wxmjRpkkaOHKkOHTpIkj799FMFBwdr8eLF6tKli/bv369Vq1Zp27ZtatCggSRp8uTJatOmjd577z2VKlXqjm0LAAAonArtmJ2jR48qPj5e4eHhtjY/Pz81atRIsbGxkqTY2Fj5+/vbgo4khYeHy9nZWVu2bLnjNQMAgMLHoUd2biQ+Pl6SFBwcbNceHBxsmxYfH6+goCC76a6urgoICLD1yU5qaqpSU1Ntz5OTkwuqbAAAUMgU2iM7t9O4cePk5+dne5QtW9bRJQEAgNuk0IadkJAQSVJCQoJde0JCgm1aSEiIEhMT7aZfu3ZN586ds/XJzogRI5SUlGR7nDhxooCrBwAAhUWhDTsVK1ZUSEiI1qxZY2tLTk7Wli1bFBYWJkkKCwvThQsXtGPHDluftWvXKiMjQ40aNcpx2R4eHvL19bV7AAAAa3LomJ1Lly7p8OHDtudHjx7V7t27FRAQoHLlymnw4MH617/+pfvuu08VK1bU66+/rlKlSqljx46SpOrVq+uxxx5T3759NX36dF29elX9+/dXly5duBILAABIcnDY2b59ux555BHb8yFDhkiSevbsqVmzZumVV15RSkqKnnvuOV24cEHNmjXTqlWr5OnpaZtnzpw56t+/v1q2bClnZ2d16tRJH3300R3fFgAAUDg5GWOMo4twtOTkZPn5+SkpKYlTWsA9psLw5Y4uwWGOjW+b73nv1f12K/tMYr8VtNz+/S60Y3YAAAAKAmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEHAABYGmEH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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import Counter\n",
    "\n",
    "\n",
    "Phi = C_t_0@Y\n",
    "Phi[Phi<0.7]=0\n",
    "Phi = Phi.detach().cpu().numpy()\n",
    "\n",
    "\n",
    "\n",
    "num_zeros_per_row = np.sum(Phi == 0, axis=1)\n",
    "\n",
    "# filtered_counts = [count for count in num_zeros_per_row if count <= 5]\n",
    "# counts = Counter(filtered_counts)\n",
    "\n",
    "\n",
    "\n",
    "counts = Counter(num_zeros_per_row)\n",
    "# Create a bar plot\n",
    "plt.bar(counts.keys(), counts.values())\n",
    "plt.xlabel(\"Number of Zeros\")\n",
    "plt.ylabel(\"Count\")\n",
    "plt.xticks(range(6))\n",
    "plt.title(\"Citeseer Bipartite Accuracy =  77.09, cr=0.3\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4599732c",
   "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
}
