{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "5bd09c7c"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.nn.parameter import Parameter\n",
    "import math\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import random\n",
    "from sam import SAM\n",
    "from numpy import linalg as LA\n",
    "import torch.optim as optim\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Neural Network Structure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "ee5a5946"
   },
   "outputs": [],
   "source": [
    "class CNN(nn.Module):\n",
    "    def __init__(self, input_dim, out_channel, patch_num):\n",
    "        super(CNN, self).__init__()\n",
    "        self.conv1 = nn.Conv1d(1, out_channel*2, int(input_dim/patch_num), int(input_dim/patch_num))\n",
    "        self.out_channel = out_channel\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.conv1(x)\n",
    "        x = torch.pow(x, 1)\n",
    "        x = torch.nn.functional.relu(x)\n",
    "        x = torch.mean(x,2)\n",
    "        output = torch.stack([torch.sum(x[:,:self.out_channel],1), torch.sum(x[:,self.out_channel:],1)]).transpose(1,0)\n",
    "        return output\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "hiQ0Z1NaEjpk"
   },
   "outputs": [],
   "source": [
    "def initialize_weights(m):\n",
    "    if isinstance(m, nn.Conv1d):\n",
    "        torch.nn.init.normal_(m.weight.data, mean=0.0, std= 0.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {
    "id": "0e5a4a5b"
   },
   "outputs": [],
   "source": [
    "\n",
    "def train(model, criterion, data, labels, epochs, lr = 0.01, rho = 0.07, SAMM = True, record = False):\n",
    "    Largest = []\n",
    "    Smallest = []\n",
    "    trainR = []\n",
    "    testR = []\n",
    "    testtR = []\n",
    "    optimizer = optim.SGD(model.parameters(), lr= lr, momentum=0, weight_decay=0)\n",
    "    base_optimizer = torch.optim.SGD\n",
    "    sam_optimizer = SAM(model.parameters(), base_optimizer, lr=lr, rho=rho)  # Create a new variable for the SAM optimizer\n",
    "   \n",
    "    \n",
    "    for epoch in range(epochs):  \n",
    "        if record == True:\n",
    "            funcf = model(data)[:, 1] -  model(data)[:, 0]\n",
    "            yfuncf = funcf*(labels - 0.5)*2\n",
    "            Largest.append(yfuncf.max().detach())\n",
    "            Smallest.append(yfuncf.min().detach())\n",
    "            testR.append(test_ACC(model, criterion, test_data, test_labels, epoch))\n",
    "            testtR.append(test(model, criterion, test_data, test_labels, epoch))\n",
    "            trainR.append(test(model, criterion, data, labels, epoch))\n",
    "\n",
    "            \n",
    "            \n",
    "\n",
    "        outputs = model(data)\n",
    "        \n",
    "        if SAMM == False:\n",
    "            #SGD Block\n",
    "            optimizer.zero_grad() \n",
    "            loss = criterion(outputs, labels)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "        else:\n",
    "            loss_first = criterion(outputs, labels) \n",
    "            # Create a separate loss object for the first backward pass\n",
    "            loss_first.backward(retain_graph=True)\n",
    "            sam_optimizer.first_step(zero_grad=True)\n",
    "            outputs = model(data)\n",
    "            loss_second = criterion(outputs, labels)  # Create a separate loss object for the second backward pass\n",
    "            loss_second.backward()\n",
    "            sam_optimizer.second_step(zero_grad=True)\n",
    "        \n",
    "        \n",
    "        \n",
    "#     print('Finished Training')\n",
    "\n",
    "    if record == True:    \n",
    "        return Largest, Smallest, testR, testtR, trainR\n",
    "\n",
    "        \n",
    "        # if epoch%500 == 0:   \n",
    "        #     print('Epoch %d --- loss: %.3f' %\n",
    "        #             (epoch + 1, loss.item()))\n",
    "        #     #test(model, criterion, test_data, test_labels, num_epochs)\n",
    "\n",
    "    # print('Finished Training')\n",
    "\n",
    "\n",
    "def test(model, criterion, data, labels, epochs):\n",
    "    correct = 0\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        outputs = model(data)\n",
    "    #     predicted = torch.max(outputs.data, 1).indices\n",
    "    #     correct += (predicted == labels).sum().item()\n",
    "    # outputt = 100*correct / data.shape[0]\n",
    "    outputt = criterion(outputs, labels)\n",
    "    # print('Accuracy of the network on the %d test images: %.4f %%' % (data.shape[0],\n",
    "    #     outputt))\n",
    "    return outputt\n",
    "\n",
    "def test_ACC(model, criterion, data, labels, epochs):\n",
    "    correct = 0\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        outputs = model(data)\n",
    "        predicted = torch.max(outputs.data, 1).indices\n",
    "        correct += (predicted == labels).sum().item()\n",
    "    outputt = 1 - correct / data.shape[0]\n",
    "    # print('Accuracy of the network on the %d test images: %.4f %%' % (data.shape[0],\n",
    "    #     outputt))\n",
    "    return outputt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training With Multi-Pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "dy61UnbJ5ZIo",
    "outputId": "bf63bcff-33fc-4009-f09f-7f9df70596a9"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "Training Error: tensor(0.1291)\n",
      "Test Error: 0.5036999999999999\n",
      "1\n",
      "Training Error: tensor(0.1614)\n",
      "Test Error: 0.49030000000000007\n",
      "2\n",
      "Training Error: tensor(0.2133)\n",
      "Test Error: 0.5025999999999999\n",
      "3\n",
      "Training Error: tensor(0.2007)\n",
      "Test Error: 0.5048\n",
      "4\n",
      "Training Error: tensor(0.2239)\n",
      "Test Error: 0.5032\n",
      "5\n",
      "Training Error: tensor(0.2250)\n",
      "Test Error: 0.49879999999999997\n",
      "6\n",
      "Training Error: tensor(0.2246)\n",
      "Test Error: 0.5071\n",
      "7\n",
      "Training Error: tensor(0.2141)\n",
      "Test Error: 0.49959999999999993\n",
      "8\n",
      "Training Error: tensor(0.2246)\n",
      "Test Error: 0.4864\n",
      "9\n",
      "Training Error: tensor(0.2212)\n",
      "Test Error: 0.5014000000000001\n",
      "10\n",
      "Training Error: tensor(0.2241)\n",
      "Test Error: 0.5039999999999999\n",
      "11\n",
      "Training Error: tensor(0.2065)\n",
      "Test Error: 0.4971\n",
      "12\n",
      "Training Error: tensor(0.2046)\n",
      "Test Error: 0.501\n",
      "13\n",
      "Training Error: tensor(0.2080)\n",
      "Test Error: 0.5063\n",
      "14\n",
      "Training Error: tensor(0.2148)\n",
      "Test Error: 0.4968\n",
      "15\n",
      "Training Error: tensor(0.2193)\n",
      "Test Error: 0.5056\n",
      "16\n",
      "Training Error: tensor(0.1949)\n",
      "Test Error: 0.4981\n",
      "17\n",
      "Training Error: tensor(0.2076)\n",
      "Test Error: 0.4983000000000001\n",
      "18\n",
      "Training Error: tensor(0.2053)\n",
      "Test Error: 0.5045999999999999\n",
      "19\n",
      "Training Error: tensor(0.1931)\n",
      "Test Error: 0.4949\n",
      "20\n",
      "Training Error: tensor(0.1278)\n",
      "Test Error: 0.43920000000000003\n",
      "21\n",
      "Training Error: tensor(0.1603)\n",
      "Test Error: 0.44499999999999995\n",
      "22\n",
      "Training Error: tensor(0.1660)\n",
      "Test Error: 0.44329999999999997\n",
      "23\n",
      "Training Error: tensor(0.2000)\n",
      "Test Error: 0.4338\n",
      "24\n",
      "Training Error: tensor(0.2001)\n",
      "Test Error: 0.4434\n",
      "25\n",
      "Training Error: tensor(0.1977)\n",
      "Test Error: 0.4422\n",
      "26\n",
      "Training Error: tensor(0.1861)\n",
      "Test Error: 0.4454000000000001\n",
      "27\n",
      "Training Error: tensor(0.2059)\n",
      "Test Error: 0.4337999999999999\n",
      "28\n",
      "Training Error: tensor(0.1858)\n",
      "Test Error: 0.4282\n",
      "29\n",
      "Training Error: tensor(0.1875)\n",
      "Test Error: 0.4495\n",
      "30\n",
      "Training Error: tensor(0.1826)\n",
      "Test Error: 0.4348000000000001\n",
      "31\n",
      "Training Error: tensor(0.1837)\n",
      "Test Error: 0.45269999999999994\n",
      "32\n",
      "Training Error: tensor(0.1961)\n",
      "Test Error: 0.4483\n",
      "33\n",
      "Training Error: tensor(0.1763)\n",
      "Test Error: 0.42200000000000004\n",
      "34\n",
      "Training Error: tensor(0.2057)\n",
      "Test Error: 0.45170000000000005\n",
      "35\n",
      "Training Error: tensor(0.2060)\n",
      "Test Error: 0.44509999999999994\n",
      "36\n",
      "Training Error: tensor(0.1822)\n",
      "Test Error: 0.45680000000000004\n",
      "37\n",
      "Training Error: tensor(0.1790)\n",
      "Test Error: 0.45249999999999996\n",
      "38\n",
      "Training Error: tensor(0.1842)\n",
      "Test Error: 0.44560000000000005\n",
      "39\n",
      "Training Error: tensor(0.1736)\n",
      "Test Error: 0.44090000000000007\n",
      "40\n",
      "Training Error: tensor(0.1187)\n",
      "Test Error: 0.3914\n",
      "41\n",
      "Training Error: tensor(0.1410)\n",
      "Test Error: 0.352\n",
      "42\n",
      "Training Error: tensor(0.1681)\n",
      "Test Error: 0.38709999999999994\n",
      "43\n",
      "Training Error: tensor(0.1631)\n",
      "Test Error: 0.39059999999999995\n",
      "44\n",
      "Training Error: tensor(0.1665)\n",
      "Test Error: 0.386\n",
      "45\n",
      "Training Error: tensor(0.1790)\n",
      "Test Error: 0.38380000000000003\n",
      "46\n",
      "Training Error: tensor(0.1652)\n",
      "Test Error: 0.374\n",
      "47\n",
      "Training Error: tensor(0.1597)\n",
      "Test Error: 0.36469999999999997\n",
      "48\n",
      "Training Error: tensor(0.1696)\n",
      "Test Error: 0.3653\n",
      "49\n",
      "Training Error: tensor(0.1567)\n",
      "Test Error: 0.3808\n",
      "50\n",
      "Training Error: tensor(0.1612)\n",
      "Test Error: 0.3734\n",
      "51\n",
      "Training Error: tensor(0.1709)\n",
      "Test Error: 0.3751\n",
      "52\n",
      "Training Error: tensor(0.1525)\n",
      "Test Error: 0.358\n",
      "53\n",
      "Training Error: tensor(0.1501)\n",
      "Test Error: 0.35509999999999997\n",
      "54\n",
      "Training Error: tensor(0.1531)\n",
      "Test Error: 0.4095000000000001\n",
      "55\n",
      "Training Error: tensor(0.1625)\n",
      "Test Error: 0.3682\n",
      "56\n",
      "Training Error: tensor(0.1682)\n",
      "Test Error: 0.41319999999999996\n",
      "57\n",
      "Training Error: tensor(0.1359)\n",
      "Test Error: 0.3706\n",
      "58\n",
      "Training Error: tensor(0.1288)\n",
      "Test Error: 0.35609999999999997\n",
      "59\n",
      "Training Error: tensor(0.1610)\n",
      "Test Error: 0.3821\n",
      "60\n",
      "Training Error: tensor(0.0899)\n",
      "Test Error: 0.32530000000000003\n",
      "61\n",
      "Training Error: tensor(0.1319)\n",
      "Test Error: 0.3318\n",
      "62\n",
      "Training Error: tensor(0.1524)\n",
      "Test Error: 0.3246\n",
      "63\n",
      "Training Error: tensor(0.1474)\n",
      "Test Error: 0.31259999999999993\n",
      "64\n",
      "Training Error: tensor(0.1415)\n",
      "Test Error: 0.32930000000000004\n",
      "65\n",
      "Training Error: tensor(0.1487)\n",
      "Test Error: 0.3086999999999999\n",
      "66\n",
      "Training Error: tensor(0.1720)\n",
      "Test Error: 0.373\n",
      "67\n",
      "Training Error: tensor(0.1380)\n",
      "Test Error: 0.32130000000000003\n",
      "68\n",
      "Training Error: tensor(0.1508)\n",
      "Test Error: 0.3233\n",
      "69\n",
      "Training Error: tensor(0.1478)\n",
      "Test Error: 0.3322\n",
      "70\n",
      "Training Error: tensor(0.1291)\n",
      "Test Error: 0.33520000000000005\n",
      "71\n",
      "Training Error: tensor(0.1463)\n",
      "Test Error: 0.3228\n",
      "72\n",
      "Training Error: tensor(0.1367)\n",
      "Test Error: 0.32399999999999995\n",
      "73\n",
      "Training Error: tensor(0.1395)\n",
      "Test Error: 0.31139999999999995\n",
      "74\n",
      "Training Error: tensor(0.1556)\n",
      "Test Error: 0.3403\n",
      "75\n",
      "Training Error: tensor(0.1285)\n",
      "Test Error: 0.323\n",
      "76\n",
      "Training Error: tensor(0.1320)\n",
      "Test Error: 0.32310000000000005\n",
      "77\n",
      "Training Error: tensor(0.1317)\n",
      "Test Error: 0.33609999999999995\n",
      "78\n",
      "Training Error: tensor(0.1322)\n",
      "Test Error: 0.329\n",
      "79\n",
      "Training Error: tensor(0.1384)\n",
      "Test Error: 0.3404999999999999\n",
      "80\n",
      "Training Error: tensor(0.0828)\n",
      "Test Error: 0.2824\n",
      "81\n",
      "Training Error: tensor(0.1025)\n",
      "Test Error: 0.25630000000000003\n",
      "82\n",
      "Training Error: tensor(0.1111)\n",
      "Test Error: 0.2536999999999999\n",
      "83\n",
      "Training Error: tensor(0.1388)\n",
      "Test Error: 0.2805\n",
      "84\n",
      "Training Error: tensor(0.1225)\n",
      "Test Error: 0.24180000000000001\n",
      "85\n",
      "Training Error: tensor(0.1179)\n",
      "Test Error: 0.23170000000000002\n",
      "86\n",
      "Training Error: tensor(0.1049)\n",
      "Test Error: 0.22480000000000003\n",
      "87\n",
      "Training Error: tensor(0.1135)\n",
      "Test Error: 0.22180000000000005\n",
      "88\n",
      "Training Error: tensor(0.1276)\n",
      "Test Error: 0.248\n",
      "89\n",
      "Training Error: tensor(0.1342)\n",
      "Test Error: 0.2655\n",
      "90\n",
      "Training Error: tensor(0.1275)\n",
      "Test Error: 0.2632\n",
      "91\n",
      "Training Error: tensor(0.1200)\n",
      "Test Error: 0.25559999999999994\n",
      "92\n",
      "Training Error: tensor(0.1407)\n",
      "Test Error: 0.2949\n",
      "93\n",
      "Training Error: tensor(0.1226)\n",
      "Test Error: 0.2824999999999999\n",
      "94\n",
      "Training Error: tensor(0.1296)\n",
      "Test Error: 0.2752\n",
      "95\n",
      "Training Error: tensor(0.1106)\n",
      "Test Error: 0.2466\n",
      "96\n",
      "Training Error: tensor(0.1127)\n",
      "Test Error: 0.2568\n",
      "97\n",
      "Training Error: tensor(0.1042)\n",
      "Test Error: 0.24779999999999996\n",
      "98\n",
      "Training Error: tensor(0.1049)\n",
      "Test Error: 0.23280000000000003\n",
      "99\n",
      "Training Error: tensor(0.1183)\n",
      "Test Error: 0.2351\n",
      "100\n",
      "Training Error: tensor(0.0818)\n",
      "Test Error: 0.2021\n",
      "101\n",
      "Training Error: tensor(0.0943)\n",
      "Test Error: 0.19989999999999997\n",
      "102\n",
      "Training Error: tensor(0.0804)\n",
      "Test Error: 0.17240000000000003\n",
      "103\n",
      "Training Error: tensor(0.1103)\n",
      "Test Error: 0.18770000000000003\n",
      "104\n",
      "Training Error: tensor(0.1042)\n",
      "Test Error: 0.18339999999999998\n",
      "105\n",
      "Training Error: tensor(0.1111)\n",
      "Test Error: 0.20319999999999996\n",
      "106\n",
      "Training Error: tensor(0.0946)\n",
      "Test Error: 0.16219999999999998\n",
      "107\n",
      "Training Error: tensor(0.0797)\n",
      "Test Error: 0.1536\n",
      "108\n",
      "Training Error: tensor(0.0941)\n",
      "Test Error: 0.1862\n",
      "109\n",
      "Training Error: tensor(0.1174)\n",
      "Test Error: 0.1714\n",
      "110\n",
      "Training Error: tensor(0.1003)\n",
      "Test Error: 0.18780000000000002\n",
      "111\n",
      "Training Error: tensor(0.1015)\n",
      "Test Error: 0.1928\n",
      "112\n",
      "Training Error: tensor(0.0898)\n",
      "Test Error: 0.15699999999999997\n",
      "113\n",
      "Training Error: tensor(0.0953)\n",
      "Test Error: 0.16729999999999998\n",
      "114\n",
      "Training Error: tensor(0.0799)\n",
      "Test Error: 0.15109999999999996\n",
      "115\n",
      "Training Error: tensor(0.0951)\n",
      "Test Error: 0.19380000000000003\n",
      "116\n",
      "Training Error: tensor(0.0943)\n",
      "Test Error: 0.16359999999999997\n",
      "117\n",
      "Training Error: tensor(0.0975)\n",
      "Test Error: 0.16499999999999998\n",
      "118\n",
      "Training Error: tensor(0.0856)\n",
      "Test Error: 0.1637\n",
      "119\n",
      "Training Error: tensor(0.0798)\n",
      "Test Error: 0.1631\n",
      "120\n",
      "Training Error: tensor(0.0566)\n",
      "Test Error: 0.16309999999999997\n",
      "121\n",
      "Training Error: tensor(0.0804)\n",
      "Test Error: 0.1284\n",
      "122\n",
      "Training Error: tensor(0.0813)\n",
      "Test Error: 0.1453\n",
      "123\n",
      "Training Error: tensor(0.0883)\n",
      "Test Error: 0.14279999999999998\n",
      "124\n",
      "Training Error: tensor(0.0927)\n",
      "Test Error: 0.14689999999999998\n",
      "125\n",
      "Training Error: tensor(0.0714)\n",
      "Test Error: 0.11600000000000002\n",
      "126\n",
      "Training Error: tensor(0.0725)\n",
      "Test Error: 0.0954\n",
      "127\n",
      "Training Error: tensor(0.0802)\n",
      "Test Error: 0.10800000000000001\n",
      "128\n",
      "Training Error: tensor(0.0869)\n",
      "Test Error: 0.1466\n",
      "129\n",
      "Training Error: tensor(0.0813)\n",
      "Test Error: 0.11429999999999998\n",
      "130\n",
      "Training Error: tensor(0.0869)\n",
      "Test Error: 0.1436\n",
      "131\n",
      "Training Error: tensor(0.0760)\n",
      "Test Error: 0.1139\n",
      "132\n",
      "Training Error: tensor(0.0752)\n",
      "Test Error: 0.1204\n",
      "133\n",
      "Training Error: tensor(0.0929)\n",
      "Test Error: 0.1336\n",
      "134\n",
      "Training Error: tensor(0.0556)\n",
      "Test Error: 0.10149999999999999\n",
      "135\n",
      "Training Error: tensor(0.0724)\n",
      "Test Error: 0.1083\n",
      "136\n",
      "Training Error: tensor(0.0715)\n",
      "Test Error: 0.10309999999999997\n",
      "137\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training Error: tensor(0.0804)\n",
      "Test Error: 0.14679999999999999\n",
      "138\n",
      "Training Error: tensor(0.0583)\n",
      "Test Error: 0.09590000000000001\n",
      "139\n",
      "Training Error: tensor(0.0578)\n",
      "Test Error: 0.10029999999999999\n",
      "140\n",
      "Training Error: tensor(0.0403)\n",
      "Test Error: 0.09259999999999999\n",
      "141\n",
      "Training Error: tensor(0.0657)\n",
      "Test Error: 0.0923\n",
      "142\n",
      "Training Error: tensor(0.0600)\n",
      "Test Error: 0.0653\n",
      "143\n",
      "Training Error: tensor(0.0767)\n",
      "Test Error: 0.10709999999999997\n",
      "144\n",
      "Training Error: tensor(0.0746)\n",
      "Test Error: 0.1052\n",
      "145\n",
      "Training Error: tensor(0.0658)\n",
      "Test Error: 0.08940000000000001\n",
      "146\n",
      "Training Error: tensor(0.0681)\n",
      "Test Error: 0.07900000000000004\n",
      "147\n",
      "Training Error: tensor(0.0697)\n",
      "Test Error: 0.0981\n",
      "148\n",
      "Training Error: tensor(0.0821)\n",
      "Test Error: 0.1024\n",
      "149\n",
      "Training Error: tensor(0.0412)\n",
      "Test Error: 0.037400000000000024\n",
      "150\n",
      "Training Error: tensor(0.0568)\n",
      "Test Error: 0.06960000000000001\n",
      "151\n",
      "Training Error: tensor(0.0486)\n",
      "Test Error: 0.05230000000000003\n",
      "152\n",
      "Training Error: tensor(0.0570)\n",
      "Test Error: 0.09110000000000001\n",
      "153\n",
      "Training Error: tensor(0.0446)\n",
      "Test Error: 0.04950000000000002\n",
      "154\n",
      "Training Error: tensor(0.0455)\n",
      "Test Error: 0.05140000000000002\n",
      "155\n",
      "Training Error: tensor(0.0511)\n",
      "Test Error: 0.06510000000000002\n",
      "156\n",
      "Training Error: tensor(0.0419)\n",
      "Test Error: 0.055300000000000016\n",
      "157\n",
      "Training Error: tensor(0.0411)\n",
      "Test Error: 0.04850000000000002\n",
      "158\n",
      "Training Error: tensor(0.0392)\n",
      "Test Error: 0.06020000000000002\n",
      "159\n",
      "Training Error: tensor(0.0407)\n",
      "Test Error: 0.04320000000000003\n",
      "160\n",
      "Training Error: tensor(0.0312)\n",
      "Test Error: 0.07120000000000001\n",
      "161\n",
      "Training Error: tensor(0.0422)\n",
      "Test Error: 0.044900000000000016\n",
      "162\n",
      "Training Error: tensor(0.0450)\n",
      "Test Error: 0.048299999999999996\n",
      "163\n",
      "Training Error: tensor(0.0578)\n",
      "Test Error: 0.06580000000000001\n",
      "164\n",
      "Training Error: tensor(0.0561)\n",
      "Test Error: 0.05149999999999999\n",
      "165\n",
      "Training Error: tensor(0.0456)\n",
      "Test Error: 0.044600000000000015\n",
      "166\n",
      "Training Error: tensor(0.0610)\n",
      "Test Error: 0.07110000000000001\n",
      "167\n",
      "Training Error: tensor(0.0374)\n",
      "Test Error: 0.03480000000000001\n",
      "168\n",
      "Training Error: tensor(0.0334)\n",
      "Test Error: 0.03750000000000002\n",
      "169\n",
      "Training Error: tensor(0.0233)\n",
      "Test Error: 0.016600000000000014\n",
      "170\n",
      "Training Error: tensor(0.0370)\n",
      "Test Error: 0.028500000000000025\n",
      "171\n",
      "Training Error: tensor(0.0439)\n",
      "Test Error: 0.04610000000000001\n",
      "172\n",
      "Training Error: tensor(0.0256)\n",
      "Test Error: 0.018400000000000017\n",
      "173\n",
      "Training Error: tensor(0.0359)\n",
      "Test Error: 0.028700000000000014\n",
      "174\n",
      "Training Error: tensor(0.0364)\n",
      "Test Error: 0.03610000000000001\n",
      "175\n",
      "Training Error: tensor(0.0289)\n",
      "Test Error: 0.027700000000000002\n",
      "176\n",
      "Training Error: tensor(0.0297)\n",
      "Test Error: 0.018700000000000015\n",
      "177\n",
      "Training Error: tensor(0.0285)\n",
      "Test Error: 0.024400000000000022\n",
      "178\n",
      "Training Error: tensor(0.0241)\n",
      "Test Error: 0.014000000000000012\n",
      "179\n",
      "Training Error: tensor(0.0313)\n",
      "Test Error: 0.027300000000000012\n",
      "180\n",
      "Training Error: tensor(0.0231)\n",
      "Test Error: 0.026800000000000025\n",
      "181\n",
      "Training Error: tensor(0.0457)\n",
      "Test Error: 0.052000000000000025\n",
      "182\n",
      "Training Error: tensor(0.0481)\n",
      "Test Error: 0.06220000000000002\n",
      "183\n",
      "Training Error: tensor(0.0372)\n",
      "Test Error: 0.03800000000000002\n",
      "184\n",
      "Training Error: tensor(0.0523)\n",
      "Test Error: 0.051300000000000026\n",
      "185\n",
      "Training Error: tensor(0.0315)\n",
      "Test Error: 0.023300000000000008\n",
      "186\n",
      "Training Error: tensor(0.0236)\n",
      "Test Error: 0.014400000000000013\n",
      "187\n",
      "Training Error: tensor(0.0307)\n",
      "Test Error: 0.028000000000000014\n",
      "188\n",
      "Training Error: tensor(0.0366)\n",
      "Test Error: 0.026400000000000014\n",
      "189\n",
      "Training Error: tensor(0.0480)\n",
      "Test Error: 0.05910000000000001\n",
      "190\n",
      "Training Error: tensor(0.0336)\n",
      "Test Error: 0.029400000000000003\n",
      "191\n",
      "Training Error: tensor(0.0336)\n",
      "Test Error: 0.03370000000000001\n",
      "192\n",
      "Training Error: tensor(0.0225)\n",
      "Test Error: 0.01210000000000001\n",
      "193\n",
      "Training Error: tensor(0.0338)\n",
      "Test Error: 0.02580000000000001\n",
      "194\n",
      "Training Error: tensor(0.0326)\n",
      "Test Error: 0.03570000000000002\n",
      "195\n",
      "Training Error: tensor(0.0354)\n",
      "Test Error: 0.0273\n",
      "196\n",
      "Training Error: tensor(0.0272)\n",
      "Test Error: 0.015400000000000014\n",
      "197\n",
      "Training Error: tensor(0.0242)\n",
      "Test Error: 0.012700000000000012\n",
      "198\n",
      "Training Error: tensor(0.0194)\n",
      "Test Error: 0.01180000000000001\n",
      "199\n",
      "Training Error: tensor(0.0165)\n",
      "Test Error: 0.009400000000000009\n",
      "200\n",
      "Training Error: tensor(0.0191)\n",
      "Test Error: 0.020100000000000017\n",
      "201\n",
      "Training Error: tensor(0.0199)\n",
      "Test Error: 0.012200000000000011\n",
      "202\n",
      "Training Error: tensor(0.0197)\n",
      "Test Error: 0.008100000000000007\n",
      "203\n",
      "Training Error: tensor(0.0227)\n",
      "Test Error: 0.011899999999999999\n",
      "204\n",
      "Training Error: tensor(0.0194)\n",
      "Test Error: 0.007300000000000006\n",
      "205\n",
      "Training Error: tensor(0.0371)\n",
      "Test Error: 0.03500000000000001\n",
      "206\n",
      "Training Error: tensor(0.0287)\n",
      "Test Error: 0.020300000000000006\n",
      "207\n",
      "Training Error: tensor(0.0150)\n",
      "Test Error: 0.0026000000000000025\n",
      "208\n",
      "Training Error: tensor(0.0219)\n",
      "Test Error: 0.008000000000000007\n",
      "209\n",
      "Training Error: tensor(0.0277)\n",
      "Test Error: 0.0261\n",
      "210\n",
      "Training Error: tensor(0.0158)\n",
      "Test Error: 0.005300000000000004\n",
      "211\n",
      "Training Error: tensor(0.0132)\n",
      "Test Error: 0.0029000000000000024\n",
      "212\n",
      "Training Error: tensor(0.0229)\n",
      "Test Error: 0.02200000000000001\n",
      "213\n",
      "Training Error: tensor(0.0179)\n",
      "Test Error: 0.006900000000000006\n",
      "214\n",
      "Training Error: tensor(0.0132)\n",
      "Test Error: 0.002300000000000002\n",
      "215\n",
      "Training Error: tensor(0.0276)\n",
      "Test Error: 0.021300000000000006\n",
      "216\n",
      "Training Error: tensor(0.0136)\n",
      "Test Error: 0.003400000000000003\n",
      "217\n",
      "Training Error: tensor(0.0129)\n",
      "Test Error: 0.003300000000000003\n",
      "218\n",
      "Training Error: tensor(0.0176)\n",
      "Test Error: 0.006900000000000006\n",
      "219\n",
      "Training Error: tensor(0.0119)\n",
      "Test Error: 0.005400000000000005\n",
      "220\n",
      "Training Error: tensor(0.0140)\n",
      "Test Error: 0.017000000000000005\n",
      "221\n",
      "Training Error: tensor(0.0215)\n",
      "Test Error: 0.0142\n",
      "222\n",
      "Training Error: tensor(0.0165)\n",
      "Test Error: 0.0039000000000000033\n",
      "223\n",
      "Training Error: tensor(0.0150)\n",
      "Test Error: 0.004800000000000004\n",
      "224\n",
      "Training Error: tensor(0.0204)\n",
      "Test Error: 0.0125\n",
      "225\n",
      "Training Error: tensor(0.0369)\n",
      "Test Error: 0.027700000000000002\n",
      "226\n",
      "Training Error: tensor(0.0110)\n",
      "Test Error: 0.0017000000000000014\n",
      "227\n",
      "Training Error: tensor(0.0127)\n",
      "Test Error: 0.003100000000000003\n",
      "228\n",
      "Training Error: tensor(0.0144)\n",
      "Test Error: 0.002300000000000002\n",
      "229\n",
      "Training Error: tensor(0.0141)\n",
      "Test Error: 0.0029000000000000024\n",
      "230\n",
      "Training Error: tensor(0.0089)\n",
      "Test Error: 0.0008000000000000007\n",
      "231\n",
      "Training Error: tensor(0.0141)\n",
      "Test Error: 0.0038000000000000035\n",
      "232\n",
      "Training Error: tensor(0.0116)\n",
      "Test Error: 0.002100000000000002\n",
      "233\n",
      "Training Error: tensor(0.0123)\n",
      "Test Error: 0.002300000000000002\n",
      "234\n",
      "Training Error: tensor(0.0088)\n",
      "Test Error: 0.0007000000000000006\n",
      "235\n",
      "Training Error: tensor(0.0210)\n",
      "Test Error: 0.018500000000000006\n",
      "236\n",
      "Training Error: tensor(0.0105)\n",
      "Test Error: 0.002300000000000002\n",
      "237\n",
      "Training Error: tensor(0.0088)\n",
      "Test Error: 0.0014000000000000013\n",
      "238\n",
      "Training Error: tensor(0.0085)\n",
      "Test Error: 0.0008000000000000007\n",
      "239\n",
      "Training Error: tensor(0.0079)\n",
      "Test Error: 0.0007000000000000006\n",
      "240\n",
      "Training Error: tensor(0.0118)\n",
      "Test Error: 0.008100000000000007\n",
      "241\n",
      "Training Error: tensor(0.0141)\n",
      "Test Error: 0.008399999999999996\n",
      "242\n",
      "Training Error: tensor(0.0101)\n",
      "Test Error: 0.0018000000000000017\n",
      "243\n",
      "Training Error: tensor(0.0119)\n",
      "Test Error: 0.007799999999999996\n",
      "244\n",
      "Training Error: tensor(0.0091)\n",
      "Test Error: 0.0013000000000000012\n",
      "245\n",
      "Training Error: tensor(0.0096)\n",
      "Test Error: 0.00040000000000000034\n",
      "246\n",
      "Training Error: tensor(0.0299)\n",
      "Test Error: 0.034199999999999994\n",
      "247\n",
      "Training Error: tensor(0.0064)\n",
      "Test Error: 0.00020000000000000017\n",
      "248\n",
      "Training Error: tensor(0.0074)\n",
      "Test Error: 0.0005000000000000004\n",
      "249\n",
      "Training Error: tensor(0.0123)\n",
      "Test Error: 0.0019000000000000017\n",
      "250\n",
      "Training Error: tensor(0.0099)\n",
      "Test Error: 0.0019000000000000017\n",
      "251\n",
      "Training Error: tensor(0.0062)\n",
      "Test Error: 0.0006000000000000005\n",
      "252\n",
      "Training Error: tensor(0.0066)\n",
      "Test Error: 0.0008000000000000007\n",
      "253\n",
      "Training Error: tensor(0.0075)\n",
      "Test Error: 0.0007000000000000006\n",
      "254\n",
      "Training Error: tensor(0.0097)\n",
      "Test Error: 0.001100000000000001\n",
      "255\n",
      "Training Error: tensor(0.0061)\n",
      "Test Error: 0.0005000000000000004\n",
      "256\n",
      "Training Error: tensor(0.0080)\n",
      "Test Error: 0.0007000000000000006\n",
      "257\n",
      "Training Error: tensor(0.0111)\n",
      "Test Error: 0.0016000000000000014\n",
      "258\n",
      "Training Error: tensor(0.0058)\n",
      "Test Error: 0.00010000000000000009\n",
      "259\n",
      "Training Error: tensor(0.0171)\n",
      "Test Error: 0.016100000000000003\n",
      "260\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training Error: tensor(0.0055)\n",
      "Test Error: 0.002400000000000002\n",
      "261\n",
      "Training Error: tensor(0.0099)\n",
      "Test Error: 0.0043000000000000035\n",
      "262\n",
      "Training Error: tensor(0.0066)\n",
      "Test Error: 0.00020000000000000017\n",
      "263\n",
      "Training Error: tensor(0.0060)\n",
      "Test Error: 0.00030000000000000024\n",
      "264\n",
      "Training Error: tensor(0.0062)\n",
      "Test Error: 0.00030000000000000024\n",
      "265\n",
      "Training Error: tensor(0.0071)\n",
      "Test Error: 0.0010000000000000009\n",
      "266\n",
      "Training Error: tensor(0.0068)\n",
      "Test Error: 0.0005000000000000004\n",
      "267\n",
      "Training Error: tensor(0.0090)\n",
      "Test Error: 0.0014000000000000013\n",
      "268\n",
      "Training Error: tensor(0.0046)\n",
      "Test Error: 0.00010000000000000009\n",
      "269\n",
      "Training Error: tensor(0.0147)\n",
      "Test Error: 0.009199999999999996\n",
      "270\n",
      "Training Error: tensor(0.0055)\n",
      "Test Error: 0.00010000000000000009\n",
      "271\n",
      "Training Error: tensor(0.0048)\n",
      "Test Error: 0.00010000000000000009\n",
      "272\n",
      "Training Error: tensor(0.0054)\n",
      "Test Error: 0.00020000000000000017\n",
      "273\n",
      "Training Error: tensor(0.0046)\n",
      "Test Error: 0.00020000000000000017\n",
      "274\n",
      "Training Error: tensor(0.0123)\n",
      "Test Error: 0.008999999999999998\n",
      "275\n",
      "Training Error: tensor(0.0068)\n",
      "Test Error: 0.001200000000000001\n",
      "276\n",
      "Training Error: tensor(0.0048)\n",
      "Test Error: 0.00030000000000000024\n",
      "277\n",
      "Training Error: tensor(0.0051)\n",
      "Test Error: 0.00040000000000000034\n",
      "278\n",
      "Training Error: tensor(0.0048)\n",
      "Test Error: 0.00020000000000000017\n",
      "279\n",
      "Training Error: tensor(0.0049)\n",
      "Test Error: 0.00040000000000000034\n",
      "280\n",
      "Training Error: tensor(0.0049)\n",
      "Test Error: 0.0020000000000000018\n",
      "281\n",
      "Training Error: tensor(0.0065)\n",
      "Test Error: 0.0014000000000000013\n",
      "282\n",
      "Training Error: tensor(0.0042)\n",
      "Test Error: 0.00010000000000000009\n",
      "283\n",
      "Training Error: tensor(0.0053)\n",
      "Test Error: 0.00020000000000000017\n",
      "284\n",
      "Training Error: tensor(0.0034)\n",
      "Test Error: 0.0\n",
      "285\n",
      "Training Error: tensor(0.0112)\n",
      "Test Error: 0.004500000000000004\n",
      "286\n",
      "Training Error: tensor(0.0081)\n",
      "Test Error: 0.0038000000000000035\n",
      "287\n",
      "Training Error: tensor(0.0112)\n",
      "Test Error: 0.004800000000000004\n",
      "288\n",
      "Training Error: tensor(0.0039)\n",
      "Test Error: 0.0\n",
      "289\n",
      "Training Error: tensor(0.0044)\n",
      "Test Error: 0.00020000000000000017\n",
      "290\n",
      "Training Error: tensor(0.0040)\n",
      "Test Error: 0.00010000000000000009\n",
      "291\n",
      "Training Error: tensor(0.0049)\n",
      "Test Error: 0.00030000000000000024\n",
      "292\n",
      "Training Error: tensor(0.0052)\n",
      "Test Error: 0.00040000000000000034\n",
      "293\n",
      "Training Error: tensor(0.0142)\n",
      "Test Error: 0.011\n",
      "294\n",
      "Training Error: tensor(0.0036)\n",
      "Test Error: 0.0\n",
      "295\n",
      "Training Error: tensor(0.0039)\n",
      "Test Error: 0.00010000000000000009\n",
      "296\n",
      "Training Error: tensor(0.0038)\n",
      "Test Error: 0.0\n",
      "297\n",
      "Training Error: tensor(0.0040)\n",
      "Test Error: 0.00010000000000000009\n",
      "298\n",
      "Training Error: tensor(0.0038)\n",
      "Test Error: 0.00020000000000000017\n",
      "299\n",
      "Training Error: tensor(0.0038)\n",
      "Test Error: 0.00010000000000000009\n",
      "300\n",
      "Training Error: tensor(0.0021)\n",
      "Test Error: 0.00010000000000000009\n",
      "301\n",
      "Training Error: tensor(0.0027)\n",
      "Test Error: 0.00010000000000000009\n",
      "302\n",
      "Training Error: tensor(0.0040)\n",
      "Test Error: 0.00010000000000000009\n",
      "303\n",
      "Training Error: tensor(0.0030)\n",
      "Test Error: 0.0\n",
      "304\n",
      "Training Error: tensor(0.0024)\n",
      "Test Error: 0.0\n",
      "305\n",
      "Training Error: tensor(0.0040)\n",
      "Test Error: 0.00020000000000000017\n",
      "306\n",
      "Training Error: tensor(0.0028)\n",
      "Test Error: 0.00010000000000000009\n",
      "307\n",
      "Training Error: tensor(0.0041)\n",
      "Test Error: 0.0\n",
      "308\n",
      "Training Error: tensor(0.0029)\n",
      "Test Error: 0.0\n",
      "309\n",
      "Training Error: tensor(0.0109)\n",
      "Test Error: 0.0043000000000000035\n",
      "310\n",
      "Training Error: tensor(0.0029)\n",
      "Test Error: 0.0\n",
      "311\n",
      "Training Error: tensor(0.0095)\n",
      "Test Error: 0.004600000000000004\n",
      "312\n",
      "Training Error: tensor(0.0030)\n",
      "Test Error: 0.0\n",
      "313\n",
      "Training Error: tensor(0.0033)\n",
      "Test Error: 0.00010000000000000009\n",
      "314\n",
      "Training Error: tensor(0.0030)\n",
      "Test Error: 0.0\n",
      "315\n",
      "Training Error: tensor(0.0029)\n",
      "Test Error: 0.00020000000000000017\n",
      "316\n",
      "Training Error: tensor(0.0030)\n",
      "Test Error: 0.0\n",
      "317\n",
      "Training Error: tensor(0.0030)\n",
      "Test Error: 0.0\n",
      "318\n",
      "Training Error: tensor(0.0033)\n",
      "Test Error: 0.00010000000000000009\n",
      "319\n",
      "Training Error: tensor(0.0033)\n",
      "Test Error: 0.0\n",
      "320\n",
      "Training Error: tensor(0.0030)\n",
      "Test Error: 0.00040000000000000034\n",
      "321\n",
      "Training Error: tensor(0.0056)\n",
      "Test Error: 0.001100000000000001\n",
      "322\n",
      "Training Error: tensor(0.0026)\n",
      "Test Error: 0.0\n",
      "323\n",
      "Training Error: tensor(0.0019)\n",
      "Test Error: 0.0\n",
      "324\n",
      "Training Error: tensor(0.0099)\n",
      "Test Error: 0.0029000000000000024\n",
      "325\n",
      "Training Error: tensor(0.0020)\n",
      "Test Error: 0.0\n",
      "326\n",
      "Training Error: tensor(0.0066)\n",
      "Test Error: 0.002100000000000002\n",
      "327\n",
      "Training Error: tensor(0.0039)\n",
      "Test Error: 0.00010000000000000009\n",
      "328\n",
      "Training Error: tensor(0.0023)\n",
      "Test Error: 0.0\n",
      "329\n",
      "Training Error: tensor(0.0072)\n",
      "Test Error: 0.0026000000000000025\n",
      "330\n",
      "Training Error: tensor(0.0025)\n",
      "Test Error: 0.0\n",
      "331\n",
      "Training Error: tensor(0.0025)\n",
      "Test Error: 0.0\n",
      "332\n",
      "Training Error: tensor(0.0022)\n",
      "Test Error: 0.0\n",
      "333\n",
      "Training Error: tensor(0.0025)\n",
      "Test Error: 0.0\n",
      "334\n",
      "Training Error: tensor(0.0024)\n",
      "Test Error: 0.0\n",
      "335\n",
      "Training Error: tensor(0.0025)\n",
      "Test Error: 0.0\n",
      "336\n",
      "Training Error: tensor(0.0024)\n",
      "Test Error: 0.0\n",
      "337\n",
      "Training Error: tensor(0.0037)\n",
      "Test Error: 0.0\n",
      "338\n",
      "Training Error: tensor(0.0027)\n",
      "Test Error: 0.0\n",
      "339\n",
      "Training Error: tensor(0.0116)\n",
      "Test Error: 0.005800000000000005\n",
      "340\n",
      "Training Error: tensor(0.0012)\n",
      "Test Error: 0.0\n",
      "341\n",
      "Training Error: tensor(0.0087)\n",
      "Test Error: 0.0014000000000000013\n",
      "342\n",
      "Training Error: tensor(0.0043)\n",
      "Test Error: 0.0009000000000000008\n",
      "343\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "344\n",
      "Training Error: tensor(0.0056)\n",
      "Test Error: 0.0013000000000000012\n",
      "345\n",
      "Training Error: tensor(0.0016)\n",
      "Test Error: 0.0\n",
      "346\n",
      "Training Error: tensor(0.0024)\n",
      "Test Error: 0.0\n",
      "347\n",
      "Training Error: tensor(0.0101)\n",
      "Test Error: 0.005300000000000004\n",
      "348\n",
      "Training Error: tensor(0.0019)\n",
      "Test Error: 0.0\n",
      "349\n",
      "Training Error: tensor(0.0019)\n",
      "Test Error: 0.0\n",
      "350\n",
      "Training Error: tensor(0.0118)\n",
      "Test Error: 0.006000000000000005\n",
      "351\n",
      "Training Error: tensor(0.0020)\n",
      "Test Error: 0.0\n",
      "352\n",
      "Training Error: tensor(0.0018)\n",
      "Test Error: 0.0\n",
      "353\n",
      "Training Error: tensor(0.0019)\n",
      "Test Error: 0.0\n",
      "354\n",
      "Training Error: tensor(0.0020)\n",
      "Test Error: 0.0\n",
      "355\n",
      "Training Error: tensor(0.0021)\n",
      "Test Error: 0.0\n",
      "356\n",
      "Training Error: tensor(0.0027)\n",
      "Test Error: 0.00020000000000000017\n",
      "357\n",
      "Training Error: tensor(0.0022)\n",
      "Test Error: 0.0\n",
      "358\n",
      "Training Error: tensor(0.0022)\n",
      "Test Error: 0.0\n",
      "359\n",
      "Training Error: tensor(0.0021)\n",
      "Test Error: 0.0\n",
      "360\n",
      "Training Error: tensor(0.0025)\n",
      "Test Error: 0.00030000000000000024\n",
      "361\n",
      "Training Error: tensor(0.0018)\n",
      "Test Error: 0.00010000000000000009\n",
      "362\n",
      "Training Error: tensor(0.0056)\n",
      "Test Error: 0.00020000000000000017\n",
      "363\n",
      "Training Error: tensor(0.0018)\n",
      "Test Error: 0.0\n",
      "364\n",
      "Training Error: tensor(0.0089)\n",
      "Test Error: 0.0016000000000000014\n",
      "365\n",
      "Training Error: tensor(0.0171)\n",
      "Test Error: 0.011\n",
      "366\n",
      "Training Error: tensor(0.0013)\n",
      "Test Error: 0.0\n",
      "367\n",
      "Training Error: tensor(0.0125)\n",
      "Test Error: 0.0036000000000000034\n",
      "368\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "369\n",
      "Training Error: tensor(0.0016)\n",
      "Test Error: 0.0\n",
      "370\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "371\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "372\n",
      "Training Error: tensor(0.0016)\n",
      "Test Error: 0.0\n",
      "373\n",
      "Training Error: tensor(0.0016)\n",
      "Test Error: 0.0\n",
      "374\n",
      "Training Error: tensor(0.0075)\n",
      "Test Error: 0.001200000000000001\n",
      "375\n",
      "Training Error: tensor(0.0016)\n",
      "Test Error: 0.0\n",
      "376\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "377\n",
      "Training Error: tensor(0.0017)\n",
      "Test Error: 0.0\n",
      "378\n",
      "Training Error: tensor(0.0018)\n",
      "Test Error: 0.0\n",
      "379\n",
      "Training Error: tensor(0.0017)\n",
      "Test Error: 0.0\n",
      "380\n",
      "Training Error: tensor(0.0010)\n",
      "Test Error: 0.0\n",
      "381\n",
      "Training Error: tensor(0.0009)\n",
      "Test Error: 0.0\n",
      "382\n",
      "Training Error: tensor(0.0037)\n",
      "Test Error: 0.0\n",
      "383\n",
      "Training Error: tensor(0.0073)\n",
      "Test Error: 0.0008000000000000007\n",
      "384\n",
      "Training Error: tensor(0.0010)\n",
      "Test Error: 0.0\n",
      "385\n",
      "Training Error: tensor(0.0010)\n",
      "Test Error: 0.0\n",
      "386\n",
      "Training Error: tensor(0.0011)\n",
      "Test Error: 0.00010000000000000009\n",
      "387\n",
      "Training Error: tensor(0.0012)\n",
      "Test Error: 0.0\n",
      "388\n",
      "Training Error: tensor(0.0012)\n",
      "Test Error: 0.0\n",
      "389\n",
      "Training Error: tensor(0.0011)\n",
      "Test Error: 0.0\n",
      "390\n",
      "Training Error: tensor(0.0044)\n",
      "Test Error: 0.0016000000000000014\n",
      "391\n",
      "Training Error: tensor(0.0013)\n",
      "Test Error: 0.0\n",
      "392\n",
      "Training Error: tensor(0.0013)\n",
      "Test Error: 0.0\n",
      "393\n",
      "Training Error: tensor(0.0013)\n",
      "Test Error: 0.0\n",
      "394\n",
      "Training Error: tensor(0.0106)\n",
      "Test Error: 0.006900000000000006\n",
      "395\n",
      "Training Error: tensor(0.0013)\n",
      "Test Error: 0.0\n",
      "396\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "397\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training Error: tensor(0.0014)\n",
      "Test Error: 0.0\n",
      "398\n",
      "Training Error: tensor(0.0015)\n",
      "Test Error: 0.0\n",
      "399\n",
      "Training Error: tensor(0.0017)\n",
      "Test Error: 0.0\n"
     ]
    }
   ],
   "source": [
    "random.seed(205348320) \n",
    "num_epochs = 100\n",
    "DATA_NUM = 20\n",
    "TEST_DATA_NUM = 1000\n",
    "flip = 0\n",
    "\n",
    "CLUSTER_NUM = 1\n",
    "PATCH_NUM = 2\n",
    "# # PATCH_LEN = 500\n",
    "# PATCH_LEN = 100\n",
    "Noiselevel = 1.0\n",
    "ran = 20\n",
    "repeat = 10\n",
    "strength = []\n",
    "test_acc = []\n",
    "train_acc = []\n",
    "\n",
    "# torch.autograd.set_detect_anomaly(True)\n",
    "\n",
    "Data_train = np.random.rand(ran, ran)\n",
    "Data_test = np.random.rand(ran, ran)\n",
    "for s in range(ran):\n",
    "  bmu = s*0.5\n",
    "  strength.append(bmu)\n",
    "  for t in range(ran):\n",
    "    print(ran*s + t)\n",
    "    test1 = 0\n",
    "    train1 = 0\n",
    "#     PATCH_LEN = 10000 + 1000*t\n",
    "    PATCH_LEN = 1000 + 1000*t\n",
    "    for j in range(repeat):\n",
    "      data = []\n",
    "      labels = []\n",
    "      for i in range(DATA_NUM + TEST_DATA_NUM):\n",
    "        features = torch.zeros(CLUSTER_NUM, PATCH_LEN)\n",
    "        pos = 0\n",
    "        for p in range(CLUSTER_NUM):\n",
    "            features[p,pos] = 1\n",
    "            pos+=1\n",
    "        y = np.random.choice([-1,1], 1)[0] \n",
    "        k = torch.randint(0, CLUSTER_NUM, (1,))\n",
    "        xi = torch.tensor(np.random.normal(0, Noiselevel, size=(PATCH_LEN))) \n",
    "        # orthogonal\n",
    "        # xi[:CLUSTER_NUM] = 0    \n",
    "        x = torch.stack([features[k][0]*bmu*y, xi])    \n",
    "        # random permutation\n",
    "        idx = torch.randperm(len(x))\n",
    "        x = x[idx].flatten()\n",
    "        y = np.random.choice([-1,1], 1, p = [flip, 1-flip])[0] *y\n",
    "        data.append(x)\n",
    "        labels.append(y)\n",
    "      data = torch.stack(data)\n",
    "      labels = torch.tensor(labels)\n",
    "      labels[labels==-1] = 0\n",
    "\n",
    "      training_data = data[:DATA_NUM].unsqueeze(1).float()\n",
    "      test_data = data[DATA_NUM:].unsqueeze(1).float()\n",
    "      training_labels = labels[:DATA_NUM]\n",
    "      test_labels = labels[DATA_NUM:]\n",
    "      my_mixture = CNN(2*PATCH_LEN, 10, PATCH_NUM) #input_dim, out_channel (m), cluter_num, patch_num\n",
    "      criterion = torch.nn.CrossEntropyLoss() \n",
    "    \n",
    "      train(my_mixture, criterion, training_data, training_labels, num_epochs, SAMM = True, rho = 0.3)\n",
    "      train1 += test(my_mixture, criterion, training_data, training_labels, num_epochs)\n",
    "      test1 += test_ACC(my_mixture, criterion, test_data, test_labels, num_epochs)\n",
    "    # test_acc.append(test1/10)\n",
    "    # train_acc.append(train1/10)\n",
    "    # print(train1/10)\n",
    "    # print(test1/10)\n",
    "    print(\"Training Error:\", train1/repeat)\n",
    "    print(\"Test Error:\", test1/repeat)\n",
    "    Data_train[t][s] = train1/repeat\n",
    "    Data_test[t][s] = test1/repeat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [],
   "source": [
    "import datetime\n",
    "\n",
    "# Get the current timestamp\n",
    "timestamp = datetime.datetime.now().strftime('%Y-%m-%d_%H-%M-%S')\n",
    "\n",
    "# Create a filename with the timestamp\n",
    "filename = f'train_{timestamp}.txt'\n",
    "\n",
    "# Write the list to the file\n",
    "torch.save( Data_train, filename)\n",
    "\n",
    "# Create a filename with the timestamp\n",
    "filename = f'test_{timestamp}.txt'\n",
    "\n",
    "# Write the list to the file\n",
    "torch.save(Data_test, filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "2QBKobN73kpA",
    "outputId": "2a6d74a8-717b-4a96-a3ae-25bc81d7e70e"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEOCAYAAACNY7BQAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAAhzUlEQVR4nO3de5xcZZ3n8c+3O91JuEMQhAQW1HhBZ7wh4owKeCPgzKCIL0EUYcAMCqOyOw4460tYFcfLLjsqKGaQDaCQRUUMEmQcFPBCBFTuCESC0AaI3JGQS3f/9o/n9OZUpbq6zkl11enq7zuveqXrnOc55+lT1fWr53oUEZiZmY3p63YBzMysWhwYzMyshgODmZnVcGAwM7MaDgxmZlbDgcHMzGo4MJiZTVGSzpW0WtJt4+yXpK9IWiHpFkmvauW4DgxmZlPXYmBBk/0HAfOzx0Lg660c1IHBzGyKiohrgceaJDkEOD+S5cB2knaZ6LgODGZmvWsu8EDu+VC2rakZk1acKeStP/pF4XVB5m4xXPg8u225oXAegJ1mjxbO87qdyp1r5xLn2nZwVuE8s/q3L5wHoF+DhfP0aaDEmcp9ZxIqnGc0yr1W5X6vzgmKL7dT5vp13gs3u5Czdz+ipYuz9oEl/0BqAhqzKCIWFThVo7JOeG4HBjOzDpNa++KRBYEigaDeELBb7vk8YNVEmdyUZGbWYaKvpUcbLAWOykYn7Qs8GREPTpTJNQYzsw7r62vPR6+ki4D9gR0lDQGnAgMAEXE2sAw4GFgBrAGOaeW4DgxmZh0mtacvJSKOmGB/ACcUPa4Dg5lZx1W7Fd+Bwcysw1rtfO4WBwYzsw7rU7U/eqtdOjOzHuQag5mZ1XBgMDOzGg4MU8CGkeJ5hovP9mfrgRKZgJl9xfN19m3XuWUgZmiLwnnSiL1i2jSasCVVX9qirKmxvEV3VP3aODCYmXVYuya4TZZql87MrAe5KcnMzOo4MJiZWY5rDGZmVsMT3MzMrIZrDGZmVqNdq6tOFgcGM7MOc43BzMxqtOnubJPGgQHoL/EajZaYxLx+pFz1cXi0eL4No6VORYlJwqwZXlM4z8zBbYufCAiGC+dRibd51Wem2tTmCW5mZlbDNQYzM6vlPgYzM8tz57OZmdXwcFUzM6vhmc9mZlbLNQYzM6tR7S4GBwYzs45zjcHMzGr0OzCYmVlOuMbQm0aj+Au7em1/qXPN3XKkcJ7hEktbQLka7uz+mYXzBMV/JwBR7hqaVUq144IDg5lZx/VVOzI4MJiZdZqbkszMrIY7n83MrIZrDGZmVqPacaHq8+/MzHpQn1p7tEDSAkl3SVoh6ZQG+7eVdJmkmyXdLumYiY7pGoOZWYdFm0YlSeoHzgLeCgwBN0haGhF35JKdANwREX8r6TnAXZK+HRHrxzuuawxmZp3WvhrDPsCKiLg3+6BfAhxSlyaArZXW+t4KeAya3yPXgcHMrNPU4mNic4EHcs+Hsm15ZwIvAVYBtwIfjYimd4V3UxIw0vQSNTbYV3xq8U6zys32LWNGyZrqs8PFM24zUPxaTPC+HNdoNP2i01CZm6KMlCyfSvQq9mmg1LlsCmvxPSlpIbAwt2lRRCzKJ2mQrf4P8kDgJuBNwPOBH0v6WUQ8Nd55HRjMzDqtxT6GLAgsapJkCNgt93weqWaQdwzw+YgIYIWklcCLgevHLV5LpTMzs/ZpXx/DDcB8SXtKGgQOB5bWpbkfeDOApJ2BFwH3NjuoawxmZp3WpgluETEs6UTgSqAfODcibpd0fLb/bOAzwGJJt5Kank6OiEeaHdeBwcys09rYVhMRy4BlddvOzv28CnhbkWM6MJiZdZqXxDAzsxrVjgsODGZmnRb91R7348BgZtZprjGYmVkN38HNzMxquPO5+so09w0XXwWCR9aVa1fcdmbx5Rme3FDujbf7VsXPlRZ4LKZP5d56QfHyRYnXaqBvVvFMHRYUX2JFFH+telVssnJEa9ryke47uJmZWQ03JZmZWV5UOy44MJiZdZxrDGZmVsOdz2ZmVqPsDVM6xIHBzKzTXGMwM7Ma7mMwM7O8cI3BzMxquI+h+kZK3Pd9m4HimXbbsvhMVYA5JWY+bxgt98bbUOJarBt5tnCemX3bFT8RoBJ3OFGJb2flZ8V27g++zCxmz5beqJOv1aYnd2AwM7M89zGYmVmNascFBwYzs06LXqoxSBoEPgEcAewOzKxLEhHhYGNm1kyP3cHtS8AJwBXAJcC6tpfIzKzXVTsuFA4MhwGnRsTpk1EYM7NpocdGJW0FXDcZBTEzmzYq3sdQtEJzGfDGySiImdm00afWHl1StMbwVeB8SaPAMuCx+gQRcW87CmZm1quix27tOdaMdBpw6jhpenOapJlZu/RYH8PfQ8m1AiqszGv05+HiwwpGSl65dSPFC7i+5MnK1F5nqPi1WD/6VPETAVvOeG6JXMV/qdHYUOI80K/BUvk6pVeXt5hyKt7HUCgwRMTiSSqHmdn00UuBYYzSqmR7ATsAjwJ3RkTP1STMzCZD1fsYCrcBSDoOeBC4BbgauBVYJenY9hbNzKxHSa09uqTokhhHAouAq4BvAQ8BzwWOBBZJWhMRF7W9lGZmvaTHmpL+Gfh2RLy/bvt5ki4ATgYcGMzMmql2XCjclPQiUk2hkW9l+83MrIm+vtYerZC0QNJdklZIOmWcNPtLuknS7ZKumeiYRWsMTwPzxtk3L9tvZmZNtPqhPxFJ/cBZwFuBIeAGSUsj4o5cmu2ArwELIuJ+STtNWL6C5bgC+JykN9QV7nXAZ7P9ZmbWhKSWHi3YB1gREfdGxHpgCXBIXZr3ApdExP0AEbF6ooMWDQz/DDwJXC3pfkm/kvQH4OfAU9l+MzNroo2DkuYCD+SeD2Xb8l4IbC/pakm/lnTURActOsHtIUmvIM2AfgNpHsN9wDXA4ohYU+R4VVFmgMBoiVkbzwyX63F6Tok8O80eLXWuNSXKuNVA8XrxYN/WhfMADMezhfOoxHSdgb4tCufpVVFysQNVvYe1i1odiSppIbAwt2lRRCzKJ2mQrf4FmwG8GngzMBu4TtLyiLh7vPMW/ovJPvzPzB5mZlZQX4srk2RBYFGTJEPAbrnn84BVDdI8EhHPAM9IuhZ4OTBuYKj4fYTMzHpPG1fdvgGYL2nP7NbLhwNL69L8AHiDpBmStgBeC9zZ7KAT1hgk3Qu8MyJulrSS5ovoRUQ8f6JjmplNZ+2a1BwRw5JOBK4krWx9bkTcLun4bP/ZEXGnpB+RVqsYBc6JiNuaHbeVpqRrSB3LYz97TSQzs83QztUuImIZ6f44+W1n1z3/EvClVo85YWCIiGNyPx/d6oHNzKyxFoeidk2p1VXrSZoTEY+241hmZr2u1c7nbinU+Szpg5I+nnv+F5KGgNWSbpRU5i4qZmbTSsUXVy08KukfgfxA8jOAJ4CPAdsCn25LqczMeljVA0PRpqTdgd8BSNoW2A94R0Qsk/Qo8K9tLp+ZWc+p+KrbhQNDP2m4E8DrSSOUrs6ePwBMuDiTmdl0V/G+58KB4R7g7cBPSBMpfplbBmNX4LE2lq1jRkqsHjGrv/io3bLfEtaNFM84PFruZCoxGnndyHDhPIN9GwrnARjUVqXyFeVlIDbq5O80Xa57X4/d2vN/Ah+T9Ahpxb6v5vYdQJpAMS5J50paLem23LZ3Z2uEj0rauy79J7I1xu+SdGBu+6sl3Zrt+0p2D2okzZT0f7Ptv5K0R8Hfz8xs0lW9j6FQYIiIC0n9Cv8KHBARl+R2P0xtoGhkMbCgbtttwKHAtfmNkvYi1UpemuX5Wrb2OMDXSQtLzc8eY8c8Fng8Il4A/G/gC63+bmZmnVL1wFBmEb2fk5bZrt9+agt5r63/Fh8Rd0LDCR+HAEsiYh2wUtIKYB9J9wHbRMR1Wb7zgXeQ7gVxCHBalv+7wJmSFBGerW1mldFrfQwAZPMVdgdm1e+LiGs3zVHKXGB57vnYOuMbsp/rt4/leSArx7CkJ4E5wCP1B88vZzv/xI+z64L6e1uYmU2O/oovX1ooMEiaS7q38xsb7SaNUmrXnL7x1hlvtv54K2uTp4255Wz3v/wXrlGYWceolwIDqW3/ZaQ7td0KrGt7iTYab53xIWrvO51ff3wsz5CkGaRJd1NypJSZ9a5ea0p6A/CRiLhgMgpTZylwoaQzSENh5wPXR8SIpKcl7Qv8CjiKjZ3eS4EPANcBhwE/cf+CmVVNry2i9yww4Y2kxyPpImB/YMdsjaVTSd/ov0q6g+Xlkm6KiAOzNcUvBu4AhoETImIkO9SHSCOcZpM6na/Itn8TuCDrqH6MNKrJzKxSKh4XCgeGfwfeT7opRGERccQ4u74/TvrTgdMbbL+R1KRVv30t8O4yZTMz65S+Hutj+CPwfkk/Id0YYpP2+4g4tx0F66Qy0XttqdnIxc/TaYMlZnTP7C8+uG2gb4vCeQD6VPxc60efmjhRHUW5r3T92mSg3qQJRiZOVEclxoZ0cjbyVJvBXFavrZU0dlegPUhNQvUCmHKBwcysk3otMOw5KaUwM5tG+lTtMTGFAkNE/GGyCmJmNl3M6LEaAwCS/pI0yW0O8I2IeEjSC4CHI+LpdhbQzKzX9FSNQdJM0sznQ9k40/ky4CHgi8DdwCltLqOZWU+peh9D0UFTpwNvIQ1Z3ZnaJSiuAA5slMnMzDbqa/HRLUWbko4APhkRF+aWwB6zkjRayczMmqh6jaFoYJgD3DnOvj5g5uYVx8ys9/X3VbuPoWhtZSXwunH27QPctXnFMTPrfVVvSip67vOBUyQdCQxm20LSAcBJeHKbmdmE+hQtPbqlaFPSF4GXAxcA52Tbfk66Yc+SiJjo1p6VNGtG8RdgqxJ5ZpdYbgJgZol8s0qea0OJZTvWjgwXzqOSazFuMWOnwnkG+rYsnKdPA4XzdFqZ5S3KnafiDeJTUE/1MWSrmx4u6SzSCKSdgEeBH0XENZNQPjOzntOTE9wi4mfAz9pcFjOzaaGnJriNUbrLxC40vufzvZtbKDOzXtZTTUmS5gBnAe9skrczDZ9mZlNUxW/HULjG8E3gAOBM4HfA+raXyMysx/VaU9IBwEcjYvEklMXMbFqY0cYqg6QFwJdJrTXnRMTnx0n3GmA58J6I+G6zYxYt3mPAwwXzmJlZTrsmuGVLE50FHATsBRwhaa9x0n2BFm/LXDQwfBU4Put8NjOzEto4wW0fYEVE3BsR64ElwCEN0v0j8D1obQJR0XkMZ0jaFbhD0n8Cj2+aJE4tckwzs+mmjaOS5gIP5J4PAa/NJ5A0lzRg6E3Aa1o5aNFRSQcDJ5AWy3tRgyQBTLnAsH6k+Ks0XO2+o1KzuQG2KDGAeXb/4MSJ6khlG1mLv1YRxa/FposH94agxLXo4MznMuWDqTc7u9V3v6SFwMLcpkURsSifpEG2+ov4b8DJETHSamNP0Y+BM4AbSMHhdxGxoWB+M7Npr9XVVbMgsKhJkiFgt9zzecCqujR7A0uyoLAjcLCk4Yi4dLyDFg0MuwMfiYhbC+YzM7NMG5uSbgDmS9oT+CNwOPDefIKI2HPsZ0mLgR82CwpQPDD8Fti1YB4zM8tp12jViBiWdCJptFE/cG5E3C7p+Gz/2WWOWzQwfAQ4T9I9EfGLMic0M5vu2jnBLSKWAcvqtjUMCBFxdCvHLBoYLgW2Aa6V9AzwxKbnjf9S8JhmZtNKOye4TYaigeEqNu3xNjOzAqo+5q3oPIajJ6kcZmbTRq+tlWRmZptpyi+7Leko4PKIeDT7uamIOL8tJTMz61FTPjAAi4F9SbfwXDxB2gAcGMzMmhjogc7nPYEHcz/3nJHR4nnWjxYP+Rui3NeE+58p3lX1yjnlJqWPlGj6lIq3SPZroPiJgA2jTxfOM6t/TuE8I1HuViP9Kr48yIbRNaXONdC3ReE8VV86ourla5cp38cQEX/IPX2YNL16F1Lt4EHg1xGxdnKKZ2bWe3qhKQlJM4EvAh8kLaA39msFsFbS14F/yZZ9NTOzJqb8cNXs3gs/JC3Z+gPSDLv7ScFhN+BvgJNIN4k4eNJKambWI2a0uIhet7RSYziMdEvPwyLi+w32nyPpUOBiSYdGxCVtLaGZWY/pr3hTUit940cAF48TFADIgsF3gCPbVTAzs17Vp9YeXStfC2leCVzeQrofAq/avOKYmfW+qgeGVpqSnkPqU5jI/cBOm1ccM7Pe1wujkrYA1rWQbj0wa/OKY2bW+wam+jyGzFxJz5sgzbzNLYyZ2XTQCzUGgO+2kEZM0SW5+0tMTy8zo339SLl3w0u3Lz6LebTkLOunS0yY3nqg+PSVvpL3sBro37JwnqD41PbRGC6cByBipHCeMjOYy4oSf6JTYTZyUPy6q4uzCXohMBwz6aUwM5tG+qd6U1JEnNeJgpiZTRe9UGMwM7M26rVbe5qZ2Waq+sxnBwYzsw6b8stum5lZe1W8JcmBwcys03rhDm5mZtZGbkoyM7MaHq5qZmY1HBimgNFq1+r484bi76KRkr/TzBJ3llo7Unz5iNn9JdbeACKKL28xHGsK5xns37ZwHii3JEYnTYXlLcro5vIWZVS8i8GBwcys01xjMDOzGnJgMDOzPDclmZlZDXm4qpmZ5VW9j6HqNRozs56jFh8tHUtaIOkuSSskndJg/5GSbskev5T08omO6RqDmVmHtavGIKkfOAt4KzAE3CBpaUTckUu2EtgvIh6XdBCwCHht0/K1p3hmZtaqNtYY9gFWRMS9EbEeWAIckk8QEb+MiMezp8uBeRMd1IHBzKzDpNYeLZgLPJB7PpRtG8+xwBUTHdRNSUCUGCAwo8QM4eJzdpPZJV6lR9eVi/nbDZa5WXyZERblRmWMRvFZ1jP6ZhfOU3YGc6rZFzxXyWvRq7OYp4NW/zolLQQW5jYtiohF+SQNsjV8Q0k6gBQYXj/ReR0YzMw6rNU+hiwILGqSZAjYLfd8HrCqPpGkvwTOAQ6KiEcnLF9rxTMzs3ZpYx/DDcB8SXtKGgQOB5bWnEvaHbgEeH9E3N3KQV1jMDPrsHZNcIuIYUknAlcC/cC5EXG7pOOz/WcDnwLmAF9T6rgYjoi9mx3XgcHMrMPa2TsUEcuAZXXbzs79fBxwXJFjOjCYmXVYf8XHDTgwmJl1mFdXNTOzGhWPCw4MZmad5hqDmZnVcB+DmZnVqHhccGCActW64dHOvbTrS6zOsO1guQU4Bkos9VFmRPZg3zYlckGfBgrnGYm1hfPM6JtVOA94mQprjW/UY2ZmNar+9cGBwcysw9z5bGZmNYqvwdtZDgxmZh3mGoOZmdWpdmRwYDAz67Cqj15zYDAz67Ayd/rrJAcGM7MOc43BzMzqODBU3mB/Z2Yh7jiz3GzkkRLFGy35Kz07UvwNu81g8ZMNx7OF8wDM7BssnimKV9sjyl3AYLhwHpUeolL8zrxV/6Y6XUjVvquyA4OZWcdVO0A7MJiZdVhfidpeJzkwmJl1nAODmZnllO9X6gwHBjOzjnNgMDOznKqPDnNgMDPrMFV8fVUHBjOzDnMfg5mZ1XFgMDOzHHm4avWtL7EMRF+JgL96bbk3w3aDxZfSeGJ9uXPtMHOkcJ5nhotfjO1KrGwBMDxafCmNmf3bFs4TlFu+pFynYrlvj1XvwLTxVX1JjMqUTtK5klZLui23bQdJP5Z0T/b/9rl9n5C0QtJdkg7MbX+1pFuzfV9R1RvzzGwaUouP7qhMYAAWAwvqtp0CXBUR84GrsudI2gs4HHhpludr2rjA+deBhcD87FF/TDOzrhJ9LT26pTKBISKuBR6r23wIcF7283nAO3Lbl0TEuohYCawA9pG0C7BNRFwXaXnM83N5zMwqoto1hqr3MewcEQ8CRMSDknbKts8FlufSDWXbNmQ/1283M6uMqvcPVabGUFCjqxpNtm96AGmhpBsl3bjqih+0tXBmZs1I/S09uqXqgeHhrHmI7P/V2fYhYLdcunnAqmz7vAbbNxERiyJi74jYe9eDDml7wc3MxqMW/7V0LGlBNghnhaRTGuxXNhBnhaRbJL1qomNWPTAsBT6Q/fwB4Ae57YdLmilpT1In8/VZs9PTkvbNRiMdlctjZlYR7eljyAbdnAUcBOwFHJENzsk7iI2DcRaSBug0VZk+BkkXAfsDO0oaAk4FPg9cLOlY4H7g3QARcbuki4E7gGHghIgYG4D/IdIIp9nAFdnDzKwy2jiKfh9gRUTcmx13CWlwzh25NIcA52cDcpZL2k7SLmP9t41UJjBExBHj7HrzOOlPB05vsP1G4GVtLJqZWVu1cRG9ucADuedDwGtbSDMXqH5g6KafHvzX44ZvSQsjYlEny2PV5/eFbZ4XtlRlkLSQ1PwzZlHd+66VATctD8oZU/U+hipYOHESm4b8vrBJlx8kkz3qv4yMNxCnaJoaDgxmZlPXDcB8SXtKGiStCLG0Ls1S4KhsdNK+wJPN+hfATUlmZlNWRAxLOhG4EugHzs0G5xyf7T8bWAYcTFohYg1wzETHVeqotvG4Ldka8fvCepkDg5mZ1XAfg5mZ1XBgMDOzGg4MZmZWw6OS6kjamTQrMIBVEfFwl4tkFeH3hk0X7nzOSHoFcDawLfDHbPM84AngwxHxm+6UzLrN7w2bbhwYMpJuAv4hIn5Vt31f4BsR8fKuFMy6zu8Nm27cx7DRlvV/+AARsRzYsgvlserwe8OmFfcxbHSFpMtJ94keW4lwN9I9HX7UtVJZFfi9YdOKm5JyJB1EWrt8LmlFwiFgaUQs62rBrOv83rDpxIHBzMxquI+hBdma6Gab8HvDepEDQ2vadh8+6zl+b1jPcVNSjqQXs7EdOUg3s1gaEXd2tWBWKZJeT7rX7m0R8R/dLo9Zu7nGkJF0MrCE9A3wetINMARcJOmUbpbNukvS9bmfPwicCWwNnOr3hvUi1xgyku4GXhoRG+q2DwK3R8T87pTMuk3SbyPildnPNwAHR8SfJG0JLI+Iv+huCc3ayzWGjUaBXRts3yXbZ9NXn6TtJc0hfZn6E0BEPAMMd7doZu3nCW4bfQy4StI9bJzEtDvwAuDEbhXKKmFb4NekpsWQ9NyIeEjSVrjz2XqQm5JyJPWROhXzk5huiIiRrhbMKknSFsDOEbGy22UxaycHBjMzq+E+BjMzq+HAYGZmNRwYeoCkd0i6VtJqSc9K+oOkSyUtyKXZX9JpWT9KpY1XVkl7SApJx03y+Z8raamkx7LzfWycdK/IyrlDg30h6bOTXM6Zkk6SdLOkpyU9Jel3ks6TND+XbrGk+yazLK2SdLWkq7tdDmuu8h8S1pykjwDfB+4BjgXeDox9IL0pl3R/4FSmxmu+P90t66eA/UjX83WkiY+NvIJUzk0CQ4dcBHwG+B7wLuA9wCLghcBeuXSfAd7Z8dLZlOXhqlPfPwGXRsSxuW0/Af69bO1A0gAwHNN3ZMJLgJsj4vvdLsh4JD2P9GH/sYj4cm7XFcAZ+dc+In7f6fLZ1DYVvj1aczsADzXaERGjAJJOI32zBdiQNXNEtm+seebDkr4oaRWwDtgu23+opOWS1kh6QtJ3JO2eP4+k+yR9S9Lhku6U9IykG7M1hahL+9Es/VpJ10v6q+z54onKmtMv6dOSHszKdJmkeRNdKCUnSbpL0vos/5mStslfC1KN5Q1j55a0R4NjHQ38n+zpPeOllfQRSSuzpp5rJL20wbEmvMYNjNVSmr722fE3aUqS9DxJy7Jzrpb0vyQtrP8dWn1tJb1G0nclDSk1Z94l6XOSZk/we1gVRYQfU/hBqh2sAT4OvHCcNPOAc0gLA/41sC+wb7Zvj2z7H4FLgb8hLSQ4Gzg+23cucDCpqeJOYCWwde749wF/IK0vdVh2jN8CTwDb5dIdlx3vHOBA4MNZ3ieAxQXKeh9wIXAQ8AHgEeCaFq7V57L8Z2bnPwn4M/Az0pekmdn5bgZ+M3ZuYGaDYz2H1EQT2e9ckzZXziuBv8vSrARWADNyx2npGjc4/1bAk1m695HmU4yXdjFwX+75IPD77DU/OjvvJdlrGMAeJV7bdwGfzPbvl722DwFL6spyNXB1t/9u/Jjgb6XbBfBjM1/A1J58S/YHHdmH5EXA2+rSnZbtn1G3fezD9jdk81qy7WMfPOc2SL+e1IQxtu0+4HFg+9y2vbPjvjd73keaUb6s7niHZukWFyjrNXXb/ynbvmuT67QDsDZ/nmz7+7K8f5fb9vNWPryyD9UAXtBgX5D6fQZy2w7Ltv9V0Ws8zvn/FvhT7rX/PSnovbgu3WJqA8PCLP0+uW0iBcRGgaHpa9ugXCI1U7+PtJzMnNy+q1u5tn509+GmpCkuIu4GXkn6lnY6cBOp7flKSZ8scKhLI/vLzbwO2Ab4tqQZYw/SbPDfAW+sy39dRDyee35r9v9Yk8i87PGdunw/oPh6Q5fXPa8/VyP7kmoE36rbviQ7/34Fy9CKH0ftooz15Sx6jWtExGWkIHIo8FXSt/gPA7+V9JYmWfcF7o+I/79qbPbaf2+c9BO9tkjaRtIXJP2e1BS5AbiAFCS8AOUU487nHhBpyY5rsweSdiXdpP5USWfV/VGP58G65ztl///nOOnrj/lYXZnWSQKYlW3aJft/dX3ZJT3SQvnGPRfpgyh/rkbG2uRrfs+IGJb0KJMzsmiicha9xpuItJDf97MHkvbNjvd50jf7Rnah7nXIPDxO+oleW0j9LW8hjei6CXiGtLzMWTR/XayCHBh6UESsknQO8GXSt7XrJ8gCqWkg79Hs/6OB2xukf7pgscY+kHfKb5TUD+xY8FhljH24PZfc75N9Q5/Dxt+3k9p9jYmI5ZL+A1jQJNmD1A5nHbNz0fMBSJpF6pc6LXIjpCR5OfIpyoFhipO0W0Q80GDXi7P/x0atjH1bnU1rHzi/zNK9ICLO27xSAql5ZAh4NxtH8wC8g03fh0XL2orl2XEPB67KbX9Pdv5rShwzX84ySl9jSVuT+oSeqtveT/oyUF8DzFsOHCNpn7HmJKUqwLuKlCFnJtBPaj7KO7rk8azLHBimvtsk/ZTUlLCS1GZ9MGm0y8URcX+W7o7s//8m6QpgJCJuHO+gEfGUpI8DZ0l6Dml8/JOklWf3I3UgXthqISNiVNL/IM2vOIfU1/A84JTsuPl7XhQqa4vnf0zSGcAnJD0DLCPNV/gsqbO5vt+iFWPlPEHSeaQPxlsiYn2LZdqca/wi4KeSLiAFutWkJqLjgJeR+hrGsxg4GbhE0n8ndWAfB2yf7S90/5GIeFLSctLr9SBpAMTfZ7+HTUEODFPfyaRA8GlSU8AIcDfpA/ffcul+CHyN9IHxKVKnYNN7CUTENyQ9QBoK+15ggDTE8VpSO3IhEXGO0j0MTiKNWLkNOBK4jPSBWLqsLRr7EDw+O/ajwPnAJyI37r9VEXFzNu9iIfBB0sirPUkjeVo9RtlrvAL4Eqld/52k5rg/Z3neHRHfbXLO9ZLeRuqwPjvLdyHwK1LfxJPj5W3iCODrpD6FZ4GLgY+SXkubYrzstnWVpNeQ+kCOiogLul2e6UzSD4GXRMTzu10W6y7XGKxjJO0JnECaUPYUqSnnX0hNYOMNlbRJIOm/kmoK9wBbk/p+3g58qJvlsmpwYLBOepbU/n0UqT37cdLQylMiYk03CzYNrSM16e1O6ji+CzguIr7Z1VJZJbgpyczManjms5mZ1XBgMDOzGg4MZmZWw4HBzMxqODCYmVkNBwYzM6vx/wCi7MD3MajiKgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Data_test1 = Data_test[50:100, 0:50]\n",
    "# Data_train1 = Data_train[50:100, 0:50]\n",
    "\n",
    "A1 =  np.multiply(range(ran), 0.5)\n",
    "# A1 =  range(1, 11)\n",
    "A2 =  np.multiply(range(1, ran + 1), 1000)\n",
    "xlabels = ['{:3.1f}'.format(x) for x in A1]\n",
    "# ylabels = ['{:3.1f}'.format(y) for y in A2]\n",
    "ylabels = A2\n",
    "ax = sns.heatmap(Data_test, xticklabels = xlabels, yticklabels = ylabels, cmap = \"YlGnBu\", vmax = 1, vmin = 0)\n",
    "# ax = sns.heatmap(Data_test, cmap = \"YlGnBu\")\n",
    "ax.invert_yaxis()\n",
    "\n",
    "# ax.set_title(\"Test Error Heatmap\")\n",
    "plt.gcf().subplots_adjust(bottom=0.15)\n",
    "ax.set_xlabel('Strength of the Signal', fontsize = 16)\n",
    "ax.set_ylabel('Dimension', fontsize = 16)\n",
    "ax.set_xticks(ax.get_xticks()[::10])\n",
    "ax.set_xticklabels(xlabels[::10])\n",
    "ax.set_yticks(ax.get_yticks()[::10])\n",
    "ax.set_yticklabels(ylabels[::10])\n",
    "plt.savefig('5.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "M7F2upvKgBkY",
    "outputId": "820fd61d-e830-42f5-cf4b-aea707130347"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mounted at /content/gdrive\n"
     ]
    }
   ],
   "source": [
    "from google.colab import drive\n",
    "drive.mount('/content/gdrive')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "Data_test = np.loadtxt('data_test100.csv')\n",
    "Data_train = np.loadtxt('data_train100.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "OA1ARuekgSKW"
   },
   "outputs": [],
   "source": [
    "np.savetxt('data_test100.csv', Data_test)\n",
    "np.savetxt('data_train100.csv', Data_train)\n",
    "!cp data_test100.csv \"gdrive/My Drive/\"\n",
    "!cp data_train100.csv \"gdrive/My Drive/\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "QGMUlCBTGlAy",
    "outputId": "f59cb993-879b-49ce-c75c-71d00ececabf"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Data_test1 = Data_test[50:100, 0:50]\n",
    "# Data_train1 = Data_train[50:100, 0:50]\n",
    "\n",
    "A1 =  np.multiply(range(100), 0.1)\n",
    "# A1 =  range(1, 11)\n",
    "A2 =  np.multiply(range(1, 101), 10)\n",
    "xlabels = ['{:3.1f}'.format(x) for x in A1]\n",
    "# ylabels = ['{:3.1f}'.format(y) for y in A2]\n",
    "ylabels = A2\n",
    "ax = sns.heatmap(Data_test> 0.2, xticklabels = xlabels, yticklabels = ylabels, cmap = \"YlGnBu\", vmax = 1)\n",
    "# ax = sns.heatmap(Data_test, cmap = \"YlGnBu\")\n",
    "ax.invert_yaxis()\n",
    "plt.gcf().subplots_adjust(bottom=0.15)\n",
    "# ax.set_title(\"Test Error Heatmap\")\n",
    "ax.set_xlabel('Strength of the Signal', fontsize = 16)\n",
    "ax.set_ylabel('Dimension', fontsize = 16)\n",
    "ax.set_xticks(ax.get_xticks()[::10])\n",
    "ax.set_xticklabels(xlabels[::10])\n",
    "ax.set_yticks(ax.get_yticks()[::10])\n",
    "ax.set_yticklabels(ylabels[::10])\n",
    "plt.savefig('4.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "a7L4RV2qHShi",
    "outputId": "aebcecd0-4f5a-4db9-d734-62da33c79c85"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Data_test1 = Data_test[50:100, 0:50]\n",
    "# Data_train1 = Data_train[50:100, 0:50]\n",
    "\n",
    "A1 =  np.multiply(range(100), 0.01)\n",
    "A2 =  range(100, 1100)\n",
    "xlabels = ['{:3.1f}'.format(x) for x in A1]\n",
    "# ylabels = ['{:3.1f}'.format(y) for y in A2]\n",
    "ylabels = A2\n",
    "ax = sns.heatmap(Data_train, xticklabels = xlabels, yticklabels = ylabels, cmap = \"YlGnBu\", vmax = 1)\n",
    "# ax = sns.heatmap(Data_test, cmap = \"YlGnBu\")\n",
    "ax.invert_yaxis()\n",
    "\n",
    "ax.set_title(\"Training Loss Heatmap\")\n",
    "ax.set_xlabel('SNR')\n",
    "ax.set_ylabel('Training Data Number')\n",
    "ax.set_xticks(ax.get_xticks()[::10])\n",
    "ax.set_xticklabels(xlabels[::10])\n",
    "ax.set_yticks(ax.get_yticks()[::10])\n",
    "ax.set_yticklabels(ylabels[::10])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 308
    },
    "id": "XJoi0dF3JsWj",
    "outputId": "5244db40-075f-49aa-c9f2-92e2baab2f89"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.suptitle('n = 100, d = 400')\n",
    "plt.plot(strength,test_acc, label = 'test nonlinear')\n",
    "plt.plot(strength,train_acc, label = 'training nonlinear')\n",
    "plt.xlabel('Signal Ratio (mu divided by the noise std)')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
