{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "34d69c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:True\n",
      "GPU 0:NVIDIA RTX A5000:23.99GB\n"
     ]
    }
   ],
   "source": [
    "\n",
    "import torch, random\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision import datasets, transforms\n",
    "import torch.optim.lr_scheduler as lr_scheduler\n",
    "from torch.utils.data import DataLoader, Subset\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "import time\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "# ---------\n",
    "# torch.set_grad_enabled(False)\n",
    "# ============================\n",
    "#       Radom Seed\n",
    "# ============================\n",
    "seed = 99\n",
    "\n",
    "torch.manual_seed(seed)\n",
    "if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "torch.backends.cudnn.benchmark = True\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    print(f\"cuda:True\")\n",
    "    for i in range(torch.cuda.device_count()):\n",
    "        device = torch.device(f\"cuda:{i}\")\n",
    "        properties = torch.cuda.get_device_properties(device)\n",
    "        print(f\"GPU {i}:{properties.name}:{properties.total_memory/1024/1024/1024:.2f}GB\")\n",
    "else:\n",
    "    print(f\"cuda:False\")\n",
    "    device = torch.device(\"cpu\")\n",
    "\n",
    "\n",
    "# ============================\n",
    "#       Equilibrium CNN\n",
    "# ============================\n",
    "def linear(x):\n",
    "    # return F.hardsigmoid(x)\n",
    "    return x\n",
    "def hardtanh6(x):\n",
    "    # return F.hardsigmoid(x)\n",
    "    return x.clamp(min = -6, max=6)\n",
    "def hardtanh6_d(x):\n",
    "        return ((x > -6) & (x < 6)).float()\n",
    "def hardtanh(x):\n",
    "    # return F.hardsigmoid(x)\n",
    "    return x.clamp(min = -1, max=1)\n",
    "def hardtanh_d(x):\n",
    "        return ((x > -1) & (x < 1)).float()\n",
    "def hardsigm(x):\n",
    "    # return F.hardsigmoid(x)\n",
    "    return x.clamp(min = 0, max=1)\n",
    "def hardsigm_d(x):\n",
    "        return ((x > 0) & (x < 1)).float()\n",
    "def relu6(x):\n",
    "    # return F.hardsigmoid(x)\n",
    "    return x.clamp(min = 0, max=6)\n",
    "def relu6_d(x):\n",
    "        return ((x > 0) & (x < 6)).float()\n",
    "def relu(x):\n",
    "    # return F.hardsigmoid(x)\n",
    "    return x.clamp(min = 0)\n",
    "def relu_d(x):\n",
    "        return ((x > 0)).float()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "43a5fbd7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "True\n",
      "GPU 0:NVIDIA RTX A5000:23.99GB\n"
     ]
    }
   ],
   "source": [
    "\n",
    "fsave=True\n",
    "current_time_start = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "res_path = Path(f\"./Res/Final_conv_{current_time_start}-CIFAR10\")\n",
    "res_path.mkdir(parents=True, exist_ok=True)\n",
    "\n",
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize((0.4914, 0.4822, 0.4465),\n",
    "                        (3*0.2023, 3*0.1994, 3*0.2010))\n",
    "])\n",
    "\n",
    "train_set = datasets.CIFAR10(root='./data', train=True, download=True, transform=transform)\n",
    "test_set = datasets.CIFAR10(root='./data', train=False, download=True, transform=transform)\n",
    "\n",
    "train_subset = Subset(train_set, range(int(1 * len(train_set))))\n",
    "test_subset = Subset(test_set, range(int(1 * len(test_set))))\n",
    "\n",
    "train_loader = DataLoader(train_subset, batch_size=128, shuffle=True)\n",
    "test_loader = DataLoader(test_subset, batch_size=512, shuffle=False)\n",
    "\n",
    "print(torch.cuda.is_available())\n",
    "if torch.cuda.is_available():\n",
    "    for i in range(torch.cuda.device_count()):\n",
    "        device = torch.device(f\"cuda:{i}\")\n",
    "        properties = torch.cuda.get_device_properties(device)\n",
    "        print(f\"GPU {i}:{properties.name}:{properties.total_memory/1024/1024/1024:.2f}GB\")\n",
    "\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "train_loader_gpu = [(data.to(device), target.to(device)) for data, target in train_loader]\n",
    "test_loader_gpu = [(data.to(device), target.to(device)) for data, target in test_loader]\n",
    "\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "\n",
    "num_epochs = 40\n",
    "multest =1 #5\n",
    "fbsc_range = [0] # 0.01, 0.1, 1\n",
    "res = np.zeros((len(fbsc_range),multest,3,num_epochs))\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "09191e6b",
   "metadata": {},
   "source": [
    "### Network conv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a4ac1dcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "class aEP_CNN(nn.Module):\n",
    "    def __init__(self, fbsc=0.1, nudge= 0.2, deviden=True, T=60, K=20, chl= [32, 64, 128]):\n",
    "        super().__init__()\n",
    "\n",
    "        self.T = T\n",
    "        self.K = K\n",
    "        self.eta = 1 # leaky rate\n",
    "        self.ffSC, self.fbSC, self.nudge = 1.0, fbsc, nudge\n",
    "        self.deviden = deviden\n",
    "        self.chl = chl\n",
    "        self.rho = hardsigm # hardsigm relu6 relu6 hardtanh hardtanh6 linear\n",
    "\n",
    "        self.conv1 = nn.Conv2d(3, self.chl[0], kernel_size=3, stride=1, padding=1)\n",
    "        self.pool1 = nn.MaxPool2d(2, stride = 2, return_indices = True)  \n",
    "        self.conv2 = nn.Conv2d(self.chl[0], self.chl[1], kernel_size=3, stride=1, padding=1)\n",
    "        self.pool2 = nn.MaxPool2d(2, stride = 2, return_indices = True)  \n",
    "        \n",
    "        self.conv3 = nn.Conv2d(self.chl[1], self.chl[2], kernel_size=3, stride=1, padding=1)\n",
    "        self.pool3 = nn.MaxPool2d(2, stride = 2, return_indices = True)  \n",
    "\n",
    "        self.fc1 = nn.Linear(self.chl[2] * 4 * 4, 10)\n",
    "\n",
    "        self.unpool1 = nn.MaxUnpool2d(2, stride = 2)  \n",
    "        self.unpool2 = nn.MaxUnpool2d(2, stride = 2)  \n",
    "        self.unpool3 = nn.MaxUnpool2d(2, stride = 2)  \n",
    "\n",
    "        self.device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "        self.to(self.device)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def forward(self, x, t=0, s=0, nudge = 0, target=None):\n",
    "        if t>0:\n",
    "            x1, p1, ind1, x2, p2, ind2, x3, p3, ind3, fc1 = s  \n",
    "        else:\n",
    "            # x1, p1, ind1, x2, p2, ind2, x3 = 0, 0, 0, 0, 0, 0, 0\n",
    "            x1 = self.conv1(torch.zeros_like(x,device=self.device))       # torch.zeros_like(x,device=self.device)\n",
    "            p1, ind1 = self.pool1(self.rho(x1))\n",
    "            x2 = self.conv2(p1)      # (B, 32, 16, 16)\n",
    "            p2, ind2 = self.pool2(self.rho(x2))\n",
    "            x3 = self.conv3(p2)      # (B, 32, 16, 16)\n",
    "            p3, ind3 = self.pool3(self.rho(x3))\n",
    "\n",
    "            fc1 = ( self.fc1(p3.view(p3.size(0), -1)))\n",
    "        \n",
    "        # if nudge!=0:\n",
    "        if nudge!=0: \n",
    "            fb =  (target-F.softmax(fc1,dim=1)) @ self.fc1.weight \n",
    "            fbs = fb.view(fb.size(0), self.chl[2], 4, 4)\n",
    "        else:\n",
    "            fbs = torch.zeros_like(p3,device=self.device)\n",
    "        # else:\n",
    "        #     fbs = torch.zeros_like(p2,device=self.device) F.conv_transpose2d(delta_conv4, self.conv2.weight, stride=1, padding=1) #.permute([0,1,3,2])\n",
    "        p1, ind1 = self.pool1(self.rho(x1))       # output_size =(B, 128, 16, 16)\n",
    "        p2, ind2 = self.pool2(self.rho(x2))      # (B, 256, 8, 8)\n",
    "        p3, ind3 = self.pool3(self.rho(x3))      # (B, 512, 4, 4)\n",
    "        \n",
    "        dx1 =  (self.conv1(x)*self.ffSC +self.unpool1( F.conv_transpose2d(self.rho(x2), self.conv2.weight, stride=1, padding=1),\n",
    "                                            ind1,output_size=x1.shape)*self.fbSC)\n",
    "        \n",
    "        dx2 =  (self.conv2(p1)*self.ffSC + self.unpool2(F.conv_transpose2d(self.rho(x3), self.conv3.weight, stride=1, padding=1),\n",
    "                                                        ind2,output_size=x2.shape)*self.fbSC)\n",
    "\n",
    "        dx3 =  (self.conv3(p2)*self.ffSC + self.unpool3(fbs,ind3,output_size=x3.shape)* nudge )\n",
    "\n",
    "        dfc = ( self.fc1(p3.view(p3.size(0), -1)))\n",
    "\n",
    "        x1 =dx1\n",
    "        x2 =dx2\n",
    "        x3 =dx3\n",
    "        fc1 = dfc\n",
    "        # if nudge == 0: fc1 = dfc\n",
    "        return x1, p1, ind1, x2, p2, ind2, x3, p3, ind3, fc1\n",
    "    \n",
    "    \n",
    "    @torch.no_grad()\n",
    "    def ep_step(self, x, y):\n",
    "        x = x.to(self.device)\n",
    "        y = y.to(self.device)\n",
    "        y_onehot = F.one_hot(y, num_classes=10).float().to(self.device)\n",
    "\n",
    "        # Free phase dynamics\n",
    "        sf = 0\n",
    "        \n",
    "        # self.deconv2.bias.data = self.conv2.bias.clone()\n",
    "        for t in range(self.T):\n",
    "            sf = self.forward(x, t=t, s=sf, nudge=0, target=y_onehot)\n",
    "\n",
    "        x1, p1, _, x2, p2, _, x3, p3, _, fc1 = sf\n",
    "        # self.x1, self.x2, self.x3, self.xfc1 = x1, x2, x3, fc1\n",
    "        preds = torch.argmax(sf[-1], dim=1)\n",
    "\n",
    "        # Nudged phase dynamics\n",
    "        sn = [t.clone() for t in sf]\n",
    "        for t in range(self.K):\n",
    "            sn = self.forward(x, t=self.T+t, s=sn, nudge=self.nudge, target=y_onehot)\n",
    "\n",
    "        # Weight update: contrastive Hebbian rule (difference of activations)\n",
    "        \n",
    "        x1n, _, _, x2n, _, _, x3n, _, _, fc1n = sn\n",
    "\n",
    "        # after free-phase we had: x1,x2,x3,x4 and p1,p2,p3,p4 and fc1 (free)\n",
    "        # after nudged-phase sn we get x1n,...,x4n and p4n and fc1_nudged (sn[-1])\n",
    "        beta = self.nudge if self.deviden else 1#\n",
    "        \n",
    "        # fc\n",
    "        # delta_fc = (F.softmax(fc1, dim=1) - F.softmax(fc1n, dim=1)) / (beta * x.size(0))\n",
    "        delta_fc = (F.softmax(fc1, dim=1) - y_onehot) / (x.size(0))\n",
    "        flatp4 = p3.view(p3.size(0), -1).contiguous()\n",
    "        self.fc1.weight.grad = delta_fc.T @ flatp4\n",
    "        self.fc1.bias.grad = delta_fc.sum(0)\n",
    "\n",
    "\n",
    "        # conv3\n",
    "        delta_conv3 = ((self.rho(x3) - self.rho(x3n)) / ( self.fbSC**0 * beta * x.size(0))).contiguous()\n",
    "        grad_conv3_w = torch.nn.grad.conv2d_weight(p2.contiguous(), self.conv3.weight.shape, delta_conv3, stride=1, padding=1)\n",
    "        self.conv3.weight.grad = grad_conv3_w\n",
    "        self.conv3.bias.grad = delta_conv3.sum(dim=(0,2,3))\n",
    "\n",
    "        # conv2\n",
    "        delta_conv2 = ((self.rho(x2) - self.rho(x2n)) / ( self.fbSC**0 * beta * x.size(0))).contiguous()\n",
    "        grad_conv2_w = torch.nn.grad.conv2d_weight(p1.contiguous(), self.conv2.weight.shape, delta_conv2, stride=1, padding=1)\n",
    "        self.conv2.weight.grad = grad_conv2_w\n",
    "        self.conv2.bias.grad = delta_conv2.sum(dim=(0,2,3))\n",
    "\n",
    "        # conv1\n",
    "        delta_conv1 = ((self.rho(x1) - self.rho(x1n)) / ( self.fbSC**0 * beta * x.size(0))).contiguous()\n",
    "        grad_conv1_w = torch.nn.grad.conv2d_weight(x.contiguous(), self.conv1.weight.shape, delta_conv1, stride=1, padding=1)\n",
    "        self.conv1.weight.grad = grad_conv1_w\n",
    "        self.conv1.bias.grad = delta_conv1.sum(dim=(0,2,3))\n",
    "\n",
    "        \n",
    "        # self.dx1, self.dx2, self.dx3, self.dx4, self.dxfc1 = (self.rho(x1) - self.rho(x1n)), (self.rho(x2) - self.rho(x2n)), (self.rho(x3) - self.rho(x3n)), (self.rho(x4) - self.rho(x4n)), (F.softmax(fc1, dim=1) - F.softmax(fc1n, dim=1))\n",
    "\n",
    "        return preds, F.cross_entropy(fc1, y).item()\n",
    "    \n",
    "\n",
    "    # @torch.no_grad()\n",
    "    # def bw_symm(self):\n",
    "    #     self.deconv2.weight.data = self.conv2.weight.data.clone()\n",
    "    #     return\n",
    "    \n",
    "    @torch.no_grad()\n",
    "    def predict(self, x):\n",
    "        with torch.no_grad():\n",
    "            x = x.to(self.device)\n",
    "            sf = 0\n",
    "            \n",
    "            for t in range(self.T):\n",
    "                sf = self.forward(x, t=t, s=sf, nudge=0, target=None)\n",
    "\n",
    "            preds = torch.argmax(sf[-1], dim=1)\n",
    "        return preds\n",
    "    \n",
    "    def forward_BP(self, x):\n",
    "        # return pre-activations(z) and post-activations(x) and pooled results\n",
    "        # z* = pre-activation (conv output), x* = post-activation = rho(z*)\n",
    "        z1 = self.conv1(x)\n",
    "        x1 = self.rho(z1)\n",
    "        p1, ind1 = self.pool1(x1)\n",
    "\n",
    "        z2 = self.conv2(p1)\n",
    "        x2 = self.rho(z2)\n",
    "        p2, ind2 = self.pool2(x2)\n",
    "\n",
    "        z3 = self.conv3(p2)\n",
    "        x3 = self.rho(z3)\n",
    "        p3, ind3 = self.pool3(x3)\n",
    "\n",
    "        # fix: use p4.size(0) (batch dim of p4) for view\n",
    "        fc1 = self.fc1(p3.view(p3.size(0), -1))\n",
    "\n",
    "        #  post, pools, inds, logits\n",
    "        \n",
    "        # self.x1, self.x2, self.x3, self.xfc1 = x1, x2, x3, fc1\n",
    "        return z1, x1, p1, ind1, z2, x2, p2, ind2, z3, x3, p3, ind3, fc1\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74c02f5a",
   "metadata": {},
   "source": [
    "### BP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a321a50e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 start at 20250924-163648\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:03, 121.45batch/s, loss=1.701606]                               1.701606]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.50e-04\n",
      "Epoch 1 Train Loss = 1.7016, Accuracy = 39.32%, Test Accuracy = 48.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:02, 193.79batch/s, loss=1.363052]                               1.363052]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.49e-04\n",
      "Epoch 2 Train Loss = 1.3631, Accuracy = 51.61%, Test Accuracy = 54.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:02, 192.18batch/s, loss=1.243485]                               1.243485]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.48e-04\n",
      "Epoch 3 Train Loss = 1.2435, Accuracy = 56.30%, Test Accuracy = 58.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:02, 177.66batch/s, loss=1.150283]                               1.150283]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.46e-04\n",
      "Epoch 4 Train Loss = 1.1503, Accuracy = 59.82%, Test Accuracy = 60.75%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:02, 185.81batch/s, loss=1.076913]                               1.076913]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.44e-04\n",
      "Epoch 5 Train Loss = 1.0769, Accuracy = 62.63%, Test Accuracy = 62.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:02, 176.37batch/s, loss=1.017625]                               1.017625]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.41e-04\n",
      "Epoch 6 Train Loss = 1.0176, Accuracy = 64.48%, Test Accuracy = 63.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:02, 175.98batch/s, loss=0.968508]                               0.968508]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.38e-04\n",
      "Epoch 7 Train Loss = 0.9685, Accuracy = 66.29%, Test Accuracy = 65.99%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:02, 176.36batch/s, loss=0.924126]                               0.924126]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.35e-04\n",
      "Epoch 8 Train Loss = 0.9241, Accuracy = 68.11%, Test Accuracy = 66.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:02, 188.32batch/s, loss=0.887492]                               0.887492]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.31e-04\n",
      "Epoch 9 Train Loss = 0.8875, Accuracy = 69.34%, Test Accuracy = 67.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:02, 177.76batch/s, loss=0.855365]                              0.855365]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.26e-04\n",
      "Epoch 10 Train Loss = 0.8554, Accuracy = 70.64%, Test Accuracy = 69.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:02, 189.56batch/s, loss=0.830619]                              0.830619]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.21e-04\n",
      "Epoch 11 Train Loss = 0.8306, Accuracy = 71.45%, Test Accuracy = 69.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:02, 198.42batch/s, loss=0.802792]                              0.802792]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.16e-04\n",
      "Epoch 12 Train Loss = 0.8028, Accuracy = 72.43%, Test Accuracy = 69.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:01, 235.58batch/s, loss=0.782855]                              0.782855]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.11e-04\n",
      "Epoch 13 Train Loss = 0.7829, Accuracy = 73.05%, Test Accuracy = 71.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:02, 183.94batch/s, loss=0.760192]                              0.760192]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.05e-04\n",
      "Epoch 14 Train Loss = 0.7602, Accuracy = 73.91%, Test Accuracy = 71.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:02, 195.43batch/s, loss=0.744585]                              0.744585]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 1.99e-04\n",
      "Epoch 15 Train Loss = 0.7446, Accuracy = 74.68%, Test Accuracy = 71.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:02, 168.70batch/s, loss=0.724096]                              0.724096]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 1.92e-04\n",
      "Epoch 16 Train Loss = 0.7241, Accuracy = 75.24%, Test Accuracy = 71.83%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:02, 182.76batch/s, loss=0.709278]                              0.709278]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 1.85e-04\n",
      "Epoch 17 Train Loss = 0.7093, Accuracy = 75.68%, Test Accuracy = 71.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:01, 204.99batch/s, loss=0.693544]                              0.693544]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 1.79e-04\n",
      "Epoch 18 Train Loss = 0.6935, Accuracy = 76.18%, Test Accuracy = 72.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:02, 186.86batch/s, loss=0.679734]                              0.679734]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 1.71e-04\n",
      "Epoch 19 Train Loss = 0.6797, Accuracy = 76.88%, Test Accuracy = 73.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:02, 195.57batch/s, loss=0.668227]                              0.668227]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 1.64e-04\n",
      "Epoch 20 Train Loss = 0.6682, Accuracy = 77.43%, Test Accuracy = 73.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:01, 207.45batch/s, loss=0.654602]                              0.654602]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 1.56e-04\n",
      "Epoch 21 Train Loss = 0.6546, Accuracy = 77.88%, Test Accuracy = 73.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:02, 198.86batch/s, loss=0.644035]                              0.644035]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 1.49e-04\n",
      "Epoch 22 Train Loss = 0.6440, Accuracy = 78.30%, Test Accuracy = 73.52%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:02, 185.05batch/s, loss=0.632841]                              0.632841]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 1.41e-04\n",
      "Epoch 23 Train Loss = 0.6328, Accuracy = 78.57%, Test Accuracy = 73.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:01, 217.84batch/s, loss=0.620457]                              0.620457]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 1.33e-04\n",
      "Epoch 24 Train Loss = 0.6205, Accuracy = 79.21%, Test Accuracy = 73.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:01, 214.72batch/s, loss=0.612170]                              0.612170]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 1.25e-04\n",
      "Epoch 25 Train Loss = 0.6122, Accuracy = 79.45%, Test Accuracy = 74.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:02, 198.30batch/s, loss=0.602726]                              0.602726]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 1.18e-04\n",
      "Epoch 26 Train Loss = 0.6027, Accuracy = 79.69%, Test Accuracy = 73.96%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:01, 219.21batch/s, loss=0.592995]                              0.592995]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 1.10e-04\n",
      "Epoch 27 Train Loss = 0.5930, Accuracy = 80.19%, Test Accuracy = 74.39%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:01, 209.90batch/s, loss=0.585232]                              0.585232]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 1.02e-04\n",
      "Epoch 28 Train Loss = 0.5852, Accuracy = 80.53%, Test Accuracy = 74.43%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:01, 201.59batch/s, loss=0.577915]                              0.577915]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 9.45e-05\n",
      "Epoch 29 Train Loss = 0.5779, Accuracy = 80.72%, Test Accuracy = 74.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:01, 209.03batch/s, loss=0.571567]                              0.571567]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 8.70e-05\n",
      "Epoch 30 Train Loss = 0.5716, Accuracy = 81.02%, Test Accuracy = 74.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:02, 166.26batch/s, loss=0.563523]                              0.563523]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 7.97e-05\n",
      "Epoch 31 Train Loss = 0.5635, Accuracy = 81.31%, Test Accuracy = 74.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:02, 193.93batch/s, loss=0.557851]                              0.557851]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 7.25e-05\n",
      "Epoch 32 Train Loss = 0.5579, Accuracy = 81.49%, Test Accuracy = 74.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:02, 167.87batch/s, loss=0.552883]                              0.552883]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 6.55e-05\n",
      "Epoch 33 Train Loss = 0.5529, Accuracy = 81.72%, Test Accuracy = 74.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:02, 157.64batch/s, loss=0.547688]                              0.547688]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 5.88e-05\n",
      "Epoch 34 Train Loss = 0.5477, Accuracy = 81.91%, Test Accuracy = 74.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:02, 148.18batch/s, loss=0.542586]                              0.542586]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 5.23e-05\n",
      "Epoch 35 Train Loss = 0.5426, Accuracy = 82.12%, Test Accuracy = 74.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:02, 164.68batch/s, loss=0.537735]                              0.537735]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 4.61e-05\n",
      "Epoch 36 Train Loss = 0.5377, Accuracy = 82.25%, Test Accuracy = 75.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:02, 178.33batch/s, loss=0.534037]                              0.534037]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 4.03e-05\n",
      "Epoch 37 Train Loss = 0.5340, Accuracy = 82.43%, Test Accuracy = 74.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:02, 171.83batch/s, loss=0.530500]                              0.530500]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 3.47e-05\n",
      "Epoch 38 Train Loss = 0.5305, Accuracy = 82.55%, Test Accuracy = 75.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:02, 172.40batch/s, loss=0.527416]                              0.527416]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.96e-05\n",
      "Epoch 39 Train Loss = 0.5274, Accuracy = 82.79%, Test Accuracy = 75.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:02, 178.14batch/s, loss=0.524839]                              0.524839]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.48e-05\n",
      "Epoch 40 Train Loss = 0.5248, Accuracy = 82.94%, Test Accuracy = 75.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:01, 200.11batch/s, loss=0.521453]                              0.521453]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41, Current LR: 2.04e-05\n",
      "Epoch 41 Train Loss = 0.5215, Accuracy = 82.96%, Test Accuracy = 75.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:02, 150.52batch/s, loss=0.519207]                              0.519207]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42, Current LR: 1.64e-05\n",
      "Epoch 42 Train Loss = 0.5192, Accuracy = 83.07%, Test Accuracy = 75.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:02, 169.66batch/s, loss=0.517458]                              0.517458]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43, Current LR: 1.28e-05\n",
      "Epoch 43 Train Loss = 0.5175, Accuracy = 83.22%, Test Accuracy = 75.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:02, 186.77batch/s, loss=0.515951]                              0.515951]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44, Current LR: 9.74e-06\n",
      "Epoch 44 Train Loss = 0.5160, Accuracy = 83.25%, Test Accuracy = 75.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:02, 196.90batch/s, loss=0.514637]                              0.514637]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45, Current LR: 7.09e-06\n",
      "Epoch 45 Train Loss = 0.5146, Accuracy = 83.33%, Test Accuracy = 75.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:02, 170.67batch/s, loss=0.513663]                              0.513663]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46, Current LR: 4.91e-06\n",
      "Epoch 46 Train Loss = 0.5137, Accuracy = 83.31%, Test Accuracy = 75.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:01, 215.13batch/s, loss=0.512576]                              0.512576]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47, Current LR: 3.21e-06\n",
      "Epoch 47 Train Loss = 0.5126, Accuracy = 83.42%, Test Accuracy = 75.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:02, 171.32batch/s, loss=0.512046]                              0.512046]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48, Current LR: 1.98e-06\n",
      "Epoch 48 Train Loss = 0.5120, Accuracy = 83.45%, Test Accuracy = 75.35%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:02, 145.53batch/s, loss=0.511556]                              0.511556]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49, Current LR: 1.25e-06\n",
      "Epoch 49 Train Loss = 0.5116, Accuracy = 83.43%, Test Accuracy = 75.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:02, 149.06batch/s, loss=0.511327]                              0.511327]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50, Current LR: 1.00e-06\n",
      "Epoch 50 Train Loss = 0.5113, Accuracy = 83.52%, Test Accuracy = 75.27%\n",
      "0 end at 20250924-163840\n",
      "1 start at 20250924-163840\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:02, 156.60batch/s, loss=1.703343]                               1.703343]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.50e-04\n",
      "Epoch 1 Train Loss = 1.7033, Accuracy = 38.31%, Test Accuracy = 47.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:02, 172.99batch/s, loss=1.372543]                               1.372543]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.49e-04\n",
      "Epoch 2 Train Loss = 1.3725, Accuracy = 50.52%, Test Accuracy = 52.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:02, 144.90batch/s, loss=1.257552]                               1.257552]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.48e-04\n",
      "Epoch 3 Train Loss = 1.2576, Accuracy = 55.41%, Test Accuracy = 56.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:02, 180.57batch/s, loss=1.177598]                               1.177598]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.46e-04\n",
      "Epoch 4 Train Loss = 1.1776, Accuracy = 58.56%, Test Accuracy = 59.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:02, 169.71batch/s, loss=1.109526]                               1.109526]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.44e-04\n",
      "Epoch 5 Train Loss = 1.1095, Accuracy = 61.09%, Test Accuracy = 62.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:02, 166.22batch/s, loss=1.054341]                               1.054341]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.41e-04\n",
      "Epoch 6 Train Loss = 1.0543, Accuracy = 63.34%, Test Accuracy = 63.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:02, 187.85batch/s, loss=1.004514]                               1.004514]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.38e-04\n",
      "Epoch 7 Train Loss = 1.0045, Accuracy = 65.30%, Test Accuracy = 65.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:02, 176.86batch/s, loss=0.959664]                               0.959664]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.35e-04\n",
      "Epoch 8 Train Loss = 0.9597, Accuracy = 66.91%, Test Accuracy = 66.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:01, 212.04batch/s, loss=0.924521]                               0.924521]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.31e-04\n",
      "Epoch 9 Train Loss = 0.9245, Accuracy = 68.22%, Test Accuracy = 67.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:02, 157.27batch/s, loss=0.888257]                              0.888257]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.26e-04\n",
      "Epoch 10 Train Loss = 0.8883, Accuracy = 69.43%, Test Accuracy = 67.83%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:02, 164.31batch/s, loss=0.858481]                              0.858481]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.21e-04\n",
      "Epoch 11 Train Loss = 0.8585, Accuracy = 70.71%, Test Accuracy = 68.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:02, 156.50batch/s, loss=0.833729]                              0.833729]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.16e-04\n",
      "Epoch 12 Train Loss = 0.8337, Accuracy = 71.49%, Test Accuracy = 69.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:02, 176.57batch/s, loss=0.811485]                              0.811485]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.11e-04\n",
      "Epoch 13 Train Loss = 0.8115, Accuracy = 72.20%, Test Accuracy = 69.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:02, 160.27batch/s, loss=0.786742]                              0.786742]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.05e-04\n",
      "Epoch 14 Train Loss = 0.7867, Accuracy = 72.98%, Test Accuracy = 70.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:01, 206.84batch/s, loss=0.767249]                              0.767249]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 1.99e-04\n",
      "Epoch 15 Train Loss = 0.7672, Accuracy = 73.84%, Test Accuracy = 71.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:02, 195.20batch/s, loss=0.750403]                              0.750403]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 1.92e-04\n",
      "Epoch 16 Train Loss = 0.7504, Accuracy = 74.49%, Test Accuracy = 71.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:02, 175.55batch/s, loss=0.733393]                              0.733393]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 1.85e-04\n",
      "Epoch 17 Train Loss = 0.7334, Accuracy = 75.10%, Test Accuracy = 72.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:01, 216.92batch/s, loss=0.715085]                              0.715085]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 1.79e-04\n",
      "Epoch 18 Train Loss = 0.7151, Accuracy = 75.68%, Test Accuracy = 72.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:02, 171.91batch/s, loss=0.702106]                              0.702106]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 1.71e-04\n",
      "Epoch 19 Train Loss = 0.7021, Accuracy = 76.22%, Test Accuracy = 72.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:01, 221.36batch/s, loss=0.687264]                              0.687264]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 1.64e-04\n",
      "Epoch 20 Train Loss = 0.6873, Accuracy = 76.94%, Test Accuracy = 72.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:01, 221.70batch/s, loss=0.674088]                              0.674088]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 1.56e-04\n",
      "Epoch 21 Train Loss = 0.6741, Accuracy = 77.38%, Test Accuracy = 73.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:01, 210.05batch/s, loss=0.661815]                              0.661815]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 1.49e-04\n",
      "Epoch 22 Train Loss = 0.6618, Accuracy = 77.77%, Test Accuracy = 72.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:01, 201.83batch/s, loss=0.650859]                              0.650859]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 1.41e-04\n",
      "Epoch 23 Train Loss = 0.6509, Accuracy = 78.30%, Test Accuracy = 73.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:01, 253.25batch/s, loss=0.638787]                              0.638787]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 1.33e-04\n",
      "Epoch 24 Train Loss = 0.6388, Accuracy = 78.74%, Test Accuracy = 73.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:01, 200.36batch/s, loss=0.630052]                              0.630052]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 1.25e-04\n",
      "Epoch 25 Train Loss = 0.6301, Accuracy = 78.89%, Test Accuracy = 73.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:01, 203.53batch/s, loss=0.619554]                              0.619554]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 1.18e-04\n",
      "Epoch 26 Train Loss = 0.6196, Accuracy = 79.49%, Test Accuracy = 73.81%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:01, 252.11batch/s, loss=0.609867]                              0.609867]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 1.10e-04\n",
      "Epoch 27 Train Loss = 0.6099, Accuracy = 79.82%, Test Accuracy = 73.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:01, 211.30batch/s, loss=0.602190]                              0.602190]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 1.02e-04\n",
      "Epoch 28 Train Loss = 0.6022, Accuracy = 80.07%, Test Accuracy = 73.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:01, 239.84batch/s, loss=0.593687]                              0.593687]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 9.45e-05\n",
      "Epoch 29 Train Loss = 0.5937, Accuracy = 80.44%, Test Accuracy = 74.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:02, 198.05batch/s, loss=0.586772]                              0.586772]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 8.70e-05\n",
      "Epoch 30 Train Loss = 0.5868, Accuracy = 80.59%, Test Accuracy = 74.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:02, 197.32batch/s, loss=0.578956]                              0.578956]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 7.97e-05\n",
      "Epoch 31 Train Loss = 0.5790, Accuracy = 80.84%, Test Accuracy = 74.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:01, 201.10batch/s, loss=0.573569]                              0.573569]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 7.25e-05\n",
      "Epoch 32 Train Loss = 0.5736, Accuracy = 81.20%, Test Accuracy = 74.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:02, 162.13batch/s, loss=0.567728]                              0.567728]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 6.55e-05\n",
      "Epoch 33 Train Loss = 0.5677, Accuracy = 81.54%, Test Accuracy = 74.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:01, 204.31batch/s, loss=0.562100]                              0.562100]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 5.88e-05\n",
      "Epoch 34 Train Loss = 0.5621, Accuracy = 81.66%, Test Accuracy = 74.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:02, 187.62batch/s, loss=0.556993]                              0.556993]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 5.23e-05\n",
      "Epoch 35 Train Loss = 0.5570, Accuracy = 81.77%, Test Accuracy = 74.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:01, 211.65batch/s, loss=0.552835]                              0.552835]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 4.61e-05\n",
      "Epoch 36 Train Loss = 0.5528, Accuracy = 81.90%, Test Accuracy = 74.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:01, 222.24batch/s, loss=0.548945]                              0.548945]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 4.03e-05\n",
      "Epoch 37 Train Loss = 0.5489, Accuracy = 82.10%, Test Accuracy = 74.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:02, 184.17batch/s, loss=0.545272]                              0.545272]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 3.47e-05\n",
      "Epoch 38 Train Loss = 0.5453, Accuracy = 82.28%, Test Accuracy = 74.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:02, 188.63batch/s, loss=0.541879]                              0.541879]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.96e-05\n",
      "Epoch 39 Train Loss = 0.5419, Accuracy = 82.36%, Test Accuracy = 74.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:01, 201.44batch/s, loss=0.538630]                              0.538630]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.48e-05\n",
      "Epoch 40 Train Loss = 0.5386, Accuracy = 82.53%, Test Accuracy = 74.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:01, 218.71batch/s, loss=0.536268]                              0.536268]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41, Current LR: 2.04e-05\n",
      "Epoch 41 Train Loss = 0.5363, Accuracy = 82.62%, Test Accuracy = 74.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:01, 219.75batch/s, loss=0.534097]                              0.534097]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42, Current LR: 1.64e-05\n",
      "Epoch 42 Train Loss = 0.5341, Accuracy = 82.71%, Test Accuracy = 74.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:01, 217.44batch/s, loss=0.532248]                              0.532248]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43, Current LR: 1.28e-05\n",
      "Epoch 43 Train Loss = 0.5322, Accuracy = 82.87%, Test Accuracy = 74.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:01, 227.41batch/s, loss=0.530461]                              0.530461]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44, Current LR: 9.74e-06\n",
      "Epoch 44 Train Loss = 0.5305, Accuracy = 82.96%, Test Accuracy = 74.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:01, 239.33batch/s, loss=0.529037]                              0.529037]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45, Current LR: 7.09e-06\n",
      "Epoch 45 Train Loss = 0.5290, Accuracy = 82.90%, Test Accuracy = 74.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:02, 179.70batch/s, loss=0.528184]                              0.528184]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46, Current LR: 4.91e-06\n",
      "Epoch 46 Train Loss = 0.5282, Accuracy = 83.01%, Test Accuracy = 74.81%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:01, 211.01batch/s, loss=0.527134]                              0.527134]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47, Current LR: 3.21e-06\n",
      "Epoch 47 Train Loss = 0.5271, Accuracy = 83.05%, Test Accuracy = 74.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:01, 204.32batch/s, loss=0.526510]                              0.526510]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48, Current LR: 1.98e-06\n",
      "Epoch 48 Train Loss = 0.5265, Accuracy = 83.06%, Test Accuracy = 74.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:02, 182.12batch/s, loss=0.526074]                              0.526074]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49, Current LR: 1.25e-06\n",
      "Epoch 49 Train Loss = 0.5261, Accuracy = 83.09%, Test Accuracy = 74.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:01, 208.66batch/s, loss=0.525795]                              0.525795]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50, Current LR: 1.00e-06\n",
      "Epoch 50 Train Loss = 0.5258, Accuracy = 83.11%, Test Accuracy = 74.76%\n",
      "1 end at 20250924-164026\n",
      "2 start at 20250924-164026\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:02, 182.94batch/s, loss=1.701770]                               1.701770]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.50e-04\n",
      "Epoch 1 Train Loss = 1.7018, Accuracy = 38.87%, Test Accuracy = 47.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:01, 265.72batch/s, loss=1.369401]                               1.369401]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.49e-04\n",
      "Epoch 2 Train Loss = 1.3694, Accuracy = 50.90%, Test Accuracy = 53.57%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:02, 183.04batch/s, loss=1.238820]                               1.238820]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.48e-04\n",
      "Epoch 3 Train Loss = 1.2388, Accuracy = 56.00%, Test Accuracy = 57.74%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:01, 205.87batch/s, loss=1.153892]                               1.153892]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.46e-04\n",
      "Epoch 4 Train Loss = 1.1539, Accuracy = 59.24%, Test Accuracy = 60.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:01, 274.79batch/s, loss=1.079073]                               1.079073]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.44e-04\n",
      "Epoch 5 Train Loss = 1.0791, Accuracy = 62.30%, Test Accuracy = 61.60%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:02, 186.49batch/s, loss=1.018161]                               1.018161]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.41e-04\n",
      "Epoch 6 Train Loss = 1.0182, Accuracy = 64.31%, Test Accuracy = 64.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:02, 177.97batch/s, loss=0.967933]                               0.967933]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.38e-04\n",
      "Epoch 7 Train Loss = 0.9679, Accuracy = 66.39%, Test Accuracy = 65.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:01, 239.93batch/s, loss=0.920588]                               0.920588]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.35e-04\n",
      "Epoch 8 Train Loss = 0.9206, Accuracy = 68.07%, Test Accuracy = 66.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:01, 212.34batch/s, loss=0.888675]                               0.888675]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.31e-04\n",
      "Epoch 9 Train Loss = 0.8887, Accuracy = 69.13%, Test Accuracy = 68.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:01, 246.97batch/s, loss=0.850129]                              0.850129]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.26e-04\n",
      "Epoch 10 Train Loss = 0.8501, Accuracy = 70.57%, Test Accuracy = 69.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:01, 216.52batch/s, loss=0.820222]                              0.820222]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.21e-04\n",
      "Epoch 11 Train Loss = 0.8202, Accuracy = 71.59%, Test Accuracy = 69.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:01, 245.81batch/s, loss=0.790358]                              0.790358]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.16e-04\n",
      "Epoch 12 Train Loss = 0.7904, Accuracy = 72.87%, Test Accuracy = 70.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:01, 229.65batch/s, loss=0.769532]                              0.769532]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.11e-04\n",
      "Epoch 13 Train Loss = 0.7695, Accuracy = 73.53%, Test Accuracy = 71.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:01, 223.11batch/s, loss=0.749615]                              0.749615]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.05e-04\n",
      "Epoch 14 Train Loss = 0.7496, Accuracy = 74.20%, Test Accuracy = 71.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:01, 207.42batch/s, loss=0.729528]                              0.729528]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 1.99e-04\n",
      "Epoch 15 Train Loss = 0.7295, Accuracy = 75.01%, Test Accuracy = 71.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:01, 249.84batch/s, loss=0.711169]                              0.711169]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 1.92e-04\n",
      "Epoch 16 Train Loss = 0.7112, Accuracy = 75.74%, Test Accuracy = 72.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:01, 227.95batch/s, loss=0.692948]                              0.692948]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 1.85e-04\n",
      "Epoch 17 Train Loss = 0.6929, Accuracy = 76.39%, Test Accuracy = 72.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:01, 200.96batch/s, loss=0.676012]                              0.676012]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 1.79e-04\n",
      "Epoch 18 Train Loss = 0.6760, Accuracy = 77.11%, Test Accuracy = 73.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:01, 213.36batch/s, loss=0.662644]                              0.662644]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 1.71e-04\n",
      "Epoch 19 Train Loss = 0.6626, Accuracy = 77.53%, Test Accuracy = 73.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:02, 192.70batch/s, loss=0.647721]                              0.647721]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 1.64e-04\n",
      "Epoch 20 Train Loss = 0.6477, Accuracy = 78.10%, Test Accuracy = 73.35%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:01, 211.19batch/s, loss=0.636001]                              0.636001]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 1.56e-04\n",
      "Epoch 21 Train Loss = 0.6360, Accuracy = 78.47%, Test Accuracy = 73.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:02, 192.99batch/s, loss=0.624475]                              0.624475]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 1.49e-04\n",
      "Epoch 22 Train Loss = 0.6245, Accuracy = 78.87%, Test Accuracy = 73.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:01, 216.43batch/s, loss=0.611147]                              0.611147]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 1.41e-04\n",
      "Epoch 23 Train Loss = 0.6111, Accuracy = 79.36%, Test Accuracy = 73.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:01, 206.21batch/s, loss=0.601131]                              0.601131]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 1.33e-04\n",
      "Epoch 24 Train Loss = 0.6011, Accuracy = 79.81%, Test Accuracy = 74.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:01, 202.07batch/s, loss=0.590339]                              0.590339]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 1.25e-04\n",
      "Epoch 25 Train Loss = 0.5903, Accuracy = 80.14%, Test Accuracy = 74.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:01, 210.75batch/s, loss=0.581326]                              0.581326]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 1.18e-04\n",
      "Epoch 26 Train Loss = 0.5813, Accuracy = 80.61%, Test Accuracy = 74.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:01, 237.77batch/s, loss=0.572976]                              0.572976]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 1.10e-04\n",
      "Epoch 27 Train Loss = 0.5730, Accuracy = 81.07%, Test Accuracy = 74.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:01, 248.00batch/s, loss=0.563992]                              0.563992]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 1.02e-04\n",
      "Epoch 28 Train Loss = 0.5640, Accuracy = 81.19%, Test Accuracy = 74.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:02, 185.46batch/s, loss=0.555921]                              0.555921]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 9.45e-05\n",
      "Epoch 29 Train Loss = 0.5559, Accuracy = 81.61%, Test Accuracy = 75.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:01, 212.79batch/s, loss=0.549778]                              0.549778]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 8.70e-05\n",
      "Epoch 30 Train Loss = 0.5498, Accuracy = 81.77%, Test Accuracy = 74.74%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:01, 210.22batch/s, loss=0.541875]                              0.541875]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 7.97e-05\n",
      "Epoch 31 Train Loss = 0.5419, Accuracy = 82.00%, Test Accuracy = 74.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:01, 236.77batch/s, loss=0.536321]                              0.536321]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 7.25e-05\n",
      "Epoch 32 Train Loss = 0.5363, Accuracy = 82.30%, Test Accuracy = 75.46%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:02, 188.16batch/s, loss=0.530658]                              0.530658]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 6.55e-05\n",
      "Epoch 33 Train Loss = 0.5307, Accuracy = 82.46%, Test Accuracy = 75.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:01, 235.76batch/s, loss=0.525087]                              0.525087]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 5.88e-05\n",
      "Epoch 34 Train Loss = 0.5251, Accuracy = 82.68%, Test Accuracy = 75.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:01, 250.32batch/s, loss=0.519720]                              0.519720]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 5.23e-05\n",
      "Epoch 35 Train Loss = 0.5197, Accuracy = 83.01%, Test Accuracy = 75.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:02, 188.54batch/s, loss=0.515642]                              0.515642]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 4.61e-05\n",
      "Epoch 36 Train Loss = 0.5156, Accuracy = 83.13%, Test Accuracy = 75.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:01, 208.96batch/s, loss=0.511171]                              0.511171]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 4.03e-05\n",
      "Epoch 37 Train Loss = 0.5112, Accuracy = 83.28%, Test Accuracy = 75.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:01, 273.32batch/s, loss=0.508074]                              0.508074]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 3.47e-05\n",
      "Epoch 38 Train Loss = 0.5081, Accuracy = 83.44%, Test Accuracy = 75.67%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:01, 217.51batch/s, loss=0.504027]                              0.504027]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.96e-05\n",
      "Epoch 39 Train Loss = 0.5040, Accuracy = 83.68%, Test Accuracy = 75.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:01, 217.42batch/s, loss=0.501232]                              0.501232]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.48e-05\n",
      "Epoch 40 Train Loss = 0.5012, Accuracy = 83.73%, Test Accuracy = 75.71%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:01, 227.63batch/s, loss=0.498963]                              0.498963]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41, Current LR: 2.04e-05\n",
      "Epoch 41 Train Loss = 0.4990, Accuracy = 83.86%, Test Accuracy = 75.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:02, 199.53batch/s, loss=0.496574]                              0.496574]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42, Current LR: 1.64e-05\n",
      "Epoch 42 Train Loss = 0.4966, Accuracy = 83.93%, Test Accuracy = 76.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:01, 234.65batch/s, loss=0.494618]                              0.494618]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43, Current LR: 1.28e-05\n",
      "Epoch 43 Train Loss = 0.4946, Accuracy = 84.06%, Test Accuracy = 75.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:01, 228.41batch/s, loss=0.493155]                              0.493155]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44, Current LR: 9.74e-06\n",
      "Epoch 44 Train Loss = 0.4932, Accuracy = 84.05%, Test Accuracy = 76.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:01, 207.41batch/s, loss=0.491940]                              0.491940]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45, Current LR: 7.09e-06\n",
      "Epoch 45 Train Loss = 0.4919, Accuracy = 84.16%, Test Accuracy = 75.93%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:02, 194.97batch/s, loss=0.490700]                              0.490700]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46, Current LR: 4.91e-06\n",
      "Epoch 46 Train Loss = 0.4907, Accuracy = 84.21%, Test Accuracy = 75.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:01, 254.10batch/s, loss=0.490000]                              0.490000]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47, Current LR: 3.21e-06\n",
      "Epoch 47 Train Loss = 0.4900, Accuracy = 84.21%, Test Accuracy = 76.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:01, 210.87batch/s, loss=0.489252]                              0.489252]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48, Current LR: 1.98e-06\n",
      "Epoch 48 Train Loss = 0.4893, Accuracy = 84.23%, Test Accuracy = 76.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:01, 221.16batch/s, loss=0.488879]                              0.488879]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49, Current LR: 1.25e-06\n",
      "Epoch 49 Train Loss = 0.4889, Accuracy = 84.31%, Test Accuracy = 76.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:01, 221.78batch/s, loss=0.488580]                              0.488580]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50, Current LR: 1.00e-06\n",
      "Epoch 50 Train Loss = 0.4886, Accuracy = 84.26%, Test Accuracy = 75.99%\n",
      "2 end at 20250924-164201\n",
      "3 start at 20250924-164201\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:01, 291.08batch/s, loss=1.695389]                               1.695389]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.50e-04\n",
      "Epoch 1 Train Loss = 1.6954, Accuracy = 39.01%, Test Accuracy = 47.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:01, 202.68batch/s, loss=1.363827]                               1.363827]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.49e-04\n",
      "Epoch 2 Train Loss = 1.3638, Accuracy = 51.09%, Test Accuracy = 53.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:01, 234.58batch/s, loss=1.252182]                               1.252182]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.48e-04\n",
      "Epoch 3 Train Loss = 1.2522, Accuracy = 55.50%, Test Accuracy = 57.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:01, 205.60batch/s, loss=1.168202]                               1.168202]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.46e-04\n",
      "Epoch 4 Train Loss = 1.1682, Accuracy = 58.82%, Test Accuracy = 59.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:01, 237.27batch/s, loss=1.099726]                               1.099726]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.44e-04\n",
      "Epoch 5 Train Loss = 1.0997, Accuracy = 61.72%, Test Accuracy = 62.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:01, 226.35batch/s, loss=1.038570]                               1.038570]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.41e-04\n",
      "Epoch 6 Train Loss = 1.0386, Accuracy = 63.79%, Test Accuracy = 64.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:01, 226.64batch/s, loss=0.987753]                               0.987753]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.38e-04\n",
      "Epoch 7 Train Loss = 0.9878, Accuracy = 65.64%, Test Accuracy = 65.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:01, 235.25batch/s, loss=0.939456]                               0.939456]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.35e-04\n",
      "Epoch 8 Train Loss = 0.9395, Accuracy = 67.56%, Test Accuracy = 67.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:01, 219.20batch/s, loss=0.902971]                               0.902971]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.31e-04\n",
      "Epoch 9 Train Loss = 0.9030, Accuracy = 68.98%, Test Accuracy = 66.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:01, 237.50batch/s, loss=0.866163]                              0.866163]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.26e-04\n",
      "Epoch 10 Train Loss = 0.8662, Accuracy = 70.28%, Test Accuracy = 68.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:01, 254.92batch/s, loss=0.835754]                              0.835754]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.21e-04\n",
      "Epoch 11 Train Loss = 0.8358, Accuracy = 71.35%, Test Accuracy = 69.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:01, 200.44batch/s, loss=0.811102]                              0.811102]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.16e-04\n",
      "Epoch 12 Train Loss = 0.8111, Accuracy = 72.16%, Test Accuracy = 69.96%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:01, 205.88batch/s, loss=0.786931]                              0.786931]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.11e-04\n",
      "Epoch 13 Train Loss = 0.7869, Accuracy = 73.17%, Test Accuracy = 70.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:02, 189.23batch/s, loss=0.763215]                              0.763215]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.05e-04\n",
      "Epoch 14 Train Loss = 0.7632, Accuracy = 73.96%, Test Accuracy = 71.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:01, 259.48batch/s, loss=0.743954]                              0.743954]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 1.99e-04\n",
      "Epoch 15 Train Loss = 0.7440, Accuracy = 74.55%, Test Accuracy = 71.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:01, 226.58batch/s, loss=0.727085]                              0.727085]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 1.92e-04\n",
      "Epoch 16 Train Loss = 0.7271, Accuracy = 75.32%, Test Accuracy = 72.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:01, 207.95batch/s, loss=0.706355]                              0.706355]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 1.85e-04\n",
      "Epoch 17 Train Loss = 0.7064, Accuracy = 75.95%, Test Accuracy = 71.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:01, 222.13batch/s, loss=0.692356]                              0.692356]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 1.79e-04\n",
      "Epoch 18 Train Loss = 0.6924, Accuracy = 76.55%, Test Accuracy = 71.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:01, 207.59batch/s, loss=0.675266]                              0.675266]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 1.71e-04\n",
      "Epoch 19 Train Loss = 0.6753, Accuracy = 77.15%, Test Accuracy = 72.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:01, 240.04batch/s, loss=0.661537]                              0.661537]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 1.64e-04\n",
      "Epoch 20 Train Loss = 0.6615, Accuracy = 77.68%, Test Accuracy = 73.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:01, 230.94batch/s, loss=0.648716]                              0.648716]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 1.56e-04\n",
      "Epoch 21 Train Loss = 0.6487, Accuracy = 78.15%, Test Accuracy = 73.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:01, 203.27batch/s, loss=0.636417]                              0.636417]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 1.49e-04\n",
      "Epoch 22 Train Loss = 0.6364, Accuracy = 78.58%, Test Accuracy = 72.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:01, 260.95batch/s, loss=0.624625]                              0.624625]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 1.41e-04\n",
      "Epoch 23 Train Loss = 0.6246, Accuracy = 79.03%, Test Accuracy = 73.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:01, 236.07batch/s, loss=0.613609]                              0.613609]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 1.33e-04\n",
      "Epoch 24 Train Loss = 0.6136, Accuracy = 79.45%, Test Accuracy = 73.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:02, 186.69batch/s, loss=0.603913]                              0.603913]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 1.25e-04\n",
      "Epoch 25 Train Loss = 0.6039, Accuracy = 79.74%, Test Accuracy = 74.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:02, 184.49batch/s, loss=0.592741]                              0.592741]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 1.18e-04\n",
      "Epoch 26 Train Loss = 0.5927, Accuracy = 80.33%, Test Accuracy = 74.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:01, 255.56batch/s, loss=0.585582]                              0.585582]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 1.10e-04\n",
      "Epoch 27 Train Loss = 0.5856, Accuracy = 80.54%, Test Accuracy = 73.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:01, 203.28batch/s, loss=0.577731]                              0.577731]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 1.02e-04\n",
      "Epoch 28 Train Loss = 0.5777, Accuracy = 80.77%, Test Accuracy = 74.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:01, 255.50batch/s, loss=0.567680]                              0.567680]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 9.45e-05\n",
      "Epoch 29 Train Loss = 0.5677, Accuracy = 81.17%, Test Accuracy = 74.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:01, 204.75batch/s, loss=0.560035]                              0.560035]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 8.70e-05\n",
      "Epoch 30 Train Loss = 0.5600, Accuracy = 81.46%, Test Accuracy = 74.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:01, 229.59batch/s, loss=0.553765]                              0.553765]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 7.97e-05\n",
      "Epoch 31 Train Loss = 0.5538, Accuracy = 81.67%, Test Accuracy = 74.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:01, 213.88batch/s, loss=0.547787]                              0.547787]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 7.25e-05\n",
      "Epoch 32 Train Loss = 0.5478, Accuracy = 81.97%, Test Accuracy = 74.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:01, 245.78batch/s, loss=0.542127]                              0.542127]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 6.55e-05\n",
      "Epoch 33 Train Loss = 0.5421, Accuracy = 82.08%, Test Accuracy = 74.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:01, 204.18batch/s, loss=0.536675]                              0.536675]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 5.88e-05\n",
      "Epoch 34 Train Loss = 0.5367, Accuracy = 82.45%, Test Accuracy = 74.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:01, 201.40batch/s, loss=0.531149]                              0.531149]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 5.23e-05\n",
      "Epoch 35 Train Loss = 0.5311, Accuracy = 82.58%, Test Accuracy = 75.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:02, 192.09batch/s, loss=0.526666]                              0.526666]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 4.61e-05\n",
      "Epoch 36 Train Loss = 0.5267, Accuracy = 82.82%, Test Accuracy = 75.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:02, 189.80batch/s, loss=0.522500]                              0.522500]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 4.03e-05\n",
      "Epoch 37 Train Loss = 0.5225, Accuracy = 82.85%, Test Accuracy = 75.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:01, 220.84batch/s, loss=0.518723]                              0.518723]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 3.47e-05\n",
      "Epoch 38 Train Loss = 0.5187, Accuracy = 83.05%, Test Accuracy = 75.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:01, 202.70batch/s, loss=0.516479]                              0.516479]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.96e-05\n",
      "Epoch 39 Train Loss = 0.5165, Accuracy = 83.06%, Test Accuracy = 75.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:01, 210.66batch/s, loss=0.512439]                              0.512439]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.48e-05\n",
      "Epoch 40 Train Loss = 0.5124, Accuracy = 83.32%, Test Accuracy = 75.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:01, 209.38batch/s, loss=0.509766]                              0.509766]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41, Current LR: 2.04e-05\n",
      "Epoch 41 Train Loss = 0.5098, Accuracy = 83.41%, Test Accuracy = 75.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:01, 274.27batch/s, loss=0.507715]                              0.507715]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42, Current LR: 1.64e-05\n",
      "Epoch 42 Train Loss = 0.5077, Accuracy = 83.53%, Test Accuracy = 75.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:01, 218.14batch/s, loss=0.505747]                              0.505747]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43, Current LR: 1.28e-05\n",
      "Epoch 43 Train Loss = 0.5057, Accuracy = 83.62%, Test Accuracy = 75.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:01, 206.73batch/s, loss=0.504123]                              0.504123]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44, Current LR: 9.74e-06\n",
      "Epoch 44 Train Loss = 0.5041, Accuracy = 83.70%, Test Accuracy = 75.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:01, 222.83batch/s, loss=0.502748]                              0.502748]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45, Current LR: 7.09e-06\n",
      "Epoch 45 Train Loss = 0.5027, Accuracy = 83.70%, Test Accuracy = 75.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:01, 208.96batch/s, loss=0.501631]                              0.501631]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46, Current LR: 4.91e-06\n",
      "Epoch 46 Train Loss = 0.5016, Accuracy = 83.74%, Test Accuracy = 75.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:02, 196.47batch/s, loss=0.500888]                              0.500888]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47, Current LR: 3.21e-06\n",
      "Epoch 47 Train Loss = 0.5009, Accuracy = 83.80%, Test Accuracy = 75.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:02, 198.04batch/s, loss=0.500049]                              0.500049]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48, Current LR: 1.98e-06\n",
      "Epoch 48 Train Loss = 0.5000, Accuracy = 83.85%, Test Accuracy = 75.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:01, 201.16batch/s, loss=0.499764]                              0.499764]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49, Current LR: 1.25e-06\n",
      "Epoch 49 Train Loss = 0.4998, Accuracy = 83.82%, Test Accuracy = 75.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:01, 202.71batch/s, loss=0.499407]                              0.499407]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50, Current LR: 1.00e-06\n",
      "Epoch 50 Train Loss = 0.4994, Accuracy = 83.85%, Test Accuracy = 75.41%\n",
      "3 end at 20250924-164336\n",
      "4 start at 20250924-164336\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:02, 184.34batch/s, loss=1.712479]                               1.712479]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.50e-04\n",
      "Epoch 1 Train Loss = 1.7125, Accuracy = 38.42%, Test Accuracy = 47.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:01, 206.80batch/s, loss=1.385692]                               1.385692]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.49e-04\n",
      "Epoch 2 Train Loss = 1.3857, Accuracy = 50.19%, Test Accuracy = 53.41%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:02, 166.08batch/s, loss=1.265864]                               1.265864]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.48e-04\n",
      "Epoch 3 Train Loss = 1.2659, Accuracy = 55.20%, Test Accuracy = 55.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:02, 177.90batch/s, loss=1.179719]                               1.179719]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.46e-04\n",
      "Epoch 4 Train Loss = 1.1797, Accuracy = 58.62%, Test Accuracy = 58.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:01, 235.08batch/s, loss=1.107504]                               1.107504]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.44e-04\n",
      "Epoch 5 Train Loss = 1.1075, Accuracy = 61.25%, Test Accuracy = 62.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:02, 197.49batch/s, loss=1.048499]                               1.048499]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.41e-04\n",
      "Epoch 6 Train Loss = 1.0485, Accuracy = 63.54%, Test Accuracy = 63.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:01, 243.88batch/s, loss=0.998322]                               0.998322]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.38e-04\n",
      "Epoch 7 Train Loss = 0.9983, Accuracy = 65.35%, Test Accuracy = 65.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:01, 210.41batch/s, loss=0.951897]                               0.951897]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.35e-04\n",
      "Epoch 8 Train Loss = 0.9519, Accuracy = 66.84%, Test Accuracy = 66.46%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:01, 230.36batch/s, loss=0.914616]                               0.914616]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.31e-04\n",
      "Epoch 9 Train Loss = 0.9146, Accuracy = 68.38%, Test Accuracy = 67.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:01, 206.38batch/s, loss=0.878277]                              0.878277]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.26e-04\n",
      "Epoch 10 Train Loss = 0.8783, Accuracy = 69.61%, Test Accuracy = 67.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:01, 211.70batch/s, loss=0.848898]                              0.848898]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.21e-04\n",
      "Epoch 11 Train Loss = 0.8489, Accuracy = 70.65%, Test Accuracy = 68.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:02, 196.89batch/s, loss=0.819485]                              0.819485]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.16e-04\n",
      "Epoch 12 Train Loss = 0.8195, Accuracy = 71.85%, Test Accuracy = 68.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:02, 194.31batch/s, loss=0.798537]                              0.798537]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.11e-04\n",
      "Epoch 13 Train Loss = 0.7985, Accuracy = 72.48%, Test Accuracy = 70.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:01, 223.64batch/s, loss=0.775239]                              0.775239]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.05e-04\n",
      "Epoch 14 Train Loss = 0.7752, Accuracy = 73.35%, Test Accuracy = 70.43%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:01, 222.86batch/s, loss=0.755467]                              0.755467]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 1.99e-04\n",
      "Epoch 15 Train Loss = 0.7555, Accuracy = 74.09%, Test Accuracy = 71.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:02, 184.63batch/s, loss=0.735936]                              0.735936]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 1.92e-04\n",
      "Epoch 16 Train Loss = 0.7359, Accuracy = 75.06%, Test Accuracy = 71.57%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:01, 214.13batch/s, loss=0.720168]                              0.720168]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 1.85e-04\n",
      "Epoch 17 Train Loss = 0.7202, Accuracy = 75.35%, Test Accuracy = 72.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:01, 241.91batch/s, loss=0.703466]                              0.703466]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 1.79e-04\n",
      "Epoch 18 Train Loss = 0.7035, Accuracy = 76.00%, Test Accuracy = 71.46%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:01, 221.07batch/s, loss=0.689919]                              0.689919]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 1.71e-04\n",
      "Epoch 19 Train Loss = 0.6899, Accuracy = 76.56%, Test Accuracy = 72.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:02, 175.75batch/s, loss=0.675147]                              0.675147]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 1.64e-04\n",
      "Epoch 20 Train Loss = 0.6751, Accuracy = 77.01%, Test Accuracy = 71.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:01, 239.96batch/s, loss=0.661313]                              0.661313]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 1.56e-04\n",
      "Epoch 21 Train Loss = 0.6613, Accuracy = 77.48%, Test Accuracy = 73.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:01, 214.93batch/s, loss=0.649368]                              0.649368]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 1.49e-04\n",
      "Epoch 22 Train Loss = 0.6494, Accuracy = 78.08%, Test Accuracy = 73.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:01, 231.34batch/s, loss=0.636413]                              0.636413]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 1.41e-04\n",
      "Epoch 23 Train Loss = 0.6364, Accuracy = 78.50%, Test Accuracy = 73.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:02, 184.87batch/s, loss=0.626811]                              0.626811]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 1.33e-04\n",
      "Epoch 24 Train Loss = 0.6268, Accuracy = 78.86%, Test Accuracy = 73.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:02, 197.31batch/s, loss=0.615781]                              0.615781]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 1.25e-04\n",
      "Epoch 25 Train Loss = 0.6158, Accuracy = 79.36%, Test Accuracy = 74.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:01, 235.55batch/s, loss=0.607292]                              0.607292]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 1.18e-04\n",
      "Epoch 26 Train Loss = 0.6073, Accuracy = 79.54%, Test Accuracy = 73.39%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:01, 244.36batch/s, loss=0.598592]                              0.598592]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 1.10e-04\n",
      "Epoch 27 Train Loss = 0.5986, Accuracy = 79.88%, Test Accuracy = 74.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:02, 189.65batch/s, loss=0.592040]                              0.592040]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 1.02e-04\n",
      "Epoch 28 Train Loss = 0.5920, Accuracy = 80.18%, Test Accuracy = 74.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:01, 249.25batch/s, loss=0.584097]                              0.584097]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 9.45e-05\n",
      "Epoch 29 Train Loss = 0.5841, Accuracy = 80.50%, Test Accuracy = 74.60%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:01, 218.29batch/s, loss=0.575905]                              0.575905]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 8.70e-05\n",
      "Epoch 30 Train Loss = 0.5759, Accuracy = 80.77%, Test Accuracy = 74.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:01, 218.47batch/s, loss=0.568432]                              0.568432]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 7.97e-05\n",
      "Epoch 31 Train Loss = 0.5684, Accuracy = 81.20%, Test Accuracy = 74.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:01, 206.65batch/s, loss=0.562102]                              0.562102]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 7.25e-05\n",
      "Epoch 32 Train Loss = 0.5621, Accuracy = 81.26%, Test Accuracy = 74.86%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:02, 173.25batch/s, loss=0.556254]                              0.556254]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 6.55e-05\n",
      "Epoch 33 Train Loss = 0.5563, Accuracy = 81.47%, Test Accuracy = 74.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:02, 185.42batch/s, loss=0.551324]                              0.551324]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 5.88e-05\n",
      "Epoch 34 Train Loss = 0.5513, Accuracy = 81.74%, Test Accuracy = 74.93%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:01, 268.95batch/s, loss=0.546497]                              0.546497]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 5.23e-05\n",
      "Epoch 35 Train Loss = 0.5465, Accuracy = 81.96%, Test Accuracy = 74.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:01, 271.06batch/s, loss=0.542001]                              0.542001]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 4.61e-05\n",
      "Epoch 36 Train Loss = 0.5420, Accuracy = 82.16%, Test Accuracy = 75.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:02, 194.10batch/s, loss=0.537131]                              0.537131]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 4.03e-05\n",
      "Epoch 37 Train Loss = 0.5371, Accuracy = 82.30%, Test Accuracy = 75.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:02, 186.51batch/s, loss=0.534331]                              0.534331]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 3.47e-05\n",
      "Epoch 38 Train Loss = 0.5343, Accuracy = 82.33%, Test Accuracy = 75.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:02, 190.32batch/s, loss=0.531631]                              0.531631]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.96e-05\n",
      "Epoch 39 Train Loss = 0.5316, Accuracy = 82.47%, Test Accuracy = 75.52%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:01, 209.61batch/s, loss=0.528145]                              0.528145]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.48e-05\n",
      "Epoch 40 Train Loss = 0.5281, Accuracy = 82.65%, Test Accuracy = 75.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:02, 191.70batch/s, loss=0.525424]                              0.525424]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41, Current LR: 2.04e-05\n",
      "Epoch 41 Train Loss = 0.5254, Accuracy = 82.77%, Test Accuracy = 75.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:01, 200.60batch/s, loss=0.523424]                              0.523424]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42, Current LR: 1.64e-05\n",
      "Epoch 42 Train Loss = 0.5234, Accuracy = 82.85%, Test Accuracy = 75.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:02, 185.85batch/s, loss=0.521288]                              0.521288]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43, Current LR: 1.28e-05\n",
      "Epoch 43 Train Loss = 0.5213, Accuracy = 82.97%, Test Accuracy = 75.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:01, 235.08batch/s, loss=0.519539]                              0.519539]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44, Current LR: 9.74e-06\n",
      "Epoch 44 Train Loss = 0.5195, Accuracy = 83.00%, Test Accuracy = 75.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:01, 229.50batch/s, loss=0.518297]                              0.518297]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45, Current LR: 7.09e-06\n",
      "Epoch 45 Train Loss = 0.5183, Accuracy = 83.09%, Test Accuracy = 75.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:02, 180.12batch/s, loss=0.517217]                              0.517217]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46, Current LR: 4.91e-06\n",
      "Epoch 46 Train Loss = 0.5172, Accuracy = 83.23%, Test Accuracy = 75.39%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:01, 208.95batch/s, loss=0.516346]                              0.516346]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47, Current LR: 3.21e-06\n",
      "Epoch 47 Train Loss = 0.5163, Accuracy = 83.18%, Test Accuracy = 75.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:01, 219.55batch/s, loss=0.515781]                              0.515781]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48, Current LR: 1.98e-06\n",
      "Epoch 48 Train Loss = 0.5158, Accuracy = 83.23%, Test Accuracy = 75.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:01, 201.78batch/s, loss=0.515334]                              0.515334]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49, Current LR: 1.25e-06\n",
      "Epoch 49 Train Loss = 0.5153, Accuracy = 83.26%, Test Accuracy = 75.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:02, 199.86batch/s, loss=0.515065]                              0.515065]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50, Current LR: 1.00e-06\n",
      "Epoch 50 Train Loss = 0.5151, Accuracy = 83.25%, Test Accuracy = 75.36%\n",
      "4 end at 20250924-164514\n"
     ]
    }
   ],
   "source": [
    "\n",
    "num_epochs = 50\n",
    "multest = 5 #5\n",
    "fbsc_range = [0] # 0.01, 0.1, 1\n",
    "res = np.zeros((len(fbsc_range),multest,3,num_epochs))\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    for imul in range(multest):\n",
    "        current_time_tmp = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "        print(f\"{imul} start at {current_time_tmp}\")\n",
    "        model = aEP_CNN( chl=[32,64,128])\n",
    "\n",
    "        optimizer = torch.optim.AdamW(model.parameters(), lr=2.5e-4, weight_decay=2e-4)\n",
    "        scheduler = lr_scheduler.CosineAnnealingLR(optimizer, \n",
    "                                         T_max=num_epochs,  \n",
    "                                         eta_min=1e-6) \n",
    "\n",
    "        for epoch in range(num_epochs):\n",
    "            total_loss = 0\n",
    "            correct = 0\n",
    "            total = 0\n",
    "\n",
    "            random.shuffle(train_loader_gpu)\n",
    "            with tqdm(total=len(train_loader_gpu), desc=f\"Epoch {epoch + 1}/{num_epochs}:\", unit='batch', ncols=90, mininterval=1, colour='blue') as pbar:\n",
    "                for batch_idx, (data, target) in enumerate(train_loader_gpu):\n",
    "                    optimizer.zero_grad()\n",
    "                    preds = model.forward_BP(data)# eta=[0.015, 0.035, 0.15]\n",
    "                    loss = criterion(preds[-1], target)\n",
    "                    loss.backward()\n",
    "                    optimizer.step()\n",
    "                    total_loss += loss\n",
    "\n",
    "                    if batch_idx % 10 == 0: \n",
    "                        pbar.set_postfix({'loss': f'{total_loss/(batch_idx+1):.6f}'})  \n",
    "                        pbar.update(10)\n",
    "\n",
    "                    correct += (torch.argmax(preds[-1], dim=1) == target).sum().item()\n",
    "                    total += target.size(0)\n",
    "                    \n",
    "            scheduler.step()\n",
    "            current_lr = optimizer.param_groups[0]['lr']\n",
    "            print(f\"Epoch {epoch+1}, Current LR: {current_lr:.2e}\")\n",
    "\n",
    "            acc = correct / total\n",
    "            avg_loss = total_loss / len(train_loader_gpu)\n",
    "            res[ifbsc,imul,0,epoch]=(avg_loss)\n",
    "            res[ifbsc,imul,1,epoch]=(acc)\n",
    "\n",
    "            # Test\n",
    "            correct = 0\n",
    "            total = 0\n",
    "            with torch.no_grad():\n",
    "                for data, target in test_loader_gpu:\n",
    "                    preds = model.forward_BP(data)\n",
    "                    correct += (torch.argmax(preds[-1], dim=1) == target).sum().item()\n",
    "                    total += target.size(0)\n",
    "            test_acc = correct / total\n",
    "            res[ifbsc,imul,2,epoch]=(test_acc)\n",
    "\n",
    "            print(f\"Epoch {epoch+1} Train Loss = {avg_loss:.4f}, Accuracy = {acc*100:.2f}%, Test Accuracy = {test_acc*100:.2f}%\")\n",
    "        \n",
    "        current_time_tmp = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "        print(f\"{imul} end at {current_time_tmp}\")\n",
    "        \n",
    "res_BP = res\n",
    "current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "if fsave: \n",
    "    save_dict = {\n",
    "        \"res\": res\n",
    "}\n",
    "np.savez_compressed(res_path / f\"res_BP\",  **save_dict)\n",
    "     "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c4b2bf0e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t_train: 83.61%+-0.48% (83.11% 84.31%)\t test: 75.45%+-0.46% (74.85% 76.14%)\n",
      "\n",
      "Current Time: 20250924-164515\n"
     ]
    },
    {
     "data": {
      "image/png": "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8eH2U+u6xnjUNYPUqcaPH8+qVauYM2cOFosFi8XCokWLsFgsvPvuu2RlZeFyufjwww/59ttvueGGG0hJSSEmJoYBAwawYsWKKvs7vZvXYrHw97//nTFjxhAVFUWXLl146623gutP7+ZdtGgRycnJbNiwgd69exMTE8O1115Lbm5u8DM+n4977rmHhIQEkpKS+N3vfsdtt93G6NGjz/rfSkSkKahl2gjKvH4y/+vdWtbauf+z95vsu7fNGEGU88z/jHPmzOHrr7+mV69ezJgxA4CtW7cCcP/99/PnP/+ZTp06kZCQwP79+xk5ciQzZ84kIiKCF198kVGjRrFjxw46dOhQ63dMnz6dJ598kj/96U/MnTuXW2+9lT179tCqVasaty8tLeWNN95g0aJFOJ1Ofvazn3Hffffx8ssvA/DEE0/w8ssvs3DhQnr06MGcOXN44403uOqqqxpaTSIiTUot0xYiPj4ep9NJVFQUqamppKamYrPZAJgxYwbDhg3j4osvJikpiT59+vDLX/6S3r1706VLF2bOnEmnTp2qtDRrMn78eG655RY6d+7MY489RklJCZ999lmt23u9XiZOnEj//v3p168fd999N++9915w/dy5c5k2bRpjxoyhe/fuzJs3j4SEhEapDxGRxqSWaSOIdNjYNmNEteVer5d3313OiBHDm+wGvZEOW8j7yMrKqvK+pKSE6dOn869//YuDBw/i8/koKyurcgefmlxyySXB19HR0cTGxnL48OFat4+KiiItLS34Pi0tLbj9iRMnOHToEJdddllwvc1mo3///gQCgQYdn4hIU1OYNgKLxVJjV6vXYuCyQZTTjsNx/lb16aNy/9//+3+8++67/PnPf6Zz585ERkYyduxYPB5Pnfs5/Q8Gi8VSZ/DVtP3p54BPv7t9fc8Ri4icS+rmbUGcTid+v/+M23344YeMHz+eMWPG0Lt3b1JTU9m9e3fTF/AU8fHxpKSkVOkm9vv9bNiw4ZyWQ0SkPs7f5pI0uo4dO7J27Vp2795NTExMra3Gzp078/rrrzNq1CgsFgsPP/xwWLpWf/3rXzNr1iw6d+5M9+7dmTt3LseOHavWWhURCTe1TFuQ++67D5vNRmZmJsnJybWeA33mmWdITExk8ODBjBo1ihEjRtCvX79zXFr43e9+xy233MLPf/5zsrOziYmJYcSIEURERJzz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n//8J3379g0ut1gspKamNmnZRUREKoUtTD0eD+vXr+eBBx6osnz48OF88skn9dpHIBCgqKiIVq1aVVleXFxMeno6fr+fSy+9lD/84Q9VwvZ0brcbt9sdfF9YWAiA1+vF6/XW95CqqfxsKPtozlQ/dVP91E31UzvVTd0aUj/1rcOwhWl+fj5+v5+UlJQqy1NSUsjLy6vXPp566ilKSkq46aabgsu6d+/OokWL6N27N4WFhcyZM4chQ4awadMmunTpUuN+Zs2axfTp06stX758OVFRUQ04qprl5OSEvI/mTPVTN9VP3VQ/tVPd1K0+9VNaWlqvfYW1mxfMLtlTGYZRbVlNXn31VR599FHefPNN2rRpE1w+aNAgBg0aFHw/ZMgQ+vXrx9y5c3n22Wdr3Ne0adOYOnVq8H1hYSHt27dn+PDhxMXFNfSQgrxeLzk5OQwbNgyHw3HW+2muVD91U/3UTfVTO9VN3RpSP5U9lWcStjBt3bo1NputWiv08OHD1Vqrp1uyZAkTJkzgtdde45prrqlzW6vVyoABA9i5c2et27hcLlwuV7XlDoejUX4QG2s/zZXqp26qn7qpfmqnuqlbfeqnvvUXttG8TqeT/v37V2tm5+TkMHjw4Fo/9+qrrzJ+/HheeeUVrr/++jN+j2EYbNy4kbS0tJDLLCIiUpOwdvNOnTqVcePGkZWVRXZ2Ns8//zx79+5l4sSJgNn9euDAAV566SXADNKf//znzJkzh0GDBgVbtZGRkcTHxwMwffp0Bg0aRJcuXSgsLOTZZ59l48aN/OUvfwnPQYqISLMX1jC9+eabOXr0KDNmzCA3N5devXrx9ttvk56eDkBubm6Va07/9re/4fP5mDx5MpMnTw4uv+2221i0aBEAx48f56677iIvL4/4+Hj69u3L6tWrueyyy87psYmISMsR9gFIkyZNYtKkSTWuqwzISitXrjzj/p555hmeeeaZRiiZiIhI/YR9OkEREZELncJUREQkRApTERGREClMRUREQqQwFRERCZHCVEREJEQKUxERkRApTEVEREKkMBUREQmRwlRERCREClMREZEQKUxFRERCpDAVEREJkcJUREQkRApTERGREClMRUREQqQwFRERCZHCVEREJEQKUxERkRApTEVEREKkMBUREQmRwlRERCREClMREZEQKUxFRERCpDAVEREJkcJUREQkRApTERGREClMRUREQqQwFRERCZHCVEREJEQKUxERkRApTEVEREKkMBUREQmRwlRERCREClMREZEQKUxFRERCpDAVEREJkcJUREQkRApTERGREClMRUREQqQwFRERCZHCVEREJEQKUxERkRApTEVEREKkMBUREQmRwlRERCREClMREZEQKUxFRERCpDAVEREJkcJUREQkRApTERGREClMRUREQqQwFRERCZHCVEREJEQKUxERkRApTEVEREKkMBUREQmRwlRERCREClMREZEQKUxFRERCpDAVEREJkcJUREQkRApTERGREClMRUREQqQwFRERCZHCVEREJERhD9PnnnuOjIwMIiIi6N+/Px9++GGd269atYr+/fsTERFBp06d+Otf/1ptm6VLl5KZmYnL5SIzM5Nly5Y1VfFFRETCG6ZLlixhypQpPPjgg2zYsIHLL7+c6667jr1799a4/a5duxg5ciSXX345GzZs4Pe//z333HMPS5cuDW6zZs0abr75ZsaNG8emTZsYN24cN910E2vXrj1XhyUiIi1MWMP06aefZsKECdxxxx306NGD2bNn0759e+bPn1/j9n/961/p0KEDs2fPpkePHtxxxx3cfvvt/PnPfw5uM3v2bIYNG8a0adPo3r0706ZN4+qrr2b27Nnn6KhERKSlsYfriz0eD+vXr+eBBx6osnz48OF88sknNX5mzZo1DB8+vMqyESNGsGDBArxeLw6HgzVr1vCb3/ym2jZ1hanb7cbtdgffnzhxAoCCggK8Xm9DDqsKr9dLaWkpR48exeFwnPV+mivVT91UP3VT/dROdVO3htRPUVERAIZh1Lld2MI0Pz8fv99PSkpKleUpKSnk5eXV+Jm8vLwat/f5fOTn55OWllbrNrXtE2DWrFlMnz692vKMjIz6Ho6IiDRjRUVFxMfH17o+bGFayWKxVHlvGEa1ZWfa/vTlDd3ntGnTmDp1avB9IBCgoKCApKSkOj93JoWFhbRv3559+/YRFxd31vtprlQ/dVP91E31UzvVTd0aUj+GYVBUVETbtm3r3C5sYdq6dWtsNlu1FuPhw4ertSwrpaam1ri93W4nKSmpzm1q2yeAy+XC5XJVWZaQkFDfQzmjuLg4/UDXQfVTN9VP3VQ/tVPd1K2+9VNXi7RS2AYgOZ1O+vfvT05OTpXlOTk5DB48uMbPZGdnV9t+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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    testacctt = np.max(res[ifbsc,:,2,:], axis= -1)\n",
    "\n",
    "    trainacctt = np.max(res[ifbsc,:,1,:], axis= -1)\n",
    "\n",
    "    print(f'\\t_'\n",
    "        f\"train: {np.mean(trainacctt) * 100:.2f}%+-{np.std(trainacctt, ddof=1)*100:.2f}% ({np.min(trainacctt) * 100:.2f}% {np.max(trainacctt) * 100:.2f}%)\"\n",
    "        f\"\\t test: {np.mean(testacctt) * 100:.2f}%+-{np.std(testacctt, ddof=1)*100:.2f}% ({np.min(testacctt) * 100:.2f}% {np.max(testacctt) * 100:.2f}%)\\n\")\n",
    "\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    plt.figure(figsize=(5, 4))\n",
    "    tt = res[ifbsc,:,1,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'training')  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    tt = res[ifbsc,:,2,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'testing')  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    if np.min(tt)<0.8:\n",
    "        plt.ylim([0.0, 1.0])\n",
    "        plt.yticks(np.arange(0.0,1.01,0.25))\n",
    "    else:\n",
    "        plt.ylim([0.9, 1.0])\n",
    "        plt.yticks(np.arange(0.9,1.01,0.02))\n",
    "    plt.grid()\n",
    "    plt.title(f\"BP\")\n",
    "    plt.xlabel(f'Epoch')\n",
    "    plt.ylabel('Accuracy')\n",
    "    plt.legend(frameon=False, fancybox=False, shadow=False)\n",
    "\n",
    "    current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "    print(f'Current Time: {current_time}')\n",
    "    plt.savefig(res_path /f\"BP_cnn_MNIST_maxacc{np.max(tt)}-fbsc{fbsc_range[ifbsc]}-{current_time}.svg\", format=\"svg\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1fab32e2",
   "metadata": {},
   "source": [
    "### EP conv with weak feedback"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "aa37777e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 start at 20250924-164515\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:25, 15.58batch/s, loss=1.707588]                                1.707588]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 1.7076, Accuracy = 38.52%, Test Accuracy = 47.57%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:25, 15.76batch/s, loss=1.388959]                                1.388959]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 1.3890, Accuracy = 50.45%, Test Accuracy = 51.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:25, 15.57batch/s, loss=1.278278]                                1.278278]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 1.2783, Accuracy = 54.84%, Test Accuracy = 56.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:25, 15.75batch/s, loss=1.192730]                                1.192730]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 1.1927, Accuracy = 58.16%, Test Accuracy = 57.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:25, 15.79batch/s, loss=1.123274]                                1.123274]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 1.1233, Accuracy = 60.75%, Test Accuracy = 60.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:25, 15.75batch/s, loss=1.059073]                                1.059073]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 1.0591, Accuracy = 63.04%, Test Accuracy = 63.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:25, 15.88batch/s, loss=1.004009]                                1.004009]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 1.0040, Accuracy = 65.01%, Test Accuracy = 64.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:25, 15.79batch/s, loss=0.965686]                                0.965686]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.9657, Accuracy = 66.27%, Test Accuracy = 65.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:25, 15.65batch/s, loss=0.923676]                                0.923676]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.9237, Accuracy = 67.93%, Test Accuracy = 67.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:26, 15.38batch/s, loss=0.893528]                               0.893528]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.8935, Accuracy = 68.84%, Test Accuracy = 68.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:26, 15.30batch/s, loss=0.862469]                               0.862469]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.8625, Accuracy = 70.10%, Test Accuracy = 68.41%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:25, 15.71batch/s, loss=0.836553]                               0.836553]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.8366, Accuracy = 71.06%, Test Accuracy = 69.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:25, 15.59batch/s, loss=0.814099]                               0.814099]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.8141, Accuracy = 71.97%, Test Accuracy = 70.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:25, 15.52batch/s, loss=0.798884]                               0.798884]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.7989, Accuracy = 72.35%, Test Accuracy = 70.53%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:25, 15.45batch/s, loss=0.778698]                               0.778698]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.7787, Accuracy = 73.12%, Test Accuracy = 70.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:26, 15.34batch/s, loss=0.762440]                               0.762440]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.7624, Accuracy = 73.85%, Test Accuracy = 71.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:25, 15.43batch/s, loss=0.744785]                               0.744785]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.7448, Accuracy = 74.39%, Test Accuracy = 71.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:25, 15.60batch/s, loss=0.730241]                               0.730241]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.7302, Accuracy = 74.79%, Test Accuracy = 71.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:26, 15.34batch/s, loss=0.716864]                               0.716864]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.7169, Accuracy = 75.38%, Test Accuracy = 72.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:26, 15.34batch/s, loss=0.704434]                               0.704434]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.7044, Accuracy = 75.63%, Test Accuracy = 73.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:25, 15.48batch/s, loss=0.691785]                               0.691785]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.6918, Accuracy = 76.36%, Test Accuracy = 72.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:25, 15.62batch/s, loss=0.682276]                               0.682276]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.6823, Accuracy = 76.66%, Test Accuracy = 73.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:25, 15.69batch/s, loss=0.669456]                               0.669456]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.6695, Accuracy = 77.02%, Test Accuracy = 73.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:25, 15.41batch/s, loss=0.659810]                               0.659810]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.6598, Accuracy = 77.48%, Test Accuracy = 74.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:25, 15.86batch/s, loss=0.650262]                               0.650262]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.6503, Accuracy = 77.80%, Test Accuracy = 73.90%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:25, 15.71batch/s, loss=0.642871]                               0.642871]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.6429, Accuracy = 77.91%, Test Accuracy = 74.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:25, 15.74batch/s, loss=0.635067]                               0.635067]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.6351, Accuracy = 78.31%, Test Accuracy = 74.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:25, 15.65batch/s, loss=0.627516]                               0.627516]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.6275, Accuracy = 78.50%, Test Accuracy = 73.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:25, 15.48batch/s, loss=0.620839]                               0.620839]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.6208, Accuracy = 78.81%, Test Accuracy = 74.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:25, 15.85batch/s, loss=0.614677]                               0.614677]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.6147, Accuracy = 79.26%, Test Accuracy = 74.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:25, 15.59batch/s, loss=0.608324]                               0.608324]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.6083, Accuracy = 79.30%, Test Accuracy = 74.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:25, 15.53batch/s, loss=0.602377]                               0.602377]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.6024, Accuracy = 79.57%, Test Accuracy = 74.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:25, 15.56batch/s, loss=0.598047]                               0.598047]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.5980, Accuracy = 79.73%, Test Accuracy = 74.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:25, 15.94batch/s, loss=0.591799]                               0.591799]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.5918, Accuracy = 79.95%, Test Accuracy = 74.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:25, 15.90batch/s, loss=0.588188]                               0.588188]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.5882, Accuracy = 80.22%, Test Accuracy = 75.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:25, 15.80batch/s, loss=0.585119]                               0.585119]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.5851, Accuracy = 80.23%, Test Accuracy = 75.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:25, 15.82batch/s, loss=0.580297]                               0.580297]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.5803, Accuracy = 80.37%, Test Accuracy = 75.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:25, 15.67batch/s, loss=0.578036]                               0.578036]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.5780, Accuracy = 80.48%, Test Accuracy = 75.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:25, 15.89batch/s, loss=0.574122]                               0.574122]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.5741, Accuracy = 80.74%, Test Accuracy = 75.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:24, 16.02batch/s, loss=0.571949]                               0.571949]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.5719, Accuracy = 80.73%, Test Accuracy = 75.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:25, 15.74batch/s, loss=0.569791]                               0.569791]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 Train Loss = 0.5698, Accuracy = 80.79%, Test Accuracy = 75.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:25, 15.86batch/s, loss=0.567610]                               0.567610]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 Train Loss = 0.5676, Accuracy = 80.85%, Test Accuracy = 75.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:25, 15.57batch/s, loss=0.565873]                               0.565873]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 Train Loss = 0.5659, Accuracy = 81.02%, Test Accuracy = 75.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:25, 15.90batch/s, loss=0.564256]                               0.564256]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 Train Loss = 0.5643, Accuracy = 81.14%, Test Accuracy = 75.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:25, 15.78batch/s, loss=0.563013]                               0.563013]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 Train Loss = 0.5630, Accuracy = 81.10%, Test Accuracy = 75.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:24, 16.07batch/s, loss=0.561984]                               0.561984]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 Train Loss = 0.5620, Accuracy = 81.15%, Test Accuracy = 75.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:25, 15.88batch/s, loss=0.561220]                               0.561220]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 Train Loss = 0.5612, Accuracy = 81.23%, Test Accuracy = 75.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:25, 15.54batch/s, loss=0.560392]                               0.560392]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 Train Loss = 0.5604, Accuracy = 81.27%, Test Accuracy = 75.71%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:25, 15.82batch/s, loss=0.559964]                               0.559964]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 Train Loss = 0.5600, Accuracy = 81.27%, Test Accuracy = 75.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:25, 15.54batch/s, loss=0.559723]                               0.559723]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 Train Loss = 0.5597, Accuracy = 81.25%, Test Accuracy = 75.74%\n",
      "0-0 end at 20250924-170912\n",
      "0 start at 20250924-170912\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:25, 15.65batch/s, loss=1.710356]                                1.710356]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 1.7104, Accuracy = 38.29%, Test Accuracy = 47.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:25, 15.87batch/s, loss=1.403055]                                1.403055]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 1.4031, Accuracy = 49.68%, Test Accuracy = 51.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:25, 15.84batch/s, loss=1.288142]                                1.288142]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 1.2881, Accuracy = 54.37%, Test Accuracy = 54.74%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:25, 15.50batch/s, loss=1.197061]                                1.197061]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 1.1971, Accuracy = 57.83%, Test Accuracy = 58.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:25, 15.61batch/s, loss=1.124065]                                1.124065]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 1.1241, Accuracy = 60.63%, Test Accuracy = 60.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:25, 15.61batch/s, loss=1.058616]                                1.058616]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 1.0586, Accuracy = 62.97%, Test Accuracy = 63.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:25, 15.87batch/s, loss=1.005363]                                1.005363]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 1.0054, Accuracy = 64.85%, Test Accuracy = 65.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:25, 15.63batch/s, loss=0.964657]                                0.964657]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.9647, Accuracy = 66.47%, Test Accuracy = 66.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:25, 15.83batch/s, loss=0.930017]                                0.930017]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.9300, Accuracy = 67.54%, Test Accuracy = 67.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:25, 15.50batch/s, loss=0.899693]                               0.899693]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.8997, Accuracy = 68.92%, Test Accuracy = 67.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:25, 15.88batch/s, loss=0.873714]                               0.873714]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.8737, Accuracy = 69.97%, Test Accuracy = 68.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:25, 15.90batch/s, loss=0.851104]                               0.851104]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.8511, Accuracy = 70.63%, Test Accuracy = 68.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:25, 15.56batch/s, loss=0.829969]                               0.829969]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.8300, Accuracy = 71.49%, Test Accuracy = 69.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:25, 15.72batch/s, loss=0.810478]                               0.810478]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.8105, Accuracy = 72.17%, Test Accuracy = 69.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:25, 15.67batch/s, loss=0.793633]                               0.793633]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.7936, Accuracy = 72.84%, Test Accuracy = 70.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:25, 15.95batch/s, loss=0.776264]                               0.776264]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.7763, Accuracy = 73.45%, Test Accuracy = 70.53%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:25, 15.60batch/s, loss=0.760117]                               0.760117]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.7601, Accuracy = 74.02%, Test Accuracy = 71.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:25, 15.71batch/s, loss=0.747741]                               0.747741]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.7477, Accuracy = 74.45%, Test Accuracy = 71.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:25, 15.59batch/s, loss=0.733547]                               0.733547]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.7335, Accuracy = 74.91%, Test Accuracy = 71.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:25, 15.56batch/s, loss=0.720774]                               0.720774]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.7208, Accuracy = 75.30%, Test Accuracy = 71.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:25, 15.76batch/s, loss=0.707714]                               0.707714]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.7077, Accuracy = 75.80%, Test Accuracy = 72.43%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:25, 15.42batch/s, loss=0.698699]                               0.698699]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.6987, Accuracy = 76.20%, Test Accuracy = 71.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:25, 15.76batch/s, loss=0.687908]                               0.687908]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.6879, Accuracy = 76.42%, Test Accuracy = 71.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:25, 15.68batch/s, loss=0.678915]                               0.678915]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.6789, Accuracy = 76.87%, Test Accuracy = 72.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:25, 15.50batch/s, loss=0.671792]                               0.671792]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.6718, Accuracy = 77.08%, Test Accuracy = 72.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:25, 15.91batch/s, loss=0.661250]                               0.661250]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.6613, Accuracy = 77.45%, Test Accuracy = 72.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:25, 15.87batch/s, loss=0.651170]                               0.651170]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.6512, Accuracy = 77.90%, Test Accuracy = 72.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:25, 15.84batch/s, loss=0.645668]                               0.645668]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.6457, Accuracy = 77.95%, Test Accuracy = 73.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:25, 15.95batch/s, loss=0.639704]                               0.639704]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.6397, Accuracy = 78.22%, Test Accuracy = 73.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:25, 15.89batch/s, loss=0.633069]                               0.633069]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.6331, Accuracy = 78.46%, Test Accuracy = 73.75%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:24, 16.01batch/s, loss=0.626604]                               0.626604]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.6266, Accuracy = 78.71%, Test Accuracy = 73.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:25, 15.86batch/s, loss=0.619912]                               0.619912]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.6199, Accuracy = 79.08%, Test Accuracy = 73.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:25, 15.67batch/s, loss=0.614486]                               0.614486]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.6145, Accuracy = 79.31%, Test Accuracy = 73.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:25, 15.77batch/s, loss=0.610172]                               0.610172]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.6102, Accuracy = 79.29%, Test Accuracy = 73.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:25, 15.82batch/s, loss=0.606050]                               0.606050]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.6060, Accuracy = 79.42%, Test Accuracy = 73.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:25, 15.74batch/s, loss=0.601529]                               0.601529]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.6015, Accuracy = 79.64%, Test Accuracy = 73.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:25, 15.78batch/s, loss=0.597303]                               0.597303]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.5973, Accuracy = 79.87%, Test Accuracy = 73.67%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:25, 15.97batch/s, loss=0.594209]                               0.594209]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.5942, Accuracy = 79.89%, Test Accuracy = 74.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:25, 15.93batch/s, loss=0.591062]                               0.591062]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.5911, Accuracy = 80.14%, Test Accuracy = 74.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:25, 15.98batch/s, loss=0.588648]                               0.588648]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.5886, Accuracy = 80.24%, Test Accuracy = 74.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:25, 15.98batch/s, loss=0.586691]                               0.586691]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 Train Loss = 0.5867, Accuracy = 80.22%, Test Accuracy = 74.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:25, 15.82batch/s, loss=0.584370]                               0.584370]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 Train Loss = 0.5844, Accuracy = 80.45%, Test Accuracy = 74.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:25, 15.64batch/s, loss=0.582435]                               0.582435]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 Train Loss = 0.5824, Accuracy = 80.43%, Test Accuracy = 74.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:25, 15.77batch/s, loss=0.581193]                               0.581193]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 Train Loss = 0.5812, Accuracy = 80.57%, Test Accuracy = 74.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:25, 15.78batch/s, loss=0.579523]                               0.579523]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 Train Loss = 0.5795, Accuracy = 80.61%, Test Accuracy = 74.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:25, 15.92batch/s, loss=0.578686]                               0.578686]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 Train Loss = 0.5787, Accuracy = 80.64%, Test Accuracy = 74.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:25, 15.83batch/s, loss=0.577781]                               0.577781]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 Train Loss = 0.5778, Accuracy = 80.62%, Test Accuracy = 74.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:25, 15.88batch/s, loss=0.577339]                               0.577339]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 Train Loss = 0.5773, Accuracy = 80.66%, Test Accuracy = 74.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:25, 15.88batch/s, loss=0.576889]                               0.576889]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 Train Loss = 0.5769, Accuracy = 80.68%, Test Accuracy = 74.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:25, 15.83batch/s, loss=0.576619]                               0.576619]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 Train Loss = 0.5766, Accuracy = 80.75%, Test Accuracy = 74.35%\n",
      "0-1 end at 20250924-173301\n",
      "0 start at 20250924-173301\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:25, 15.74batch/s, loss=1.727059]                                1.727059]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 1.7271, Accuracy = 37.70%, Test Accuracy = 47.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:25, 15.78batch/s, loss=1.398844]                                1.398844]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 1.3988, Accuracy = 50.08%, Test Accuracy = 53.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:25, 15.57batch/s, loss=1.282161]                                1.282161]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 1.2822, Accuracy = 54.55%, Test Accuracy = 56.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:25, 15.57batch/s, loss=1.192193]                                1.192193]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 1.1922, Accuracy = 58.15%, Test Accuracy = 59.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:25, 15.57batch/s, loss=1.120263]                                1.120263]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 1.1203, Accuracy = 60.85%, Test Accuracy = 61.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:25, 15.89batch/s, loss=1.061269]                                1.061269]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 1.0613, Accuracy = 63.03%, Test Accuracy = 61.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:25, 15.59batch/s, loss=1.011953]                                1.011953]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 1.0120, Accuracy = 64.87%, Test Accuracy = 63.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:25, 15.87batch/s, loss=0.966681]                                0.966681]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.9667, Accuracy = 66.65%, Test Accuracy = 65.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:25, 15.73batch/s, loss=0.929761]                                0.929761]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.9298, Accuracy = 67.89%, Test Accuracy = 65.57%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:25, 15.46batch/s, loss=0.899303]                               0.899303]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.8993, Accuracy = 68.88%, Test Accuracy = 67.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:25, 15.60batch/s, loss=0.874636]                               0.874636]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.8746, Accuracy = 69.86%, Test Accuracy = 69.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:26, 15.04batch/s, loss=0.848363]                               0.848363]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.8484, Accuracy = 70.76%, Test Accuracy = 69.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:25, 15.55batch/s, loss=0.824574]                               0.824574]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.8246, Accuracy = 71.80%, Test Accuracy = 70.40%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:26, 15.27batch/s, loss=0.807609]                               0.807609]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.8076, Accuracy = 72.27%, Test Accuracy = 70.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:25, 15.84batch/s, loss=0.791804]                               0.791804]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.7918, Accuracy = 72.78%, Test Accuracy = 70.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:25, 15.66batch/s, loss=0.777055]                               0.777055]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.7771, Accuracy = 73.32%, Test Accuracy = 71.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:25, 15.64batch/s, loss=0.759156]                               0.759156]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.7592, Accuracy = 73.94%, Test Accuracy = 71.71%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:25, 15.55batch/s, loss=0.745917]                               0.745917]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.7459, Accuracy = 74.55%, Test Accuracy = 71.42%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:25, 15.79batch/s, loss=0.730553]                               0.730553]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.7306, Accuracy = 75.17%, Test Accuracy = 70.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:25, 15.54batch/s, loss=0.719352]                               0.719352]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.7194, Accuracy = 75.45%, Test Accuracy = 70.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:25, 15.75batch/s, loss=0.708452]                               0.708452]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.7085, Accuracy = 75.83%, Test Accuracy = 72.90%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:25, 15.96batch/s, loss=0.696222]                               0.696222]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.6962, Accuracy = 76.16%, Test Accuracy = 72.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:25, 15.75batch/s, loss=0.686977]                               0.686977]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.6870, Accuracy = 76.47%, Test Accuracy = 73.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:25, 15.62batch/s, loss=0.677106]                               0.677106]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.6771, Accuracy = 77.00%, Test Accuracy = 73.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:25, 15.83batch/s, loss=0.667567]                               0.667567]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.6676, Accuracy = 77.27%, Test Accuracy = 72.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:25, 15.77batch/s, loss=0.659620]                               0.659620]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.6596, Accuracy = 77.71%, Test Accuracy = 73.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:25, 15.41batch/s, loss=0.651246]                               0.651246]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.6512, Accuracy = 77.85%, Test Accuracy = 73.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:25, 15.53batch/s, loss=0.644822]                               0.644822]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.6448, Accuracy = 78.00%, Test Accuracy = 73.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:25, 15.58batch/s, loss=0.637316]                               0.637316]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.6373, Accuracy = 78.29%, Test Accuracy = 73.46%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:25, 15.56batch/s, loss=0.633262]                               0.633262]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.6333, Accuracy = 78.49%, Test Accuracy = 73.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:25, 15.72batch/s, loss=0.628775]                               0.628775]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.6288, Accuracy = 78.67%, Test Accuracy = 73.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:25, 15.76batch/s, loss=0.623092]                               0.623092]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.6231, Accuracy = 78.83%, Test Accuracy = 74.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:25, 15.54batch/s, loss=0.618069]                               0.618069]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.6181, Accuracy = 79.03%, Test Accuracy = 74.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:25, 15.71batch/s, loss=0.615021]                               0.615021]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.6150, Accuracy = 79.14%, Test Accuracy = 74.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:25, 15.50batch/s, loss=0.610418]                               0.610418]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.6104, Accuracy = 79.38%, Test Accuracy = 74.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:25, 15.56batch/s, loss=0.606405]                               0.606405]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.6064, Accuracy = 79.52%, Test Accuracy = 74.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:25, 15.60batch/s, loss=0.603234]                               0.603234]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.6032, Accuracy = 79.60%, Test Accuracy = 74.46%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:26, 15.36batch/s, loss=0.598515]                               0.598515]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.5985, Accuracy = 79.78%, Test Accuracy = 74.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:25, 15.89batch/s, loss=0.595461]                               0.595461]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.5955, Accuracy = 79.82%, Test Accuracy = 74.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:25, 15.49batch/s, loss=0.592731]                               0.592731]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.5927, Accuracy = 80.09%, Test Accuracy = 74.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:25, 15.53batch/s, loss=0.590479]                               0.590479]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 Train Loss = 0.5905, Accuracy = 80.15%, Test Accuracy = 74.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:25, 15.75batch/s, loss=0.588052]                               0.588052]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 Train Loss = 0.5881, Accuracy = 80.21%, Test Accuracy = 74.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:25, 15.57batch/s, loss=0.586474]                               0.586474]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 Train Loss = 0.5865, Accuracy = 80.27%, Test Accuracy = 74.83%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:26, 15.17batch/s, loss=0.585229]                               0.585229]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 Train Loss = 0.5852, Accuracy = 80.30%, Test Accuracy = 74.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:26, 15.28batch/s, loss=0.583865]                               0.583865]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 Train Loss = 0.5839, Accuracy = 80.22%, Test Accuracy = 74.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:25, 15.54batch/s, loss=0.582746]                               0.582746]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 Train Loss = 0.5827, Accuracy = 80.38%, Test Accuracy = 74.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:26, 15.06batch/s, loss=0.582011]                               0.582011]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 Train Loss = 0.5820, Accuracy = 80.38%, Test Accuracy = 74.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:26, 15.26batch/s, loss=0.581601]                               0.581601]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 Train Loss = 0.5816, Accuracy = 80.41%, Test Accuracy = 74.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:25, 15.57batch/s, loss=0.580997]                               0.580997]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 Train Loss = 0.5810, Accuracy = 80.43%, Test Accuracy = 74.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:26, 15.35batch/s, loss=0.580700]                               0.580700]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 Train Loss = 0.5807, Accuracy = 80.40%, Test Accuracy = 74.84%\n",
      "0-2 end at 20250924-175705\n",
      "0 start at 20250924-175705\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:25, 15.55batch/s, loss=1.725832]                                1.725832]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 1.7258, Accuracy = 37.78%, Test Accuracy = 47.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:25, 15.57batch/s, loss=1.404613]                                1.404613]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 1.4046, Accuracy = 49.74%, Test Accuracy = 52.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:26, 15.17batch/s, loss=1.295872]                                1.295872]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 1.2959, Accuracy = 53.83%, Test Accuracy = 56.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:25, 15.69batch/s, loss=1.211673]                                1.211673]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 1.2117, Accuracy = 57.23%, Test Accuracy = 58.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:25, 15.91batch/s, loss=1.140069]                                1.140069]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 1.1401, Accuracy = 59.80%, Test Accuracy = 60.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:25, 15.57batch/s, loss=1.073785]                                1.073785]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 1.0738, Accuracy = 62.59%, Test Accuracy = 63.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:25, 15.55batch/s, loss=1.018474]                                1.018474]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 1.0185, Accuracy = 64.48%, Test Accuracy = 65.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:25, 15.69batch/s, loss=0.974401]                                0.974401]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.9744, Accuracy = 66.12%, Test Accuracy = 66.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:25, 15.61batch/s, loss=0.936787]                                0.936787]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.9368, Accuracy = 67.52%, Test Accuracy = 67.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:25, 15.69batch/s, loss=0.903646]                               0.903646]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.9036, Accuracy = 68.58%, Test Accuracy = 66.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:25, 15.50batch/s, loss=0.878149]                               0.878149]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.8781, Accuracy = 69.56%, Test Accuracy = 69.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:25, 15.66batch/s, loss=0.847609]                               0.847609]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.8476, Accuracy = 70.58%, Test Accuracy = 69.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:25, 15.78batch/s, loss=0.828939]                               0.828939]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.8289, Accuracy = 71.28%, Test Accuracy = 69.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:25, 15.74batch/s, loss=0.808516]                               0.808516]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.8085, Accuracy = 72.03%, Test Accuracy = 70.71%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:25, 15.49batch/s, loss=0.790844]                               0.790844]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.7908, Accuracy = 72.70%, Test Accuracy = 71.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:25, 15.48batch/s, loss=0.771838]                               0.771838]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.7718, Accuracy = 73.38%, Test Accuracy = 71.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:25, 15.48batch/s, loss=0.758539]                               0.758539]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.7585, Accuracy = 73.79%, Test Accuracy = 71.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:25, 15.54batch/s, loss=0.743473]                               0.743473]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.7435, Accuracy = 74.57%, Test Accuracy = 71.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:25, 15.81batch/s, loss=0.732526]                               0.732526]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.7325, Accuracy = 74.83%, Test Accuracy = 72.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:25, 15.54batch/s, loss=0.717547]                               0.717547]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.7175, Accuracy = 75.39%, Test Accuracy = 72.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:25, 15.89batch/s, loss=0.704599]                               0.704599]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.7046, Accuracy = 75.87%, Test Accuracy = 72.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:25, 15.82batch/s, loss=0.698105]                               0.698105]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.6981, Accuracy = 76.03%, Test Accuracy = 73.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:26, 15.27batch/s, loss=0.684237]                               0.684237]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.6842, Accuracy = 76.62%, Test Accuracy = 73.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:25, 15.76batch/s, loss=0.675376]                               0.675376]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.6754, Accuracy = 76.93%, Test Accuracy = 73.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:25, 15.81batch/s, loss=0.668998]                               0.668998]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.6690, Accuracy = 77.04%, Test Accuracy = 73.57%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:25, 15.88batch/s, loss=0.661518]                               0.661518]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.6615, Accuracy = 77.31%, Test Accuracy = 73.53%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:25, 15.47batch/s, loss=0.653325]                               0.653325]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.6533, Accuracy = 77.74%, Test Accuracy = 73.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:25, 15.78batch/s, loss=0.644774]                               0.644774]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.6448, Accuracy = 78.07%, Test Accuracy = 73.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:25, 15.60batch/s, loss=0.637223]                               0.637223]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.6372, Accuracy = 78.35%, Test Accuracy = 74.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:25, 15.66batch/s, loss=0.630610]                               0.630610]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.6306, Accuracy = 78.42%, Test Accuracy = 73.74%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:25, 15.63batch/s, loss=0.626736]                               0.626736]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.6267, Accuracy = 78.60%, Test Accuracy = 74.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:25, 15.77batch/s, loss=0.618980]                               0.618980]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.6190, Accuracy = 79.01%, Test Accuracy = 74.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:25, 15.81batch/s, loss=0.614479]                               0.614479]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.6145, Accuracy = 79.13%, Test Accuracy = 74.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:25, 15.65batch/s, loss=0.608909]                               0.608909]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.6089, Accuracy = 79.37%, Test Accuracy = 74.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:25, 15.53batch/s, loss=0.605611]                               0.605611]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.6056, Accuracy = 79.48%, Test Accuracy = 74.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:25, 15.69batch/s, loss=0.601461]                               0.601461]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.6015, Accuracy = 79.69%, Test Accuracy = 74.67%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:25, 15.67batch/s, loss=0.597993]                               0.597993]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.5980, Accuracy = 79.79%, Test Accuracy = 74.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:25, 15.84batch/s, loss=0.594810]                               0.594810]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.5948, Accuracy = 79.83%, Test Accuracy = 74.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:25, 15.49batch/s, loss=0.591514]                               0.591514]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.5915, Accuracy = 80.03%, Test Accuracy = 74.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:25, 15.80batch/s, loss=0.589123]                               0.589123]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.5891, Accuracy = 80.13%, Test Accuracy = 74.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:25, 15.70batch/s, loss=0.586880]                               0.586880]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 Train Loss = 0.5869, Accuracy = 80.22%, Test Accuracy = 75.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:25, 15.69batch/s, loss=0.584803]                               0.584803]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 Train Loss = 0.5848, Accuracy = 80.28%, Test Accuracy = 74.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:25, 15.96batch/s, loss=0.583317]                               0.583317]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 Train Loss = 0.5833, Accuracy = 80.29%, Test Accuracy = 74.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:25, 15.79batch/s, loss=0.581195]                               0.581195]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 Train Loss = 0.5812, Accuracy = 80.38%, Test Accuracy = 75.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:25, 15.65batch/s, loss=0.579665]                               0.579665]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 Train Loss = 0.5797, Accuracy = 80.49%, Test Accuracy = 75.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:25, 15.55batch/s, loss=0.578983]                               0.578983]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 Train Loss = 0.5790, Accuracy = 80.44%, Test Accuracy = 75.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:25, 15.85batch/s, loss=0.578295]                               0.578295]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 Train Loss = 0.5783, Accuracy = 80.51%, Test Accuracy = 75.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:25, 15.51batch/s, loss=0.577411]                               0.577411]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 Train Loss = 0.5774, Accuracy = 80.56%, Test Accuracy = 75.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:25, 15.60batch/s, loss=0.577102]                               0.577102]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 Train Loss = 0.5771, Accuracy = 80.60%, Test Accuracy = 75.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:25, 15.72batch/s, loss=0.576841]                               0.576841]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 Train Loss = 0.5768, Accuracy = 80.62%, Test Accuracy = 75.19%\n",
      "0-3 end at 20250924-182102\n",
      "0 start at 20250924-182102\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [00:25, 15.47batch/s, loss=1.679366]                                1.679366]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 1.6794, Accuracy = 39.50%, Test Accuracy = 48.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [00:26, 15.33batch/s, loss=1.366373]                                1.366373]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 1.3664, Accuracy = 50.97%, Test Accuracy = 51.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [00:25, 15.81batch/s, loss=1.256422]                                1.256422]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 1.2564, Accuracy = 55.45%, Test Accuracy = 57.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [00:25, 15.64batch/s, loss=1.173519]                                1.173519]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 1.1735, Accuracy = 58.78%, Test Accuracy = 59.63%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [00:25, 15.55batch/s, loss=1.101050]                                1.101050]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 1.1010, Accuracy = 61.57%, Test Accuracy = 61.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [00:25, 15.73batch/s, loss=1.042925]                                1.042925]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 1.0429, Accuracy = 63.69%, Test Accuracy = 64.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [00:25, 15.87batch/s, loss=0.987574]                                0.987574]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.9876, Accuracy = 65.51%, Test Accuracy = 65.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [00:25, 15.71batch/s, loss=0.945678]                                0.945678]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.9457, Accuracy = 66.97%, Test Accuracy = 66.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [00:25, 15.89batch/s, loss=0.910745]                                0.910745]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.9107, Accuracy = 68.46%, Test Accuracy = 67.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [00:25, 15.50batch/s, loss=0.878918]                               0.878918]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.8789, Accuracy = 69.59%, Test Accuracy = 68.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [00:26, 15.19batch/s, loss=0.853985]                               0.853985]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.8540, Accuracy = 70.40%, Test Accuracy = 69.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [00:25, 15.45batch/s, loss=0.828796]                               0.828796]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.8288, Accuracy = 71.42%, Test Accuracy = 69.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [00:26, 15.04batch/s, loss=0.808098]                               0.808098]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.8081, Accuracy = 72.21%, Test Accuracy = 69.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [00:26, 15.01batch/s, loss=0.791496]                               0.791496]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.7915, Accuracy = 72.81%, Test Accuracy = 70.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [00:26, 15.32batch/s, loss=0.777365]                               0.777365]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.7774, Accuracy = 73.21%, Test Accuracy = 71.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [00:25, 15.80batch/s, loss=0.760760]                               0.760760]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.7608, Accuracy = 73.92%, Test Accuracy = 70.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [00:25, 15.77batch/s, loss=0.742379]                               0.742379]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.7424, Accuracy = 74.58%, Test Accuracy = 71.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [00:25, 15.77batch/s, loss=0.730295]                               0.730295]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.7303, Accuracy = 74.88%, Test Accuracy = 72.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [00:25, 15.65batch/s, loss=0.716757]                               0.716757]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.7168, Accuracy = 75.43%, Test Accuracy = 72.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [00:25, 15.76batch/s, loss=0.706992]                               0.706992]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.7070, Accuracy = 75.81%, Test Accuracy = 72.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [00:25, 15.75batch/s, loss=0.691193]                               0.691193]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.6912, Accuracy = 76.22%, Test Accuracy = 72.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [00:25, 15.78batch/s, loss=0.681565]                               0.681565]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.6816, Accuracy = 76.69%, Test Accuracy = 72.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [00:25, 15.42batch/s, loss=0.675458]                               0.675458]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.6755, Accuracy = 77.00%, Test Accuracy = 73.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [00:25, 15.83batch/s, loss=0.662790]                               0.662790]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.6628, Accuracy = 77.54%, Test Accuracy = 73.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [00:25, 15.78batch/s, loss=0.655869]                               0.655869]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.6559, Accuracy = 77.61%, Test Accuracy = 73.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [00:26, 15.24batch/s, loss=0.647472]                               0.647472]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.6475, Accuracy = 77.93%, Test Accuracy = 73.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [00:25, 15.87batch/s, loss=0.640023]                               0.640023]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.6400, Accuracy = 78.24%, Test Accuracy = 73.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [00:25, 15.86batch/s, loss=0.633864]                               0.633864]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.6339, Accuracy = 78.45%, Test Accuracy = 74.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [00:25, 15.77batch/s, loss=0.626044]                               0.626044]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.6260, Accuracy = 78.66%, Test Accuracy = 73.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [00:25, 15.54batch/s, loss=0.620599]                               0.620599]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.6206, Accuracy = 78.93%, Test Accuracy = 74.43%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [00:25, 15.66batch/s, loss=0.614183]                               0.614183]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.6142, Accuracy = 79.16%, Test Accuracy = 74.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [00:25, 15.49batch/s, loss=0.610001]                               0.610001]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.6100, Accuracy = 79.29%, Test Accuracy = 74.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [00:25, 15.71batch/s, loss=0.605858]                               0.605858]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.6059, Accuracy = 79.50%, Test Accuracy = 73.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [00:25, 15.94batch/s, loss=0.600522]                               0.600522]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.6005, Accuracy = 79.67%, Test Accuracy = 74.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [00:24, 16.07batch/s, loss=0.597126]                               0.597126]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.5971, Accuracy = 79.92%, Test Accuracy = 74.39%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [00:25, 15.77batch/s, loss=0.592926]                               0.592926]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.5929, Accuracy = 79.93%, Test Accuracy = 74.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [00:25, 15.74batch/s, loss=0.589342]                               0.589342]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.5893, Accuracy = 79.94%, Test Accuracy = 74.57%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [00:25, 15.65batch/s, loss=0.585829]                               0.585829]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.5858, Accuracy = 80.13%, Test Accuracy = 74.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [00:25, 15.51batch/s, loss=0.582520]                               0.582520]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.5825, Accuracy = 80.32%, Test Accuracy = 74.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [00:25, 15.71batch/s, loss=0.580340]                               0.580340]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.5803, Accuracy = 80.30%, Test Accuracy = 74.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [00:25, 15.72batch/s, loss=0.578298]                               0.578298]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 Train Loss = 0.5783, Accuracy = 80.46%, Test Accuracy = 74.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [00:25, 15.84batch/s, loss=0.576064]                               0.576064]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 Train Loss = 0.5761, Accuracy = 80.62%, Test Accuracy = 74.43%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [00:25, 15.50batch/s, loss=0.574815]                               0.574815]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 Train Loss = 0.5748, Accuracy = 80.62%, Test Accuracy = 74.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [00:25, 15.42batch/s, loss=0.572824]                               0.572824]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 Train Loss = 0.5728, Accuracy = 80.69%, Test Accuracy = 74.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [00:25, 15.75batch/s, loss=0.571513]                               0.571513]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 Train Loss = 0.5715, Accuracy = 80.77%, Test Accuracy = 74.99%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [00:25, 15.64batch/s, loss=0.570408]                               0.570408]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 Train Loss = 0.5704, Accuracy = 80.77%, Test Accuracy = 74.93%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [00:25, 15.69batch/s, loss=0.569743]                               0.569743]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 Train Loss = 0.5697, Accuracy = 80.80%, Test Accuracy = 75.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [00:25, 15.44batch/s, loss=0.569112]                               0.569112]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 Train Loss = 0.5691, Accuracy = 80.87%, Test Accuracy = 75.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [00:25, 15.59batch/s, loss=0.568679]                               0.568679]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 Train Loss = 0.5687, Accuracy = 80.83%, Test Accuracy = 74.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [00:25, 15.83batch/s, loss=0.568478]                               0.568478]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 Train Loss = 0.5685, Accuracy = 80.86%, Test Accuracy = 74.98%\n",
      "0-4 end at 20250924-184501\n"
     ]
    }
   ],
   "source": [
    "\n",
    "num_epochs = 50\n",
    "multest = 5 #5\n",
    "fbsc_range = [0] # 0.01, 0.1, 1\n",
    "res = np.zeros((len(fbsc_range),multest,3,num_epochs))\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    for imul in range(multest):\n",
    "        \n",
    "        current_time_tmp = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "        print(f\"{ifbsc} start at {current_time_tmp}\")\n",
    "\n",
    "        model = aEP_CNN(fbsc=0.01, nudge=0.25, deviden=False, T=40, K=10, chl=[32,64,128])\n",
    "        \n",
    "        optimizer = torch.optim.AdamW(model.parameters(), lr=2.5e-4, weight_decay=2e-4) # 2.5 ~ 1e-4 0.5e-4\n",
    "        scheduler = lr_scheduler.CosineAnnealingLR(optimizer, \n",
    "                                         T_max=num_epochs,  \n",
    "                                         eta_min=1e-6) \n",
    "        \n",
    "        for epoch in range(num_epochs):\n",
    "            total_loss = 0\n",
    "            correct = 0\n",
    "            total = 0\n",
    "\n",
    "            random.shuffle(train_loader_gpu)\n",
    "            with tqdm(total=len(train_loader_gpu), desc=f\"Epoch {epoch + 1}/{num_epochs}:\", unit='batch', ncols=90, mininterval=1, colour='blue') as pbar:\n",
    "                for batch_idx, (data, target) in enumerate(train_loader_gpu):\n",
    "                    optimizer.zero_grad()\n",
    "                    # model.bw_symm()\n",
    "                    preds, loss = model.ep_step(data, target)# eta=[0.015, 0.035, 0.15]\n",
    "                    torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=5)\n",
    "                    optimizer.step()\n",
    "                    total_loss += loss\n",
    "\n",
    "                    if batch_idx % 10 == 0: \n",
    "                        pbar.set_postfix({'loss': f'{total_loss/(batch_idx+1):.6f}'})  \n",
    "                        pbar.update(10)\n",
    "\n",
    "                    correct += (preds == target).sum().item()\n",
    "                    total += target.size(0)\n",
    "                                    \n",
    "            scheduler.step()\n",
    "\n",
    "            acc = correct / total\n",
    "            avg_loss = total_loss / len(train_loader_gpu)\n",
    "            res[ifbsc,imul,0,epoch]=(avg_loss)\n",
    "            res[ifbsc,imul,1,epoch]=(acc)\n",
    "\n",
    "            # Test\n",
    "            correct = 0\n",
    "            total = 0\n",
    "            with torch.no_grad():\n",
    "                for data, target in test_loader_gpu:\n",
    "                    preds = model.predict(data)\n",
    "                    correct += (preds == target).sum().item()\n",
    "                    total += target.size(0)\n",
    "            test_acc = correct / total\n",
    "            res[ifbsc,imul,2,epoch]=(test_acc)\n",
    "\n",
    "            print(f\"Epoch {epoch+1} Train Loss = {avg_loss:.4f}, Accuracy = {acc*100:.2f}%, Test Accuracy = {test_acc*100:.2f}%\")\n",
    "        \n",
    "        current_time_tmp = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "        print(f\"{ifbsc}-{imul} end at {current_time_tmp}\")\n",
    "        \n",
    "res_aEP = res\n",
    "current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "if fsave: \n",
    "    save_dict = {\n",
    "        \"res\": res\n",
    "}\n",
    "np.savez_compressed(res_path / f\"res_aEP\",  **save_dict)\n",
    "     "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d424a189",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t_train: 80.79%+-0.31% (80.43% 81.27%)\t test: 75.04%+-0.51% (74.35% 75.74%)\n",
      "\n",
      "Current Time: 20250924-184501\n"
     ]
    },
    {
     "data": {
      "image/png": "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GUJaWlq5ZcuWLaN///6BL1zVOkOHDj1j5RQRkaalQVumeXl5/PDDD4H3e/bsYdOmTcTHx9O6dWumTZvGwYMHefvttwFr5O7LL7/M1KlTuf3221m9ejVvvPFGuVG69913HxdddBHPPPMMV199NR988AHLly/niy++OOPfT0REmoYGbZmuX7+ePn360KdPHwCmTp1Knz59+NOf/gRAeno6+/fvD6zfrl07PvroI1asWEHv3r3585//zEsvvcS1114bWGfo0KEsWLCAuXPn0rNnT+bNm8fChQt1P0UREak3DdoyveSSS6juMtd58+ZVWHbxxRfzzTffVLvf8ePHM378+GCLJyIiUiPn1DlTERGRs5HCVEREJEgKUxERkSApTEVERIKkMBUREQmSwlRERCRIClMRETkj2rZtW+0dvE61YsUKDMMgOzu73spUV86puXlFROTMuuSSS+jdu3etQrAq69atIyIiosbrDx06lPT0dGJiYoI+dn1TmIqIyGkzTROfz4fD8fNx0rx581rtOyQkhKSkpNMt2hmlbl4RkTPMNE0Kir31+nD7qHR5dbPOnWry5MmsXLmSWbNmYRgGhmEwb948DMNg6dKl9O/fH5fLxeeff86PP/7I1VdfTWJiIpGRkQwYMIDly5eX29+p3byGYfD6668zbtw4wsPD6dixIx9++GHg81O7eefNm0dsbCxLly6la9euREZGcsUVV5Cenh7Yxuv1cu+99xIbG0tCQgJ//OMfuemmmxg7duxp/VvVlFqmIiJnWKHHR+qfltbzURz8Ye2nFZZuf2IU4SE1+9U/a9Ysvv/+e7p3784TTzwBwLZt2wD4wx/+wHPPPUf79u2JjY3lp59+YsyYMTz55JOEhoby1ltvcdVVV7Fz505at25d5TGmT5/Os88+y1//+ldmz57NDTfcwL59+4iPj690/YKCAp577jn++c9/YrPZuPHGG3nggQd45513AHjmmWd45513mDt3Ll27dmXWrFm8//77XHrppTX6zqdLLVMREalUTEwMISEhhIeHk5SURFJSEna7HYAnnniCESNGcP7555OQkECvXr34n//5H3r06EHHjh158sknad++fbmWZmUmT57MxIkT6dChA0899RT5+fmsXbu2yvU9Hg+vvvoq/fv3p2/fvtx999188skngc9nz57NtGnTGDduHF26dOHll18mNja2TuqjOmqZioicYWFOO9ufGFVv+/d4PCxduoxRo0ZWuPl1mNNeJ8fo379/uff5+flMnz6d//znPxw6dAiv10thYWG5O39VpmfPnoHXERERREVFkZmZWeX64eHhnH/++YH3ycnJgfVPnDjB4cOHGThwYOBzu91Ov3798Pv9tfp+taUwFRE5wwzDqHFX6+nwGCYuO4SHOHA66+c4p47K/X//7/+xdOlSnnvuOTp06EBYWBjjx4+nuLi42v2cGvaGYVQbfJWtf+p5YMMwyr2vzXni06VuXhERqVJISAg+n+9n1/v888+ZPHky48aNo0ePHiQlJbF37976L2AZMTExJCYmlusm9vl8bNy4sd6PrZapiIhUqW3btqxZs4a9e/cSGRlZZauxQ4cOvPfee1x11VUYhsGjjz5a712rlbnnnnuYMWMGHTp0oEuXLsyePZvjx49XaK3WNbVMRUSkSg888AB2u53U1FSaN29e5TnQF198kbi4OIYOHcpVV13FqFGj6Nu37xkuLfzxj39k4sSJ/OY3v2HIkCFERkYyatQoQkND6/W4apmKiEiVOnXqxOrVq8stmzx5coX12rZty6eflr8U56677ir3/tRu38rOZZadOvCSSy4pt87kyZMrHHvs2LHl1nE4HMyePZvZs2cD4Pf76dq1KxMmTKhwrLqkMBURkUZj3759LFu2jIsvvhi3283LL7/Mnj17+PWvf12vx1U3r4iINBo2m4158+YxYMAAhg0bxtatW1m+fDldu3at1+OqZSoiIo1Gq1at+PLLL8/4cdUyFRERCZLCVEREJEgKUxERkSApTEVERIKkMBUREQmSwlRERCRIClMREWlQe/fuxTAMNm3a1NBFOW0KUxERqdIll1zC/fffX2f7mzx5MmPHji23rFWrVqSnp9O9e/c6O86ZpkkbRESkQdntdpKSkhq6GEFRy1RE5EwzTSjOr9eH3eeu/LNa3Ch78uTJrFy5klmzZmEYBoZhsHfvXrZv386YMWOIjIwkMTGRSZMmkZWVFdju3//+Nz169CAsLIyEhAQuv/xy8vPzefzxx3nrrbf44IMPAvtbsWJFhW7eFStWYBgGn3zyCf379yc8PJyhQ4eyc+fOcuV78sknadGiBVFRUdx22208+OCD9O7duy7+hWpNLVMRkTPNUwBPpdTb7p3ALwC2VPLhQ4cgJKJG+5k1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meqneqqf6ql+qqa6qV5t6qemddhgYZqVlYXP5yMxMbHc8sTERDIyMmq0j+eff578/HwmTJgQWNalSxfmzZtHjx49yMnJYdasWQwbNozNmzfTsWPHSvczY8YMpk+fXmH5smXLCA8Pr8W3qlxaWlrQ+2jMVD/VU/1UT/VTNdVN9WpSPwUFBTXaV4N284LVJVuWaZoVllVm/vz5PP7443zwwQe0aNEisHzw4MEMHjw48H7YsGH07duX2bNn89JLL1W6r2nTpjF16tTA+5ycHFq1asXIkSOJjo6u7VcK8Hg8pKWlMWLECJxO52nvp7FS/VRP9VM91U/VVDfVq039lPZU/pwGC9NmzZpht9srtEIzMzMrtFZPtXDhQm699VYWLVrE5ZdfXu26NpuNAQMGsGvXrirXcblcuFyuCsudTmed/CDW1X4aK9VP9VQ/1VP9VE11U72a1E9N66/BRvOGhITQr1+/Cs3stLQ0hg4dWuV28+fPZ/Lkybz77rtceeWVP3sc0zTZtGkTycnJQZdZRESkMg3azTt16lQmTZpE//79GTJkCK+99hr79+9nypQpgNX9evDgQd5++23ACtLf/OY3zJo1i8GDBwdatWFhYcTExAAwffp0Bg8eTMeOHcnJyeGll15i06ZN/O1vf2uYLykiIo1eg4bpddddx9GjR3niiSdIT0+ne/fufPTRR7Rp0waA9PT0ctec/v3vf8fr9XLXXXdx1113BZbfdNNNzJs3D4Ds7GzuuOMOMjIyiImJoU+fPqxatYqBAwee0e8mIiJNR4MPQLrzzju58847K/2sNCBLrVix4mf39+KLL/Liiy/WQclERERqpsGnExQRETnXKUxFRESCpDAVEREJksJUREQkSApTERGRIClMRUREgqQwFRERCZLCVEREJEgKUxERkSApTEVERIKkMBUREQmSwlRERCRIClMREZEgKUxFRESCpDAVEREJksJUREQkSApTERGRIClMRUREgqQwFRERCZLCVEREJEgKUxERkSApTEVERIKkMBUREQmSwlRERCRIClMREZEgKUxFRESCpDAVEREJksJUREQkSApTERGRIClMRUREgqQwFRERCZLCVEREJEgKUxERkSApTEVERIKkMBUREQmSwlRERCRIClMREZEgKUxFRESCpDAVEREJksJUREQkSApTERGRIClMRUREgqQwFRER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qiu45557+PDDD/nss89o2bJlYLnqyLrDVIcOHejfvz8zZsygV69ezJo1q8nXzYYNG8jMzKRfv344HA4cDgcrV67kpZdewuFwBOqgqdZPZSIiIujRowe7du2q858fhWkdO51byzVV7dq1IykpqVxdFRcXs3LlyiZTV6Zpcvfdd/Pee+/x6aef0q5du3Kfq44qMk0Tt9vd5Otm+PDhbN26lU2bNgUe/fv354YbbmDTpk20b9++SddPZdxuNzt27CA5Obnuf35qPWRJftaCBQtMp9NpvvHGG+b27dvN+++/34yIiDD37t3b0EU743Jzc82NGzeaGzduNAHzhRdeMDdu3Gju27fPNE3TfPrpp82YmBjzvffeM7du3WpOnDjRTE5ONnNychq45GfGb3/7WzMmJsZcsWKFmZ6eHngUFBQE1mnKdTRt2jRz1apV5p49e8wtW7aYDz30kGmz2cxly5aZptm066YyZUfzmqbq5/e//725YsUKc/fu3ebXX39t/uIXvzCjoqICv4vrsn4UpvWkulvLNSWfffaZCVR43HTTTaZpWsPTH3vsMTMpKcl0uVzmRRddZG7durVhC30GVVY3gDl37tzAOk25jm655ZbA/6PmzZubw4cPDwSpaTbtuqnMqWHa1OvnuuuuM5OTk02n02mmpKSY11xzjblt27bA53VZP7oFm4iISJB0zlRERCRIClMREZEgKUxFRESCpDAVEREJksJUREQkSApTERGRIClMRUREgqQwFRERCZLCVETqlGEYvP/++w1dDJEzSmEq0ohMnjwZwzAqPK644oqGLppIo6b7mYo0MldccQVz584tt8zlcjVQaUSaBrVMRRoZl8tFUlJSuUdcXBxgdcHOmTOH0aNHExYWRrt27Vi0aFG57bdu3cpll11GWFgYCQkJ3HHHHeTl5ZVb580336Rbt264XC6Sk5O5++67y32elZXFuHHjCA8Pp2PHjnz44Yf1+6VFGpjCVKSJefTRR7n22mvZvHkzN954IxMnTmTHjh0AFBQUcMUVVxAXF8e6detYtGgRy5cvLxeWc+bM4a677uKOO+5g69atfPjhh3To0KHcMaZPn86ECRPYsmULY8aM4YYbbuDYsWNn9HuKnFF1c6MbETkb3HTTTabdbjcjIiLKPZ544gnTNK1bvk2ZMqXcNoMGDTJ/+9vfmqZpmq+99poZFxdn5uXlBT7/v//7P9Nms5kZGRmmaZpmSkqK+fDDD1dZBsB85JFHAu/z8vJMwzDM//73v3X2PUXONjpnKtLIXHrppcyZM6fcsvj4+MDrIUOGlPtsyJAhbNq0CYAdO3bQq1cvIiIiAp8PGzYMv9/Pzp07MQyDQ4cOMXz48GrL0LNnz8DriIgIoqKiyMzMPN2vJHLWU5iKNDIREREVul1/jmEYAJimGXhd2TphYWE12p/T6aywrd/vr1WZRM4lOmcq0sR8/fXXFd536dIFgNTUVDZt2kR+fn7g8y+//BKbzUanTp2Iioqibdu2fPLJJ2e0zCJnO7VMRRoZt9tNRkZGuWUOh4NmzZoBsGjRIvr3788FF1zAO++8w9q1a3njjTcAuOGGG3jssce46aabePzxxzly5Aj33HMPkyZNIjExEYDHH3+cKVOm0KJFC0aPHk1ubi5ffvkl99xzz5n9oiJnEYWpSCPz8ccfk5ycXG5Z586d+e677wBrpO2CBQu48847SUpK4p133iE1NRWA8PBwli5dyn333ceAAQMIDw/n2muv5YUXXgjs66abbqKoqIgXX3yRBx54gGbNmjF+/Pgz9wVFzkKGaZpmQxdCRM4MwzBYsmQJY8eObeiiiDQqOmcqIiISJIWpiIhIkHTOVKQJ0VkdkfqhlqmIiEiQFKYiIiJBUpiKiIgESWEqIiISJIWpiIhIkBSmIiIiQVKYioiIBElhKiIiEqT/D9XZxbGsL/LMAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    testacctt = np.max(res[ifbsc,:,2,:], axis= -1)\n",
    "\n",
    "    trainacctt = np.max(res[ifbsc,:,1,:], axis= -1)\n",
    "\n",
    "    print(f'\\t_'\n",
    "        f\"train: {np.mean(trainacctt) * 100:.2f}%+-{np.std(trainacctt, ddof=1)*100:.2f}% ({np.min(trainacctt) * 100:.2f}% {np.max(trainacctt) * 100:.2f}%)\"\n",
    "        f\"\\t test: {np.mean(testacctt) * 100:.2f}%+-{np.std(testacctt, ddof=1)*100:.2f}% ({np.min(testacctt) * 100:.2f}% {np.max(testacctt) * 100:.2f}%)\\n\")\n",
    "\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    plt.figure(figsize=(5, 4))\n",
    "    tt = res[ifbsc,:,1,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'training')  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    tt = res[ifbsc,:,2,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'testing')  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    if np.min(tt)<0.8:\n",
    "        plt.ylim([0.0, 1.0])\n",
    "        plt.yticks(np.arange(0.0,1.01,0.25))\n",
    "    else:\n",
    "        plt.ylim([0.9, 1.0])\n",
    "        plt.yticks(np.arange(0.9,1.01,0.02))\n",
    "    plt.grid()\n",
    "    plt.title(r'$\\beta_i$'+f\"={fbsc_range[ifbsc]}\")\n",
    "    plt.xlabel(f'Epoch')\n",
    "    plt.ylabel('Accuracy')\n",
    "    plt.legend(frameon=False, fancybox=False, shadow=False)\n",
    "\n",
    "    current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "    print(f'Current Time: {current_time}')\n",
    "    plt.savefig(res_path /f\"aEP_cnn_MNIST_maxacc{np.max(tt)}-fbsc{fbsc_range[ifbsc]}-{current_time}.svg\", format=\"svg\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b17535d4",
   "metadata": {},
   "source": [
    "### EP conv without weak feedback"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "54eea047",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 start at 20250924-184501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50::   0%|\u001b[34m                                             \u001b[0m| 0/391 [00:00<?, ?batch/s]\u001b[0m"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/50:: 400batch [02:28,  2.70batch/s, loss=2.134952]                                2.134952]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 2.1350, Accuracy = 20.85%, Test Accuracy = 26.74%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/50:: 400batch [02:24,  2.77batch/s, loss=2.003887]                                2.003887]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 2.0039, Accuracy = 26.87%, Test Accuracy = 30.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/50:: 400batch [02:24,  2.78batch/s, loss=1.928690]                                1.928690]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 1.9287, Accuracy = 29.92%, Test Accuracy = 32.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/50:: 400batch [02:23,  2.78batch/s, loss=1.896201]                                1.896201]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 1.8962, Accuracy = 31.46%, Test Accuracy = 35.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/50:: 400batch [02:25,  2.76batch/s, loss=1.842575]                                1.842575]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 1.8426, Accuracy = 33.71%, Test Accuracy = 34.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/50:: 400batch [02:26,  2.72batch/s, loss=1.820466]                                1.820466]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 1.8205, Accuracy = 34.70%, Test Accuracy = 32.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/50:: 400batch [02:26,  2.73batch/s, loss=1.822247]                                1.822247]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 1.8222, Accuracy = 34.77%, Test Accuracy = 33.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/50:: 400batch [02:27,  2.71batch/s, loss=1.861275]                                1.861275]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 1.8613, Accuracy = 33.30%, Test Accuracy = 34.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/50:: 400batch [02:27,  2.71batch/s, loss=1.830999]                                1.830999]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 1.8310, Accuracy = 34.79%, Test Accuracy = 37.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/50:: 400batch [02:26,  2.73batch/s, loss=1.780540]                               1.780540]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 1.7805, Accuracy = 36.40%, Test Accuracy = 36.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/50:: 400batch [02:28,  2.70batch/s, loss=1.748845]                               1.748845]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 1.7488, Accuracy = 37.71%, Test Accuracy = 37.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/50:: 400batch [02:27,  2.72batch/s, loss=1.732577]                               1.732577]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 1.7326, Accuracy = 37.98%, Test Accuracy = 39.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/50:: 400batch [02:26,  2.73batch/s, loss=1.721179]                               1.721179]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 1.7212, Accuracy = 38.25%, Test Accuracy = 36.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/50:: 400batch [02:27,  2.71batch/s, loss=1.725773]                               1.725773]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 1.7258, Accuracy = 38.51%, Test Accuracy = 39.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/50:: 400batch [02:27,  2.72batch/s, loss=1.725786]                               1.725786]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 1.7258, Accuracy = 38.79%, Test Accuracy = 39.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/50:: 400batch [02:27,  2.71batch/s, loss=1.714414]                               1.714414]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 1.7144, Accuracy = 38.87%, Test Accuracy = 29.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/50:: 400batch [02:27,  2.71batch/s, loss=1.851986]                               1.851986]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 1.8520, Accuracy = 33.52%, Test Accuracy = 36.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/50:: 400batch [02:28,  2.70batch/s, loss=1.750188]                               1.750188]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 1.7502, Accuracy = 37.44%, Test Accuracy = 40.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/50:: 400batch [02:26,  2.72batch/s, loss=1.673918]                               1.673918]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 1.6739, Accuracy = 40.32%, Test Accuracy = 39.73%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/50:: 400batch [02:27,  2.71batch/s, loss=1.656983]                               1.656983]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 1.6570, Accuracy = 40.68%, Test Accuracy = 42.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/50:: 400batch [02:26,  2.72batch/s, loss=1.637421]                               1.637421]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 1.6374, Accuracy = 41.73%, Test Accuracy = 41.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/50:: 400batch [02:28,  2.70batch/s, loss=1.616482]                               1.616482]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 1.6165, Accuracy = 42.48%, Test Accuracy = 43.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/50:: 400batch [02:27,  2.71batch/s, loss=1.601470]                               1.601470]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 1.6015, Accuracy = 42.84%, Test Accuracy = 42.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/50:: 400batch [02:27,  2.71batch/s, loss=1.598857]                               1.598857]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 1.5989, Accuracy = 42.95%, Test Accuracy = 44.41%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/50:: 400batch [02:28,  2.70batch/s, loss=1.596270]                               1.596270]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 1.5963, Accuracy = 42.99%, Test Accuracy = 38.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/50:: 400batch [02:27,  2.70batch/s, loss=1.716626]                               1.716626]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 1.7166, Accuracy = 38.74%, Test Accuracy = 37.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/50:: 400batch [02:27,  2.71batch/s, loss=1.748955]                               1.748955]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 1.7490, Accuracy = 37.50%, Test Accuracy = 37.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/50:: 400batch [02:27,  2.72batch/s, loss=1.779641]                               1.779641]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 1.7796, Accuracy = 36.26%, Test Accuracy = 38.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/50:: 400batch [02:28,  2.70batch/s, loss=1.705829]                               1.705829]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 1.7058, Accuracy = 38.76%, Test Accuracy = 39.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/50:: 400batch [02:28,  2.70batch/s, loss=1.671272]                               1.671272]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 1.6713, Accuracy = 40.02%, Test Accuracy = 41.83%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/50:: 400batch [02:27,  2.72batch/s, loss=1.644302]                               1.644302]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 1.6443, Accuracy = 41.32%, Test Accuracy = 41.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/50:: 400batch [02:27,  2.71batch/s, loss=1.625586]                               1.625586]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 1.6256, Accuracy = 41.80%, Test Accuracy = 43.52%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/50:: 400batch [02:28,  2.69batch/s, loss=1.577220]                               1.577220]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 1.5772, Accuracy = 43.59%, Test Accuracy = 43.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/50:: 400batch [02:28,  2.70batch/s, loss=1.596005]                               1.596005]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 1.5960, Accuracy = 43.01%, Test Accuracy = 43.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/50:: 400batch [02:29,  2.68batch/s, loss=1.637744]                               1.637744]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 1.6377, Accuracy = 41.36%, Test Accuracy = 40.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/50:: 400batch [02:28,  2.69batch/s, loss=1.687469]                               1.687469]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 1.6875, Accuracy = 39.59%, Test Accuracy = 39.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/50:: 400batch [02:28,  2.69batch/s, loss=1.693694]                               1.693694]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 1.6937, Accuracy = 39.76%, Test Accuracy = 39.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/50:: 400batch [02:28,  2.69batch/s, loss=1.678013]                               1.678013]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 1.6780, Accuracy = 40.32%, Test Accuracy = 41.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/50:: 400batch [02:28,  2.70batch/s, loss=1.657659]                               1.657659]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 1.6577, Accuracy = 41.28%, Test Accuracy = 41.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/50:: 400batch [02:38,  2.53batch/s, loss=1.645165]                               1.645165]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 1.6452, Accuracy = 42.01%, Test Accuracy = 42.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 41/50:: 400batch [02:58,  2.25batch/s, loss=1.639345]                               1.639345]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 Train Loss = 1.6393, Accuracy = 42.40%, Test Accuracy = 41.85%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 42/50:: 400batch [02:53,  2.31batch/s, loss=1.636588]                               1.636588]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 Train Loss = 1.6366, Accuracy = 42.29%, Test Accuracy = 42.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 43/50:: 400batch [02:28,  2.69batch/s, loss=1.635983]                               1.635983]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 Train Loss = 1.6360, Accuracy = 42.29%, Test Accuracy = 42.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 44/50:: 400batch [02:27,  2.71batch/s, loss=1.634056]                               1.634056]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 Train Loss = 1.6341, Accuracy = 42.29%, Test Accuracy = 42.54%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 45/50:: 400batch [02:27,  2.71batch/s, loss=1.632782]                               1.632782]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 Train Loss = 1.6328, Accuracy = 42.18%, Test Accuracy = 42.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 46/50:: 400batch [02:28,  2.69batch/s, loss=1.639025]                               1.639025]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 Train Loss = 1.6390, Accuracy = 42.01%, Test Accuracy = 42.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 47/50:: 400batch [02:29,  2.68batch/s, loss=1.642786]                               1.642786]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 Train Loss = 1.6428, Accuracy = 42.32%, Test Accuracy = 42.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 48/50:: 400batch [02:27,  2.70batch/s, loss=1.645238]                               1.645238]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 Train Loss = 1.6452, Accuracy = 42.11%, Test Accuracy = 42.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 49/50:: 400batch [02:28,  2.69batch/s, loss=1.644957]                               1.644957]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 Train Loss = 1.6450, Accuracy = 42.28%, Test Accuracy = 42.53%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 50/50:: 400batch [02:28,  2.69batch/s, loss=1.644595]                               1.644595]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 Train Loss = 1.6446, Accuracy = 42.16%, Test Accuracy = 42.61%\n",
      "0-0 end at 20250924-210844\n"
     ]
    }
   ],
   "source": [
    "\n",
    "num_epochs = 50\n",
    "multest =1 #5\n",
    "fbsc_range = [0] # 0.01, 0.1, 1\n",
    "res = np.zeros((len(fbsc_range),multest,3,num_epochs))\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "# for ilr, lr in enumerate([2.5e-4]):\n",
    "#     for iwd, wd in enumerate( [2.5e-4]):\n",
    "    for imul in range(multest):\n",
    "        current_time_tmp = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "        print(f\"{ifbsc} start at {current_time_tmp}\")\n",
    "\n",
    "        model = aEP_CNN(fbsc=1, nudge=0.25,  T=300, K=10, chl=[32,64,128])\n",
    "        \n",
    "        optimizer = torch.optim.AdamW(model.parameters(), lr=2.5e-4, weight_decay=2e-4) # 0.5 2.5 2e-4 5e-4\n",
    "        scheduler = lr_scheduler.CosineAnnealingLR(optimizer, \n",
    "                                         T_max=num_epochs,  \n",
    "                                         eta_min=1e-6) \n",
    "\n",
    "        for epoch in range(num_epochs):\n",
    "            total_loss = 0\n",
    "            correct = 0\n",
    "            total = 0\n",
    "\n",
    "            random.shuffle(train_loader_gpu)\n",
    "            with tqdm(total=len(train_loader_gpu), desc=f\"Epoch {epoch + 1}/{num_epochs}:\", unit='batch', ncols=90, mininterval=1, colour='blue') as pbar:\n",
    "                for batch_idx, (data, target) in enumerate(train_loader_gpu):\n",
    "                    optimizer.zero_grad()\n",
    "                    # model.bw_symm()\n",
    "                    preds, loss = model.ep_step(data, target)# eta=[0.015, 0.035, 0.15]\n",
    "                    optimizer.step()\n",
    "                    total_loss += loss\n",
    "\n",
    "                    if batch_idx % 10 == 0: \n",
    "                        pbar.set_postfix({'loss': f'{total_loss/(batch_idx+1):.6f}'})  \n",
    "                        pbar.update(10)\n",
    "\n",
    "                    correct += (preds == target).sum().item()\n",
    "                    total += target.size(0)\n",
    "                        \n",
    "            scheduler.step()\n",
    "            \n",
    "            acc = correct / total\n",
    "            avg_loss = total_loss / len(train_loader_gpu)\n",
    "            res[ifbsc,imul,0,epoch]=(avg_loss)\n",
    "            res[ifbsc,imul,1,epoch]=(acc)\n",
    "\n",
    "            # Test\n",
    "            correct = 0\n",
    "            total = 0\n",
    "            with torch.no_grad():\n",
    "                for data, target in test_loader_gpu:\n",
    "                    preds = model.predict(data)\n",
    "                    correct += (preds == target).sum().item()\n",
    "                    total += target.size(0)\n",
    "            test_acc = correct / total\n",
    "            res[ifbsc,imul,2,epoch]=(test_acc)\n",
    "\n",
    "            print(f\"Epoch {epoch+1} Train Loss = {avg_loss:.4f}, Accuracy = {acc*100:.2f}%, Test Accuracy = {test_acc*100:.2f}%\")\n",
    "        \n",
    "        current_time_tmp = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "        print(f\"{ifbsc}-{imul} end at {current_time_tmp}\")\n",
    "        \n",
    "res_EP = res\n",
    "current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "if fsave: \n",
    "    save_dict = {\n",
    "        \"res\": res\n",
    "}\n",
    "np.savez_compressed(res_path / f\"res_EP\",  **save_dict)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4c6678f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t_train: 43.59%+-nan% (43.59% 43.59%)\t test: 44.41%+-nan% (44.41% 44.41%)\n",
      "\n",
      "Current Time: 20250924-210844\n",
      "Current Time: 20250924-210844\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\op1\\anaconda3\\envs\\torchgpu\\lib\\site-packages\\numpy\\core\\_methods.py:206: RuntimeWarning: Degrees of freedom <= 0 for slice\n",
      "  ret = _var(a, axis=axis, dtype=dtype, out=out, ddof=ddof,\n",
      "c:\\Users\\op1\\anaconda3\\envs\\torchgpu\\lib\\site-packages\\numpy\\core\\_methods.py:198: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "data": {
      "image/png": "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iojILcfT05Nly5YVdzXs1AFJRETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxULGH6aeffkr16tXx8PCgWbNmrFmzJteygwcPxmQyZXvVr1/fXmbmzJk5lklLS7sZhyMiIrehYg3TuXPnMmLECEaPHs2OHTto27Yt3bp1IyYmJsfykydPJjY21v46efIk5cuX54EHHshSrmzZslnKxcbG4uHhcTMOSUREbkPFGqYTJkxgyJAhDB06lHr16jFp0iRCQkKYOnVqjuV9fX0JDAy0v7Zu3cqFCxd47LHHspQzmUxZygUGBt6MwxERkduUS3HtOCMjg23btvHKK69kWd65c2fWr1+fr21MmzaNu+++m9DQ0CzLk5OTCQ0NxWKx0LhxY/71r3/RpEmTXLeTnp5Oenq6/X1iYiIAZrMZs9mc30PK5upnHdlGaab2yZvaJ29qn9ypbfJWkPbJbxsWW5ieO3cOi8VCQEBAluUBAQHExcX97edjY2P55Zdf+O6777IsDwsLY+bMmURERJCYmMjkyZNp06YNu3btonbt2jlua/z48YwZMybb8qVLl+Ll5VWAo8pZdHS0w9sozdQ+eVP75E3tkzu1Td7y0z6pqan52laxhelVJpMpy3vDMLIty8nMmTPx8/OjV69eWZa3atWKVq1a2d+3adOGpk2bMmXKFD766KMctzVq1ChGjhxpf5+YmEhISAidO3embNmyBTiarMxmM9HR0XTq1AlXV9cb3k5ppfbJm9onb2qf3Klt8laQ9rl6pfLvFFuYVqxYEWdn52xnofHx8dnOVq9nGAbTp09n0KBBuLm55VnWycmJ5s2bc+jQoVzLuLu74+7unm25q6trofwgFtZ2Siu1T97UPnlT++RObZO3/LRPftuv2Dogubm50axZs2yn2dHR0bRu3TrPz65atYrDhw8zZMiQv92PYRjs3LmToKAgh+orIiKSm2K9zDty5EgGDRpEZGQkUVFRfPHFF8TExDBs2DDAdvn11KlTfPXVV1k+N23aNFq2bEmDBg2ybXPMmDG0atWK2rVrk5iYyEcffcTOnTv55JNPbsoxiYjI7adYw7R///6cP3+et99+m9jYWBo0aMDixYvtvXNjY2OzPXN66dIl5s+fz+TJk3Pc5sWLF3nyySeJi4vD19eXJk2asHr1alq0aFHkxyMiIrenYu+A9PTTT/P000/nuG7mzJnZlvn6+ubZu2rixIlMnDixsKonIiLyt4p9OEEREZFbncJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcVCBw7RatWq8/fbbxMTEFEV9REREbjkFDtN//OMfLFq0iBo1atCpUyfmzJlDenp6UdRNRETkllDgMH322WfZtm0b27ZtIzw8nOeee46goCCeeeYZtm/fXhR1FBERKdFu+J5po0aNmDx5MqdOneLNN9/kyy+/pHnz5jRq1Ijp06djGEZh1lNERKTEcrnRD5rNZhYuXMiMGTOIjo6mVatWDBkyhNOnTzN69GiWLVvGd999V5h1FRERKZEKHKbbt29nxowZzJ49G2dnZwYNGsTEiRMJCwuzl+ncuTPt2rUr1IqKiIiUVAUO0+bNm9OpUyemTp1Kr169cHV1zVYmPDycBx98sFAqKCIiUtIVOEyPHj1KaGhonmW8vb2ZMWPGDVdKRETkVlLgDkjx8fFs2rQp2/JNmzaxdevWQqmUiIjIraTAYTp8+HBOnjyZbfmpU6cYPnx4oVRKRETkVlLgMN23bx9NmzbNtrxJkybs27evUColIiJyKylwmLq7u3PmzJlsy2NjY3FxueEnbURERG5ZBQ7TTp06MWrUKC5dumRfdvHiRV599VU6depUqJUTERG5FRT4VPLDDz+kXbt2hIaG0qRJEwB27txJQEAAX3/9daFXUEREpKQrcJhWrlyZ3bt38+2337Jr1y48PT157LHH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QQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcZDCVERExEEKUxEREQcpTEVERBykMBUREXGQwlRERMRBClMREREHKUxFREQcpDAVERFxkMJURETEQQpTERERBylMRUREHKQwFRERcVCxh+mnn35K9erV8fDwoFmzZqxZsybP8qtWraJZs2Z4eHhQo0YNPvvss2xl5s+fT3h4OO7u7oSHh7Nw4cKiqr6IiEjxhuncuXMZMWIEo0ePZseOHbRt25Zu3boRExOTY/ljx47RvXt32rZty44dO3j11Vd57rnnmD9/vr3Mhg0b6N+/P4MGDWLXrl0MGjSIfv36sWnTppt1WCIicpsp1jCdMGECQ4YMYejQodSrV49JkyYREhLC1KlTcyz/2WefUbVqVSZNmkS9evUYOnQojz/+OB988IG9zKRJk+jUqROjRo0iLCyMUaNG0bFjRyZNmnSTjkpERG43LsW144yMDLZt28Yrr7ySZXnnzp1Zv359jp/ZsGEDnTt3zrKsS5cuTJs2DbPZjKurKxs2bOCFF17IViavME1PTyc9Pd3+/tKlSwAkJCRgNpsLclhZmM1mUlNTOX/+PK6urje8ndJK7ZM3tU/e1D65U9vkrSDtk5SUBIBhGHmWK7YwPXfuHBaLhYCAgCzLAwICiIuLy/EzcXFxOZbPzMzk3LlzBAUF5Vomt20CjB8/njFjxmRbXr169fwejoiIlGJJSUn4+vrmur7YwvQqk8mU5b1hGNmW/V3565cXdJujRo1i5MiR9vdWq5WEhAQqVKiQ5+f+TmJiIiEhIZw8eZKyZcve8HZKK7VP3tQ+eVP75E5tk7eCtI9hGCQlJREcHJxnuWIL04oVK+Ls7JztjDE+Pj7bmeVVgYGBOZZ3cXGhQoUKeZbJbZsA7u7uuLu7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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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OAKBQJPtX0SkNdA90zbm9ddfJykpqcryf//3f9W2CwaDzJw5k9WrV3PWWWfFoKQiIi2H5jOtQb3nM20hl3mvuuoqtm/fzrRp06qsb9euHe3ataNr167k5eXhdrvx+Xx4PB4mTZrEfffdh8Ohv7tEpO2pax7oMm9jsKwmvdTamBITE+nZs+dh3//d737HVVddRUJCAjk5OVj1uB8rItJWKUylioyMjFrDVkREqlOYtjE+n4/8/Pwq61wuFxkZGTEqkYhIy6cwbWPefvttcnJyqqzr3bs369evj1GJRERaPjVAqkG9GyCJiEirVNc8UBNNERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoKUxFRESipDAVERGJksJUGiwQCMS6CCIizYLCtBHYtk1poDQmS33mKfD5fNx0001kZmYSFxfHqaeeyhdffAHAzJkzSUtLq7L9q6++WmVy8LvuuosTTjiBGTNm0L17d7xeL7Zt8/LLLzNgwADi4+Np3749Z599NiUlJY1ybkVEWgJNwdYIyoJlDHthWEy+e8nPlpDgTqjTtr///e+ZO3cuTz/9NLm5udx///2cc845bNy4sc7ft3HjRl566SXmzp2L0+kkPz+fyy+/nPvvv58LL7yQoqIiPv7443qFvIhIS6cwbSNKSkqYNm0aM2fOZOzYsQD861//YsGCBUyfPp0OHTrUaT9+v59nn302sv2XX35JMBjkoosuIjc3F4ABAwY0zUGIiDRTCtNGEO+KZ8nPlsTsu+ti06ZNBAIBTjnllMg6t9vNSSedxLp16+ocprm5uVW2HThwIGeddRYDBgzgnHPOYfTo0VxyySWkp6fX70BERFowhWkjsCyrzpdaY6Xysuuh90Ar11uWhcPhqHZptqYGRomJiVVeO51OFixYwKeffsq7777LI488wu23386SJUvo1q1bIx+FiEjzpAZIbUTPnj3xeDx88sknkXWBQIClS5dy3HHH0aFDB4qKiqo0HFqxYkWd9m1ZFqeccgp33303y5cvx+PxMG/evMY+BBGRZks10zYiMTGR66+/nt/97ne0a9eOLl26cP/991NaWsrVV1+NbdskJCRw2223ceONN/L5558zc+bMI+53yZIlvP/++4wePZrMzEyWLFnC7t27Oe6445r+oEREmgmF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CwtJTU2loKCAlJSUOh/P4QRDYU68by6Bjn/GcgR55EePcEbnM6Ler4iINK265kG9GyCNGzcumnJF+P1+li1bxq233lpl/ejRo/n0009r/eygQYMoLy+nb9++3HHHHZx55pmR9xYvXsyvf/3rKtufc845PPTQQ4fdn8/nw+fzRV4XFhbW40iO7D8rt1OasACPI0ifdsdxeqfTG3X/IiISW/UO0zvvvLNRvnjPnj2EQiGysqqORZuVlUV+fn6Nn8nJyeHJJ59kyJAh+Hw+nn32Wc466ywWLlzIyJEjAcjPz6/XPgGmTp3K3XffHeURHd70JV/gTv8cgMlDfq3GWiIirUyDZ41pLD8MFtu2Dxs2vXv3pnfv3pHXI0aMYNu2bfztb3+LhGl99wkwZcoUJk+eHHldWFhI586d63Uch7NxVyEb/a/jTgjRO20AIzqOaJT9iohI81HvMHU4HLUGU11b+mZkZOB0OqvVGHft2lWtZlmb4cOH89xzz0VeZ2dn13ufXq8Xr9db5++sj78vWogrdRkAtw6bfIStRUSkJap3mP6wm0kgEGD58uU8/fTT9bpU6vF4GDJkCAsWLODCCy+MrF+wYAEXXHBBnfezfPlycnJyIq9HjBjBggULqtw3fffddzn55JPrvM/GUuYP8Mmul7GSwnRLPIGh2UOPehlERKTp1TtMawq6Sy65hH79+jF79myuvvrqOu9r8uTJTJgwgaFDhzJixAiefPJJtm7dysSJEwFz+XX79u0888wzADz00EN07dqVfv364ff7ee6555g7dy5z586N7PPmm29m5MiR/OUvf+GCCy7gtdde47333uOTTz6p76FG7dkvl2AnrsAC7jr1t0f9+0VE5OhotHumw4YN49prr63XZ8aPH8/evXu55557yMvLo3///rz55pvk5uYCkJeXV6XPqd/v57e//S3bt28nPj6efv368cYbb3DuuedGtjn55JOZNWsWd9xxB3/84x/p0aMHs2fPZtiwYY1zoPXw9Lp/YTlsslyDGZw98Kh/v4iIHB317mdak7KyMqZMmcJbb73VKqZha4x+ph9+u4KbPp6AbVs8evoznNHthMYtpIiINLkm62f6wwHtbdumqKiIhISEKg2B2jo77CElNATbdihIRURauXqH6YMPPlglTB0OBx06dGDYsGGkp6c3auFash/17MuI3Ccp9wdjXRQREWli9Q7Tq666qgmK0TrFuz3EuzXFmohIa1fvge6feuop5syZU239nDlzePrppxulUCIiIi1JvcP0vvvuIyMjo9r6zMxM/vznPzdKoURERFqSeofpli1b6NatW7X1ubm5R5w6TUREpDWqd5hmZmayatWqautXrlxJ+/btG6VQIiIiLUm9w/Syyy7jpptu4sMPPyQUChEKhfjggw+4+eabueyyy5qijCIiIs1avVvz3nvvvWzZsoWzzjoLl8t8PBwO84tf/EL3TEWaO9uGoA/ccbEuiUir0uARkL755htWrFhBfHw8AwYMiAwB2Bo0xghIIs2OrxhmXwHbPodrP4TMPrEukUiz12QjIFXq1asXvXr1aujHRSQa/hJwxYHDWbftfUXw3CWw7TPzesk0OP/hpiufSBtT73uml1xyCffdd1+19X/961/56U9/2iiFEpFabPoA/t4HHhlsaplHUl4Iz15kgtRVcXl31RyzvjWybfjuv7B2Pmz+CPJWwv4tUHYAwuFYl05aqXpf5u3QoQMffPABAwYMqLJ+9erVnH322ezcubNRCxgLuswrzdb6N2DOVRDym9eWE07/A5z2G3DWcKGp7AA8dzFsXwpxaTBhHsybCHs2wLl/g5PqN9NTsxcKwhuT4cvDDSBjQVwKJOdA+55myehV8bwXJLSDQ4ZLFWmyy7zFxcV4PNWHyHO73RQWttK/dEWag1VzYN7/gB2CPueBOwFWvwQL/wyb3oeLnoT0rge3L9sPz14IO5ZDfDr84jXIGQhDfwVv/wGWzoATr2k94eEvgZd/BV+/DZYDjhliat/lBVB+AILlgF3xugB2r6++j7g06HoqXPCoOWfScOEwFGyDXetg11rY/x2EAubfbzgE4WDF8zBgQ3w7SMqEpKxDHiuee5Ob/b/Teodp//79mT17Nn/605+qrJ81axZ9+/ZttIKJyCGWPgWv/xqw4fjL4IJ/mppor1Hwxm9g2xKYdir8+O9w/KUmSJ+5APJXQUJ7E6TZFVeTBl4G791lfuC2LYEuw2N5ZI2jeDe8OB62LzOXsi+eDsedV3WbQPnBYC3YBns3wZ5vYO9GsxRsM++tfx1KdsOEV8GTEIODaUZCAfNvqXQflO0zj4EywDaX03/4WH7A/Lvatd78seIvbpxyuBNMsCZnVzzmQHIWJGWblumBcgiWHXwM+kw5g+Vw6q8hpWPjlKMW9b7MO3/+fC6++GJ+9rOf8aMf/QiA999/nxdeeIGXX36ZcePGNUU5jypd5pVm5dNH4N07zPMTr4GxfwXHIc0d9m+BV6472Lio/8Ww+2vYuRoSMuDK/0DWD/7QfW0SLH8OBlwKF//r6BxHU9m7yVzK3r/Z1CYvnw1dhtV/P4EyE8azfmZCt+couPxFcLobv8yNwa4IMEcdm774iiF/tbmHvGuNaZQWCpjgCfkPLkE/+AqgdD/4i6Iro8MNHXpDhz7mUro7Dhwuc3vC4TRXEBwVdbqyfVC8C4ryzWPxTvMYbRmu/cBcpWiguuZBg7rGvPHGG/z5z3+OdI0ZOHAgd955JykpKZxwwgkNLnRzoTCVo2LrEvjkQUjPhZwTzCXYjGMP3vu0bVg4FRb9xbw+5RY4+66aL3eFgmZfC6eaS2cAiZkmSGvqArP9S/jXmeD0wOR1kFh9vO2YC4ehaIepfdR0Pxjg+2XwwqVQugfScuHnc8090GhsXWJq9cEy88fGhU/UPbAaUygA3y40VxdK9ppjLNlT8VjxOuQ35yelI6QeAymVS0dzb3jXeshbYQJ0zzdAQ3pCWhCfZv5QiW8H7ngTgpZl3jv00Z0AmcdVLH2hXffo/xjxl5hgLcqvCNqdhzzmmfPkijPlcsVVPI87uG7wlZDWucFf36RheqgDBw7w/PPPM336dFauXEkoFIpmd82CwlSa3OaP4IXxECitut4VD9n9TbD6S2HlC2b9WX8yjYyO5PulpoFRyA9XvAwdjj38tk+cbn5oR90Dp9zc4ENpErYNr1wLq+eYwG/f0/yh0aFPRU2nN+zbbLYJlJo/Rn72krn01xi+fhdmXW7u6w2bCGPuOzr37Gzb/KGzajZ8NdcEZmNK7mj+beUcby7/Oz1mcXlN6DkrHuNSK8Iz3TyvaxesVqjJw/SDDz5gxowZvPLKK+Tm5nLxxRdz8cUXM2jQoAYXurlQmEqT2vQhvHi5qfl0GwmZ/UzNIX9VzfeYxv4Vhl1X9/3bNtjhI/8AfvkMzL8R0rvBjV/GpvZ1OB9OhUXVu+DVqOfZ8NOnwZvUuGVY9ZIJa4Az74DTf9e4+z/Uvm9NA7NVs2HfpoPrEzKg51nmPmFihnmdmGGCMKG9CcGiPCjYDoU7oPB781iw3dzrzOhl/tDoeIIJ0aTMpjuGVqpJWvN+//33zJw5kxkzZlBSUsKll15KIBBg7ty5anwkUhffvGfuyYV80OscuPSZg0P7hcPmhzRvpWmBu3uDaSw04JL6fYdlmXtSR9L/YnjnDnOv8dsPTCg1B6tfPhik5/8DepxpzsXu9RWPFYu/CAZNMI2umuK+5vGXmgY3b/8BPrzXdJs58erG/Y49G+H1W+C7jw+uc8WbxlPHj4fuZx7+EnellI5R3ROUxlHnmum5557LJ598wnnnnccVV1zBmDFjcDqduN1uVq5c2arCVDVTaRJfvwOzf24uwfb+Mfz0KVOziKU3fw+fP2HKc/kLsS0LmMvUT51r/tg4+UYYfW/N29m2aanpjm/6Mn1wL3z0V8Ay/836XRj9Pm0blk43f8wEy8w9yO5nmADt82PTFUSahUavmb777rvcdNNNXH/99RpGUKS+1r8BL10J4QAcdz5cPANc1ftrH3VDf2XC9Ou3zKXB1GNiV5YD28zl75APep8LZ999+G0t6+gEKcCZt5uGP8uegrnXmsAfManh3S2KdsL8G+Cbd83rbqebfq1pXRqvzHLU1fkmyccff0xRURFDhw5l2LBhPProo+zevbspyybSMqyZB2/dCp8+Cuv+A3mrTNeKSmtfg5d+YYK034VwyVPNI0jBtPTNPdXcYz3sqEFHga/YBGnJLsjqDxf9q/k0erEscym5/yXmv+HiR+HhgTD/JtMtpz7WvQ7TRpggdXrhnKmmP6uCtMWrdwOk0tJSZs2axYwZM/j8888JhUI88MAD/OpXvyI5uXVcmtBl3lYiUG760+WtOtjAp3AH/PgB6HNu43zH98tg+tkmjH4oLs38SO5cY7qrDPgpjHv8yPfAjrbVL8Pcq00Xi19/dfT7VYZD5vL3hjdNd55rP4iqK0OTsW0z0tTHD8CW/5p1lgP6XWQGBsjuf/jP+org7VtN316ArAFmxKof9v+VZueodI3ZsGED06dP59lnn+XAgQOMGjWK+fPnN3R3zYbCtAXbuQYW/xN2rDANVuwaumr1Gg1XzIn+uwLl8MRIM85t52Hmst/+LXBgC5TurbrtwJ+ZS3nNpbZ1qKAfHuxrRv259Fno+5Oj+/0L/gT/fdjU1K56AzqfeHS/vyG2LIZPHjh4qRagx1lmZJ5guVkqR+AJlptL2CW7AMt0QzrzttjfL5c6OWr9TAFCoRD/+c9/mDFjhsJUGsd3n5gf1/r8sO7eADPOMV0CKiVkmD512cebPnPv3Wn6zf3+u+i7giy4E/77kKlNTVpiWntW8hXDga0mWF1e6HZG8+p68kPv3W3CofsZZujBpmbbZgi/VbMrGvcAF/0bjm9hM0/lrTKDZayZxxEHREjtAhc+Dl1POSpFk8ZxVMO0tVGYxlA4DB/cY36gsOAnj8DgCUf+XOEOmD7ajK96zBAY+TsToCkdD3a2DwXhvi4QKIHrF0d3ie37pTB9lLm8e9kLpgVmS7Z/i7kPiA2TPjeDIjQ2f6npAvLNAlOjO7Dl4Hsjfw8/ur3xv/No2bvJ3BvHNl1b3HHm0eU1DaXcCdBpKHgSY11SqacmnxxcpNH5is2sKOtfr1hhm1aPgVIY9j+H/1zZATPxdcE2M1LOz+ZAYvvq2zld5gdt8yIzjm1DwzRQDq9eb4J0wKUtP0jBDGnYa5QJuRnnmIEiBlwS/ag/xbtMyHz9Nmz+2LTUreT0QO4p0G8cDPpFdN8Ta+17wGmTY10KiSGFqTQPld0idq42l3d/8ohpMLT4UXjr92Z8zpp+rALlMOsK09AoKQt+/krNQVqpy3ATpls/M91CGuLD/wd7vjbfN/YvDdtHc3TuX2F2vjnvr1xjLl2e94CZqaM+SveZVs1fzTU10UMbZ6V2gV5nm/vWXU9r/FGLRGJEYSqxt+0LMypQyS5I7GAum3Y+yYxA40k0A72/f7cJ1B/dcbC2FA7BvOtgyyfgTTGDnKfn1v5dldONbf2s4WVd/Kh5ft5DVe+TtnTpXU1L2k8eMud8wxum1erY+81/i9pqqeUFsOEtE6CbPjBj2lY6Zij0vQCOPceMr9vM56UUaQiFqUQnFDTzF6Z1bthkyqvmmOnAQj7Tv/DyFw/2ubMs0+rRnWAaDn38N3PJ95w/m/ffvtVcQnS4YfxzB+frrE2nE013hgNboDAPUnLqXtZA2cHLu8df1njda5oTp9uMQdvnXHOseSvNHyxr5sF5D5paauEO2PmVmc6r8nHvJqo0wMkeYIYr7Hdh1QnLRVophak0nG2be5xfvWxeJ3c0gwBk9j04DVPGsaYG6SuE8kJTg6l8vn2ZGX0HzIg3F/2r5st+p95iaqhv/hY+e8zUUNO6wOdPmvcvegK6n163MnuTIaufCYBtn9VvaLgP/x/s/cb0xxxbx0HYW6qsfnDN+6bLysL7zAhJj35i7jsf2lr6UBnHVgToRbXPViPSCilMpeFWPH8wSMHMPVm0w1zmq49TboGz7qy968hJ15oa6vwbqo7UM+Y+8wNeH11GmDDdWo8w3brEjHAEcP7DDauFtzRON4z8rflD57X/NYPvgxlEP+NYM0hBVv+KxwGNN/2ZSAukMJWG2bvJDJIOZq7NE68x/Tx3rYVd6yoe11d0VMc0KopLNRMWe1MqnqdC/4vM/bS6GHSF6XLwynXmntwpN8Pw6+tf9s7DTK22rvdNg34TJthm8IXeY+r/nS1ZVl+4+j3Y+qn5b9ehz8GZbkQEUJhKQwT9Zvi5QIlpkXnKLWZkn84nmeVQ5YWmr11jjfbS/2JI62qmKutfz6nJKnUZYR7zV5vuOEdqUbrpAzPAQEIGjPlzw76zpXO6zNyrIlKjZjwkizRbH/4/c8kvLg0ufKL2IfLiUhp/2LROQ0zr0oaOKJR6DKR2NkMNbl965O2/mmseB/y0bVzeFZF6U5hK/Xy70DRKAdMXNJZTdkWjrl1k/KVmAHao/71ZEWkzdJm3pVkzDz76O7TrCjkDIWeQeUzq0PTfXbIX5k0EbBhy1dEfEL0xdR4Gq+ccOUy/eQf8xab1cKehR6dsItLiKExbktUvwyvXmn6OO1ebUWYqpRxjQrXjIDjhZ5DaqXG/27Zh/o1QlGdacp7Twu8dVt43/f4L01f2cNOiVV7i7X+xBhsQkcNSmLYUX809GKTHjzed4nesMJ3q926Ewu1m2fAmLHkCLp/VuFNZLZ1hRsRxeuDif7f8AbszjzMtU32FZijCnIHVtykvhK8rptjSJV4RqYXCtCVYMw/mVgTpCT839yoPbXzjKzItU3esMH0/d34FT59npnuqz6AENfGXmMB+5zbz+qw7aw6elsbhNKMhbXrf9CGt6Zg2vGlGZso41vSnFBE5DIVpc7f2NXj5atPy9IQrqgcpmFF9ck82y+BfwMu/Mvf65lxlptY65ebaL1GGw/DtB7D9S1O7Ldhuhowr/N6MWFSpx49g+P82yWHGRJcRFWG6GIZdV/391RUDUugSr4gcgcK0OVs73wSjHYKBl9ccpD/kTTLj2759qxmY4L07Yf9mOPdvZkSbQ/lLYOWL8NnjZpi8w/Ekm+4o4x5v3hNc11eXYeZx62fmnvChgVmyF7790DzXJV4ROQKFaXO17j/w8i/NSD/Hj4cL/ll7f85DOZxmOq12PUyoLpsJB7bCT2eaUYcKtpugXTYTyg+Yz3hTzLycaV1MY6bUY8xjyjGmr2hrdMwQcLjMEIgF2w4OsA+wbr4599nHQ0av2JVRRFoEhWlztO4/5hJtOGgmnx43re5BeqjhE01AzL3ajOIzY4wZwHzNvINTZKV3hWHXm6H6vMmNeRTNnyfRhOWOL81900PD9NBWvCIiR9CKrtm1Estmwku/qAjSn5pGRA0J0kp9zoVfvmkmst611vStDAch91QY/zzc+KUJ3bYWpJUqu8hsXXxwXWEefPeJed7/oqNfJhFpcVQzbS5sGxbdDwsr+m8O+jmc93B0QVqp4yAzndYbv4GE9jDsf6DjCdHvtzXoMgw++ydsW3Jw3dpXAdsM7HBobVVE5DAUps1BOGTm6lw6w7we+Ts48/bGbUGa1hmueKnx9tdadK4YVnDnGig7APFpusQrIvWmMI21QBnMvQbWvw5YpuHQSdfGulRtR3IWpHczLZ6/XwoZPc2oSJYD+o6LdelEpIVQmMZS6T548XLY9pmZ7/Pif9V9bk9pPF2GmzDdutgM0wjQ9VRNdi0idaYwjZWC7+G5i2H3evCmwuUvmB9wOfq6DDf9bbctMZd6oeFzpYpIm6QwjYVAOTz9EzPBdXIO/Hyu6bIisVF533TrYtPS2eGC486PbZlEpEVR15hYWPzowSC9+l0FaaxlHGsm/a7se9vjLEhoF9syiUiLojA92grz4OMHzPNR96jrRXPgcJhuMJXUildE6klherS9fzcESqDTSWZQBmkeulRc6nXFmYEuRETqQWF6NH2/1DR0ARh7n2YiaU76XgBxaXDiNW13NCgRaTA1QDpawmF46w/m+cCfmUHWpflo1x1u3RLrUohIC6Wa6dGyeg5sXwqeJDj7zliXRkREGpHC9GjwFZt5RQFOmwzJ2bEtj4iINCqF6dHw34egKA/ScmH4pFiXRkREGpnCtKnt3wKfPmKej74X3HGxLY+IiDQ6hWlTW/AnCJZD19M0qo6ISCulMG1K3/3XzI1pOWCMusKIiLRWCtOmEg7B2xVdYYZcBdn9Y1ocERFpOgrTprLhTchfDXGpZqJvERFptTRoQ1Ppcx5cMgOCPkjMiHVpRESkCcW8ZvrYY4/RrVs34uLiGDJkCB9//PFht33llVcYNWoUHTp0ICUlhREjRvDOO+9U2WbmzJlYllVtKS8vb+pDqcqyzIDpJ/zs6H6viIgcdTEN09mzZ3PLLbdw++23s3z5ck477TTGjh3L1q1ba9z+o48+YtSoUbz55pssW7aMM888k/PPP5/ly5dX2S4lJYW8vLwqS1ycuqSIiEjTsGzbtmP15cOGDWPw4MFMmzYtsu64445j3LhxTJ06tU776NevH+PHj+dPf/oTYGqmt9xyCwcOHGhwuQoLC0lNTaWgoICUlJQG70dERFq2uuZBzGqmfr+fZcuWMXr06CrrR48ezaefflqnfYTDYYqKimjXrupEzsXFxeTm5tKpUyfOO++8ajXXH/L5fBQWFlZZRERE6ipmYbpnzx5CoRBZWVlV1mdlZZGfn1+nffz973+npKSESy+9NLKuT58+zJw5k/nz5/Piiy8SFxfHKaecwjfffHPY/UydOpXU1NTI0rlz54YdlIiItEkxb4Bk/WAgA9u2q62ryYsvvshdd93F7NmzyczMjKwfPnw4P//5zxk4cCCnnXYaL730EsceeyyPPPLIYfc1ZcoUCgoKIsu2bdsafkAiItLmxKxrTEZGBk6ns1otdNeuXdVqqz80e/Zsrr76aubMmcPZZ59d67YOh4MTTzyx1pqp1+vF6/XWvfAiIiKHiFnN1OPxMGTIEBYsWFBl/YIFCzj55JMP+7kXX3yRq666ihdeeIEf//jHR/we27ZZsWIFOTk5UZdZRESkJjEdtGHy5MlMmDCBoUOHMmLECJ588km2bt3KxIkTAXP5dfv27TzzzDOACdJf/OIXPPzwwwwfPjxSq42Pjyc1NRWAu+++m+HDh9OrVy8KCwv5xz/+wYoVK/jnP/8Zm4MUEZFWL6ZhOn78ePbu3cs999xDXl4e/fv358033yQ3NxeAvLy8Kn1On3jiCYLBIJMmTWLSpIPzgl555ZXMnDkTgAMHDnDdddeRn59PamoqgwYN4qOPPuKkk046qscmIiJtR0z7mTZX6mcqIiLQAvqZioiItBYKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoKUxFRESipDAVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoKUxFRESipDAVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoKUxFRESipDAVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoKUxFRESipDAVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoKUxFRESipDAVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKKkMBUREYmSwlRERCRKClMREZEoxTxMH3vsMbp160ZcXBxDhgzh448/rnX7RYsWMWTIEOLi4ujevTuPP/54tW3mzp1L37598Xq99O3bl3nz5jVV8UVERGIbprNnz+aWW27h9ttvZ/ny5Zx22mmMHTuWrVu31rj95s2bOffccznttNNYvnw5t912GzfddBNz586NbLN48WLGjx/PhAkTWLlyJRMmTODSSy9lyZIlR+uwRESkjbFs27Zj9eXDhg1j8ODBTJs2LbLuuOOOY9y4cUydOrXa9n/4wx+YP38+69ati6ybOHEiK1euZPHixQCMHz+ewsJC3nrrrcg2Y8aMIT09nRdffLFO5SosLCQ1NZWCggJSUlIaengiItLC1TUPXEexTFX4/X6WLVvGrbfeWmX96NGj+fTTT2v8zOLFixk9enSVdeeccw7Tp08nEAjgdrtZvHgxv/71r6tt89BDDx22LD6fD5/PF3ldUFAAmJMoIiJtV2UOHKneGbMw3bNnD6FQiKysrCrrs7KyyM/Pr/Ez+fn5NW4fDAbZs2cPOTk5h93mcPsEmDp1KnfffXe19Z07d67r4YiISCtWVFREamrqYd+PWZhWsiyrymvbtqutO9L2P1xf331OmTKFyZMnR16Hw2H27dtH+/bta/3ckRQWFtK5c2e2bdumy8U10Pmpnc5P7XR+Dk/npnb1OT+2bVNUVETHjh1r3S5mYZqRkYHT6axWY9y1a1e1mmWl7OzsGrd3uVy0b9++1m0Ot08Ar9eL1+utsi4tLa2uh3JEKSkp+gddC52f2un81E7n5/B0bmpX1/NTW420Usxa83o8HoYMGcKCBQuqrF+wYAEnn3xyjZ8ZMWJEte3fffddhg4ditvtrnWbw+1TREQkWjG9zDt58mQmTJjA0KFDGTFiBE8++SRbt25l4sSJgLn8un37dp555hnAtNx99NFHmTx5Mtdeey2LFy9m+vTpVVrp3nzzzYwcOZK//OUvXHDBBbz22mu89957fPLJJzE5RhERaQPsGPvnP/9p5+bm2h6Pxx48eLC9aNGiyHtXXnmlffrpp1fZfuHChfagQYNsj8djd+3a1Z42bVq1fc6ZM8fu3bu37Xa77T59+thz585t6sOoUXl5uX3nnXfa5eXlMfn+5k7np3Y6P7XT+Tk8nZvaNcX5iWk/UxERkdYg5sMJioiItHQKUxERkSgpTEVERKKkMBUREYmSwrSJ1Hdqudbqo48+4vzzz6djx45YlsWrr75a5X3btrnrrrvo2LEj8fHxnHHGGaxZsyY2hY2BqVOncuKJJ5KcnExmZibjxo1jw4YNVbZpy+do2rRpHH/88ZHO9SNGjKgyiUVbPjc/NHXqVCzL4pZbbomsa+vn56677sKyrCpLdnZ25P3GPD8K0yZQ36nlWrOSkhIGDhzIo48+WuP7999/Pw888ACPPvooX3zxBdnZ2YwaNYqioqKjXNLYWLRoEZMmTeKzzz5jwYIFBINBRo8eTUlJSWSbtnyOOnXqxH333cfSpUtZunQpP/rRj7jgggsiP3ht+dwc6osvvuDJJ5/k+OOPr7Je5wf69etHXl5eZFm9enXkvUY9P43WyUYiTjrpJHvixIlV1vXp08e+9dZbY1Si5gGw582bF3kdDoft7Oxs+7777ousKy8vt1NTU+3HH388BiWMvV27dtlApL+1zlF16enp9r///W+dmwpFRUV2r1697AULFtinn366ffPNN9u2rX87tm3bd955pz1w4MAa32vs86OaaSOrnFruh1PF1Ta1XFu1efNm8vPzq5wrr9fL6aef3mbPVeX0f+3atQN0jg4VCoWYNWsWJSUljBgxQuemwqRJk/jxj3/M2WefXWW9zo/xzTff0LFjR7p168Zll13Gt99+CzT++Yn5rDGtTUOmlmurKs9HTedqy5YtsShSTNm2zeTJkzn11FPp378/oHMEsHr1akaMGEF5eTlJSUnMmzePvn37Rn7w2vK5mTVrFl9++SVffPFFtff0bweGDRvGM888w7HHHsvOnTu59957Ofnkk1mzZk2jnx+FaROp7zRwbZnOlXHDDTewatWqGseRbsvnqHfv3qxYsYIDBw4wd+5crrzyShYtWhR5v62em23btnHzzTfz7rvvEhcXd9jt2ur5ARg7dmzk+YABAxgxYgQ9evTg6aefZvjw4UDjnR9d5m1kDZlarq2qbFWncwU33ngj8+fP58MPP6RTp06R9TpHZoapnj17MnToUKZOncrAgQN5+OGH2/y5WbZsGbt27WLIkCG4XC5cLheLFi3iH//4By6XK3IO2ur5qUliYiIDBgzgm2++afR/PwrTRtaQqeXaqm7dupGdnV3lXPn9fhYtWtRmzpVt29xwww288sorfPDBB3Tr1q3K+zpH1dm2jc/na/Pn5qyzzmL16tWsWLEisgwdOpQrrriCFStW0L179zZ9fmri8/lYt24dOTk5jf/vp95NluSIZs2aZbvdbnv69On22rVr7VtuucVOTEy0v/vuu1gX7agrKiqyly9fbi9fvtwG7AceeMBevny5vWXLFtu2bfu+++6zU1NT7VdeecVevXq1ffnll9s5OTl2YWFhjEt+dFx//fV2amqqvXDhQjsvLy+ylJaWRrZpy+doypQp9kcffWRv3rzZXrVqlX3bbbfZDofDfvfdd23bbtvnpiaHtua1bZ2f3/zmN/bChQvtb7/91v7ss8/s8847z05OTo78Fjfm+VGYNpHappZrSz788EMbqLZceeWVtm2b5ul33nmnnZ2dbXu9XnvkyJH26tWrY1voo6imcwPYTz31VGSbtnyOfvWrX0X+/6hDhw72WWedFQlS227b56YmPwzTtn5+xo8fb+fk5Nhut9vu2LGjfdFFF9lr1qyJvN+Y50dTsImIiERJ90xFRESipDAVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEWkUVmWxauvvhrrYogcVQpTkVbkqquuwrKsasuYMWNiXTSRVk3zmYq0MmPGjOGpp56qss7r9caoNCJtg2qmIq2M1+slOzu7ypKeng6YS7DTpk1j7NixxMfH061bN+bMmVPl86tXr+ZHP/oR8fHxtG/fnuuuu47i4uIq28yYMYN+/frh9XrJycnhhhtuqPL+nj17uPDCC0lISKBXr17Mnz+/aQ9aJMYUpiJtzB//+EcuvvhiVq5cyc9//nMuv/xy1q1bB0BpaSljxowhPT2dL774gjlz5vDee+9VCctp06YxadIkrrvuOlavXs38+fPp2bNnle+4++67ufTSS1m1ahXnnnsuV1xxBfv27TuqxylyVDXORDci0hxceeWVttPptBMTE6ss99xzj23bZsq3iRMnVvnMsGHD7Ouvv962bdt+8skn7fT0dLu4uDjy/htvvGE7HA47Pz/ftm3b7tixo3377bcftgyAfccdd0ReFxcX25Zl2W+99VajHadIc6N7piKtzJlnnsm0adOqrGvXrl3k+YgRI6q8N2LECFasWAHAunXrGDhwIImJiZH3TznlFMLhMBs2bMCyLHbs2MFZZ51VaxmOP/74yPPExESSk5PZtWtXQw9JpNlTmIq0MomJidUuux6JZVkA2LYdeV7TNvHx8XXan9vtrvbZcDhcrzKJtCS6ZyrSxnz22WfVXvfp0weAvn37smLFCkpKSiLv//e//8XhcHDssceSnJxM165def/9949qmUWaO9VMRVoZn89Hfn5+lXUul4uMjAwA5syZw9ChQzn11FN5/vnn+fzzz5k+fToAV1xxBXfeeSdXXnkld911F7t37+bGG29kwoQJZGVlAXDXXXcxceJEMjMzGTt2LEVFRfz3v//lxhtvPLoHKtKMKExFWpm3336bnJycKut69+7N+vXrAdPSdtasWfzv//4v2dnZPP/88/Tt2xeAhIQE3nnnHW6++WZOPPFEEhISuPjii3nggQci+7ryyispLy/nwQcf5Le//S0ZGRlccsklR+8ARZohy7ZtO9aFEJGjw7Is5s2bx7hx42JdFJFWRfdMRUREoqQwFRERiZLumYq0IbqrI9I0VDMVERGJksJUREQkSgpTERGRKClMRUREoqQwFRERiZLCVEREJEoKUxERkSgpTEVERKL0/wFPLF0/jkahNgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "     \n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    testacctt = np.max(res[ifbsc,:,2,:], axis= -1)\n",
    "\n",
    "    trainacctt = np.max(res[ifbsc,:,1,:], axis= -1)\n",
    "\n",
    "    print(f'\\t_'\n",
    "        f\"train: {np.mean(trainacctt) * 100:.2f}%+-{np.std(trainacctt, ddof=1)*100:.2f}% ({np.min(trainacctt) * 100:.2f}% {np.max(trainacctt) * 100:.2f}%)\"\n",
    "        f\"\\t test: {np.mean(testacctt) * 100:.2f}%+-{np.std(testacctt, ddof=1)*100:.2f}% ({np.min(testacctt) * 100:.2f}% {np.max(testacctt) * 100:.2f}%)\\n\")\n",
    "\n",
    "for ifbsc in range(len(fbsc_range)):\n",
    "    plt.figure(figsize=(5, 4))\n",
    "    tt = res[ifbsc,:,1,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'training')  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    tt = res[ifbsc,:,2,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'testing')  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    if np.min(tt)<0.8:\n",
    "        plt.ylim([0.0, 1.0])\n",
    "        plt.yticks(np.arange(0.0,1.01,0.25))\n",
    "    else:\n",
    "        plt.ylim([0.9, 1.0])\n",
    "        plt.yticks(np.arange(0.9,1.01,0.02))\n",
    "    plt.grid()\n",
    "    plt.title(r'$\\beta_i$'+f\"={fbsc_range[ifbsc]}\")\n",
    "    plt.xlabel(f'Epoch')\n",
    "    plt.ylabel('Accuracy')\n",
    "    plt.legend(frameon=False, fancybox=False, shadow=False)\n",
    "\n",
    "    current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "    print(f'Current Time: {current_time}')\n",
    "    plt.savefig(res_path /f\"EP_cnn_MNIST_maxacc{np.max(tt)}-fbsc{fbsc_range[ifbsc]}-{current_time}.svg\", format=\"svg\")\n",
    "\n",
    "\n",
    "    plt.figure(figsize=(5, 4))\n",
    "for labels, res in zip(['BP', 'EP', 'ours'], [res_BP, res_EP, res_aEP]):\n",
    "    ifbsc = 0\n",
    "    # tt = res[ifbsc,:,1,:]\n",
    "    # plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=f'training')  #  plot\n",
    "    # plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    tt = res[ifbsc,:,2,:]\n",
    "    plt.plot(np.arange(len(np.mean(tt, axis=0))), np.mean(tt, axis=0), label=labels)  #  plot\n",
    "    plt.fill_between(np.arange(len(np.mean(tt, axis=0))), np.min(tt, axis=0), np.max(tt, axis=0), alpha=0.25)\n",
    "    if np.min(tt)<0.8:\n",
    "        plt.ylim([0.0, 1.0])\n",
    "        plt.yticks(np.arange(0.0,1.01,0.25))\n",
    "    else:\n",
    "        plt.ylim([0.9, 1.0])\n",
    "        plt.yticks(np.arange(0.9,1.01,0.02))\n",
    "    # plt.grid()\n",
    "    # plt.title(r'$\\beta_i$'+f\"={fbsc_range[ifbsc]}\")\n",
    "    plt.xlabel(f'Epoch')\n",
    "    plt.ylabel('Accuracy')\n",
    "    plt.legend(frameon=False, fancybox=False, shadow=False)\n",
    "\n",
    "current_time = time.strftime(\"%Y%m%d-%H%M%S\", time.localtime())\n",
    "print(f'Current Time: {current_time}')\n",
    "plt.savefig(res_path /f\"All_cnn_MNIST_maxacc{np.max(tt)}-fbsc{fbsc_range[ifbsc]}-{current_time}.svg\", format=\"svg\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torchgpu",
   "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.9.20"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
