{
 "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": "markdown",
   "id": "25ab91f1",
   "metadata": {},
   "source": [
    "### Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "43a5fbd7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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}-MNIST\")\n",
    "res_path.mkdir(parents=True, exist_ok=True)\n",
    "\n",
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "])\n",
    "\n",
    "train_set = datasets.MNIST(root='./data', train=True, download=True, transform=transform)\n",
    "test_set = datasets.MNIST(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": "ee58c750",
   "metadata": {},
   "source": [
    "### Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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=50, K=20, chl= [32, 64]):\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.chl = chl\n",
    "        self.rho = hardsigm # hardsigm relu6 relu6 hardtanh hardtanh6 linear\n",
    "\n",
    "        self.deviden = deviden\n",
    "\n",
    "        self.conv1 = nn.Conv2d(1, self.chl[0], kernel_size=5, stride=1, padding=0)\n",
    "        self.pool1 = nn.MaxPool2d(2, stride = 2, return_indices = True)  \n",
    "        self.conv2 = nn.Conv2d(self.chl[0], self.chl[1], kernel_size=5, stride=1, padding=0)\n",
    "        self.pool2 = nn.MaxPool2d(2, stride = 2, return_indices = True)  \n",
    "        self.fc1 = nn.Linear(self.chl[1] * 4 * 4, 10)\n",
    "\n",
    "        self.unpool1 = nn.MaxUnpool2d(2, stride = 2)  \n",
    "        self.unpool2 = 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, 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",
    "\n",
    "            fc1 = ( self.fc1(p2.view(p2.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[1], 4, 4)\n",
    "        else:\n",
    "            fbs = torch.zeros_like(p2,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",
    "        dx1 =  (self.conv1(x)*self.ffSC +self.unpool1( F.conv_transpose2d(self.rho(x2), self.conv2.weight, stride=1, padding=0),\n",
    "                                            ind1,output_size=x1.shape)*self.fbSC)\n",
    "        p1, ind1 = self.pool1(self.rho(x1))       # output_size =(B, 128, 16, 16)\n",
    "        \n",
    "        dx2 =  (self.conv2(p1)*self.ffSC + self.unpool2(fbs,ind2,output_size=x2.shape)* nudge )\n",
    "        p2, ind2 = self.pool2(self.rho(x2))      # (B, 256, 8, 8)\n",
    "\n",
    "        dfc = ( self.fc1(p2.view(p2.size(0), -1)))\n",
    "\n",
    "        x1 =dx1\n",
    "        x2 =dx2\n",
    "        fc1 = dfc\n",
    "        # if nudge == 0: fc1 = dfc\n",
    "        return x1, p1, ind1, x2, p2, ind2, 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, _, fc1 = sf\n",
    "        # self.x1, self.x2, self.xfc1 = x1, x2, 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, _, _, 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 = p2.view(p2.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",
    "        # 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=0)\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=0)\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 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",
    "        # fix: use p4.size(0) (batch dim of p4) for view\n",
    "        fc1 = self.fc1(p2.view(p2.size(0), -1))\n",
    "\n",
    "        # pre, 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, fc1\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b437b327",
   "metadata": {},
   "source": [
    "### BP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9c27096e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 start at 20250923-151914\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:03, 138.77batch/s, loss=0.628028]                               0.628028]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.00e-04\n",
      "Epoch 1 Train Loss = 0.6210, Accuracy = 86.85%, Test Accuracy = 94.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:02, 184.45batch/s, loss=0.163142]                               0.163142]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.00e-04\n",
      "Epoch 2 Train Loss = 0.1622, Accuracy = 95.99%, Test Accuracy = 97.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:02, 172.13batch/s, loss=0.106189]                               0.106189]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.00e-04\n",
      "Epoch 3 Train Loss = 0.1055, Accuracy = 97.25%, Test Accuracy = 97.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:02, 207.74batch/s, loss=0.081409]                               0.081409]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.00e-04\n",
      "Epoch 4 Train Loss = 0.0812, Accuracy = 97.90%, Test Accuracy = 98.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:02, 177.81batch/s, loss=0.067180]                               0.067180]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.00e-04\n",
      "Epoch 5 Train Loss = 0.0672, Accuracy = 98.22%, Test Accuracy = 98.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:02, 211.28batch/s, loss=0.057476]                               0.057476]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.00e-04\n",
      "Epoch 6 Train Loss = 0.0576, Accuracy = 98.46%, Test Accuracy = 98.60%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:02, 198.18batch/s, loss=0.050963]                               0.050963]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.00e-04\n",
      "Epoch 7 Train Loss = 0.0508, Accuracy = 98.65%, Test Accuracy = 98.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:02, 211.86batch/s, loss=0.044850]                               0.044850]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.00e-04\n",
      "Epoch 8 Train Loss = 0.0453, Accuracy = 98.85%, Test Accuracy = 98.81%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:02, 198.12batch/s, loss=0.041112]                               0.041112]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.00e-04\n",
      "Epoch 9 Train Loss = 0.0411, Accuracy = 98.92%, Test Accuracy = 98.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:02, 195.67batch/s, loss=0.037320]                              0.037320]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.00e-04\n",
      "Epoch 10 Train Loss = 0.0373, Accuracy = 99.02%, Test Accuracy = 99.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:02, 204.69batch/s, loss=0.034207]                              0.034207]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.00e-04\n",
      "Epoch 11 Train Loss = 0.0341, Accuracy = 99.10%, Test Accuracy = 99.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:02, 189.89batch/s, loss=0.031586]                              0.031586]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.00e-04\n",
      "Epoch 12 Train Loss = 0.0316, Accuracy = 99.17%, Test Accuracy = 99.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:02, 192.12batch/s, loss=0.029535]                              0.029535]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.00e-04\n",
      "Epoch 13 Train Loss = 0.0293, Accuracy = 99.22%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:02, 229.71batch/s, loss=0.027009]                              0.027009]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.00e-04\n",
      "Epoch 14 Train Loss = 0.0270, Accuracy = 99.30%, Test Accuracy = 99.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:02, 180.07batch/s, loss=0.025496]                              0.025496]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 2.00e-04\n",
      "Epoch 15 Train Loss = 0.0253, Accuracy = 99.35%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:02, 215.55batch/s, loss=0.023780]                              0.023780]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 2.00e-04\n",
      "Epoch 16 Train Loss = 0.0238, Accuracy = 99.39%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:02, 180.39batch/s, loss=0.021977]                              0.021977]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 2.00e-04\n",
      "Epoch 17 Train Loss = 0.0220, Accuracy = 99.44%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:02, 194.09batch/s, loss=0.020447]                              0.020447]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 2.00e-04\n",
      "Epoch 18 Train Loss = 0.0206, Accuracy = 99.49%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:02, 208.79batch/s, loss=0.019023]                              0.019023]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 2.00e-04\n",
      "Epoch 19 Train Loss = 0.0192, Accuracy = 99.52%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:02, 191.76batch/s, loss=0.018130]                              0.018130]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 2.00e-04\n",
      "Epoch 20 Train Loss = 0.0181, Accuracy = 99.55%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:02, 177.42batch/s, loss=0.016979]                              0.016979]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 2.00e-04\n",
      "Epoch 21 Train Loss = 0.0170, Accuracy = 99.58%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:01, 235.95batch/s, loss=0.015604]                              0.015604]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 2.00e-04\n",
      "Epoch 22 Train Loss = 0.0156, Accuracy = 99.63%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:01, 269.30batch/s, loss=0.014824]                              0.014824]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 2.00e-04\n",
      "Epoch 23 Train Loss = 0.0148, Accuracy = 99.66%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:02, 204.51batch/s, loss=0.013700]                              0.013700]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 2.00e-04\n",
      "Epoch 24 Train Loss = 0.0138, Accuracy = 99.71%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:01, 273.28batch/s, loss=0.012740]                              0.012740]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 2.00e-04\n",
      "Epoch 25 Train Loss = 0.0128, Accuracy = 99.74%, Test Accuracy = 99.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:01, 258.45batch/s, loss=0.011798]                              0.011798]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 2.00e-04\n",
      "Epoch 26 Train Loss = 0.0120, Accuracy = 99.76%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:01, 246.20batch/s, loss=0.011196]                              0.011196]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 2.00e-04\n",
      "Epoch 27 Train Loss = 0.0112, Accuracy = 99.77%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:01, 235.14batch/s, loss=0.010298]                              0.010298]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 2.00e-04\n",
      "Epoch 28 Train Loss = 0.0103, Accuracy = 99.80%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:02, 226.66batch/s, loss=0.009569]                              0.009569]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 2.00e-04\n",
      "Epoch 29 Train Loss = 0.0096, Accuracy = 99.83%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:01, 253.74batch/s, loss=0.009347]                              0.009347]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 2.00e-04\n",
      "Epoch 30 Train Loss = 0.0093, Accuracy = 99.84%, Test Accuracy = 99.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:01, 263.56batch/s, loss=0.008567]                              0.008567]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 2.00e-04\n",
      "Epoch 31 Train Loss = 0.0086, Accuracy = 99.84%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:02, 227.81batch/s, loss=0.008044]                              0.008044]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 2.00e-04\n",
      "Epoch 32 Train Loss = 0.0080, Accuracy = 99.87%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:02, 223.48batch/s, loss=0.007340]                              0.007340]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 2.00e-04\n",
      "Epoch 33 Train Loss = 0.0074, Accuracy = 99.89%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:01, 325.74batch/s, loss=0.006843]                              0.006843]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 2.00e-04\n",
      "Epoch 34 Train Loss = 0.0069, Accuracy = 99.90%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:01, 268.43batch/s, loss=0.006365]                              0.006365]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 2.00e-04\n",
      "Epoch 35 Train Loss = 0.0064, Accuracy = 99.92%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:01, 274.52batch/s, loss=0.006010]                              0.006010]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 2.00e-04\n",
      "Epoch 36 Train Loss = 0.0060, Accuracy = 99.92%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:02, 223.24batch/s, loss=0.005512]                              0.005512]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 2.00e-04\n",
      "Epoch 37 Train Loss = 0.0056, Accuracy = 99.95%, Test Accuracy = 99.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:01, 257.53batch/s, loss=0.005026]                              0.005026]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 2.00e-04\n",
      "Epoch 38 Train Loss = 0.0050, Accuracy = 99.94%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:02, 193.83batch/s, loss=0.004813]                              0.004813]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.00e-04\n",
      "Epoch 39 Train Loss = 0.0048, Accuracy = 99.96%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:02, 174.71batch/s, loss=0.004513]                              0.004513]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.00e-04\n",
      "Epoch 40 Train Loss = 0.0045, Accuracy = 99.96%, Test Accuracy = 99.33%\n",
      "0 end at 20250923-152044\n",
      "1 start at 20250923-152044\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:02, 188.41batch/s, loss=0.627886]                               0.627886]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.00e-04\n",
      "Epoch 1 Train Loss = 0.6208, Accuracy = 86.39%, Test Accuracy = 95.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:02, 166.88batch/s, loss=0.164720]                               0.164720]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.00e-04\n",
      "Epoch 2 Train Loss = 0.1640, Accuracy = 95.83%, Test Accuracy = 97.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:02, 192.57batch/s, loss=0.108487]                               0.108487]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.00e-04\n",
      "Epoch 3 Train Loss = 0.1083, Accuracy = 97.22%, Test Accuracy = 97.75%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:02, 195.23batch/s, loss=0.083645]                               0.083645]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.00e-04\n",
      "Epoch 4 Train Loss = 0.0837, Accuracy = 97.79%, Test Accuracy = 98.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:02, 179.90batch/s, loss=0.068517]                               0.068517]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.00e-04\n",
      "Epoch 5 Train Loss = 0.0686, Accuracy = 98.19%, Test Accuracy = 98.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:02, 191.38batch/s, loss=0.058404]                               0.058404]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.00e-04\n",
      "Epoch 6 Train Loss = 0.0584, Accuracy = 98.48%, Test Accuracy = 98.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:02, 218.35batch/s, loss=0.050992]                               0.050992]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.00e-04\n",
      "Epoch 7 Train Loss = 0.0511, Accuracy = 98.65%, Test Accuracy = 98.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:01, 254.50batch/s, loss=0.045325]                               0.045325]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.00e-04\n",
      "Epoch 8 Train Loss = 0.0454, Accuracy = 98.80%, Test Accuracy = 98.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:02, 220.82batch/s, loss=0.040788]                               0.040788]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.00e-04\n",
      "Epoch 9 Train Loss = 0.0410, Accuracy = 98.94%, Test Accuracy = 98.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:02, 190.61batch/s, loss=0.037235]                              0.037235]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.00e-04\n",
      "Epoch 10 Train Loss = 0.0372, Accuracy = 99.03%, Test Accuracy = 98.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:02, 202.26batch/s, loss=0.033979]                              0.033979]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.00e-04\n",
      "Epoch 11 Train Loss = 0.0340, Accuracy = 99.12%, Test Accuracy = 99.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:02, 223.24batch/s, loss=0.031044]                              0.031044]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.00e-04\n",
      "Epoch 12 Train Loss = 0.0311, Accuracy = 99.19%, Test Accuracy = 99.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:02, 194.97batch/s, loss=0.028976]                              0.028976]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.00e-04\n",
      "Epoch 13 Train Loss = 0.0290, Accuracy = 99.22%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:02, 183.81batch/s, loss=0.026954]                              0.026954]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.00e-04\n",
      "Epoch 14 Train Loss = 0.0268, Accuracy = 99.30%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:02, 177.93batch/s, loss=0.024851]                              0.024851]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 2.00e-04\n",
      "Epoch 15 Train Loss = 0.0249, Accuracy = 99.36%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:01, 258.76batch/s, loss=0.023153]                              0.023153]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 2.00e-04\n",
      "Epoch 16 Train Loss = 0.0232, Accuracy = 99.40%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:01, 294.72batch/s, loss=0.021814]                              0.021814]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 2.00e-04\n",
      "Epoch 17 Train Loss = 0.0218, Accuracy = 99.42%, Test Accuracy = 99.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:01, 246.25batch/s, loss=0.020358]                              0.020358]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 2.00e-04\n",
      "Epoch 18 Train Loss = 0.0203, Accuracy = 99.49%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:01, 276.35batch/s, loss=0.018935]                              0.018935]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 2.00e-04\n",
      "Epoch 19 Train Loss = 0.0189, Accuracy = 99.53%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:01, 299.55batch/s, loss=0.017714]                              0.017714]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 2.00e-04\n",
      "Epoch 20 Train Loss = 0.0177, Accuracy = 99.58%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:01, 342.37batch/s, loss=0.016298]                              0.016298]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 2.00e-04\n",
      "Epoch 21 Train Loss = 0.0164, Accuracy = 99.63%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:01, 342.34batch/s, loss=0.015528]                              0.015528]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 2.00e-04\n",
      "Epoch 22 Train Loss = 0.0155, Accuracy = 99.64%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:01, 283.31batch/s, loss=0.014874]                              0.014874]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 2.00e-04\n",
      "Epoch 23 Train Loss = 0.0148, Accuracy = 99.65%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:01, 240.42batch/s, loss=0.013534]                              0.013534]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 2.00e-04\n",
      "Epoch 24 Train Loss = 0.0136, Accuracy = 99.70%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:01, 254.61batch/s, loss=0.012554]                              0.012554]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 2.00e-04\n",
      "Epoch 25 Train Loss = 0.0127, Accuracy = 99.72%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:01, 249.77batch/s, loss=0.011935]                              0.011935]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 2.00e-04\n",
      "Epoch 26 Train Loss = 0.0119, Accuracy = 99.77%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:01, 286.61batch/s, loss=0.010961]                              0.010961]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 2.00e-04\n",
      "Epoch 27 Train Loss = 0.0110, Accuracy = 99.79%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:01, 293.13batch/s, loss=0.010387]                              0.010387]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 2.00e-04\n",
      "Epoch 28 Train Loss = 0.0104, Accuracy = 99.81%, Test Accuracy = 99.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:01, 248.44batch/s, loss=0.009857]                              0.009857]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 2.00e-04\n",
      "Epoch 29 Train Loss = 0.0098, Accuracy = 99.82%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:01, 258.78batch/s, loss=0.009183]                              0.009183]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 2.00e-04\n",
      "Epoch 30 Train Loss = 0.0092, Accuracy = 99.84%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:02, 183.32batch/s, loss=0.008419]                              0.008419]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 2.00e-04\n",
      "Epoch 31 Train Loss = 0.0085, Accuracy = 99.87%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:01, 323.83batch/s, loss=0.007949]                              0.007949]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 2.00e-04\n",
      "Epoch 32 Train Loss = 0.0079, Accuracy = 99.89%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:01, 359.82batch/s, loss=0.007252]                              0.007252]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 2.00e-04\n",
      "Epoch 33 Train Loss = 0.0073, Accuracy = 99.89%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:01, 315.16batch/s, loss=0.006972]                              0.006972]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 2.00e-04\n",
      "Epoch 34 Train Loss = 0.0069, Accuracy = 99.92%, Test Accuracy = 99.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:01, 260.33batch/s, loss=0.006404]                              0.006404]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 2.00e-04\n",
      "Epoch 35 Train Loss = 0.0064, Accuracy = 99.94%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:01, 240.54batch/s, loss=0.005880]                              0.005880]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 2.00e-04\n",
      "Epoch 36 Train Loss = 0.0059, Accuracy = 99.94%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:01, 240.51batch/s, loss=0.005776]                              0.005776]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 2.00e-04\n",
      "Epoch 37 Train Loss = 0.0058, Accuracy = 99.94%, Test Accuracy = 99.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:01, 277.67batch/s, loss=0.005118]                              0.005118]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 2.00e-04\n",
      "Epoch 38 Train Loss = 0.0051, Accuracy = 99.95%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:02, 219.23batch/s, loss=0.004725]                              0.004725]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.00e-04\n",
      "Epoch 39 Train Loss = 0.0047, Accuracy = 99.96%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:01, 250.13batch/s, loss=0.004501]                              0.004501]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.00e-04\n",
      "Epoch 40 Train Loss = 0.0045, Accuracy = 99.96%, Test Accuracy = 99.26%\n",
      "1 end at 20250923-152205\n",
      "2 start at 20250923-152205\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:01, 251.14batch/s, loss=0.598246]                               0.598246]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.00e-04\n",
      "Epoch 1 Train Loss = 0.5914, Accuracy = 87.24%, Test Accuracy = 95.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:01, 264.26batch/s, loss=0.155721]                               0.155721]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.00e-04\n",
      "Epoch 2 Train Loss = 0.1556, Accuracy = 96.10%, Test Accuracy = 97.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:01, 270.03batch/s, loss=0.103204]                               0.103204]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.00e-04\n",
      "Epoch 3 Train Loss = 0.1031, Accuracy = 97.33%, Test Accuracy = 97.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:01, 246.28batch/s, loss=0.079528]                               0.079528]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.00e-04\n",
      "Epoch 4 Train Loss = 0.0794, Accuracy = 97.88%, Test Accuracy = 98.35%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:02, 217.39batch/s, loss=0.064781]                               0.064781]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.00e-04\n",
      "Epoch 5 Train Loss = 0.0650, Accuracy = 98.29%, Test Accuracy = 98.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:02, 214.16batch/s, loss=0.056172]                               0.056172]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.00e-04\n",
      "Epoch 6 Train Loss = 0.0560, Accuracy = 98.54%, Test Accuracy = 98.64%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:01, 253.12batch/s, loss=0.049270]                               0.049270]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.00e-04\n",
      "Epoch 7 Train Loss = 0.0492, Accuracy = 98.69%, Test Accuracy = 98.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:02, 223.92batch/s, loss=0.043867]                               0.043867]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.00e-04\n",
      "Epoch 8 Train Loss = 0.0436, Accuracy = 98.82%, Test Accuracy = 98.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:02, 202.54batch/s, loss=0.039369]                               0.039369]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.00e-04\n",
      "Epoch 9 Train Loss = 0.0394, Accuracy = 98.96%, Test Accuracy = 98.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:02, 224.81batch/s, loss=0.036023]                              0.036023]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.00e-04\n",
      "Epoch 10 Train Loss = 0.0359, Accuracy = 99.05%, Test Accuracy = 99.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:02, 232.08batch/s, loss=0.032913]                              0.032913]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.00e-04\n",
      "Epoch 11 Train Loss = 0.0330, Accuracy = 99.16%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:01, 271.47batch/s, loss=0.030251]                              0.030251]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.00e-04\n",
      "Epoch 12 Train Loss = 0.0302, Accuracy = 99.20%, Test Accuracy = 99.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:01, 252.94batch/s, loss=0.027877]                              0.027877]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.00e-04\n",
      "Epoch 13 Train Loss = 0.0280, Accuracy = 99.29%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:01, 251.77batch/s, loss=0.026183]                              0.026183]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.00e-04\n",
      "Epoch 14 Train Loss = 0.0261, Accuracy = 99.33%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:01, 276.20batch/s, loss=0.023841]                              0.023841]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 2.00e-04\n",
      "Epoch 15 Train Loss = 0.0241, Accuracy = 99.39%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:01, 246.72batch/s, loss=0.022500]                              0.022500]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 2.00e-04\n",
      "Epoch 16 Train Loss = 0.0224, Accuracy = 99.44%, Test Accuracy = 99.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:01, 258.33batch/s, loss=0.021113]                              0.021113]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 2.00e-04\n",
      "Epoch 17 Train Loss = 0.0211, Accuracy = 99.45%, Test Accuracy = 99.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:01, 241.52batch/s, loss=0.019672]                              0.019672]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 2.00e-04\n",
      "Epoch 18 Train Loss = 0.0196, Accuracy = 99.52%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:01, 236.65batch/s, loss=0.018228]                              0.018228]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 2.00e-04\n",
      "Epoch 19 Train Loss = 0.0182, Accuracy = 99.56%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:02, 231.54batch/s, loss=0.016962]                              0.016962]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 2.00e-04\n",
      "Epoch 20 Train Loss = 0.0171, Accuracy = 99.61%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:01, 274.24batch/s, loss=0.015995]                              0.015995]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 2.00e-04\n",
      "Epoch 21 Train Loss = 0.0160, Accuracy = 99.63%, Test Accuracy = 99.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:01, 276.10batch/s, loss=0.015288]                              0.015288]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 2.00e-04\n",
      "Epoch 22 Train Loss = 0.0152, Accuracy = 99.67%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:02, 208.49batch/s, loss=0.013994]                              0.013994]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 2.00e-04\n",
      "Epoch 23 Train Loss = 0.0141, Accuracy = 99.69%, Test Accuracy = 99.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:01, 272.98batch/s, loss=0.013380]                              0.013380]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 2.00e-04\n",
      "Epoch 24 Train Loss = 0.0134, Accuracy = 99.70%, Test Accuracy = 99.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:01, 294.72batch/s, loss=0.012189]                              0.012189]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 2.00e-04\n",
      "Epoch 25 Train Loss = 0.0122, Accuracy = 99.76%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:01, 284.14batch/s, loss=0.011290]                              0.011290]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 2.00e-04\n",
      "Epoch 26 Train Loss = 0.0113, Accuracy = 99.78%, Test Accuracy = 99.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:02, 219.99batch/s, loss=0.011017]                              0.011017]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 2.00e-04\n",
      "Epoch 27 Train Loss = 0.0110, Accuracy = 99.77%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:02, 221.04batch/s, loss=0.010013]                              0.010013]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 2.00e-04\n",
      "Epoch 28 Train Loss = 0.0100, Accuracy = 99.82%, Test Accuracy = 99.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:01, 237.29batch/s, loss=0.009288]                              0.009288]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 2.00e-04\n",
      "Epoch 29 Train Loss = 0.0093, Accuracy = 99.83%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:01, 257.25batch/s, loss=0.008813]                              0.008813]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 2.00e-04\n",
      "Epoch 30 Train Loss = 0.0088, Accuracy = 99.85%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:01, 295.77batch/s, loss=0.008116]                              0.008116]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 2.00e-04\n",
      "Epoch 31 Train Loss = 0.0081, Accuracy = 99.88%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:01, 301.83batch/s, loss=0.007534]                              0.007534]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 2.00e-04\n",
      "Epoch 32 Train Loss = 0.0075, Accuracy = 99.89%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:01, 260.09batch/s, loss=0.007189]                              0.007189]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 2.00e-04\n",
      "Epoch 33 Train Loss = 0.0073, Accuracy = 99.90%, Test Accuracy = 99.35%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:02, 211.07batch/s, loss=0.006689]                              0.006689]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 2.00e-04\n",
      "Epoch 34 Train Loss = 0.0067, Accuracy = 99.91%, Test Accuracy = 99.35%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:01, 273.63batch/s, loss=0.006108]                              0.006108]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 2.00e-04\n",
      "Epoch 35 Train Loss = 0.0061, Accuracy = 99.93%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:01, 241.68batch/s, loss=0.005708]                              0.005708]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 2.00e-04\n",
      "Epoch 36 Train Loss = 0.0057, Accuracy = 99.93%, Test Accuracy = 99.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:02, 231.09batch/s, loss=0.005309]                              0.005309]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 2.00e-04\n",
      "Epoch 37 Train Loss = 0.0053, Accuracy = 99.95%, Test Accuracy = 99.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:02, 190.86batch/s, loss=0.005052]                              0.005052]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 2.00e-04\n",
      "Epoch 38 Train Loss = 0.0050, Accuracy = 99.95%, Test Accuracy = 99.40%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:02, 223.78batch/s, loss=0.004500]                              0.004500]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.00e-04\n",
      "Epoch 39 Train Loss = 0.0045, Accuracy = 99.97%, Test Accuracy = 99.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:01, 248.37batch/s, loss=0.004241]                              0.004241]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.00e-04\n",
      "Epoch 40 Train Loss = 0.0043, Accuracy = 99.97%, Test Accuracy = 99.33%\n",
      "2 end at 20250923-152324\n",
      "3 start at 20250923-152324\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:01, 274.44batch/s, loss=0.593103]                               0.593103]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.00e-04\n",
      "Epoch 1 Train Loss = 0.5875, Accuracy = 86.84%, Test Accuracy = 95.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:01, 310.00batch/s, loss=0.152959]                               0.152959]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.00e-04\n",
      "Epoch 2 Train Loss = 0.1528, Accuracy = 96.07%, Test Accuracy = 97.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:01, 245.52batch/s, loss=0.104967]                               0.104967]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.00e-04\n",
      "Epoch 3 Train Loss = 0.1045, Accuracy = 97.20%, Test Accuracy = 97.86%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:01, 240.94batch/s, loss=0.082157]                               0.082157]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.00e-04\n",
      "Epoch 4 Train Loss = 0.0819, Accuracy = 97.84%, Test Accuracy = 98.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:01, 307.73batch/s, loss=0.068413]                               0.068413]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.00e-04\n",
      "Epoch 5 Train Loss = 0.0684, Accuracy = 98.18%, Test Accuracy = 98.39%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:01, 285.40batch/s, loss=0.058496]                               0.058496]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.00e-04\n",
      "Epoch 6 Train Loss = 0.0584, Accuracy = 98.45%, Test Accuracy = 98.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:01, 252.67batch/s, loss=0.051275]                               0.051275]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.00e-04\n",
      "Epoch 7 Train Loss = 0.0511, Accuracy = 98.64%, Test Accuracy = 98.75%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:02, 200.30batch/s, loss=0.045657]                               0.045657]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.00e-04\n",
      "Epoch 8 Train Loss = 0.0458, Accuracy = 98.77%, Test Accuracy = 98.82%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:01, 247.15batch/s, loss=0.041314]                               0.041314]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.00e-04\n",
      "Epoch 9 Train Loss = 0.0413, Accuracy = 98.91%, Test Accuracy = 98.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:01, 286.18batch/s, loss=0.037302]                              0.037302]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.00e-04\n",
      "Epoch 10 Train Loss = 0.0375, Accuracy = 99.04%, Test Accuracy = 98.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:01, 313.81batch/s, loss=0.034229]                              0.034229]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.00e-04\n",
      "Epoch 11 Train Loss = 0.0341, Accuracy = 99.13%, Test Accuracy = 98.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:02, 205.11batch/s, loss=0.031619]                              0.031619]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.00e-04\n",
      "Epoch 12 Train Loss = 0.0316, Accuracy = 99.19%, Test Accuracy = 98.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:01, 272.74batch/s, loss=0.028970]                              0.028970]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.00e-04\n",
      "Epoch 13 Train Loss = 0.0288, Accuracy = 99.27%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:02, 213.51batch/s, loss=0.027100]                              0.027100]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.00e-04\n",
      "Epoch 14 Train Loss = 0.0271, Accuracy = 99.29%, Test Accuracy = 99.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:02, 212.17batch/s, loss=0.025065]                              0.025065]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 2.00e-04\n",
      "Epoch 15 Train Loss = 0.0250, Accuracy = 99.37%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:01, 239.61batch/s, loss=0.023219]                              0.023219]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 2.00e-04\n",
      "Epoch 16 Train Loss = 0.0233, Accuracy = 99.39%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:01, 280.75batch/s, loss=0.021770]                              0.021770]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 2.00e-04\n",
      "Epoch 17 Train Loss = 0.0218, Accuracy = 99.47%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:01, 244.48batch/s, loss=0.019776]                              0.019776]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 2.00e-04\n",
      "Epoch 18 Train Loss = 0.0200, Accuracy = 99.51%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:01, 262.28batch/s, loss=0.018790]                              0.018790]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 2.00e-04\n",
      "Epoch 19 Train Loss = 0.0188, Accuracy = 99.55%, Test Accuracy = 99.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:01, 259.25batch/s, loss=0.017398]                              0.017398]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 2.00e-04\n",
      "Epoch 20 Train Loss = 0.0174, Accuracy = 99.58%, Test Accuracy = 99.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:02, 228.86batch/s, loss=0.016560]                              0.016560]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 2.00e-04\n",
      "Epoch 21 Train Loss = 0.0165, Accuracy = 99.62%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:01, 261.71batch/s, loss=0.015493]                              0.015493]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 2.00e-04\n",
      "Epoch 22 Train Loss = 0.0154, Accuracy = 99.66%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:01, 268.30batch/s, loss=0.014331]                              0.014331]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 2.00e-04\n",
      "Epoch 23 Train Loss = 0.0143, Accuracy = 99.69%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:01, 264.81batch/s, loss=0.013336]                              0.013336]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 2.00e-04\n",
      "Epoch 24 Train Loss = 0.0134, Accuracy = 99.72%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:01, 279.36batch/s, loss=0.012561]                              0.012561]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 2.00e-04\n",
      "Epoch 25 Train Loss = 0.0125, Accuracy = 99.74%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:01, 306.22batch/s, loss=0.011692]                              0.011692]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 2.00e-04\n",
      "Epoch 26 Train Loss = 0.0117, Accuracy = 99.77%, Test Accuracy = 99.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:01, 289.90batch/s, loss=0.010710]                              0.010710]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 2.00e-04\n",
      "Epoch 27 Train Loss = 0.0107, Accuracy = 99.81%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:02, 226.63batch/s, loss=0.010128]                              0.010128]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 2.00e-04\n",
      "Epoch 28 Train Loss = 0.0101, Accuracy = 99.82%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:01, 244.39batch/s, loss=0.009425]                              0.009425]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 2.00e-04\n",
      "Epoch 29 Train Loss = 0.0095, Accuracy = 99.82%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:02, 233.23batch/s, loss=0.008744]                              0.008744]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 2.00e-04\n",
      "Epoch 30 Train Loss = 0.0088, Accuracy = 99.86%, Test Accuracy = 99.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:01, 281.32batch/s, loss=0.008059]                              0.008059]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 2.00e-04\n",
      "Epoch 31 Train Loss = 0.0080, Accuracy = 99.89%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:01, 262.66batch/s, loss=0.007483]                              0.007483]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 2.00e-04\n",
      "Epoch 32 Train Loss = 0.0076, Accuracy = 99.91%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:01, 265.09batch/s, loss=0.006909]                              0.006909]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 2.00e-04\n",
      "Epoch 33 Train Loss = 0.0069, Accuracy = 99.91%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:01, 244.97batch/s, loss=0.006572]                              0.006572]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 2.00e-04\n",
      "Epoch 34 Train Loss = 0.0066, Accuracy = 99.92%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:01, 291.22batch/s, loss=0.005841]                              0.005841]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 2.00e-04\n",
      "Epoch 35 Train Loss = 0.0059, Accuracy = 99.94%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:01, 305.51batch/s, loss=0.005728]                              0.005728]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 2.00e-04\n",
      "Epoch 36 Train Loss = 0.0057, Accuracy = 99.94%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:02, 228.10batch/s, loss=0.005029]                              0.005029]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 2.00e-04\n",
      "Epoch 37 Train Loss = 0.0050, Accuracy = 99.97%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:02, 219.52batch/s, loss=0.004853]                              0.004853]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 2.00e-04\n",
      "Epoch 38 Train Loss = 0.0049, Accuracy = 99.95%, Test Accuracy = 99.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:01, 242.29batch/s, loss=0.004470]                              0.004470]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.00e-04\n",
      "Epoch 39 Train Loss = 0.0045, Accuracy = 99.97%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:02, 206.00batch/s, loss=0.004010]                              0.004010]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.00e-04\n",
      "Epoch 40 Train Loss = 0.0040, Accuracy = 99.98%, Test Accuracy = 99.26%\n",
      "3 end at 20250923-152439\n",
      "4 start at 20250923-152439\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:01, 275.24batch/s, loss=0.596632]                               0.596632]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Current LR: 2.00e-04\n",
      "Epoch 1 Train Loss = 0.5900, Accuracy = 87.92%, Test Accuracy = 95.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:01, 247.80batch/s, loss=0.152199]                               0.152199]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Current LR: 2.00e-04\n",
      "Epoch 2 Train Loss = 0.1516, Accuracy = 96.17%, Test Accuracy = 97.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:02, 228.37batch/s, loss=0.100403]                               0.100403]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Current LR: 2.00e-04\n",
      "Epoch 3 Train Loss = 0.1003, Accuracy = 97.39%, Test Accuracy = 97.90%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:01, 243.50batch/s, loss=0.076573]                               0.076573]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Current LR: 2.00e-04\n",
      "Epoch 4 Train Loss = 0.0768, Accuracy = 97.99%, Test Accuracy = 98.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:01, 264.56batch/s, loss=0.062644]                               0.062644]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Current LR: 2.00e-04\n",
      "Epoch 5 Train Loss = 0.0626, Accuracy = 98.34%, Test Accuracy = 98.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:02, 210.41batch/s, loss=0.053679]                               0.053679]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Current LR: 2.00e-04\n",
      "Epoch 6 Train Loss = 0.0538, Accuracy = 98.60%, Test Accuracy = 98.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:01, 258.21batch/s, loss=0.046703]                               0.046703]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Current LR: 2.00e-04\n",
      "Epoch 7 Train Loss = 0.0469, Accuracy = 98.74%, Test Accuracy = 98.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:02, 214.37batch/s, loss=0.041847]                               0.041847]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Current LR: 2.00e-04\n",
      "Epoch 8 Train Loss = 0.0418, Accuracy = 98.90%, Test Accuracy = 98.93%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:01, 254.88batch/s, loss=0.037934]                               0.037934]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Current LR: 2.00e-04\n",
      "Epoch 9 Train Loss = 0.0379, Accuracy = 99.02%, Test Accuracy = 98.96%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:01, 299.35batch/s, loss=0.034053]                              0.034053]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Current LR: 2.00e-04\n",
      "Epoch 10 Train Loss = 0.0342, Accuracy = 99.11%, Test Accuracy = 99.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:02, 208.09batch/s, loss=0.031306]                              0.031306]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Current LR: 2.00e-04\n",
      "Epoch 11 Train Loss = 0.0313, Accuracy = 99.16%, Test Accuracy = 99.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:01, 254.29batch/s, loss=0.028754]                              0.028754]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Current LR: 2.00e-04\n",
      "Epoch 12 Train Loss = 0.0287, Accuracy = 99.25%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:01, 256.95batch/s, loss=0.026510]                              0.026510]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Current LR: 2.00e-04\n",
      "Epoch 13 Train Loss = 0.0267, Accuracy = 99.31%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:02, 221.69batch/s, loss=0.024726]                              0.024726]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Current LR: 2.00e-04\n",
      "Epoch 14 Train Loss = 0.0248, Accuracy = 99.33%, Test Accuracy = 99.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:01, 261.38batch/s, loss=0.023005]                              0.023005]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Current LR: 2.00e-04\n",
      "Epoch 15 Train Loss = 0.0230, Accuracy = 99.40%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:01, 255.87batch/s, loss=0.021420]                              0.021420]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16, Current LR: 2.00e-04\n",
      "Epoch 16 Train Loss = 0.0214, Accuracy = 99.47%, Test Accuracy = 99.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:02, 218.94batch/s, loss=0.019963]                              0.019963]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17, Current LR: 2.00e-04\n",
      "Epoch 17 Train Loss = 0.0199, Accuracy = 99.48%, Test Accuracy = 99.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:01, 264.65batch/s, loss=0.018766]                              0.018766]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18, Current LR: 2.00e-04\n",
      "Epoch 18 Train Loss = 0.0188, Accuracy = 99.52%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:02, 220.75batch/s, loss=0.017507]                              0.017507]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19, Current LR: 2.00e-04\n",
      "Epoch 19 Train Loss = 0.0175, Accuracy = 99.58%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:01, 244.67batch/s, loss=0.016137]                              0.016137]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20, Current LR: 2.00e-04\n",
      "Epoch 20 Train Loss = 0.0162, Accuracy = 99.61%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:02, 207.65batch/s, loss=0.014903]                              0.014903]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21, Current LR: 2.00e-04\n",
      "Epoch 21 Train Loss = 0.0150, Accuracy = 99.66%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:02, 212.74batch/s, loss=0.014058]                              0.014058]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22, Current LR: 2.00e-04\n",
      "Epoch 22 Train Loss = 0.0141, Accuracy = 99.69%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:01, 251.27batch/s, loss=0.013173]                              0.013173]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23, Current LR: 2.00e-04\n",
      "Epoch 23 Train Loss = 0.0131, Accuracy = 99.72%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:02, 231.96batch/s, loss=0.012258]                              0.012258]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24, Current LR: 2.00e-04\n",
      "Epoch 24 Train Loss = 0.0122, Accuracy = 99.74%, Test Accuracy = 99.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:02, 199.95batch/s, loss=0.011440]                              0.011440]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25, Current LR: 2.00e-04\n",
      "Epoch 25 Train Loss = 0.0114, Accuracy = 99.78%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:02, 229.86batch/s, loss=0.010568]                              0.010568]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26, Current LR: 2.00e-04\n",
      "Epoch 26 Train Loss = 0.0107, Accuracy = 99.79%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:02, 206.77batch/s, loss=0.009901]                              0.009901]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27, Current LR: 2.00e-04\n",
      "Epoch 27 Train Loss = 0.0100, Accuracy = 99.80%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:01, 269.78batch/s, loss=0.009052]                              0.009052]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28, Current LR: 2.00e-04\n",
      "Epoch 28 Train Loss = 0.0091, Accuracy = 99.85%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:01, 259.49batch/s, loss=0.008543]                              0.008543]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29, Current LR: 2.00e-04\n",
      "Epoch 29 Train Loss = 0.0085, Accuracy = 99.87%, Test Accuracy = 99.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:02, 223.35batch/s, loss=0.007928]                              0.007928]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30, Current LR: 2.00e-04\n",
      "Epoch 30 Train Loss = 0.0079, Accuracy = 99.87%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:01, 261.28batch/s, loss=0.007287]                              0.007287]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31, Current LR: 2.00e-04\n",
      "Epoch 31 Train Loss = 0.0073, Accuracy = 99.89%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:01, 290.46batch/s, loss=0.006881]                              0.006881]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32, Current LR: 2.00e-04\n",
      "Epoch 32 Train Loss = 0.0069, Accuracy = 99.89%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:01, 263.15batch/s, loss=0.006263]                              0.006263]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33, Current LR: 2.00e-04\n",
      "Epoch 33 Train Loss = 0.0063, Accuracy = 99.94%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:01, 269.14batch/s, loss=0.005854]                              0.005854]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34, Current LR: 2.00e-04\n",
      "Epoch 34 Train Loss = 0.0059, Accuracy = 99.94%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:01, 241.66batch/s, loss=0.005589]                              0.005589]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35, Current LR: 2.00e-04\n",
      "Epoch 35 Train Loss = 0.0055, Accuracy = 99.93%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:01, 271.71batch/s, loss=0.005010]                              0.005010]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36, Current LR: 2.00e-04\n",
      "Epoch 36 Train Loss = 0.0051, Accuracy = 99.94%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:01, 290.16batch/s, loss=0.004660]                              0.004660]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37, Current LR: 2.00e-04\n",
      "Epoch 37 Train Loss = 0.0046, Accuracy = 99.97%, Test Accuracy = 99.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:01, 260.53batch/s, loss=0.004413]                              0.004413]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38, Current LR: 2.00e-04\n",
      "Epoch 38 Train Loss = 0.0044, Accuracy = 99.97%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:01, 248.66batch/s, loss=0.003877]                              0.003877]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39, Current LR: 2.00e-04\n",
      "Epoch 39 Train Loss = 0.0039, Accuracy = 99.98%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:01, 253.95batch/s, loss=0.003741]                              0.003741]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40, Current LR: 2.00e-04\n",
      "Epoch 40 Train Loss = 0.0037, Accuracy = 99.98%, Test Accuracy = 99.30%\n",
      "4 end at 20250923-152557\n"
     ]
    }
   ],
   "source": [
    "\n",
    "num_epochs = 40\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",
    "\n",
    "        model = aEP_CNN(fbsc=0.01, deviden=False, T=20, K=10, chl=[32,64])\n",
    "        \n",
    "        # optimizer = torch.optim.SGD([\n",
    "        #     {'params': model.conv1.parameters(), 'lr': 0.05, 'weight_decay': 1e-6},  # conv1 \n",
    "        #     {'params': model.conv2.parameters(), 'lr': 0.15, 'weight_decay': 1e-6},  # conv2 \n",
    "        #     {'params': model.fc1.parameters(), 'lr': 0.5, 'weight_decay': 1e-6},  # \n",
    "        # ])\n",
    "        optimizer = torch.optim.AdamW(model.parameters(), lr=2e-4, weight_decay=1e-6) # 2.5 ~ 1e-4 0.5e-4\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": "d90b50ec",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\t_train: 99.97%+-0.01% (99.96% 99.98%)\t test: 99.34%+-0.04% (99.31% 99.40%)\n",
      "\n",
      "Current Time: 20250923-152557\n"
     ]
    },
    {
     "data": {
      "image/png": "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RoOEhAR89tlnNp8/ePAg7rjjDmg0GoSGhuLxxx9HbW2tzTYrV67EDTfcAJVKhaioKDz11FM260tLS3H//ffDx8cHXbt2xbfffnttD5rIDTChEl1nZs6ciQceeAD79+/HI488gnHjxuHo0aMAgPr6etx9990IDg7G7t278dlnn2HTpk02CXP58uWYMmUKHn/8cRw8eBDffvstunTpYvMdc+bMwYMPPogDBw5gxIgRePjhh1FeXu7U4yRyOofNh0NELjdhwgRBJpMJvr6+No+5c+cKgiBOczZp0iSbz/Tr10948sknBUEQhBUrVgjBwcFCbW2tdf0PP/wgSKVSoaioSBAEQYiOjhZeeumlVmMAILz88svW97W1tYJEIhH++9//Ouw4idwRr6ESeZnBgwdj+fLlNstCQkKsr9PT023WpaenY9++fQCAo0ePonfv3vD19bWuHzhwIEwmE3JzcyGRSFBQUIA777zzkjH06tXL+trX1xf+/v4oKSm50kMi8ghMqERextfX164J9nIkEgkAQBAE6+uWttFoNG3an0KhsPusyWRqV0xEnobXUImuM7/99pvd+x49egAAkpOTsW/fPtTV1VnXb9++HVKpFN26dYO/vz/i4+Px888/OzVmIk/AGiqRl9FqtSgqKrJZJpfLERYWBgD47LPPkJaWhltuuQVr165FdnY2PvzwQwDAww8/jFmzZmHChAmYPXs2Lly4gKeffhrjx49HREQEAGD27NmYNGkSOnTogOHDh6Ompgbbt2/H008/7dwDJXIzTKhEXubHH39EVFSUzbLu3bvjjz/+ACD2wF23bh0mT56MyMhIrF27FsnJyQAAHx8f/PTTT5g6dSr69u0LHx8fPPDAA1i0aJF1XxMmTEBjYyPeeustPP/88wgLC8Po0aOdd4BEbkoiCILg6iCIyDkkEgm++uorjBo1ytWhEHkdXkMlIiJyACZUIiIiB+A1VKLrCK/wEF07rKESERE5ABMqERGRAzChEhEROQATKhERkQMwoRIRETkAEyoREZEDMKESERE5ABMqERGRA/x/3DzEVjeoYusAAAAASUVORK5CYII=",
      "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": "df9f3564",
   "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 20250923-152558\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:12, 36.35batch/s, loss=0.688024]                                0.688024]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 0.6816, Accuracy = 86.97%, Test Accuracy = 94.81%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:12, 38.98batch/s, loss=0.216661]                                0.216661]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 0.2158, Accuracy = 95.39%, Test Accuracy = 96.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:12, 38.97batch/s, loss=0.149725]                                0.149725]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 0.1493, Accuracy = 96.59%, Test Accuracy = 97.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:12, 37.94batch/s, loss=0.120118]                                0.120118]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 0.1199, Accuracy = 97.16%, Test Accuracy = 97.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:11, 39.24batch/s, loss=0.104499]                                0.104499]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 0.1046, Accuracy = 97.55%, Test Accuracy = 97.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:12, 38.16batch/s, loss=0.095416]                                0.095416]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 0.0950, Accuracy = 97.76%, Test Accuracy = 98.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:12, 39.09batch/s, loss=0.086589]                                0.086589]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.0866, Accuracy = 97.95%, Test Accuracy = 98.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:12, 37.87batch/s, loss=0.077448]                                0.077448]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.0774, Accuracy = 98.13%, Test Accuracy = 98.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:12, 37.88batch/s, loss=0.069135]                                0.069135]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.0689, Accuracy = 98.32%, Test Accuracy = 98.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:12, 38.35batch/s, loss=0.063309]                               0.063309]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.0630, Accuracy = 98.44%, Test Accuracy = 98.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:12, 37.86batch/s, loss=0.057904]                               0.057904]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.0578, Accuracy = 98.56%, Test Accuracy = 98.67%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:12, 38.44batch/s, loss=0.052750]                               0.052750]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.0527, Accuracy = 98.69%, Test Accuracy = 98.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:12, 37.87batch/s, loss=0.048848]                               0.048848]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.0489, Accuracy = 98.77%, Test Accuracy = 98.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:11, 39.21batch/s, loss=0.046420]                               0.046420]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.0463, Accuracy = 98.83%, Test Accuracy = 98.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:12, 39.06batch/s, loss=0.044493]                               0.044493]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.0443, Accuracy = 98.90%, Test Accuracy = 98.78%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:12, 38.96batch/s, loss=0.042010]                               0.042010]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.0418, Accuracy = 98.93%, Test Accuracy = 98.89%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:12, 39.10batch/s, loss=0.038135]                               0.038135]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.0381, Accuracy = 99.00%, Test Accuracy = 98.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:12, 38.63batch/s, loss=0.035767]                               0.035767]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.0358, Accuracy = 99.08%, Test Accuracy = 98.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:11, 39.26batch/s, loss=0.033601]                               0.033601]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.0336, Accuracy = 99.11%, Test Accuracy = 99.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:12, 38.12batch/s, loss=0.031446]                               0.031446]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.0315, Accuracy = 99.19%, Test Accuracy = 99.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:11, 39.26batch/s, loss=0.029435]                               0.029435]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.0295, Accuracy = 99.25%, Test Accuracy = 99.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:11, 39.26batch/s, loss=0.028224]                               0.028224]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.0283, Accuracy = 99.30%, Test Accuracy = 99.01%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:12, 37.76batch/s, loss=0.026990]                               0.026990]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.0269, Accuracy = 99.32%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:12, 38.77batch/s, loss=0.025203]                               0.025203]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.0252, Accuracy = 99.41%, Test Accuracy = 99.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:12, 38.91batch/s, loss=0.023361]                               0.023361]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.0235, Accuracy = 99.44%, Test Accuracy = 99.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:12, 39.07batch/s, loss=0.021005]                               0.021005]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.0214, Accuracy = 99.50%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:12, 38.22batch/s, loss=0.020661]                               0.020661]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.0206, Accuracy = 99.53%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:12, 37.56batch/s, loss=0.020272]                               0.020272]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.0202, Accuracy = 99.53%, Test Accuracy = 99.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:12, 38.75batch/s, loss=0.018712]                               0.018712]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.0189, Accuracy = 99.58%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:12, 38.70batch/s, loss=0.019985]                               0.019985]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.0200, Accuracy = 99.59%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:12, 37.79batch/s, loss=0.023128]                               0.023128]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.0231, Accuracy = 99.49%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:12, 39.02batch/s, loss=0.021819]                               0.021819]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.0219, Accuracy = 99.52%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:13, 34.03batch/s, loss=0.021604]                               0.021604]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.0216, Accuracy = 99.53%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:12, 37.57batch/s, loss=0.020313]                               0.020313]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.0202, Accuracy = 99.55%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:12, 37.43batch/s, loss=0.019341]                               0.019341]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.0193, Accuracy = 99.61%, Test Accuracy = 99.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:11, 39.22batch/s, loss=0.017905]                               0.017905]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.0178, Accuracy = 99.60%, Test Accuracy = 99.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:12, 37.89batch/s, loss=0.016776]                               0.016776]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.0167, Accuracy = 99.63%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:12, 38.66batch/s, loss=0.015950]                               0.015950]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.0159, Accuracy = 99.69%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:12, 37.82batch/s, loss=0.014946]                               0.014946]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.0151, Accuracy = 99.72%, Test Accuracy = 99.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:12, 36.47batch/s, loss=0.014242]                               0.014242]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.0143, Accuracy = 99.75%, Test Accuracy = 99.19%\n",
      "0-0 end at 20250923-153439\n",
      "0 start at 20250923-153439\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:13, 35.61batch/s, loss=0.667881]                                0.667881]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 0.6613, Accuracy = 86.76%, Test Accuracy = 95.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:12, 36.38batch/s, loss=0.216482]                                0.216482]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 0.2159, Accuracy = 95.51%, Test Accuracy = 96.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:13, 35.38batch/s, loss=0.160906]                                0.160906]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 0.1610, Accuracy = 96.58%, Test Accuracy = 97.36%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:13, 34.48batch/s, loss=0.133602]                                0.133602]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 0.1334, Accuracy = 97.11%, Test Accuracy = 97.58%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:13, 34.95batch/s, loss=0.114912]                                0.114912]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 0.1147, Accuracy = 97.48%, Test Accuracy = 97.86%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:13, 34.06batch/s, loss=0.100822]                                0.100822]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 0.1008, Accuracy = 97.76%, Test Accuracy = 98.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:12, 36.16batch/s, loss=0.090311]                                0.090311]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.0901, Accuracy = 97.99%, Test Accuracy = 98.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:12, 37.03batch/s, loss=0.079172]                                0.079172]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.0791, Accuracy = 98.18%, Test Accuracy = 98.40%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:12, 37.18batch/s, loss=0.068626]                                0.068626]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.0683, Accuracy = 98.40%, Test Accuracy = 98.48%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:12, 37.51batch/s, loss=0.059200]                               0.059200]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.0593, Accuracy = 98.56%, Test Accuracy = 98.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:12, 37.52batch/s, loss=0.051924]                               0.051924]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.0518, Accuracy = 98.71%, Test Accuracy = 98.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:12, 38.97batch/s, loss=0.045624]                               0.045624]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.0457, Accuracy = 98.84%, Test Accuracy = 98.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:12, 36.91batch/s, loss=0.040782]                               0.040782]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.0408, Accuracy = 98.97%, Test Accuracy = 98.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:12, 37.07batch/s, loss=0.036770]                               0.036770]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.0369, Accuracy = 99.07%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:12, 38.08batch/s, loss=0.033601]                               0.033601]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.0337, Accuracy = 99.15%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:12, 36.71batch/s, loss=0.030470]                               0.030470]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.0304, Accuracy = 99.22%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:12, 38.50batch/s, loss=0.027866]                               0.027866]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.0279, Accuracy = 99.30%, Test Accuracy = 99.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:12, 37.62batch/s, loss=0.025717]                               0.025717]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.0256, Accuracy = 99.34%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:12, 37.85batch/s, loss=0.023372]                               0.023372]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.0234, Accuracy = 99.43%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:13, 36.14batch/s, loss=0.022126]                               0.022126]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.0221, Accuracy = 99.47%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:12, 36.88batch/s, loss=0.020985]                               0.020985]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.0210, Accuracy = 99.51%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:12, 36.81batch/s, loss=0.019696]                               0.019696]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.0198, Accuracy = 99.55%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:12, 37.55batch/s, loss=0.018276]                               0.018276]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.0183, Accuracy = 99.61%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:12, 36.58batch/s, loss=0.016923]                               0.016923]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.0168, Accuracy = 99.63%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:12, 37.36batch/s, loss=0.015492]                               0.015492]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.0155, Accuracy = 99.68%, Test Accuracy = 99.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:14, 33.54batch/s, loss=0.013956]                               0.013956]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.0140, Accuracy = 99.73%, Test Accuracy = 99.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:13, 35.25batch/s, loss=0.012717]                               0.012717]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.0128, Accuracy = 99.75%, Test Accuracy = 99.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:12, 37.12batch/s, loss=0.011520]                               0.011520]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.0115, Accuracy = 99.81%, Test Accuracy = 99.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:12, 37.20batch/s, loss=0.010534]                               0.010534]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.0106, Accuracy = 99.81%, Test Accuracy = 99.27%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:12, 37.92batch/s, loss=0.009619]                               0.009619]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.0097, Accuracy = 99.85%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:12, 37.94batch/s, loss=0.008664]                               0.008664]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.0086, Accuracy = 99.87%, Test Accuracy = 99.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:12, 38.64batch/s, loss=0.007974]                               0.007974]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.0080, Accuracy = 99.88%, Test Accuracy = 99.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:12, 37.68batch/s, loss=0.007205]                               0.007205]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.0072, Accuracy = 99.91%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:12, 37.26batch/s, loss=0.006673]                               0.006673]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.0067, Accuracy = 99.91%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:12, 37.84batch/s, loss=0.006064]                               0.006064]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.0061, Accuracy = 99.94%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:12, 37.48batch/s, loss=0.006105]                               0.006105]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.0061, Accuracy = 99.94%, Test Accuracy = 99.32%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:12, 38.40batch/s, loss=0.006347]                               0.006347]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.0064, Accuracy = 99.94%, Test Accuracy = 99.37%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:12, 37.72batch/s, loss=0.006616]                               0.006616]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.0066, Accuracy = 99.94%, Test Accuracy = 99.30%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:12, 36.79batch/s, loss=0.007912]                               0.007912]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.0079, Accuracy = 99.93%, Test Accuracy = 99.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:12, 37.53batch/s, loss=0.008243]                               0.008243]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.0082, Accuracy = 99.91%, Test Accuracy = 99.28%\n",
      "0-1 end at 20250923-154338\n",
      "0 start at 20250923-154338\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:12, 37.53batch/s, loss=0.692546]                                0.692546]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 0.6858, Accuracy = 86.65%, Test Accuracy = 95.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:12, 37.24batch/s, loss=0.220229]                                0.220229]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 0.2195, Accuracy = 95.43%, Test Accuracy = 96.43%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:12, 38.41batch/s, loss=0.158637]                                0.158637]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 0.1583, Accuracy = 96.54%, Test Accuracy = 97.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:12, 37.66batch/s, loss=0.126382]                                0.126382]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 0.1262, Accuracy = 97.14%, Test Accuracy = 97.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:12, 37.56batch/s, loss=0.106107]                                0.106107]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 0.1062, Accuracy = 97.55%, Test Accuracy = 97.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:12, 37.39batch/s, loss=0.092895]                                0.092895]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 0.0928, Accuracy = 97.81%, Test Accuracy = 98.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:12, 37.75batch/s, loss=0.081964]                                0.081964]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.0816, Accuracy = 98.04%, Test Accuracy = 98.34%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:12, 37.79batch/s, loss=0.071223]                                0.071223]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.0709, Accuracy = 98.26%, Test Accuracy = 98.49%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:12, 37.01batch/s, loss=0.060430]                                0.060430]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.0606, Accuracy = 98.41%, Test Accuracy = 98.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:12, 38.10batch/s, loss=0.054409]                               0.054409]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.0543, Accuracy = 98.63%, Test Accuracy = 98.75%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:12, 36.94batch/s, loss=0.048985]                               0.048985]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.0495, Accuracy = 98.76%, Test Accuracy = 98.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:12, 38.00batch/s, loss=0.046015]                               0.046015]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.0460, Accuracy = 98.85%, Test Accuracy = 98.84%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:12, 38.26batch/s, loss=0.043296]                               0.043296]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.0431, Accuracy = 98.93%, Test Accuracy = 98.87%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:12, 38.06batch/s, loss=0.039921]                               0.039921]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.0399, Accuracy = 99.00%, Test Accuracy = 98.90%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:12, 37.45batch/s, loss=0.036391]                               0.036391]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.0364, Accuracy = 99.05%, Test Accuracy = 98.90%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:12, 38.40batch/s, loss=0.033775]                               0.033775]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.0338, Accuracy = 99.11%, Test Accuracy = 98.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:12, 38.51batch/s, loss=0.030998]                               0.030998]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.0310, Accuracy = 99.20%, Test Accuracy = 99.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:12, 38.22batch/s, loss=0.029104]                               0.029104]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.0291, Accuracy = 99.29%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:12, 37.63batch/s, loss=0.026721]                               0.026721]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.0266, Accuracy = 99.30%, Test Accuracy = 99.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:12, 37.41batch/s, loss=0.024918]                               0.024918]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.0248, Accuracy = 99.33%, Test Accuracy = 99.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:12, 37.29batch/s, loss=0.022807]                               0.022807]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.0228, Accuracy = 99.43%, Test Accuracy = 99.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:12, 37.12batch/s, loss=0.021582]                               0.021582]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.0217, Accuracy = 99.45%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:12, 37.53batch/s, loss=0.020651]                               0.020651]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.0207, Accuracy = 99.52%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:12, 37.59batch/s, loss=0.019477]                               0.019477]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.0196, Accuracy = 99.54%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:12, 37.14batch/s, loss=0.018744]                               0.018744]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.0186, Accuracy = 99.58%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:12, 37.62batch/s, loss=0.017781]                               0.017781]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.0178, Accuracy = 99.61%, Test Accuracy = 99.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:12, 38.16batch/s, loss=0.017288]                               0.017288]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.0173, Accuracy = 99.64%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:12, 37.16batch/s, loss=0.015860]                               0.015860]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.0160, Accuracy = 99.66%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:12, 37.92batch/s, loss=0.014990]                               0.014990]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.0150, Accuracy = 99.69%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:12, 38.32batch/s, loss=0.014228]                               0.014228]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.0143, Accuracy = 99.70%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:12, 37.01batch/s, loss=0.014719]                               0.014719]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.0147, Accuracy = 99.68%, Test Accuracy = 99.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:12, 38.18batch/s, loss=0.016115]                               0.016115]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.0161, Accuracy = 99.65%, Test Accuracy = 99.00%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:12, 38.24batch/s, loss=0.014475]                               0.014475]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.0147, Accuracy = 99.71%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:12, 37.87batch/s, loss=0.015579]                               0.015579]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.0156, Accuracy = 99.71%, Test Accuracy = 99.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:12, 36.51batch/s, loss=0.015859]                               0.015859]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.0158, Accuracy = 99.66%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:12, 36.66batch/s, loss=0.016008]                               0.016008]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.0160, Accuracy = 99.66%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:12, 36.93batch/s, loss=0.017325]                               0.017325]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.0175, Accuracy = 99.64%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:12, 37.86batch/s, loss=0.019093]                               0.019093]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.0191, Accuracy = 99.61%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:12, 37.33batch/s, loss=0.018395]                               0.018395]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.0184, Accuracy = 99.60%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:12, 37.24batch/s, loss=0.017443]                               0.017443]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.0175, Accuracy = 99.64%, Test Accuracy = 99.06%\n",
      "0-2 end at 20250923-155227\n",
      "0 start at 20250923-155227\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:12, 37.75batch/s, loss=0.709382]                                0.709382]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 0.7018, Accuracy = 85.31%, Test Accuracy = 94.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:12, 37.78batch/s, loss=0.230610]                                0.230610]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 0.2297, Accuracy = 95.12%, Test Accuracy = 96.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:12, 36.88batch/s, loss=0.159267]                                0.159267]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 0.1585, Accuracy = 96.41%, Test Accuracy = 97.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:12, 37.42batch/s, loss=0.123641]                                0.123641]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 0.1237, Accuracy = 97.03%, Test Accuracy = 97.60%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:13, 34.87batch/s, loss=0.103112]                                0.103112]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 0.1029, Accuracy = 97.51%, Test Accuracy = 97.86%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:13, 34.22batch/s, loss=0.088032]                                0.088032]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 0.0880, Accuracy = 97.89%, Test Accuracy = 98.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:13, 35.21batch/s, loss=0.077630]                                0.077630]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.0773, Accuracy = 98.07%, Test Accuracy = 98.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:13, 35.74batch/s, loss=0.068348]                                0.068348]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.0683, Accuracy = 98.27%, Test Accuracy = 98.33%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:13, 34.47batch/s, loss=0.061687]                                0.061687]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.0614, Accuracy = 98.45%, Test Accuracy = 98.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:13, 34.63batch/s, loss=0.055003]                               0.055003]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.0549, Accuracy = 98.60%, Test Accuracy = 98.60%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:13, 35.88batch/s, loss=0.050597]                               0.050597]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.0507, Accuracy = 98.71%, Test Accuracy = 98.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:13, 34.30batch/s, loss=0.047232]                               0.047232]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.0472, Accuracy = 98.78%, Test Accuracy = 98.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:13, 35.38batch/s, loss=0.043774]                               0.043774]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.0438, Accuracy = 98.89%, Test Accuracy = 98.81%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:13, 34.64batch/s, loss=0.040756]                               0.040756]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.0408, Accuracy = 98.94%, Test Accuracy = 98.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:13, 34.12batch/s, loss=0.038231]                               0.038231]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.0380, Accuracy = 99.00%, Test Accuracy = 98.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:13, 35.73batch/s, loss=0.034786]                               0.034786]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.0349, Accuracy = 99.05%, Test Accuracy = 98.94%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:13, 35.22batch/s, loss=0.032494]                               0.032494]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.0324, Accuracy = 99.12%, Test Accuracy = 98.97%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:13, 35.33batch/s, loss=0.030249]                               0.030249]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.0302, Accuracy = 99.16%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:13, 35.20batch/s, loss=0.028712]                               0.028712]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.0285, Accuracy = 99.22%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:13, 34.85batch/s, loss=0.027163]                               0.027163]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.0271, Accuracy = 99.31%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:13, 35.12batch/s, loss=0.026036]                               0.026036]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.0260, Accuracy = 99.30%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:12, 37.59batch/s, loss=0.025316]                               0.025316]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.0252, Accuracy = 99.35%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:12, 36.69batch/s, loss=0.024178]                               0.024178]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.0243, Accuracy = 99.41%, Test Accuracy = 99.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:12, 37.47batch/s, loss=0.024206]                               0.024206]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.0243, Accuracy = 99.39%, Test Accuracy = 99.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:12, 37.09batch/s, loss=0.025177]                               0.025177]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.0252, Accuracy = 99.40%, Test Accuracy = 98.98%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:12, 36.77batch/s, loss=0.025657]                               0.025657]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.0256, Accuracy = 99.36%, Test Accuracy = 99.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:12, 37.95batch/s, loss=0.025178]                               0.025178]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.0253, Accuracy = 99.39%, Test Accuracy = 99.07%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:12, 36.98batch/s, loss=0.026998]                               0.026998]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.0270, Accuracy = 99.36%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:12, 36.95batch/s, loss=0.026793]                               0.026793]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.0269, Accuracy = 99.39%, Test Accuracy = 99.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:12, 37.88batch/s, loss=0.028728]                               0.028728]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.0288, Accuracy = 99.40%, Test Accuracy = 99.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:12, 37.26batch/s, loss=0.030250]                               0.030250]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.0301, Accuracy = 99.37%, Test Accuracy = 99.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:12, 36.78batch/s, loss=0.028708]                               0.028708]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.0287, Accuracy = 99.40%, Test Accuracy = 99.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:12, 36.16batch/s, loss=0.027533]                               0.027533]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.0275, Accuracy = 99.41%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:12, 36.76batch/s, loss=0.025718]                               0.025718]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.0257, Accuracy = 99.47%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:12, 38.34batch/s, loss=0.025010]                               0.025010]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.0251, Accuracy = 99.46%, Test Accuracy = 99.13%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:12, 36.89batch/s, loss=0.021961]                               0.021961]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.0220, Accuracy = 99.45%, Test Accuracy = 99.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:12, 36.67batch/s, loss=0.019118]                               0.019118]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.0190, Accuracy = 99.52%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:12, 37.89batch/s, loss=0.016839]                               0.016839]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.0167, Accuracy = 99.60%, Test Accuracy = 99.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:12, 37.45batch/s, loss=0.015629]                               0.015629]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.0156, Accuracy = 99.64%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:12, 37.12batch/s, loss=0.014545]                               0.014545]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.0144, Accuracy = 99.71%, Test Accuracy = 99.24%\n",
      "0-3 end at 20250923-160135\n",
      "0 start at 20250923-160135\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [00:12, 37.95batch/s, loss=0.690663]                                0.690663]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 0.6839, Accuracy = 86.26%, Test Accuracy = 94.44%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [00:12, 37.82batch/s, loss=0.234225]                                0.234225]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 0.2336, Accuracy = 94.98%, Test Accuracy = 96.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [00:12, 37.57batch/s, loss=0.166542]                                0.166542]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 0.1664, Accuracy = 96.26%, Test Accuracy = 97.02%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [00:12, 37.58batch/s, loss=0.131238]                                0.131238]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 0.1314, Accuracy = 96.91%, Test Accuracy = 97.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [00:12, 38.06batch/s, loss=0.108747]                                0.108747]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 0.1087, Accuracy = 97.37%, Test Accuracy = 97.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [00:12, 37.74batch/s, loss=0.088982]                                0.088982]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 0.0888, Accuracy = 97.77%, Test Accuracy = 98.08%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [00:12, 37.13batch/s, loss=0.077990]                                0.077990]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.0778, Accuracy = 98.10%, Test Accuracy = 98.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [00:12, 37.53batch/s, loss=0.069565]                                0.069565]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.0694, Accuracy = 98.28%, Test Accuracy = 98.29%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [00:12, 36.73batch/s, loss=0.063178]                                0.063178]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.0629, Accuracy = 98.46%, Test Accuracy = 98.51%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [00:12, 38.86batch/s, loss=0.057366]                               0.057366]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.0574, Accuracy = 98.56%, Test Accuracy = 98.55%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [00:12, 37.36batch/s, loss=0.052624]                               0.052624]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.0528, Accuracy = 98.68%, Test Accuracy = 98.70%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [00:12, 37.38batch/s, loss=0.048145]                               0.048145]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.0481, Accuracy = 98.77%, Test Accuracy = 98.72%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [00:12, 38.28batch/s, loss=0.044129]                               0.044129]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.0440, Accuracy = 98.86%, Test Accuracy = 98.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [00:12, 37.30batch/s, loss=0.040506]                               0.040506]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.0404, Accuracy = 98.95%, Test Accuracy = 98.93%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [00:12, 38.15batch/s, loss=0.036915]                               0.036915]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.0368, Accuracy = 99.06%, Test Accuracy = 98.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [00:12, 37.06batch/s, loss=0.034359]                               0.034359]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.0343, Accuracy = 99.10%, Test Accuracy = 98.96%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [00:12, 37.54batch/s, loss=0.032507]                               0.032507]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.0326, Accuracy = 99.16%, Test Accuracy = 98.91%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [00:12, 37.73batch/s, loss=0.030606]                               0.030606]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.0306, Accuracy = 99.23%, Test Accuracy = 98.99%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [00:12, 37.96batch/s, loss=0.027519]                               0.027519]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.0277, Accuracy = 99.31%, Test Accuracy = 99.05%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [00:12, 37.77batch/s, loss=0.025627]                               0.025627]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.0257, Accuracy = 99.36%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [00:12, 37.86batch/s, loss=0.023957]                               0.023957]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.0238, Accuracy = 99.42%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [00:12, 36.52batch/s, loss=0.022546]                               0.022546]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.0225, Accuracy = 99.44%, Test Accuracy = 99.09%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [00:12, 36.17batch/s, loss=0.021077]                               0.021077]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.0210, Accuracy = 99.51%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [00:12, 37.23batch/s, loss=0.019041]                               0.019041]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.0191, Accuracy = 99.58%, Test Accuracy = 99.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [00:12, 37.41batch/s, loss=0.017764]                               0.017764]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.0178, Accuracy = 99.61%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [00:12, 36.84batch/s, loss=0.016581]                               0.016581]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.0166, Accuracy = 99.65%, Test Accuracy = 99.22%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [00:12, 37.21batch/s, loss=0.015653]                               0.015653]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.0157, Accuracy = 99.69%, Test Accuracy = 99.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [00:12, 36.87batch/s, loss=0.014924]                               0.014924]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.0149, Accuracy = 99.72%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [00:12, 36.70batch/s, loss=0.014771]                               0.014771]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.0147, Accuracy = 99.73%, Test Accuracy = 99.14%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [00:12, 36.26batch/s, loss=0.014327]                               0.014327]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.0144, Accuracy = 99.75%, Test Accuracy = 99.19%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [00:12, 37.22batch/s, loss=0.013627]                               0.013627]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.0138, Accuracy = 99.76%, Test Accuracy = 99.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [00:12, 38.48batch/s, loss=0.014012]                               0.014012]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.0140, Accuracy = 99.74%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [00:12, 37.74batch/s, loss=0.015077]                               0.015077]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.0152, Accuracy = 99.72%, Test Accuracy = 99.18%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [00:12, 38.34batch/s, loss=0.023889]                               0.023889]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.0241, Accuracy = 99.62%, Test Accuracy = 98.88%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [00:12, 38.04batch/s, loss=0.029610]                               0.029610]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.0297, Accuracy = 99.48%, Test Accuracy = 99.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [00:12, 38.13batch/s, loss=0.027968]                               0.027968]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.0280, Accuracy = 99.47%, Test Accuracy = 99.04%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [00:12, 37.83batch/s, loss=0.025187]                               0.025187]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.0253, Accuracy = 99.53%, Test Accuracy = 99.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [00:12, 37.21batch/s, loss=0.023923]                               0.023923]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.0238, Accuracy = 99.58%, Test Accuracy = 99.16%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [00:12, 36.95batch/s, loss=0.022459]                               0.022459]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.0226, Accuracy = 99.61%, Test Accuracy = 99.23%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [00:12, 37.22batch/s, loss=0.021374]                               0.021374]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.0214, Accuracy = 99.65%, Test Accuracy = 99.15%\n",
      "0-4 end at 20250923-161026\n"
     ]
    }
   ],
   "source": [
    "\n",
    "num_epochs = 40\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 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=0.01, nudge=0.25, deviden=False, T=20, K=10, chl=[32,64])\n",
    "        \n",
    "        \n",
    "        # optimizer = torch.optim.SGD([\n",
    "        #     {'params': model.conv1.parameters(), 'lr': 0.05, 'weight_decay': 1e-6},  # conv1 \n",
    "        #     {'params': model.conv2.parameters(), 'lr': 0.15, 'weight_decay': 1e-6},  # conv2 \n",
    "        #     {'params': model.fc1.parameters(), 'lr': 0.5, 'weight_decay': 1e-6},  # \n",
    "        # ])\n",
    "        optimizer = torch.optim.AdamW(model.parameters(), lr=2e-4, weight_decay=1e-6) # 2.5 ~ 1e-4 0.5e-4\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_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: 99.78%+-0.10% (99.71% 99.94%)\t test: 99.27%+-0.07% (99.19% 99.38%)\n",
      "\n",
      "Current Time: 20250923-161026\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAdQAAAGJCAYAAAAzN8JFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABnPklEQVR4nO3deXxU9fX4/9edfSb7RhYIgbAGWZRFBNwVENSKWxEtlRatC3Up9fepqFSxFiutqEWhorJoVfxaq7UtVXBFBQwiOwoqSxASQvZ19vv7485MGJJAApOZyXCej8c8ZubOnTvnXvGenPd93/dbUVVVRQghhBCnRBfpAIQQQohYIAlVCCGECAFJqEIIIUQISEIVQgghQkASqhBCCBECklCFEEKIEJCEKoQQQoSAJFQhhBAiBCShCiGEECEgCVUIIYQIAUmoQgghRAhIQhUihjU0NDBnzhz69++PxWIhLS2NKVOmUFlZGfLfqqur49577yUnJweLxcKZZ57JihUrQv47QkQrQ6QDEEJ0DFVVmTJlCmvWrOH3v/89Z555Jlu3buU3v/kNvXr14rHHHgvp711zzTVs2LCBP/3pT/Tt25fXXnuNKVOm4PV6ufHGG0P6W0JEI0VmmxEiNn3yySdcdNFFvPnmm1x33XWB5VlZWUyZMoWnnnoqZL+1cuVKLr/88kAS9Rs3bhw7duygqKgIvV4fst8TIhpJk68QMerNN98kJSWFq6++OrBszZo1HD58mIsvvjikv/X2228THx/P9ddfH7T8F7/4BYcOHeLLL78M6e8JEY0koQoRo9auXcvIkSMBOHToEEuXLuXaa6/lkksu4YorrmjxO6qq4na72/Q42vbt2ykoKMBgCL6KNHjw4MDnQsQ6SahCxCC73c727dsZOXIkc+fOpWvXrvzyl7/EZrOxbNkyFEUBwOFwkJWVRXV1NQCffvopRqOxTY99+/YFfq+8vJzU1NRmcfiXlZeXd/xOCxFh0ilJiBj09ddf43a7Ofvss+nfvz8jR45k/fr1PP3005x//vls3bqV+Ph4zGYzJSUlge8NGzaMDRs2tOk3cnJygt77k3RLjveZELFCEqoQMaiwsBCAs88+m/T0dPLz8xk3bhx9+/ZlypQprF+/nksvvZRnnnmGbdu28eKLLwIQHx/PmWee2abfOLp5Ny0trcUqtKKiAqDF6lWIWCNNvkLEoMLCQvLz80lPT2/xc391uXXrVgYNGhRYfrJNvoMGDeKbb75pdm1127ZtAAwcODDEeyhE9JEKVYgYVFhYSHZ2dtAyVVV58cUXGThwIAMGDAC0hPqzn/0ssM7JNvleffXVvPDCC7z11ltMnjw5sHz58uXk5OQEOkcJEcskoQoRYyoqKvjhhx/44YcfuOWWW5gyZQoNDQ0sWbKEzz//nI8//hgAr9fLzp07Az1xARISEhg+fHi7f3PChAmMHTuWO+64g5qaGnr37s3rr7/Oe++9x9///ne5B1WcFiShChFj/NdPf/7zn/Pee+/x8ssvk52dzdlnn82XX37JkCFDAPj+++9JSkoiLS0tJL/7z3/+kwcffJDf//73VFRU0L9/f15//XVuuOGGkGxfiGgnCVWIGFNYWIjRaOT555/HYrG0ut7WrVuDqtNTFR8fzzPPPMMzzzwTsm0K0ZlIpyQhYkxhYSGDBg06bjIFrcNQKBOqEKc7GctXiBiTmZnJNddcw6JFiyIdihCnFUmoQgghRAhEtMl3zZo1XHnlleTk5KAoCu+8884Jv/Ppp58ybNgwLBYL+fn5/O1vf2u2zltvvcWAAQMwm80MGDCAt99+uwOiF0IIIZpENKHW19czZMgQnn322Tatv3fvXiZOnMh5553Hpk2beOCBB7j77rt56623AuusW7eOyZMnM3XqVLZs2cLUqVP56U9/KrNdCCGE6FBR0+SrKApvv/02kyZNanWd3/3ud7z77rt88803gWW33347W7ZsYd26dQBMnjyZmpoa/ve//wXWueyyy0hJSeH111/vsPiFEEKc3jrVbTPr1q1j3LhxQcvGjx/PSy+9hMvlwmg0sm7dOn7zm980W+fpp59udbsOhwOHwxF47/V6qaioIC0tTQb1FkKI05iqqtTW1pKTk4NOd/xG3U6VUEtKSsjMzAxalpmZidvtpqysjOzs7FbXOXpGjWM9/vjjzJkzp0NiFkII0fkdOHCAbt26HXedTpVQofk0UP4W66OXt7TO8SrNWbNmMXPmzMD76upqunfvzt69e0lISDjpWF0uFx9//DEXXXQRRqPxpLcTThJzeHTGmKFzxi0xt5+qqri9Km6PF7dXxeVR8XpVVEA746qoqvZaVbXXbpebbzeto2DoKPS+mYgURTsf+8++bW3wU1BQFNArCnodKDpFe60oKIqCXqegU059WsC2HOfa2lp69uzZplzQqRJqVlZWs0qztLQUg8EQGD6ttXWOrVqPZjabMZvNzZanpqaSmJh40vG6XC5sNhtpaWmd6n9kibnjdcaYoXPGfTrF7PJ4cbi9OFwenB4vDpcXTxu6yXi9Kk6PF7dHxe314vKAqiq0p9+qV+fGZrNRr1jR+VNLUwbuEDoF9LrgJKtTFHS+9z3SbZgNrY8j3Zbj7F/eluTdqRLqqFGj+Pe//x20bNWqVQwfPjyw06NGjWL16tVB11FXrVrF6NGjwxqrEEK0h78q9HhV7E5tGrzqRic6p4pX1SpEr4r22lcVOj1enG4tiTrdXjzeqOhjGjZeFbye1rN2bqo1rPFENKHW1dXx/fffB97v3buXzZs3k5qaSvfu3Zk1axYHDx7k5ZdfBrQevc8++ywzZ87k1ltvZd26dbz00ktBvXfvuecezj//fJ544gmuuuoq/vWvf/HBBx/w+eefh33/hBBCS3ge7C7t2eH24vJVgx5vUxI9Ohl6PVpC3VVSh07fqeqe01pE/0t99dVXXHTRRYH3/uuYN998M8uWLaO4uJiioqLA5z179mTlypX85je/4bnnniMnJ4e//vWvXHvttYF1Ro8ezYoVK3jooYeYPXs2vXr14o033pD5GIUQJ83p9tLo9ODyen3XDrULiNo1RO29/5qiP4E6XFrleLpVjaeziCbUCy+8kOPdBrts2bJmyy644AK+/vrr4273uuuu47rrrjvV8IQQpxmvV6XR5aHe6abR6aHe4aHR5cbplqTY2TjcHvYcqaNfViJGfXjGMJK2BCHEacHp9uD0Krg9Ki6v1uTqCvRi1SrQRpeH6BjqRhyPqqrUOdyU1Tkpq3VQVu/QnuucHKlzUFbnoNauNZt/MPN8enc5+bs12kMSqhAiZni9Kg0uDw1ONw0OrdKsb9QGbdl8oFquR0YZr6pSa3dTUe+kssFJZb2TigYntXY3dt8fOHaX9qy91v7wsbvb9odPnFlPRb2r43fER/51CSE6Ha9XxeH2Ynd5tATqcFPv1E6+x55otV6gHcft9VLd4KKq0UVVg4sGX3Nxgz8ZOD2B6rfR996o15FoNZBoMZJgMZBgMZJoNZJgNpBoNRJvVKh1gaHBBTovqtrUw1dVCby3uz3U2d3UO93UOdzaa4f2ut6pfeZVVfQ6JfAw6HQYjnqv1ylYjXoSLNpvJ1i0uPyxxZsN6HTtu9/TnyirGpxUNbioavQ/u6j0JU8tibpO6RpzktVIeryJ9Hhz0yPBRIbv9ejeadhM4UtzklCFEFHp6KRpd2uJyO7yYnd7cLq9IW2aVVVt8IKjK6LgCkmrjGrsrkCSqGzUXvubFkPPAF9t6aBtt50CxFsMWI167R5PnXavp15R0AXd+wn1dXrqNm+hxu6iPXky0Wok1WYkNc5Eis1EktWIxajHYtRjNemxGHVYjfrAw2LSE2cyYDK0fG1Ur1OwGHXowjx0rCRUIURYebwq9U43zqNuH3F5vLgCz17fKD2nnjFVVaXe4aakAUoO1lBl92hNiw0uKhucVDU4qazXXrtPoVLSKwpJNiNJvipTSwJaMrAFkkJTQnB6vNTYXdTa3dQ0+p7tRz03uvGoKooCOrQk5h89yJ+8FEXBbNARbzYQZzYc9awPvI4zGzDolKDbc7Rnb+C126vS6PRQe9Tv1zS6qXW4qHd4UIFau7uNfzgogCvwKsFqJNn/sBlJtplIthlJtZlIiTORGmci2WrEcJKdhsxGHRaDdnybkq3uuIM5dCRJqEKIDqOqKvVOT6AZss7uDknHH7fXS2W9i4p6LSlWN2rNidW+ZtfqRmfgtZYoDbBld5u2bTZo1dCx1ZHFqCfRclRi8CWJFJuJeIshpNWQx+2i/NsvSS84J6LXfd1eL3V2NzV2Nw6XB68KnsAgE9rD49WaeN1uN/bi7+jedyAp8VYSrQYMJxhM/liKQuBYG/RKoGnaqNdpzzodet9y/7JoIglVCBESLo+vedblbbqO53C3q+kPtCRcY3dzpNZBeb2D8jon5XUOyuud2qPOQVWjq11J2aZXSUmwkhJnJsWXBFNsJlLi/K+NxJkNWAz6dl8v7AjRMsuVQafzVZWmE67r9bgps6ukp8e16Y8AnQI2k4E4sz5QTduM0XH8T5YkVCFEm6iqisPlAaC01oFHdWF3ewJJtK2dS1RVpbrRxZFaB0fqHByp1W5z8L8vq3Xi9HhPuB29TiEtTmtCTLaaSPQ3K1q1ptdkfxOsSUfNd4WkFwyUXr4RZDXpSbQYiPd1dLIa9VHzh0OoyL8uIUSAv8r0dwbSBlpv6gjkcWvX0faV1bcpOXm9KsU1dvaX17O/vIF9ZfXsq2igpvH4tzIoQLLNSHq8mdQ4E2nxZtLjTaTFmUmLN5EWpyXQtjSz+ofxE+HlT6CJVq3HcGsdiGKJJFQhTjNujzdwT5/96F6t7agym23T66W8zsnhGjuHaxwUVWgJtKiiAYe7ebWpKJBqM5GRYCYj3kxGgnabQ0aC9kiLM510RxVxfCaDTmtmNRmwmfSBjktHD7wfuEXHd33U41/uf+/Vbt9pWq7icukoA3p1iSc13npaJNBjSUIVIoa5Pd5Ah51G332arpPsPVtnd/NjRR0/HFGwOw5xpE5rti2ttVNe72z1mqbZoKN7qo28tDh6pGnPuanWiPXEjHVN95sqgdtHbCaDlkDN+g4bhs/lcvEdkBZnwngaJlOQhCpEzGl0eny3hLiosbev845XVamod3KwspGDVY0cqmp6rgncNqEHDjX7rlGv0CXBQkaC2ZdAbfRIiyMr0dLujiY2k554iwGTXofOlxz8c1zqFQW93n8fpG/gepc2GH1bq21F0eI16nW+h4LHqzV5Oz1eXG5vmzpTGfUKZoMek0GH2aDDbNShVxTw3d6i4Hv2T7StfYTXCw6P9seN//Yh/zRsLo8XxeMEtI47JoMOk16H0aDFa9LrMPhjP6rXqz+Jxtp1yc5EEqoQnZyqqtQ0un33Vzqxu07coQe0ZtoDFY3sOVLHnrJ69pbVc6iqscUmWr+0OBOpejs5mV3okmjRHglmuiSYSbIaT+pkrlMgznz0qEGGdjX3mg16EizNJ4f2T5lW3+igDOiflYDVYsKg0xLoiWL13xPrcmuTb7s8Xgw6xZc8tSR6ardt+GL2uMBRqz2cdeCoo9FtZxUw3FqMMT4NrMlgDs94tCHldoKrHpwN4GoAZ73214w5ESxJ2nMMdRSLnT0RIkapqjZikH8SaYevg5B/mf/+wOPxelWKq+38cKSOH3wJdH95fYvNv3pFISvJQtdkKznJVrqmWOmabCU7yYJJp1L2zXrSC3q0q8esohC4d9CgU7G4a7Uq1GoizmREp9eBooLi0eZD8+hB0UE772M8mtmgx2zQY/OFmWg1YjS2PWZ/9cqJ7xhpO7dDSyrO+kDyxG1vtprBn6jtNeCqhUpAbwRLMlhTtARrMDd9weMCV6O2fXcjuOzadt127XjqDKDTa9vQGYIfeqO2jtcNXhd4Pdprj8u3zKMtB9AZte34v+ffrs4I/r/DyveA6tASqKeVzmf2Gqj+0ddUYGtKrpbE4P3yenz75dsXl13bP7dDi9kcD6Z433NCxJOzJFQhoozL4/UNTqA12bZ3mD2Xx8uPlY3sK69nX5nWOWh/RX2LlavNpCc/PY78jHjyM+LITbHRJdHc6g35rfWYNRkUrEatk4vVpF2nM+i1G/ENegUjHmiogIZysFdpJ0o72uN4TDYtibR0sm2N1wOOGu2k7aiBhmpt+aHNYDJr29AbQX/MawDVA6r3qIeqPXt9y/3JxJ9E/Inl2GrX49KSpqvBV535qjTvKfQ49rig/oj28B8bRaclmRNt19eEfMpaS5AA/j/O6g6Dvo2Vu6o2/YHhv4xgtGrH1e04cdxuO9SXNb03Wn0JNkFLsubE5v9tOpAkVCEizOvVBhLXOg85qXd42vzdBqebfb7bUfaX17OvvIGDlY14WsjAZoOOHmlx9MpoSqCZiZbj3nqieBzo3Y3o3A3o3I3oPXbKgBy1lDhLImZbHDabDaPJ2vzE5WzQEmhjhdaceTLDIzl9Ccl/sjVYtGrGkqidLE027SRvrwFHtfbsrAv+LX/57moE74ky+EkKJFqDlgSOl3hCxdnQ8b8RCa7GU/uuq7Hpj46uQ8EUF5q42kASqhAR0OjUKopdh2tpcNGm21Ucbg/7yxvYc6SOH47Us6esjuIqOy19M86sp2eqlR4pRvKTdPRMUuiWaESv16MqCihuVGrBXoeq6LRKBwWdxx5Inma1EZuewCDlFpsOBYW9h6CbvhKjswqcQBXa9w0WreIzmH1NlR1wwnfboc6uVUGgJbDjVWfOBpTKAyQ0OsBlBn0HnVy9Hu2Bo33fU1WtKva6j2pedYPLjdFtBzUZrRtTG7dVdxgq9kDlXqjYC1X7tYTS7Wzofg6k9AxrxYa9Bqr2QaX/sR/s1VoMvn9zvh5bwe/1ZrClgi1Ne7b6nv3LjLbm++51addsPQ7tDxq3Q/tDJ/tM7Q+vMJCEKkQYHN2MW93owu7QmrKqG1xB1yJ1bjt6Vy2Ks44fK2rZVWrnuyr4rlqlqEZt8Vppus1Az1Qj+YkKvZJUeiW4yTS7UKgLXvE4f/jrdUqgudZq1a49GvXNT0Kt3nKjerUE2pYkqqpaFWmv9nXG8TfP+l4f3UHHkgTxXSCuS/Cz0apty59MvR6oOaglksr9TSfw+lIMwMUA36Ill7iMox7p2rMtXUtsjrqma5vOuqM6CtX6miXxNREbtSbfo5/9r71u3zU/h6/Z0nHUe9+z//qk2nJrhBGYCKg7DL5rpq087NVa4qz0PVqr7sq/hy2vafuaO1J7ZA7UYm6Nyw41P2rXOqt/1LZtMIH+qIfBHHitKEa6VZSg21gK1b7/Bo0VJ/73cDIMVu3fgL81wOOEFv+0BH71KeSc2TFxHBtWWH5FiNOM1+Wk1u5PoM2bcRWP9t7gqMDosaM46zhQUceOI162lsOOcqhpodUw2Qx9k6FPMvRJgt7JkGJ2A+27NucfhDzeYiDOqMPqrUOpOwTVvkTibGjqOBO4FliH3mVnpN2IviYdrElgTmpqgrX4XpvioLEaGo5Ane+aX0NZ0+v6I1qSORXmRF8iTNO2XVXUaqWqWlJwuRyYPA1N1+sq953a73ckRYeq6FG8LhSvO/i66YnoDJDcXatEU3pCl/5Qcwj2r4VDm7TtfPsf7WG0QddhkHuOlpyrf4SaA00JtK2/6WMAhrX0QXymL548SOmh/fECTdeoUX3PR12zdjVqydh/3f3o164GX8ekVv54UHRNCd8cT6uJtgNIQhUiBFSvl/raKuqqSmmsOoy9oR6vr5zUAcfe8OB0q/xYD1u//oEdFQrbK6DumARq1kNBCvRL0ZJnn2RIs5xki52qYvXWkeguI85eirmxBF3tIagt1k64bWye1QFZADUnEcOxjDYtMZoTfNdEE3yPo66PNlZDfSnUlTY9O+t8lWwNVPzQtD2DtemknZwXOIm7DfH8b0clE/uaMdrLmxJU0KNMqy4DvUYTjuo96ntvTdFO+O5GX4Xp8lVH/te+XrKK/qjm76Oawf3v9eZjesge3clJ693s9qi8t62Uy/LB6KiCxkotqTRWBj+MNkjN1/Y1tSckddO2ZzBrxyC+i/YHRN/xWtVdvAUOrIcDhVrnsH2faY/WmBMhKVfbrjnBVxE6mzoMBd47Ud0Oyl1GUrr2QZ/q/2+Q17x59lT5k63L7quYj+5kZtKOv/9/ErmGKkTn0OhwUVNZSkPVEew1R/C6Wu6RWOmAfTWwt6bpuagO3N7g//2seihIhUFp2qNPMrQ24IzO3YC1+gds1d9hri1C53WieF3oVTc61Y3O69YqHNX37LajHLezh6JVe5ZE7QRkjNOe/Q/fe7fezPZ9RxiU5kbv8HcE8nUGsvtee11a4mjWtNrlqNfpWgVxMpwNvuR6WKtYrKlaEo3v4rsOdwx/M7XRBpY4rYI7HoNZW9do9e27TXvW+UZ28ribbt3w39Lhv2XF4zi5zlct8OqMEJcCiZlt/5LOoCW/xK5NtxyZ4yFrEJRsh9yztYfqhbLdcOBL+HGDFntSt6bk6d+GJanNP+32qHyxo5KJZ6SgP1Ev35Z6S+sM2m0vOoOvR3NZy718jVYwdm37MQkjSahCtJGqqlTV2akqL6ahqhS1oRJFDb4VpdYJW8vhm4qmBFrVYp5VsOhVBqbCoHSFgWnQO6mVBKqqmBoPY63aja36O2xV32GuO4ByMk1ZcRmQkA2JOZCQoz0n5kBCVpsSnOpR2V9XyRmtnTRVVTsJ6k3BpbSiaEkpcEN/AqAcc4uK13fbylG3qtirtWrk6F6zJhuYemhJ9HgURfstYxJQCWm9wNDKKU9RfIk07sT3MuoNoE9oeaAFr1dLtkffKuNqaLoftKMoOu2/YXL3lq+LmuIge7CWVN12bf2M/tpj6M2hj0fnq9KNVl9lbgWjpalCb8v9xan5WhVdX64167en57T//lZdeFOcJFQhjsM/ClF5VSV1ZQfQ1R9B8WrXPxWg0a1d79xcBlvLYE9N8ys2CpATBz0SoWei9pwXr1LX6KF3mh696sTgrMZQW43BUY3eWaO9d1ZjbDyCrfp7DK4W2ljjM7UTYlof7YR5vM4yepOWTA1mX/KwaonJX335KzLVe8xN/Uc9PC5wOoFKLVHpfEnPvy40JSZFd1RTri+J+iu89kjI1BKRP7E2VBz/tgqdrxOPLU171hvA5QI2+TozHacTTijodE1VPRlNy73e4ATrcbXyx4TvOqLSjmvicRnaHxdGy/HXM1q1SvXw9vbdmuJP1taU46/ndsOOddp1WWsImlkVpanzldpLa+KuL9NaJY6+Xq4ovtaEhKYmelP8KQ0KcrIkoQrRglq7i/JaO9Xlh6D2MAZnLXrA6YFvK2FLmfbYXdXUoujXPR4GpUOvJOgT10C+vpx4dzlGu+9RVobhQDk0lGP11KD3nPjeSFVnQEnroyXQLgXasy219S8EEqmvF6bB5Gu2tWnJtLWTjaL3VRetDKDgcgHfQuaA4OQUGGnHd+uH0Ra6E5qiaCMDWZO1qsV/f2tDuXY9NXCLRao2CEQ0jmWr0zVdI24Llwu2rNRuddErrf+BY0tt35CERgtkDYbD29p2H2tbk7U/ZtD+rYWaojT9N/Z6teTqtvtaPRJO7o+1DiAJVQifRqeHI7UOyqurUWuKMTUeQXW52VWlNeNuLdOS6bEDDuVanYxNLmak7SAFuoMkOQ5irivGWFaO3t22zj5enRGvOQnVkoxiTUZvS0GxJGmVVnoflNRezZvy/E2a1pSmDhl6U9ub1EJJUZqSeEcz2bRHcq52PTOGxoJtpiOOq8HkS6rbtY5KLbEkaZ2conH8YJ0O4tIiHUWLYvhfohDH4fWAx4nHZaeito6KqjrqGxvxOurZc7iGreWwzXct1OlLoInUM0ApZpC5mHOsB+lvOEiO+0es9lKUSlUbb7UFbmM8LnMaLksaLmsaHks6bmsaPzQm0Tcvi7jkNGzW+FaH+wvSUpPm6ex03/+TpTdC5iAo3aF1KPMz2bQew8dr/RCtkn+NIvZ5XNrtFo2Vge7+DXY7lY0ubZaWRpUvD8O6Eth5xEWmWkq+Usw5SjFTdMX0NRbTS1dMknrUieeYVlqPwYY9vhvO+G6oSbnoknIhoQuKLR29xYZBp2BVdCToQUHB5VHZsKOS1Jw0jDqO32HFYIn+Jk3R+egN2uAOpTu1a6r+22zk39dJk4QqYpOqagm07rDWkUX14vaqVDU4qWp0caDKzTc/HqHycBHWugP00xXxE+UAPYwl6JUWkpt/OFhTMs64bBxxXbVHfDd0yd2xJKYRZzGQZNQfd2xcdHrtupQlFXZ8ro1YYzQ29Ww9eiB21at1CAnTsGniNKTTQ5czfK9Pz0nBQ0kSqogtznotidYdAY8Tl0eltrEBR8luKg9+T31ZEXH1Bzjbe4CLFN9oPcdcnvLoLThtWTjicnDasnDasnHEZeO0ZaEabZgNOuLMBhLMBrqY9NqE0idiTdZ65drStJOY65hbABRF6xCEPjzXIYXwk0QaMpJQRefm9Wo9PQFKtoK7AWdDDY0Ht6Me3glHviWh9gdSVRfZR39PARcGyk1dUZNyUZK7Y4/PxRGfi9ucEmj2MhoUbEY9SUZtnFuLsY0JFLSu/P7xZ9vSS1II0alJQhWdg6o2n1vSf8N8bTndKr7A+eEevGXfYq470GxO6Ao1ns1qHyot3TGndScnJxdzclbQjd96naINDm/0PUx6baJng7lpPk6zbySho5tom91H6NWqTUtieI+RECKiJKGK6OVxaWPN1h/ROk0c3XHH2YC3aC2e7z/GcHgrw44ZTmGPN4uN3r58pfajJrEvfXNzGJOjkHlUa6p/hhWbSU+c2YDFqE1PhtHqG83Hl0T9M5scTVHQRrYVQgiNJFQRfZwN2oDt9aW+OSZ9PC44+DXePR+jHChE53UGUtp2b0/Wegew0duXjd6+xCUkcWGeiUt7JJCaGI/HYENvMmOwGEiwGEm0GIkz6VGObb7VGeQaphDipEhCFdGjsVJLpA1HzaGoeuHwTtj7Ceq+z1GcdYEkelCXzQrHGN71jma/mkWqVce5+Un8f30y6Z6RHNiEyWwgK8lCerypeQIVQogQkYQqIsvr1Zp0aw42TeCsqlD+HexdoyXRhjJAGxO3Tp/Mf72jeMU+hu1qTxQUzuyWyMSESkaPHIbhqOHwUuKMZCdZSbJKxSmE6HiSUEVk+K+P1hRrs5OoKlTuhb1rYN/nUFcCaEnUrbfytXkEi2vH8JH9DLzosBh0XNavC+PPyKJLvIGyb9aj0ynoFMhIMJOdZMVqio7xPYUQpwdJqCK8/NdH6w5rzblVRdoEx3s/g5ofA6t59WYOJ5/Fm85RLCwbgr1e67fbJcHM+DOyuLBfBjaT9s/X69FmnuiabKVrWjxGvXQWEkKEnyRUER6NlVB9UHv2umHfF7DzHa1p10fVGXFlD2N3/Nk8V3Ym7x+04B+HfkB2IhMGZjG0ewo6XdN10ASLgVSbmbJvoGuKVZKpECJiJKGKjuP1aj11aw5qlamjDna/B9/+R5swGLRetTln4eg2hi2Gwby028IHW5umRBvaPYXrhnWjZ3rT/Io6BdITzGQmWog3G3AdO+qQEEJEgCRUEXpeL9Qe0ipSj1NLqDvfhR8+0AanB22Q9/6X4+4zge01Jl7Y6uX9/V7cvpJ0cLckrh+WS+8u8YHNWow6spIsZMSbMUglKoSIMpJQReh4vVpHo+oftcR5eBvs/BccKCQwunxKDxgwCXpewA/V8NdCWPm9HZevJB2Qncj1w7vRP0sbZUhRIMVmIjPRTLKtAyYuFkKIEJGEKk6dqkJtCVQfAJcdftwAW14Puj5KtxEw4CrIGkK928vibQZe3FRHvVMbuKFfZgLXD+/GGTlJAJiNOrokmMlIMGM2SG9dIUT0k4QqTp6qar11qw5oQwP+WOhLpN9rn+vN0OtiGPATSMrFo8K6Mgt/+LyeXaXVAPRIs3HDiO4M7paETqcEqtEkq1EGYRBCdCqSUMXJqSvVbnlxNmhNulteg4oftM8MFuh/OQy4Wpu2DDjsSeTPG128vaUUj1fFbNDx0+G5jD8jC5tZT5cEM10SLJgMcm1UCNE5SUIV7eNxQdluqC+HA19qFWlQIr0CzrhaG1wecJiSeXu/mac/OUBJjR2AYXkp/GJ0D7qn2eieapNro0KImCAJVbSdvRqO7NJGMtr0ClTs0ZYbrFpF6k+kJhteczLf1Fl44r0fWfNdEQApNiPTRvfk7J4pdEux0S3FKs26QoiYIQlVtE3VATj4Faz/GxxYry0zWKHgChh0PSTngTUFrMlUORWWrt3HS59tp87hRgHGDshk8ohcuiRYyM+II84s//SEELFFzmri+DwuKN0JG5fD5le1Cb0VvZZER/0aUnuAOQEAl8dL4d4K5r33LVt+1Dod5abauPXcnvTLSqBripWuyVKVCiFikyRU0Tp7tXYf6edPNTXvZg6EK56C3LODVi2pbmTJF/t4Zd1+Gl0ejHqFa4Z244rB2aTYTORnxAXG3hVCiFgkZzjRstJv4bPH4duVgAqmeDh3Joy5B/RN/2wanG6++L6Mp1Z/x87iGgD6dInntgt6kZtiJTfVRnaSRapSIUTMi/g9CgsXLqRnz55YLBaGDRvGZ599dtz1n3vuOQoKCrBarfTr14+XX3652TpPP/00/fr1w2q1kpuby29+8xvsdntH7UJscbvIqVyP4ZUr4dv/Air0Hgu3fwHn/zaQTD1elb1H6nl85bfMeHUTO4trMBt0/HxUHo9ceQYF2QkM7pZMjjTxCiFOExGtUN944w3uvfdeFi5cyJgxY3j++eeZMGECO3fupHv37s3WX7RoEbNmzeKFF15gxIgRFBYWcuutt5KSksKVV14JwKuvvsr999/PkiVLGD16NLt372batGkAPPXUU+Hcvc6n5hD6N3/BCH+no8SuMPYPMPAabQxAn+pGF5/uKmXBR9/zXWkdAGfkJHLrefnkplrpnhpHRoI5EnsghBARE9GEOn/+fKZPn84tt9wCaJXl+++/z6JFi3j88cebrf/KK69w2223MXnyZADy8/NZv349TzzxRCChrlu3jjFjxnDjjTcC0KNHD6ZMmUJhYWGY9qqT2vc5/OOX6OoO41GMcNbP0F/6MNhSAqt4vSr7K+pZvGYvb351ALdXxWrUc9M53bmkfxeyk6x0S7HKwPVCiNNSxBKq0+lk48aN3H///UHLx40bx9q1a1v8jsPhwGKxBC2zWq0UFhbicrkwGo2ce+65/P3vf6ewsJCzzz6bPXv2sHLlSm6++eZWY3E4HDgcjsD7mhrtWqDL5TqlqcH834326cWUwsXoP3oExePEG5/Nmm4zGHnpdIxGI/hib3S62fpjNU99+AMbi6oAOLNbEr8ck0ePNBt5aTZsJgOq14PL6wlr/J3lOB+tM8YMnTNuiTk8YjXm9uyPoqqqespRnYRDhw7RtWtXvvjiC0aPHh1YPnfuXJYvX86uXbuafeeBBx5g6dKl/Oc//2Ho0KFs3LiRyy+/nNLSUg4dOkR2djYACxYs4Le//S2qquJ2u7njjjtYuHBhq7E88sgjzJkzp9ny1157DZvNFoK9jU46r4uBB1+lZ9lHAJQknsnGvNtwG+KarVvSAC/t0lNqV9ArKtf19DKqi4pcHhVCxLKGhgZuvPFGqqurSUxMPO66Ee/le2yHFVVVW+3EMnv2bEpKSjjnnHNQVZXMzEymTZvGvHnz0Ou1GUk++eQT/vjHP7Jw4UJGjhzJ999/zz333EN2djazZ89ucbuzZs1i5syZgfc1NTXk5uYybty4Ex7A43G5XKxevZqxY8dq1V40qfoR/Zs3oSvbgYqC96yfk3bpY1ykGAIxq4qOPWX1rN5ZyvMb9uFwe0mNM3Lvxb05Jz+VbilWjFHQvBvVx7kVnTFm6JxxS8zhEasx+1ss2yJiCTU9PR29Xk9JSUnQ8tLSUjIzM1v8jtVqZcmSJTz//PMcPnyY7OxsFi9eTEJCAunp6YCWdKdOnRq4Ljto0CDq6+v51a9+xYMPPohO1zwBmM1mzObmnWiMRmNI/mGEajsh88NH8OYvwF4FpniUSx9BP+wX6PWGQBNvtUNlf2U9r67fz7+3FgPaXKX3je/LsLxUkqxRtD8+UXec26AzxgydM26JOTxiLeb27EvEyguTycSwYcNYvXp10PLVq1cHNQG3xGg00q1bN/R6PStWrOCKK64IJMqGhoZmSVOv16OqKhFq3Y4eqgprnoS/X6sl09R8mPwqjLglcDuM16sdoy0HKnnsPzsDyfSKwdn8dcqZXNC3S1QmUyGEiLSINvnOnDmTqVOnMnz4cEaNGsXixYspKiri9ttvB7Sm2IMHDwbuNd29ezeFhYWMHDmSyspK5s+fz/bt21m+fHlgm1deeSXz58/nrLPOCjT5zp49m5/85CeBZuHTktsBb02Hb/6tve91CUyYB+m9g1bbW1ZPUR0s+9c3lNc7MRt03HVxb6aO6iGJVAghjiOiCXXy5MmUl5fz6KOPUlxczMCBA1m5ciV5eXkAFBcXU1RUFFjf4/Hw5JNPsmvXLoxGIxdddBFr166lR48egXUeeughFEXhoYce4uDBg2RkZHDllVfyxz/+Mdy7Fz2cDfDaT2HfZ6AzwMjb4NzfQlxa0GoHKhp4Z/MhXtyux606yUq0MPeaQVzQNwO9TnofCSHE8US8U9Kdd97JnXfe2eJny5YtC3pfUFDApk2bjrs9g8HAww8/zMMPPxyqEDs3Ry28PEmbKcZghksfhbN+Bub4oNWO1Dp4Zf1+Fn+2D1AYkZfMUzecRbeU2O3lLIQQoRTxhCo6UGMlLLsCDm8How0uexyGTNES61Fq7C5eWbePF9ZoA+BfkOVl0bTh2Kwy2pEQQrSVJNRYVXsYll0O5d9p06td/iSccW3QwPYAdpeH19bv57mPf0AFLh+Yxdj4HzEaIn87jBBCdCZy1oxFlUXw0lgtmVqS4aqFMPD6ZsnU7fHyxoYDPLl6Nx5V5cJ+GfzluoEyWIMQQpwEqVBjzZHd8PJPoLYY4jJg0kJttpgWBtB4e9NB5q78BpdH5eyeqTx341lIYSqEECdHTp+xpHgLLJuoJdOEbLhuKfQZ1yyZAry3o4Tf/2sHDreXId2SeHbKWcSZ5bYYIYQ4WVKhxor9a+H1KdqADUm5cP0y6Da8xVU/++4I/9+bW2l0eeiflcBfrh9Cl0RLi+sKIYRoG0mosaBkG7w2GRw12uhHP/07ZJ3R4qqbD1Rx12ubqHO46ZURx2NXDaR3l/gW1xVCCNF2klA7M1WFij3w3/u0ZJrSA258s9noR37fl9Zyy/INVDW6yE21MfuKAQzpntzqZARCCCHaThJqZ+X1wJFdsP0fcGC9NgLSVQtbTaY1jS5uXrKBsjon2UkWHpzYn6F5KVExW4wQQsQCSaidkdsJpTu022O+fF5bNvI26DGm1a/c/9ZWDlY1khpn4sGJBQzulkyiRTohCSFEqEhC7WwcdVC6E1x2WPcsOOsgrQ9c3PpQi//vqwOs3F6CAtx5YS/6ZCaQk2wNX8xCCHEakITamTRUwJFvtebePR/Dj4VaU+9PFoCx5WEC95fX89h/dgIwcVA2w/JS6JURF86ohRDitCAJtbOoPgiVe7WOSA3lUOhr6h0+HfJGtfgVl9vDb9/cQo3dTW6qjSln59I3MwGDXDcVQoiQk4TaGThqtd68oCXUdc+Csx7S+8ClrTf1PvvxD3y1rxKDTmHGhb3IS4sjziz/yYUQoiNIqdIZ1B9pev3Dh/DjBq2pd8JfwNRy823h3nL+9ukPAEwekUtBdiJd5bqpEEJ0GEmonUF9ue+5DApf0F4Pmwb5F7S4ekW9gwff3o7D7WVAdiKXD84mPyMOnUwSLoQQHUYSarSzV4Pb7mvqXQCuekjvCxc90OIYvS6Pl3nv7eK70jpsJj13XNiL7CQrCXKLjBBCdChJqNGuvkx7/n41HNwIOiOM/QPY0lpc/b9bi/l/Xx0A4BdjepKTbKV7qi1c0QohxGlLEmo0U1UtodYfgQ0vasuG/hx6X9Li6t+X1vLEe9/iVeGc/FTG9EojPz0OvTT1CiFEh5OEGs3s1eB2wNoF4GqAjH5w7kzQN2++bXC6mffeLoqr7aTGmZg+Jp+MBDMpcaYIBC6EEKcfSajRrL4MynbDoa+1Xr0XPQhJXVtc9Z8bD7Jq52EAbr+gFylxRvLSZAAHIYQIF0mo0UpVoaEMvntfe9/zfOh1SYsdkUpr7fxl9S4ALhuYxaCuSXRPs2EyyH9eIYQIFznjRit7ldbku3eN9n7IjWBued7SF9bsoarBRZcEM1NGdCfJaqRLgkwYLoQQ4SQJNVrVl2nJ1G2HpG4wYFKLq5XW2Pl/X/0IwNVndcVq0pMvY/UKIUTYSUKNRv7evd+t0t6fcS0YWr6P9MXP91Ld6CIj3sy5fdLplmLFYtSHMVghhBAgCTU6NVZC2XdahyRFr42K1IIjtfbAPadXnZlDstVEdpI09QohRCRIQo1G9UeaqtO80ZCW3+JqS77YR1WDi7Q4Exf0yyA/Iw6lhU5LQgghOp4k1Gjj9UJNMez5SHt/5o0trnakxsEbG7Tq9Cdn5pCZaJGZZIQQIoIkoUabxkrYt0abni0uAwquanG15ev2UVHvJNlm5MK+XaSpVwghIkwSarQ5urm34EowN++xe6TW3lSdDskhLd4kg98LIUSESUKNJl4PlGzTHooOzvp5i6v9fV0RR+ocJFmNXNxfqlMhhIgGklCjSUMF7H5Pe911GGQNarZKaa2dFV8VAXDF4GySrEZSZbxeIYSIOEmo0aSmGL7/QHs98DrQN+9k9PqXRRyucZBgMXBpQSbZSVbp2SuEEFFAEmq08Hq0cXvtVWBJhjOubrZKaU3TtdPLB2UTbzGQkWAOb5xCCCFaJAk1WjSUNzX39hkP8V2CPlZVlTe+OsChajvxZgPjBmSRmWCRuU6FECJKSEKNFoe3a9O0AZw5pdmsMqW1DlYUatXphIFZxJn1ZElnJCGEiBqSUKOBxw3b/gGqV+uI1G1E0MeqqvLWxh85WNWIzaTnsoFZpMWbZXo2IYSIInJGjgZ1h4+59zR4mraaRhcrfNdOLxuYhc1kkFtlhBAiykhCjQa7/6cN6GCKgzOuafbxf7cVU1TRgNWoZ8IZ2q0yMsygEEJEF0mokeZxw/Z/aq97XQzJ3YM+VlWVlz7fC8D4MzKJtxjISZbqVAghoo0k1Eir2AMHvtReD7wWDMG3wXxbUsMPR+ox6hUmDMrGZtKTbJOBHIQQItpIQo20La+B1w3pfSFvTLOP1+wuA6BvZgKJFqNcOxVCiCglCTWSVBW2v6W97nsZ2NKarbJ+TzkABdmJmAwK6fEykIMQQkQjSaiRVPYdVBWB3qR1RtLpgz5WVZXNB6oALaFmJlrQyUAOQggRlSShRtLBjdpzSk9I7dHs429LaqlscGHUK/TLTCAzUZp7hRAiWklCjaTizdpzWi9t/N5jfLr7CAC9u8STk2zBqJf/XEIIEa3kDB1Jh3doz1mDmg01CPDl3qbrp9lJ1nBGJoQQop0koUZS2Xfac7ezm33k9XrZcqAagLNyk7Ga9M3WEUIIET0koUZK3RGoK9Fedx3a7ONvS2qpqHei1ykMy0sJc3BCCCHaSxJqpPg7JMV1AVtqs4/XfKfdf9o7I56MBOmMJIQQ0U4SaqT4OySl923x48K9FQAUZCeQYJFxe4UQItpFPKEuXLiQnj17YrFYGDZsGJ999tlx13/uuecoKCjAarXSr18/Xn755WbrVFVVMWPGDLKzs7FYLBQUFLBy5cqO2oWT4++Q1KV/s488XpWtP1YBMLhbEhajXD8VQohoF9HS54033uDee+9l4cKFjBkzhueff54JEyawc+dOunfv3mz9RYsWMWvWLF544QVGjBhBYWEht956KykpKVx55ZUAOJ1Oxo4dS5cuXfjHP/5Bt27dOHDgAAkJCeHevdZ5vVD+vfY6c1Czj78prqGszoleURjWo3lzsBBCiOgT0YQ6f/58pk+fzi233ALA008/zfvvv8+iRYt4/PHHm63/yiuvcNtttzF58mQA8vPzWb9+PU888UQgoS5ZsoSKigrWrl2L0WgEIC8vL0x71EaOGqjUZpAhZ0izjz/zXT/Nz4gjQ4YaFEKITiFiCdXpdLJx40buv//+oOXjxo1j7dq1LX7H4XBgsQR30LFarRQWFuJyuTAajbz77ruMGjWKGTNm8K9//YuMjAxuvPFGfve736HXt9x06nA4cDgcgfc1NTUAuFwuXC7XSe+j/7vNtlGyE6OrEVVnwJ3SF475fMNeLaH2z4zHalBPKYb2ajXmKCYxh09njFtiDo9Yjbk9+xOxhFpWVobH4yEzMzNoeWZmJiUlJS1+Z/z48bz44otMmjSJoUOHsnHjRpYsWYLL5aKsrIzs7Gz27NnDRx99xE033cTKlSv57rvvmDFjBm63m9///vctbvfxxx9nzpw5zZavWrUKm812yvu6evXqoPdZ1V8zEqgx5/DJqg+arb9lnx5QyHEdZM2HP57y75+MY2PuDCTm8OmMcUvM4RFrMTc0NLR5OxHvPqocM0KQqqrNlvnNnj2bkpISzjnnHFRVJTMzk2nTpjFv3rxA9en1eunSpQuLFy9Gr9czbNgwDh06xJ///OdWE+qsWbOYOXNm4H1NTQ25ubmMGzeOxMTEk943l8vF6tWrGTt2bKD5GUD3Xy2JJnQtYOLEiUHf2XGohvJ161EUuOjckQzLC+811NZijmYSc/h0xrgl5vCI1Zj9LZZt0e6E2qNHD375y18ybdq0FjsOtVV6ejp6vb5ZNVpaWtqsavWzWq0sWbKE559/nsOHD5Odnc3ixYtJSEggPT0dgOzsbIxGY1DzbkFBASUlJTidTkym5pNzm81mzObm1yqNRmNI/mEEbcfVCJV7ANBlDUB3zPbX7a0EoGdaHDkpCRH7hxmqfQ8niTl8OmPcEnN4xFrM7dmXdt8289vf/pZ//etf5OfnM3bsWFasWBF0/bGtTCYTw4YNa1Zqr169mtGjRx/3u0ajkW7duqHX61mxYgVXXHEFOp22K2PGjOH777/H6/UG1t+9ezfZ2dktJtOwc9RC5T7tdZczgj5SVZWv9mkJdUBOotx/KoQQnUi7E+pdd93Fxo0b2bhxIwMGDODuu+8mOzubX//613z99dft2tbMmTN58cUXWbJkCd988w2/+c1vKCoq4vbbbwe0ptif//zngfV3797N3//+d7777jsKCwu54YYb2L59O3Pnzg2sc8cdd1BeXs4999zD7t27+e9//8vcuXOZMWNGe3e1Y9QfgdpD2uvswUEf1Tnc7DikNS8UZCUSLwlVCCE6jZMe2GHIkCE888wzHDx4kIcffpgXX3yRESNGMGTIEJYsWYKqqifcxuTJk3n66ad59NFHOfPMM1mzZg0rV64M3OZSXFxMUVFRYH2Px8OTTz7JkCFDGDt2LHa7nbVr19KjR4/AOrm5uaxatYoNGzYwePBg7r77bu65555mvYkjpngrqF6wJEFy8O08Pxypo6TGjgIM6Z4s07UJIUQnctIlkMvl4u2332bp0qWsXr2ac845h+nTp3Po0CEefPBBPvjgA1577bUTbufOO+/kzjvvbPGzZcuWBb0vKChg06ZNJ9zmqFGjWL9+fZv2I6y8HjjyrfY6pScYg28B+uJ7bbq2vDQb2Ukyfq8QQnQm7U6oX3/9NUuXLuX1119Hr9czdepUnnrqKfr3bxpCb9y4cZx//vkhDTQmOGqgwjegQ1rvoI88XpVNRdr104LsRBLM0twrhBCdSbvP2iNGjGDs2LEsWrSISZMmtdgDasCAAdxwww0hCTCmOGqbRkjKCB7Dt6bRxTfFtYAvoVo6Vy85IYQ43bU7oe7Zs+eEQ/nFxcWxdOnSkw4qZjVWN/XwzRwQ9NHesnoOVjWiAIO6JsqE4kII0cm0u9dLaWkpX375ZbPlX375JV999VVIgopZVfu1Zl9FB10GBn20bo92/TQ31UZ2sjUS0QkhhDgF7U6oM2bM4MCBA82WHzx4MHpuTYlGzvqmGWYSc8CWHPjI7vKw5UAVIM29QgjRWbU7oe7cuZOhQ4c2W37WWWexc+fOkAQVk44e0CGlJxiaqlDt+qnv/lOZUFwIITqldidUs9nM4cOHmy0vLi7GYJBE0KqjE2pqPhiaRm3aX9HAgcpGAM7ITiTeJMdRCCE6m3Yn1LFjxzJr1iyqq6sDy6qqqnjggQcYO3ZsSIOLKfaapoSa0S+wWFVVCvdq10+7JlvJTrai07U8OYAQQojo1e5S6Mknn+T8888nLy+Ps846C4DNmzeTmZnJK6+8EvIAY4LHpXVGqvZde+7S1MPX5VHZdlBr7pXxe4UQovNq99m7a9eubN26lVdffZUtW7ZgtVr5xS9+wZQpUzrdDANh46yD6h/B6wajVbuG6uNVVb45evxeGdBBCCE6pZM6e8fFxfGrX/0q1LHErmM7JJmaJi2vanBRVKFNYKt1SJI/SoQQojM66XJo586dFBUV4XQ6g5b/5Cc/OeWgYk5QQu2hVak+G/ZVoAI5SRaykiyYDDIgvhBCdEYnNVLS1VdfzbZt21AUJTCrjKJoHWk8Hk9oI4wFzrqmIQdTegTdMrNhXwXgv/9UmnuFEKKzanc5dM8999CzZ08OHz6MzWZjx44drFmzhuHDh/PJJ590QIgxwOttqlDT+oC+KXH6JxSXAR2EEKJza3dJtG7dOj766CMyMjLQ6XTodDrOPfdcHn/8ce6+++42Ta922nHUQoN2awxdmgbFr3O4+bbEP6CDVKhCCNGZtbtC9Xg8xMfHA5Cens6hQ4cAyMvLY9euXaGNLkYoVfu0F/GZYEsPLC+rdeBVwWLU0SXRjNUoA+ILIURn1e6SaODAgWzdupX8/HxGjhzJvHnzMJlMLF68mPz8/I6IsdNTWumQ5HB7ATDpdcSbDYHr0EIIITqfdifUhx56iPr6egAee+wxrrjiCs477zzS0tJ44403Qh5gp+ZxAUdVqMckVLtL68BlMuikuVcIITq5dp/Fx48fH3idn5/Pzp07qaioICUlRSqsY/l6QAfdg9pChWrU60gwS4ckIYTozNp1DdXtdmMwGNi+fXvQ8tTUVEmmrVG9KFX7tdfH3DJzdIUaLxWqEEJ0au1KqAaDgby8PLnXtB3iHKUoHgfoTVpC1TUdcn+FajHo0cuA+EII0am1u5fvQw89xKxZs6ioqOiIeGJOot03IH5yHpjjgz5zuLU/TCxGGR1JCCE6u3a3M/71r3/l+++/Jycnh7y8POLi4oI+//rrr0MWXCxIbPQl1GOaewHsLq1CjZMB8YUQotNr95l80qRJHRBG7Eo6OqEaLUGf+StUm0nuPxVCiM6u3Qn14Ycf7og4YlZCUEK1BX3mr1BtJqlQhRCis5OLdx3JWU+8s1R7ndIDDC1XqGaZYUYIITq9dpdGOp3uuLfISA/gJsqRbwFQrako1uSge1ChqUK1yJCDQgjR6bU7ob799ttB710uF5s2bWL58uXMmTMnZIHFhCPfAKAm90AxWOCYP0SkQhVCiNjR7oR61VVXNVt23XXXccYZZ/DGG28wffr0kAQWC5QjOwFQW2juBXBIhSqEEDEjZKXRyJEj+eCDD0K1uZiglDZVqMc294JUqEIIEUtCciZvbGxkwYIFdOvWLRSbiw2qiuJv8j1mUHw/f4VqloEdhBCi02t3k++xg+CrqkptbS02m42///3vIQ2uU6v+EcVRgxc9JHZrMaHaAyMlSZOvEEJ0du1OqE899VRQQtXpdGRkZDBy5EhSUlJCGlyn5qjBmzOMqqoqEvTGZqMkwVEVqjT5CiFEp9fuhDpt2rQOCCMGZZ6BZ+q/+WzVB0xUFDCYm60iFaoQQsSOdpdGS5cu5c0332y2/M0332T58uUhCSrmGJvfMgNSoQohRCxp95n8T3/6E+np6c2Wd+nShblz54YkqJijb37LDDTNh2qWClUIITq9difU/fv307Nnz2bL8/LyKCoqCklQMcfYckL1z4cqFaoQQnR+7T6Td+nSha1btzZbvmXLFtLS0kISVMxpoYcvNFWocg1VCCE6v3Yn1BtuuIG7776bjz/+GI/Hg8fj4aOPPuKee+7hhhtu6IgYO78WRkkCsEuFKoQQMaPdvXwfe+wx9u/fzyWXXILBoH3d6/Xy85//XK6htqaFW2YAnIGEKhWqEEJ0du1OqCaTiTfeeIPHHnuMzZs3Y7VaGTRoEHl5eR0RX2wwmFpc3NTkKxWqEEJ0dic9s3WfPn3o06dPKGM5raiqelSnJKlQhRCis2t3aXTdddfxpz/9qdnyP//5z1x//fUhCep04E+mIBWqEELEgnafyT/99FMuv/zyZssvu+wy1qxZE5KgTgdHJ1SpUIUQovNrd0Ktq6vDZGp+TdBoNFJTUxOSoE4H/qnbdAoY9c1HURJCCNG5tDuhDhw4kDfeeKPZ8hUrVjBgwICQBHU68A87aDLogiYbEEII0Tm1u1PS7Nmzufbaa/nhhx+4+OKLAfjwww957bXX+Mc//hHyAGNV0+Ti0twrhBCxoN0J9Sc/+QnvvPMOc+fO5R//+AdWq5UhQ4bw0UcfkZiY2BExdl661pOlXQbGF0KImHJSt81cfvnlgY5JVVVVvPrqq9x7771s2bIFj8cT0gA7teMk1ECFKj18hRAiJpz02fyjjz7iZz/7GTk5OTz77LNMnDiRr776KpSxxTR/hWqRJl8hhIgJ7apQf/zxR5YtW8aSJUuor6/npz/9KS6Xi7feeks6JLWTVKhCCBFb2nw2nzhxIgMGDGDnzp0sWLCAQ4cOsWDBglMOYOHChfTs2ROLxcKwYcP47LPPjrv+c889R0FBAVarlX79+vHyyy+3uu6KFStQFIVJkyadcpyhJhWqEELEljZXqKtWreLuu+/mjjvuCNmQg2+88Qb33nsvCxcuZMyYMTz//PNMmDCBnTt30r1792brL1q0iFmzZvHCCy8wYsQICgsLufXWW0lJSeHKK68MWnf//v3cd999nHfeeSGJNdSkQhVCiNjS5rP5Z599Rm1tLcOHD2fkyJE8++yzHDly5JR+fP78+UyfPp1bbrmFgoICnn76aXJzc1m0aFGL67/yyivcdtttTJ48mfz8fG644QamT5/OE088EbSex+PhpptuYs6cOeTn559SjB3Ffx+qVeZCFUKImNDmCnXUqFGMGjWKZ555hhUrVrBkyRJmzpyJ1+tl9erV5ObmkpCQ0OYfdjqdbNy4kfvvvz9o+bhx41i7dm2L33E4HFgswXOLWq1WCgsLcblcGI1GAB599FEyMjKYPn36CZuQ/dt1OByB9/4Rn1wuFy6Xq837dCz/d1vaRr1DW2bUK6f0G6F2vJijlcQcPp0xbok5PGI15vbsj6KqqnqywezatYuXXnqJV155haqqKsaOHcu7777bpu8eOnSIrl278sUXXzB69OjA8rlz57J8+XJ27drV7DsPPPAAS5cu5T//+Q9Dhw5l48aNXH755ZSWlnLo0CGys7P54osvmDx5Mps3byY9PZ1p06ZRVVXFO++802osjzzyCHPmzGm2/LXXXsNms7Vpf9rrw4MK7xbpGZHh5We9vSf+ghBCiLBraGjgxhtvpLq6+oRjLZz09G0A/fr1Y968eTz++OP8+9//ZsmSJe3exrHD7qmq2upQfLNnz6akpIRzzjkHVVXJzMxk2rRpzJs3D71eT21tLT/72c944YUXSE9Pb3MMs2bNYubMmYH3NTU15ObmMm7cuFMarMLlcrF69WrGjh0bqJ79fvj4Byj6gV49ujNxYvT0kD5ezNFKYg6fzhi3xBwesRpze8aoP6WE6qfX65k0aVK7etOmp6ej1+spKSkJWl5aWkpmZmaL37FarSxZsoTnn3+ew4cPk52dzeLFi0lISCA9PZ2tW7eyb9++oA5KXq9W/RkMBnbt2kWvXr2abddsNmM2m5stNxqNIfmH0dJ2/JPNWE2GqPzHF6p9DyeJOXw6Y9wSc3jEWszt2ZeIdTE1mUwMGzaM1atXBy1fvXp1UBNwS4xGI926dUOv17NixQquuOIKdDod/fv3Z9u2bWzevDnw+MlPfsJFF13E5s2byc3N7chdapfAbTPSKUkIIWJCSCrUkzVz5kymTp3K8OHDGTVqFIsXL6aoqIjbb78d0JpiDx48GLjXdPfu3RQWFjJy5EgqKyuZP38+27dvZ/ny5QBYLBYGDhwY9BvJyckAzZZHWtPg+HLbjBBCxIKIJtTJkydTXl7Oo48+SnFxMQMHDmTlypXk5eUBUFxcTFFRUWB9j8fDk08+ya5duzAajVx00UWsXbuWHj16RGgPTp5/gnGpUIUQIjZENKEC3Hnnndx5550tfrZs2bKg9wUFBWzatKld2z92G9HC7pIKVQghYomczSNEKlQhhIgtklAjRCpUIYSILXI2jxB/hWqWwfGFECImSEKNEH+FapHB8YUQIibI2TxC/IPjS4UqhBCxQRJqhNjdUqEKIUQskbN5hEiFKoQQsUUSaoQ4pEIVQoiYImfzCLFLhSqEEDFFEmqEOP23zUiFKoQQMUHO5hHg8njx+OZ1t0iFKoQQMUESagT4B3UAqVCFECJWyNk8AvyDOoAMPSiEELFCzuYR4K9QTXodiqJEOBohhBChIAk1Ahz+gfGluVcIIWKGnNEjoOmWGTn8QggRK+SMHgH+QR3kHlQhhIgdklAjQCpUIYSIPXJGj4CmClUOvxBCxAo5o0dAoEI1SpOvEELECkmoERAYGF8qVCGEiBlyRo8Ah1sqVCGEiDWSUCPAfx+qTN0mhBCxQ87oEeCvUC1SoQohRMyQhBoB/rF85T5UIYSIHZJQI6CpQpXDL4QQsULO6BHgr1Ct0uQrhBAxQxJqBAR6+cptM0IIETPkjB4BgWuoUqEKIUTMkIQaAVKhCiFE7JEzegQ4XHLbjBBCxBpJqBHQdNuMHH4hhIgVckaPALsM7CCEEDFHEmoESIUqhBCxR87oERCYD1UqVCGEiBmSUCPAPx+qTN8mhBCxQ87oESAVqhBCxB5JqBHQdNuMHH4hhIgVckaPgKaBHaRCFUKIWCEJNQL8Tb5SoQohROyQM3qYebwqLo8KSIUqhBCxRBJqmDl9zb0gFaoQQsQSOaOHmX9QBwCTXg6/EELECjmjh5m/Q5Jep2CQhCqEEDFDzuhhJsMOCiFEbJKzepjJXKhCCBGb5KweZoFRkqSHrxBCxBRJqGHmH8fXJBWqEELEFDmrh5kM6iCEELFJzuph5q9QpclXCCFiS8QT6sKFC+nZsycWi4Vhw4bx2WefHXf95557joKCAqxWK/369ePll18O+vyFF17gvPPOIyUlhZSUFC699FIKCws7chfapekaasQPvRBCiBCK6Fn9jTfe4N577+XBBx9k06ZNnHfeeUyYMIGioqIW11+0aBGzZs3ikUceYceOHcyZM4cZM2bw73//O7DOJ598wpQpU/j4449Zt24d3bt3Z9y4cRw8eDBcu3VcgQpVmnyFECKmRPSsPn/+fKZPn84tt9xCQUEBTz/9NLm5uSxatKjF9V955RVuu+02Jk+eTH5+PjfccAPTp0/niSeeCKzz6quvcuedd3LmmWfSv39/XnjhBbxeLx9++GG4duu4AtdQpclXCCFiiiFSP+x0Otm4cSP3339/0PJx48axdu3aFr/jcDiwWCxBy6xWK4WFhbhcLoxGY7PvNDQ04HK5SE1NbTUWh8OBw+EIvK+pqQHA5XLhcrnavE/H8n/36G00OLTXJr1yStvuKC3FHO0k5vDpjHFLzOERqzG3Z38UVVXVU47qJBw6dIiuXbvyxRdfMHr06MDyuXPnsnz5cnbt2tXsOw888ABLly7lP//5D0OHDmXjxo1cfvnllJaWcujQIbKzs5t9Z8aMGbz//vts3769WTL2e+SRR5gzZ06z5a+99ho2m+0U9rK51QcV/lOkZ2SGlxt7e0/8BSGEEBHT0NDAjTfeSHV1NYmJicddN2IVqp+iKEHvVVVttsxv9uzZlJSUcM4556CqKpmZmUybNo158+ah1zdvQp03bx6vv/46n3zySavJFGDWrFnMnDkz8L6mpobc3FzGjRt3wgN4PC6Xi9WrVzN27NhA9fz9R99D0R565nVn4sQBJ73tjtJSzNFOYg6fzhi3xBwesRqzv8WyLSKWUNPT09Hr9ZSUlAQtLy0tJTMzs8XvWK1WlixZwvPPP8/hw4fJzs5m8eLFJCQkkJ6eHrTuX/7yF+bOncsHH3zA4MGDjxuL2WzGbDY3W240GkPyD+Po7Th9RanNbIjqf3Sh2vdwkpjDpzPGLTGHR6zF3J59iVinJJPJxLBhw1i9enXQ8tWrVwc1AbfEaDTSrVs39Ho9K1as4IorrkCna9qVP//5z/zhD3/gvffeY/jw4R0S/8ly+Hr5WozSKUkIIWJJRJt8Z86cydSpUxk+fDijRo1i8eLFFBUVcfvttwNaU+zBgwcD95ru3r2bwsJCRo4cSWVlJfPnz2f79u0sX748sM158+Yxe/ZsXnvtNXr06BGogOPj44mPjw//Th6jaaQkSahCCBFLIppQJ0+eTHl5OY8++ijFxcUMHDiQlStXkpeXB0BxcXHQPakej4cnn3ySXbt2YTQaueiii1i7di09evQIrLNw4UKcTifXXXdd0G89/PDDPPLII+HYreNqqlDlPlQhhIglEe+UdOedd3LnnXe2+NmyZcuC3hcUFLBp06bjbm/fvn0hiqxj2KVCFUKImCRlUpg1jeUrh14IIWKJnNXDzO6SClUIIWKRJNQw8ydUqVCFECK2yFk9zBxu/+D4UqEKIUQskYQaZlKhCiFEbJKzepj5K1S5hiqEELFFEmqYOaSXrxBCxCQ5q4eZf6Qks8yHKoQQMUUSapg53TJSkhDi9NSjRw+efvrpNq//ySefoCgKVVVVHRZTKEV8pKTTiaqq2P29fKVCFUJ0AhdeeCFnnnlmuxJhazZs2EBcXFyb1x89ejTFxcUkJSWd8m+HgyTUMHJ6miYUlwpVCBELVFXF4/G0ad2MjIx2bdtkMpGVlXUyYUWEnNXDyD/sIEiFKsTpTFVVGpzu4z4cHk64zsk8VFVtc5zTpk3j008/5ZlnnkFRFBRFYdmyZSiKwvvvv8/w4cMxm8189tln/PDDD8ydO5du3boRHx/PiBEj+OCDD4K2d2yTr6IovPjii1x99dXYbDb69OnDu+++G/j82CbfZcuWkZyczPvvv09BQQHx8fFcdtllFBcXB77jdru5++67SU5OJi0tjd/97nfcfPPNTJo06aT+W7WHVKhh5O+QpFPAqFciHI0QIlIaXR4G/P79E6xl4P8KPwr5b+98dDw2U9tO/c888wy7d+9m4MCBPProowDs2LEDgP/7v//jL3/5C/n5+SQnJ7N3716GDRvGokWLSEhIYPny5Vx55ZXs2rWL7t27t/obc+bMYd68efz5z39mwYIF3HTTTezfv5/U1NQW129oaOAvf/kLr7zyCjqdjp/97Gfcd999vPrqqwA88cQTvPrqqyxdupSCggKeeeYZ3nnnHS666KL2HKaTIhVqGPlvmTEZdCiKJFQhRHRLSkrCZDJhs9nIysoiKysLvV5rXXv00UcZO3YsvXr1Ii0tjSFDhjB+/HgGDRpEnz59eOyxx8jPzw+qOFsybdo0pkyZQu/evZk7dy719fUUFha2ur7L5eJvf/sbw4cPZ+jQofz617/mww8/DHy+YMECZs2axdVXX03//v159tlnSU5ODsnxOBGpUMPIX6Ga9PJ3jBCnM6tRz85Hx7f6ucvl4v33VzF+/DiMRmPIfzsUhg8fHvS+vr6eZcuWcf/991NcXIzb7aaxsTFoTuuWDB48OPA6Li6OhIQESktLW13fZrPRq1evwPvs7OzA+tXV1Rw+fJizzz478Ller2fYsGF4vd5m2wo1SahhFJi6TUZJEuK0pijKcZtdXYqKWQ82kwGjMTpP08f21r3//vtZt24dCxYsoH///litVq677jqcTudxt3PsHwyKohw3+bW0/rHXhY9tAWzPdeNTIaVSGEmFKoTobEwmU5t68X7++edcfPHFTJo0iUGDBpGVlcW+ffs6PsCjJCUlkZmZGdRk7PF42LRpU1h+Pzr/9IlR/muocsuMEKKz6NGjB19++SX79u0jPj6+1eqxV69erF+/ns2bN2MymZg9e3ZYmlmPddddd/H444/Tu3dv+vfvz4IFC6isrAxLvxU5s4eR3V+hyji+QohO4r777kOv1zNgwAAyMjJavSb6l7/8hfj4eC644AKuvPJKxo8fz9ChQ8McLfzud79jypQp/PznP2fUqFHEx8czfvx4LBZLh/+2VKhhFKhQ5R5UIUQn0bdvX9atWxe0bNq0ac3W69GjB3/4wx+YOHFi4DrnjBkzgtY5tgm4pWubRw8zeOGFFwatM23atGa/PWnSpKB1DAYDCxYsYMGCBQB4vV4KCgr46U9/2uo+hook1DDyV6hmafIVQogOsX//flatWsUFF1yAw+Hg2WefZe/evdx4440d/ttyZg8jqVCFEKJj6XQ6li1bxogRIxgzZgzbtm3jgw8+oKCgoMN/WyrUMLK7fNdQpUIVQogOkZubyxdffBGR35Yzexg5/FO3SackIYSIOXJmD6NAQpWBHYQQIuZIQg0jf5OvzDQjhBCxRxJqGDVVqHLYhRAi1siZPYz8Fao0+QohROyRhBpG/go1VLM9CCGEiB6SUMPI7pQKVQghjrVv3z4URWHz5s2RDuWUSEINI/9ISXINVQjRWVx44YXce++9IdvetGnTmDRpUtCy3NxciouLGThwYMh+JxJkYIcwssttM0II0YxerycrKyvSYZwyKZXCSG6bEUIAoKrgrD/uQ+9xnHCdk3q0Y7LtadOm8emnn/LMM8+gKAqKorBv3z527tzJxIkTiY+PJzMzk6lTp1JWVhb43j/+8Q8GDRqE1WolLS2NSy+9lPr6eh555BGWL1/Ov/71r8D2Pvnkk2ZNvp988gmKovDhhx8yfPhwbDYbo0ePZteuXUHxPfbYY3Tp0oWEhARuueUW7r//fs4888xQ/Bc6KVKhhpHMhyqEAMDVAHNzWv3YCFwBsLUDfvuBQ2CKa9OqzzzzDLt372bgwIE8+uijgDZh9wUXXMCtt97K/PnzaWxs5He/+x033ngj9957L8XFxUyZMoV58+Zx9dVXU1tby2effYaqqtx3331888031NTUsHTpUgBSU1M5dOhQi7//4IMP8uSTT5KRkcHtt9/OL3/5y8Cwgq+++ip//OMfWbhwIWPGjGHFihU8+eST9OzZMwQH6eRIQg2jwGwzUqEKITqBpKQkTCYTNpst0CT7+9//nqFDhzJ37tzAekuWLCE3N5frr7+e7Oxs3G4311xzDXl5eQAMGjQosK7VasXhcLSpifePf/wjF1xwAQD3338/l19+OXa7HYvFwoIFC5g+fTq/+MUvAnGtWrWKurq6kO1/e0lCDSOpUIUQABhtWqXYCpfLxfvvr2L8+HGBuUVD+tunYOPGjXz88cfEx8c3+6ykpITBgwdzySWXMGjQIMaPH8+4ceO47rrrSElJafdvDR48OPA6OzsbgNLSUrp3786uXbu48847g9Y/++yz+eijj9r9O6EiCTWMHFKhCiEAFOX4za6KC4/erK0T6oR6irxeL1deeSVPPPFE0HKXy8XWrVvR6/WsXr2atWvXsmrVKhYsWMCDDz7Il19+2e7m2KP/mFAUJfD7xy7za2nC8nCSUimMZOhBIURnYzKZ8Hg8gfdDhw5lx44d9OjRg969ewc9LBYLoCW6MWPGMGfOHDZt2oTJZOLtt99ucXsnq1+/fhQWFgYt++qrr055u6dCzuxh5G/ylQpVCNFZ9OjRgy+//JJ9+/ZRVlbGjBkzqKioYMqUKRQWFrJnzx5WrVrFrbfeisfjobCwkLlz5/LVV19RVFTEP//5T44cORKY4LtHjx5s3bqVXbt2UVZWhsvlOqm47rrrLl566SWWL1/Od999x2OPPcbWrVubVa3hJAk1jJy+CtUsFaoQopO477770Ov1DBgwgIyMDJxOJ1988QUej4fx48czcOBA7rnnHpKSktDpdCQkJLBmzRomTpxI3759eeihh3jyySeZMGECALfeeiv9+vVj+PDhZGRknPRk4DfddBOzZs3ivvvuY+jQoezdu5dp06YFquRIkGuoYeL2ePH42vctUqEKITqJvn37sm7dumbL//nPfwa9d7lcrFy5koKCAt57771Wt5eRkcGqVauaLT/6+ueFF17Y7HromWee2WzZ7NmzmT17duD92LFj6d279/F3qANJQg0T/yhJIBWqEEKcqoaGBv72t78xfvx49Ho9r7/+Oh988AGrV6+OWEySUMPE4Wq6CG82SEIVQohToSgKK1eu5LHHHsPhcNCvXz/eeustLr300ojFJAk1TPwVqlGvRPSiuRBCxAKr1coHH3wQ6TCCSKkUJg4Zx1cIIWKaJNQwsftumTFJc68QQsQkObuHSdMoSXLIhRAiFsnZPUz8oyRJhSqEELFJzu5h0jQXqhxyIYSIRXJ2DxN/hSqdkoQQIjZJQg0TqVCFECK2RfzsvnDhQnr27InFYmHYsGF89tlnx13/ueeeo6CgAKvVSr9+/Xj55ZebrfPWW28xYMAAzGYzAwYMCMxyEEkOGcdXCCFiWkTP7m+88Qb33nsvDz74IJs2beK8885jwoQJFBUVtbj+okWLmDVrFo888gg7duxgzpw5zJgxg3//+9+BddatW8fkyZOZOnUqW7ZsYerUqfz0pz/lyy+/DNdutUjuQxVCiNgW0YQ6f/58pk+fzi233EJBQQFPP/00ubm5LFq0qMX1X3nlFW677TYmT55Mfn4+N9xwA9OnTw+a6Pbpp59m7NixzJo1i/79+zNr1iwuueQSnn766TDtVcua5kKVhCqEELEoYkMPOp1ONm7cyP333x+0fNy4caxdu7bF7zgcjmZT81itVgoLC3G5XBiNRtatW8dvfvOboHXGjx9/3ITqcDhwOByB99XV1QBUVFSc9Fx9oM2+0NDQQHl5ORUVlXgdDaiOOsrLy096mx3t6JiNRmOkw2kTiTl8OmPcEnN4xGrMtbW1AM1mumlJxBJqWVkZHo+HzMzMoOWZmZmUlJS0+J3x48fz4osvMmnSJIYOHcrGjRtZsmQJLpeLsrIysrOzKSkpadc2AR5//HHmzJnTbHnPnj1PYs+O72/A36aHfLNCCCE6UG1tLUlJScddJ+KD4x87ULyqqq0OHj979mxKSko455xzUFWVzMxMpk2bxrx589Drm5pS27NNgFmzZjFz5szAe6/XS0VFBWlpaac0kH1NTQ25ubkcOHCAxMTEk95OOEnM4dEZY4bOGbfEHB6xGrOqqtTW1pKTk3PC7UUsoaanp6PX65tVjqWlpc0qTD+r1cqSJUt4/vnnOXz4MNnZ2SxevJiEhATS09MByMrKatc2AcxmM2azOWhZcnLySexVyxITEzvNPzA/iTk8OmPM0DnjlpjDIxZjPlFl6hexTkkmk4lhw4Y1mwx29erVjB49+rjfNRqNdOvWDb1ez4oVK7jiiivQ6bRdGTVqVLNtrlq16oTbFEIIIU5FRJt8Z86cydSpUxk+fDijRo1i8eLFFBUVcfvttwNaU+zBgwcD95ru3r2bwsJCRo4cSWVlJfPnz2f79u0sX748sM177rmH888/nyeeeIKrrrqKf/3rX3zwwQd8/vnnEdlHIYQQp4eIJtTJkydTXl7Oo48+SnFxMQMHDmTlypXk5eUBUFxcHHRPqsfj4cknn2TXrl0YjUYuuugi1q5dS48ePQLrjB49mhUrVvDQQw8xe/ZsevXqxRtvvMHIkSPDvXuYzWYefvjhZs3J0UxiDo/OGDN0zrgl5vCQmEFR29IXWAghhBDHJePgCSGEECEgCVUIIYQIAUmoQgghRAhIQhVCCCFCQBJqB2nvtHSR9sgjj6AoStAjKysr0mEFWbNmDVdeeSU5OTkoisI777wT9LmqqjzyyCPk5ORgtVq58MIL2bFjR2SC9TlRzNOmTWt23M8555zIBOvz+OOPM2LECBISEujSpQuTJk1i165dQetE27FuS8zRdqwXLVrE4MGDA4MKjBo1iv/973+Bz6PtGMOJY462Y9ySxx9/HEVRuPfeewPLQnWsJaF2gPZOSxctzjjjDIqLiwOPbdu2RTqkIPX19QwZMoRnn322xc/nzZvH/PnzefbZZ9mwYQNZWVmMHTs2MLh1JJwoZoDLLrss6LivXLkyjBE29+mnnzJjxgzWr1/P6tWrcbvdjBs3jvr6+sA60Xas2xIzRNex7tatG3/605/46quv+Oqrr7j44ou56qqrAifyaDvGbYkZousYH2vDhg0sXryYwYMHBy0P2bFWRcidffbZ6u233x60rH///ur9998foYhO7OGHH1aHDBkS6TDaDFDffvvtwHuv16tmZWWpf/rTnwLL7Ha7mpSUpP7tb3+LQITNHRuzqqrqzTffrF511VURiaetSktLVUD99NNPVVXtHMf62JhVtXMc65SUFPXFF1/sFMfYzx+zqkb3Ma6trVX79Omjrl69Wr3gggvUe+65R1XV0P57lgo1xPzT0o0bNy5o+fGmpYsW3333HTk5OfTs2ZMbbriBPXv2RDqkNtu7dy8lJSVBx91sNnPBBRdE/XH/5JNP6NKlC3379uXWW2+ltLQ00iEF8U9nmJqaCnSOY31szH7Reqw9Hg8rVqygvr6eUaNGdYpjfGzMftF6jGfMmMHll1/OpZdeGrQ8lMc64rPNxJqTmZYuGowcOZKXX36Zvn37cvjwYR577DFGjx7Njh07SEtLi3R4J+Q/ti0d9/3790cipDaZMGEC119/PXl5eezdu5fZs2dz8cUXs3HjxqgYcUZVVWbOnMm5557LwIEDgeg/1i3FDNF5rLdt28aoUaOw2+3Ex8fz9ttvM2DAgMCJPBqPcWsxQ3QeY4AVK1bw9ddfs2HDhmafhfLfsyTUDtLeKeQibcKECYHXgwYNYtSoUfTq1Yvly5cHTW0X7TrbcZ88eXLg9cCBAxk+fDh5eXn897//5ZprrolgZJpf//rXbN26tcWxsKP1WLcWczQe6379+rF582aqqqp46623uPnmm/n0008Dn0fjMW4t5gEDBkTlMT5w4AD33HMPq1atwmKxtLpeKI61NPmG2MlMSxeN4uLiGDRoEN99912kQ2kTf4/kzn7cs7OzycvLi4rjftddd/Huu+/y8ccf061bt8DyaD7WrcXckmg41iaTid69ezN8+HAef/xxhgwZwjPPPBPVx7i1mFsSDcd448aNlJaWMmzYMAwGAwaDgU8//ZS//vWvGAyGwPEMxbGWhBpipzItXTRxOBx88803ZGdnRzqUNunZsydZWVlBx93pdPLpp592quNeXl7OgQMHInrcVVXl17/+Nf/85z/56KOP6NmzZ9Dn0XisTxRzS6LhWB9LVVUcDkdUHuPW+GNuSTQc40suuYRt27axefPmwGP48OHcdNNNbN68mfz8/NAd61PuOiWaWbFihWo0GtWXXnpJ3blzp3rvvfeqcXFx6r59+yIdWqt++9vfqp988om6Z88edf369eoVV1yhJiQkRFXMtbW16qZNm9RNmzapgDp//nx106ZN6v79+1VVVdU//elPalJSkvrPf/5T3bZtmzplyhQ1OztbrampicqYa2tr1d/+9rfq2rVr1b1796off/yxOmrUKLVr164RjfmOO+5Qk5KS1E8++UQtLi4OPBoaGgLrRNuxPlHM0XisZ82apa5Zs0bdu3evunXrVvWBBx5QdTqdumrVKlVVo+8YnyjmaDzGrTm6l6+qhu5YS0LtIM8995yal5enmkwmdejQoUHd96PR5MmT1ezsbNVoNKo5OTnqNddco+7YsSPSYQX5+OOPVaDZ4+abb1ZVVev+/vDDD6tZWVmq2WxWzz//fHXbtm1RG3NDQ4M6btw4NSMjQzUajWr37t3Vm2++WS0qKopozC3FC6hLly4NrBNtx/pEMUfjsf7lL38ZOEdkZGSol1xySSCZqmr0HWNVPX7M0XiMW3NsQg3VsZbp24QQQogQkGuoQgghRAhIQhVCCCFCQBKqEEIIEQKSUIUQQogQkIQqhBBChIAkVCGEECIEJKEKIYQQISAJVQghhAgBSahCiJBSFIV33nkn0mEIEXaSUIWIIdOmTUNRlGaPyy67LNKhCRHzZD5UIWLMZZddxtKlS4OWRcNk5ULEOqlQhYgxZrOZrKysoEdKSgqgNccuWrSICRMmYLVa6dmzJ2+++WbQ97dt28bFF1+M1WolLS2NX/3qV9TV1QWts2TJEs444wzMZjPZ2dn8+te/Dvq8rKyMq6++GpvNRp8+fXj33Xc7dqeFiAKSUIU4zcyePZtrr72WLVu28LOf/YwpU6bwzTffANDQ0MBll11GSkoKGzZs4M033+SDDz4ISpiLFi1ixowZ/OpXv2Lbtm28++679O7dO+g35syZw09/+lO2bt3KxIkTuemmm6ioqAjrfgoRdiGbD0cIEXE333yzqtfr1bi4uKDHo48+qqqqNs3Z7bffHvSdkSNHqnfccYeqqqq6ePFiNSUlRa2rqwt8/t///lfV6XRqSUmJqqqqmpOToz744IOtxgCoDz30UOB9XV2dqiiK+r///S9k+ylENJJrqELEmIsuuohFixYFLUtNTQ28HjVqVNBno0aNYvPmzQB88803DBkyhLi4uMDnY8aMwev1smvXLhRF4dChQ1xyySXHjWHw4MGB13FxcSQkJFBaWnqyuyREpyAJVYgYExcX16wJ9kQURQFAVdXA65bWsVqtbdqe0Whs9l2v19uumITobOQaqhCnmfXr1zd7379/fwAGDBjA5s2bqa+vD3z+xRdfoNPp6Nu3LwkJCfTo0YMPP/wwrDEL0RlIhSpEjHE4HJSUlAQtMxgMpKenA/Dmm28yfPhwzj33XF599VUKCwt56aWXALjpppt4+OGHufnmm3nkkUc4cuQId911F1OnTiUzMxOARx55hNtvv50uXbowYcIEamtr+eKLL7jrrrvCu6NCRBlJqELEmPfee4/s7OygZf369ePbb78FtB64K1as4M477yQrK4tXX32VAQMGAGCz2Xj//fe55557GDFiBDabjWuvvZb58+cHtnXzzTdjt9t56qmnuO+++0hPT+e6664L3w4KEaUUVVXVSAchhAgPRVF4++23mTRpUqRDESLmyDVUIYQQIgQkoQohhBAhINdQhTiNyBUeITqOVKhCCCFECEhCFUIIIUJAEqoQQggRApJQhRBCiBCQhCqEEEKEgCRUIYQQIgQkoQohhBAhIAlVCCGECIH/H7HTGe3YBnNHAAAAAElFTkSuQmCC",
      "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": "027187f8",
   "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 20250923-161027\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 1/40:: 470batch [01:16,  6.12batch/s, loss=1.359240]                                1.359240]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Train Loss = 1.3474, Accuracy = 76.27%, Test Accuracy = 88.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 2/40:: 470batch [01:18,  6.03batch/s, loss=0.513059]                                0.513059]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Train Loss = 0.5129, Accuracy = 88.98%, Test Accuracy = 89.60%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 3/40:: 470batch [01:16,  6.18batch/s, loss=0.422064]                                0.422064]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Train Loss = 0.4225, Accuracy = 90.11%, Test Accuracy = 90.80%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 4/40:: 470batch [01:15,  6.26batch/s, loss=0.465506]                                0.465506]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 Train Loss = 0.4669, Accuracy = 89.39%, Test Accuracy = 90.03%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 5/40:: 470batch [01:16,  6.18batch/s, loss=0.483961]                                0.483961]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 Train Loss = 0.4840, Accuracy = 89.34%, Test Accuracy = 90.92%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 6/40:: 470batch [01:14,  6.33batch/s, loss=0.415523]                                0.415523]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 Train Loss = 0.4146, Accuracy = 90.25%, Test Accuracy = 91.56%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 7/40:: 470batch [01:14,  6.30batch/s, loss=0.388139]                                0.388139]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 Train Loss = 0.3885, Accuracy = 90.90%, Test Accuracy = 90.61%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 8/40:: 470batch [01:16,  6.14batch/s, loss=0.428776]                                0.428776]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 Train Loss = 0.4290, Accuracy = 89.19%, Test Accuracy = 90.12%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 9/40:: 470batch [01:16,  6.15batch/s, loss=0.404991]                                0.404991]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 Train Loss = 0.4049, Accuracy = 90.05%, Test Accuracy = 91.81%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 10/40:: 470batch [01:16,  6.11batch/s, loss=0.434293]                               0.434293]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 Train Loss = 0.4332, Accuracy = 90.11%, Test Accuracy = 91.25%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 11/40:: 470batch [01:16,  6.15batch/s, loss=0.353360]                               0.353360]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 Train Loss = 0.3529, Accuracy = 91.46%, Test Accuracy = 93.21%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 12/40:: 470batch [01:35,  4.90batch/s, loss=0.310045]                               0.310045]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 Train Loss = 0.3095, Accuracy = 92.04%, Test Accuracy = 93.24%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 13/40:: 470batch [01:38,  4.75batch/s, loss=0.255336]                               0.255336]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 Train Loss = 0.2547, Accuracy = 93.02%, Test Accuracy = 94.26%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 14/40:: 470batch [01:40,  4.68batch/s, loss=0.281694]                               0.281694]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 Train Loss = 0.2841, Accuracy = 92.55%, Test Accuracy = 92.06%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 15/40:: 470batch [01:37,  4.83batch/s, loss=0.332372]                               0.332372]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 Train Loss = 0.3311, Accuracy = 92.22%, Test Accuracy = 93.68%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 16/40:: 470batch [01:29,  5.27batch/s, loss=0.268725]                               0.268725]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 Train Loss = 0.2684, Accuracy = 93.17%, Test Accuracy = 93.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 17/40:: 470batch [01:14,  6.31batch/s, loss=0.273655]                               0.273655]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 Train Loss = 0.2756, Accuracy = 92.94%, Test Accuracy = 92.45%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 18/40:: 470batch [01:15,  6.26batch/s, loss=0.287777]                               0.287777]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 Train Loss = 0.2870, Accuracy = 92.75%, Test Accuracy = 93.31%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 19/40:: 470batch [01:16,  6.15batch/s, loss=0.256814]                               0.256814]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 Train Loss = 0.2557, Accuracy = 93.32%, Test Accuracy = 94.66%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 20/40:: 470batch [01:17,  6.04batch/s, loss=0.234779]                               0.234779]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 Train Loss = 0.2349, Accuracy = 93.70%, Test Accuracy = 93.15%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 21/40:: 470batch [01:17,  6.08batch/s, loss=0.564407]                               0.564407]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 Train Loss = 0.5631, Accuracy = 88.28%, Test Accuracy = 91.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 22/40:: 470batch [01:14,  6.29batch/s, loss=0.415212]                               0.415212]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 Train Loss = 0.4146, Accuracy = 90.34%, Test Accuracy = 91.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 23/40:: 470batch [01:15,  6.24batch/s, loss=0.330951]                               0.330951]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 Train Loss = 0.3290, Accuracy = 91.25%, Test Accuracy = 93.76%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 24/40:: 470batch [01:14,  6.27batch/s, loss=0.226858]                               0.226858]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 Train Loss = 0.2264, Accuracy = 93.62%, Test Accuracy = 94.20%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 25/40:: 470batch [01:14,  6.30batch/s, loss=0.207301]                               0.207301]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 Train Loss = 0.2073, Accuracy = 94.07%, Test Accuracy = 95.11%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 26/40:: 470batch [01:14,  6.31batch/s, loss=0.197985]                               0.197985]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 Train Loss = 0.1978, Accuracy = 94.27%, Test Accuracy = 94.47%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 27/40:: 470batch [01:15,  6.26batch/s, loss=0.204303]                               0.204303]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 Train Loss = 0.2045, Accuracy = 94.10%, Test Accuracy = 93.77%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 28/40:: 470batch [01:14,  6.33batch/s, loss=0.366111]                               0.366111]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 Train Loss = 0.3691, Accuracy = 90.72%, Test Accuracy = 88.95%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 29/40:: 470batch [01:15,  6.25batch/s, loss=0.450063]                               0.450063]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 Train Loss = 0.4500, Accuracy = 88.53%, Test Accuracy = 89.53%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 30/40:: 470batch [01:13,  6.35batch/s, loss=0.311627]                               0.311627]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 Train Loss = 0.3111, Accuracy = 91.10%, Test Accuracy = 91.50%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 31/40:: 470batch [01:14,  6.33batch/s, loss=0.280052]                               0.280052]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 Train Loss = 0.2791, Accuracy = 91.55%, Test Accuracy = 93.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 32/40:: 470batch [01:14,  6.31batch/s, loss=0.201501]                               0.201501]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 Train Loss = 0.2014, Accuracy = 94.34%, Test Accuracy = 95.38%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 33/40:: 470batch [01:15,  6.25batch/s, loss=0.195959]                               0.195959]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 Train Loss = 0.1953, Accuracy = 94.44%, Test Accuracy = 95.28%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 34/40:: 470batch [01:15,  6.20batch/s, loss=0.188287]                               0.188287]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 Train Loss = 0.1886, Accuracy = 94.53%, Test Accuracy = 95.10%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 35/40:: 470batch [01:16,  6.11batch/s, loss=0.171614]                               0.171614]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 Train Loss = 0.1714, Accuracy = 95.02%, Test Accuracy = 95.17%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 36/40:: 470batch [01:16,  6.12batch/s, loss=0.267745]                               0.267745]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 Train Loss = 0.2673, Accuracy = 92.59%, Test Accuracy = 93.93%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 37/40:: 470batch [01:14,  6.28batch/s, loss=0.192426]                               0.192426]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 Train Loss = 0.1931, Accuracy = 94.34%, Test Accuracy = 94.90%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 38/40:: 470batch [01:14,  6.32batch/s, loss=0.233124]                               0.233124]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 Train Loss = 0.2331, Accuracy = 93.36%, Test Accuracy = 93.59%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 39/40:: 470batch [01:14,  6.28batch/s, loss=0.229718]                               0.229718]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 Train Loss = 0.2297, Accuracy = 93.35%, Test Accuracy = 93.62%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch 40/40:: 470batch [01:17,  6.09batch/s, loss=0.247342]                               0.247342]\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 Train Loss = 0.2471, Accuracy = 92.78%, Test Accuracy = 93.43%\n",
      "0-0 end at 20250923-170722\n"
     ]
    }
   ],
   "source": [
    "\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",
    "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, deviden=False, T=200, K=10, chl=[32,64])\n",
    "        \n",
    "        \n",
    "        # optimizer = torch.optim.SGD([\n",
    "        #     {'params': model.conv1.parameters(), 'lr': 0.01, 'weight_decay': 0e-6},  # conv1 \n",
    "        #     {'params': model.conv2.parameters(), 'lr': 0.03, 'weight_decay': 0e-6},  # conv2 \n",
    "        #     {'params': model.fc1.parameters(), 'lr': 0.1, 'weight_decay': 0e-6},  # \n",
    "        # ])\n",
    "        optimizer = torch.optim.AdamW(model.parameters(), lr=2e-4, weight_decay=0e-5) # 2.5 ~ 1e-4 0.5e-4\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: 95.02%+-nan% (95.02% 95.02%)\t test: 95.38%+-nan% (95.38% 95.38%)\n",
      "\n",
      "Current Time: 20250923-170722\n",
      "Current Time: 20250923-170722\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": "iVBORw0KGgoAAAANSUhEUgAAAdQAAAGJCAYAAAAzN8JFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACH/UlEQVR4nO29d3xUdfb//5yZTHohvUBICDVIrwJ2KYINy4pYWdHVBSvr77OiosLad2VxUVkb2MWvq6xlUQkqRVqoUiUgJZQUkpDeJjP398edO2mTZCaZZGbCeT4eeczMve9775nLMK85533e5+gURVEQBEEQBKFN6N1tgCAIgiB0BkRQBUEQBMEFiKAKgiAIggsQQRUEQRAEFyCCKgiCIAguQARVEARBEFyACKogCIIguAARVEEQBEFwASKogiAIguACRFAFQRAEwQWIoAqCIAiCCxBBFYROTHl5OfPnz6dfv374+/sTGRnJ9OnTOXv2rMuvVVpaysMPP0xCQgL+/v4MGTKE5cuXu/w6guCp+LjbAEEQ2gdFUZg+fTrr1q3jqaeeYsiQIezevZtHHnmEnj178uyzz7r0etdffz1bt27lxRdfpE+fPnzyySdMnz4di8XCLbfc4tJrCYInopNuM4LQOVmzZg2XXnopn3/+OTfeeKNte1xcHNOnT+ef//yny661cuVKrrzySpuIakycOJF9+/aRmZmJwWBw2fUEwRORkK8gdFI+//xzwsPDue6662zb1q1bR05ODpdddplLr7VixQqCg4P5wx/+UG/7H//4R06fPs2WLVtcej1B8EREUAWhk7Jx40ZGjx4NwOnTp1m2bBk33HADl19+OVdddZXdYxRFoaamxqG/uuzdu5fU1FR8fOrPIg0aNMi2XxA6OyKogtAJqaysZO/evYwePZrnn3+erl27ctdddxEYGMh7772HTqcDoKqqiri4OIqKigBYu3YtRqPRob9jx47Zrpefn09EREQjO7Rt+fn57f+mBcHNSFKSIHRCduzYQU1NDaNGjaJfv36MHj2azZs3s2jRIi666CJ2795NcHAwfn5+ZGdn244bPnw4W7dudegaCQkJ9V5rIm2P5vYJQmdBBFUQOiHp6ekAjBo1iqioKFJSUpg4cSJ9+vRh+vTpbN68mfHjx/Pqq6+yZ88e3nnnHQCCg4MZMmSIQ9eoG96NjIy064UWFBQA2PVeBaGzISFfQeiEpKenk5KSQlRUlN39mne5e/duBg4caNve2pDvwIEDOXDgQKO51T179gAwYMAAF79DQfA8xEMVhE5Ieno68fHx9bYpisI777zDgAED6N+/P6AK6m233WYb09qQ73XXXcfbb7/NF198wbRp02zb33//fRISEmzJUYLQmRFBFYRORkFBAb///ju///47d999N9OnT6e8vJylS5fyyy+/8PPPPwNgsVjYv3+/LRMXICQkhBEjRjh9zcmTJzNhwgT+/Oc/U1xcTK9evfj000/5/vvv+eijj2QNqnBOIIIqCJ0Mbf70jjvu4Pvvv+eDDz4gPj6eUaNGsWXLFgYPHgzA4cOHCQsLIzIy0iXX/fLLL3niiSd46qmnKCgooF+/fnz66afcfPPNLjm/IHg6IqiC0MlIT0/HaDTy5ptv4u/v3+S43bt31/NO20pwcDCvvvoqr776qsvOKQjehCQlCUInIz09nYEDBzYrpqAmDLlSUAXhXEdq+QpCJyM2Npbrr7+eJUuWuNsUQTinEEEVBEEQBBfg1pDvunXruPrqq0lISECn0/Hf//63xWPWrl3L8OHD8ff3JyUlhX//+9+NxnzxxRf0798fPz8/+vfvz4oVK9rBekEQBEGoxa2CWlZWxuDBg3nttdccGn/06FGmTJnChRdeyM6dO3n88cd58MEH+eKLL2xjNm3axLRp07j99tv59ddfuf3227npppuk24UgCILQrnhMyFen07FixQqmTp3a5Ji//vWvfP311xw4cMC27b777uPXX39l06ZNAEybNo3i4mK+++4725grrriC8PBwPv3003azXxAEQTi38aplM5s2bWLixIn1tk2aNIl3330Xk8mE0Whk06ZNPPLII43GLFq0qMnzVlVVUVVVZXttsVgoKCggMjJSinoLgiCcwyiKQklJCQkJCej1zQd1vUpQs7OziY2NrbctNjaWmpoa8vLyiI+Pb3JM3Y4aDXnhhReYP39+u9gsCIIgeD8nTpygW7duzY7xKkGFxm2gtIh13e32xjTnac6dO5c5c+bYXhcVFdG9e3eOHj1KSEhIq201mUz8/PPPXHrppRiNxlafpyMRmzsGb7QZvNNusblj6Kw2l5SU0KNHD4e0wKsENS4urpGnmZubi4+Pj618WlNjGnqtdfHz88PPz6/R9oiICEJDQ1ttr8lkIjAw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DuTQoUPuNsUhtIxkb7/v8fHxJCUlecR9f+CBB/j666/5+eef6datm227J9/rpmy2hyfca19fX3r16sWIESN44YUXGDx4MK+++qpH3+OmbLaHJ9zj7du3k5uby/Dhw/Hx8cHHx4e1a9fyr3/9Cx8fH9v9dMW9FkF1MW1pS+dJVFVVceDAAeLj491tikP06NGDuLi4eve9urqatWvXetV9z8/P58SJE26974qicP/99/Pll1/y008/0aNHj3r7PfFet2SzPTzhXjdEURSqqqo88h43hWazPTzhHl9++eXs2bOHXbt22f5GjBjBrbfeyq5du0hJSXHdvW5z6pTQiOXLlytGo1F59913lf379ysPP/ywEhQUpBw7dszdpjXJX/7yF2XNmjXKkSNHlM2bNytXXXWVEhIS4lE2l5SUKDt37lR27typAMrChQuVnTt3KsePH1cURVFefPFFJSwsTPnyyy+VPXv2KNOnT1fi4+OV4uJij7S5pKRE+ctf/qJs3LhROXr0qPLzzz8rY8aMUbp27epWm//85z8rYWFhypo1a5SsrCzbX3l5uW2Mp93rlmz2xHs9d+5cZd26dcrRo0eV3bt3K48//rii1+uVVatWKYriefe4JZs98R43Rd0sX0Vx3b0WQW0nXn/9dSUpKUnx9fVVhg0bVi993xOZNm2aEh8frxiNRiUhIUG5/vrrlX379rnbrHr8/PPPCtDo784771QURU1/f/rpp5W4uDjFz89Pueiii5Q9e/Z4rM3l5eXKxIkTlejoaMVoNCrdu3dX7rzzTiUzM9OtNtuzF1CWLVtmG+Np97olmz3xXt91112274jo6Gjl8ssvt4mponjePVaU5m32xHvcFA0F1VX3Wtq3CYIgCIILkDlUQRAEQXABIqiCIAiC4AJEUAVBEATBBYigCoIgCIILEEEVBEEQBBcggioIgiAILkAEVRAEQRBcgAiqIAiCILgAEVRBEFyKTqfjv//9r7vNEIQORwRVEDoRM2bMQKfTNfq74oor3G2aIHR6pB+qIHQyrrjiCpYtW1Zvmyc0KxeEzo54qILQyfDz8yMuLq7eX3h4OKCGY5csWcLkyZMJCAigR48efP755/WO37NnD5dddhkBAQFERkbypz/9idLS0npjli5dynnnnYefnx/x8fHcf//99fbn5eVx3XXXERgYSO/evfn666/b900LggcggioI5xjz5s3jhhtu4Ndff+W2225j+vTpHDhwAIDy8nKuuOIKwsPD2bp1K59//jmrV6+uJ5hLlixh9uzZ/OlPf2LPnj18/fXX9OrVq9415s+fz0033cTu3buZMmUKt956KwUFBR36PgWhw3FZPxxBENzOnXfeqRgMBiUoKKje34IFCxRFUduc3XffffWOGT16tPLnP/9ZURRFeeutt5Tw8HCltLTUtv9///ufotfrlezsbEVRFCUhIUF54oknmrQBUJ588knb69LSUkWn0ynfffedy96nIHgiMocqCJ2MSy+9lCVLltTbFhERYXs+ZsyYevvGjBnDrl27ADhw4ACDBw8mKCjItn/cuHFYLBYOHjyITqfj9OnTXH755c3aMGjQINvzoKAgQkJCyM3Nbe1bEgSvQARVEDoZQUFBjUKwLaHT6QBQFMX23N6YgIAAh85nNBobHWuxWJyySRC8DZlDFYRzjM2bNzd63a9fPwD69+/Prl27KCsrs+3fsGEDer2ePn36EBISQnJyMj/++GOH2iwI3oB4qILQyaiqqiI7O7veNh8fH6KiogD4/PPPGTFiBBdccAEff/wx6enpvPvuuwDceuutPP3009x5550888wznDlzhgceeIDbb7+d2NhYAJ555hnuu+8+YmJimDx5MiUlJWzYsIEHHnigY9+oIHgYIqiC0Mn4/vvviY+Pr7etb9++/Pbbb4Cagbt8+XJmzZpFXFwcH3/8Mf379wcgMDCQH374gYceeoiRI0cSGBjIDTfcwMKFC23nuvPOO6msrOSf//wnjz76KFFRUdx4440d9wYFwUPRKYqiuNsIQRA6Bp1Ox4oVK5g6daq7TRGETofMoQqCIAiCCxBBFQRBEAQXIHOognAOITM8gtB+iIcqCIIgCC5ABFUQBEEQXIAIqiAIgiC4ABFUQRAEQXABIqiCIAiC4AJEUAVBEATBBYigCoIgCIILEEEVBEEQBBfw/wPvLgT2dJ0XfQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAdQAAAF4CAYAAADt+Qj5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB+BElEQVR4nO3dd3zb1bn48Y+25L3iFTtx9iAhIQlkAS0rgzJSCg1cSuEW2lKgQGn7K6HkMi4lQC/jtkBaRhiFEi5llLZhpGxIIIMsSMhO7CTee2l/f38cfWU7thPLljXs5/166aWvpa+kI8Xxo3POc55j0DRNQwghhBB9Yox2A4QQQoiBQAKqEEIIEQYSUIUQQogwkIAqhBBChIEEVCGEECIMJKAKIYQQYSABVQghhAgDCahCCCFEGEhAFUIIIcJAAqoQQggRBlENqB9//DHnn38++fn5GAwG3njjjeM+5qOPPmL69OnY7XZGjhzJn/70p07nvPrqq0ycOBGbzcbEiRN5/fXX+6H1QgghRJuoBtTm5mamTJnCo48+2qPz9+/fz7nnnstpp53Gpk2buO2227jxxht59dVXg+esXbuWxYsXc8UVV7BlyxauuOIKvv/97/PFF1/019sQQgghMMRKcXyDwcDrr7/OokWLuj3nN7/5DW+++SY7duwI3nbttdeyZcsW1q5dC8DixYtpaGjgrbfeCp6zYMEC0tPTeemll/qt/UIIIQY3c7QbEIq1a9cyb968DrfNnz+fp59+Go/Hg8ViYe3atfziF7/odM4jjzzS7fO6XC5cLlfwZ7/fT01NDZmZmRgMhrC+ByGEEPFD0zQaGxvJz8/HaDz2oG5cBdSysjJycnI63JaTk4PX66Wqqoq8vLxuzykrK+v2eZctW8Zdd93VL20WQggR/0pKSigoKDjmOXEVUIFOPUZ9xLr97V2dc6ye5pIlS7jllluCP9fX1zNs2DBKSkpISUkJR7OFEELEoYaGBgoLC0lOTj7uuXEVUHNzczv1NCsqKjCbzWRmZh7znKN7re3ZbDZsNlun21NSUiSgCiGE6NH0X1ytQ509ezarV6/ucNu7777LjBkzsFgsxzxnzpw5EWunEEKIwSeqPdSmpib27NkT/Hn//v1s3ryZjIwMhg0bxpIlSzh8+DDPP/88oDJ6H330UW655RZ+/OMfs3btWp5++ukO2bs33XQTp59+Ovfffz8XXnghf//73/n3v//Np59+GvH3J4QQYhDRouiDDz7QgE6XK6+8UtM0Tbvyyiu1b33rWx0e8+GHH2onnXSSZrVataKiIm358uWdnveVV17Rxo0bp1ksFm38+PHaq6++GlK76uvrNUCrr6/v7VsTQggxAIQSD2JmHWosaWhoIDU1lfr6eplDFUKIQSyUeBBXc6hCCCFErJKAKoQQQoSBBFQhhBAiDCSgCiGEEGEgAVUIIYQIAwmoQgghRBhIQBVCCCHCQAKqEEIIEQYSUIUQQogwkIAqhBBChIEEVCGEECIM4mo/VCGEGAzcPjcmgwmT0RTtpvQLv1/D7fPj9vnxePVrDbfPh9uroaFhNRmxmIxYzepiMRmxBa5NxuPvTRoNElCFEGGnaRpev4bXp+H1+/H5NTw+LXDtx69p2MwmHFYTCVYTFlP0B8va/5F3e/142l27vH48Pg2TwYDFbAj+sdf/wFvbXYfK4/fQ7G6m2dtMs6eZFk8LHr8HAwaSrEmkWlNJsaWQaEkM6Xm9Pj9Orx+f7/j7n5hMBiwm9b56spF2sO0+P06PD6dHXXv96t9Y0zT8mvpi0ORppq6lhdrWFuqdLXh9YDcnkGhJINmaiM1swWIyYjYZMBkMwdfXNPU74+ni38SnqYCbkWglK8lKVpKdFIcZu8WEzRzaewgnCahCiJBpmobL68fl8ePyBv6gen04PT5cXj/eY/wR92t+Wr1NaGgYDEYMGLCZTSRYLSRazSRaLSTaLCRaLZh70EPT/4h7/f5AAG8L3Op2Db8WuPhpO9bUsf7HX2+zpmm0uH00ubw0Or00uTyBa6/6Y+7X2r1m4DrwWn5NIy3BSkG6g4J0B0PTEnBY296Dx+/G5XPi8rXi9LXg9LXg8btpcWmU1vkprdUoq/VTVq+haZBkqyTJYSDFYSTVYSI7JYGhKckUpqeRn5qE2Wig2e2j0emivrWVBpeTRpeLZreTFrcHt8+D26vh8hpweQy4POD0gMsDrW5N/bu5NTCA3WLEYTWQYDWQYDOSYIUEm4FEGyTYwGAAl9tAqwecHg2nG9xe8PrA40O9jsdPi8dLq9sfCLIabm9X/2r1Xf5bGgCzyYABAx6fn1C2QrOajCTZzSRaTSQ7LKTYLeSn2bnhjNGMHJIUwjP1ngRUIeKM2+un0an+yDc6vbR6fKQ4zKQnWElPsPaql9SepqmemsendegV6L0EFUh9+PzqD3Jdi5u6Vg91LR7qWt00tHpULwXwawQClh+3z4XL58bj96Dhx2oyYLOgLmb92IDNrG6zmA34vTZcHhtOl5kWl5HGVj+1LW7qA69X3+rBaACL2dhuiNCAyQgmox+jyY/R4FPvCwNoBjTNiKYZ1AUDmgZ+P7R6/DQ6vTS7vPjDuKllWoKJ7BQjmckaWSmQlWyg1a1RWqdRVqdRVuenvqXrx1YGQ4oP8ABOoAY4GL4GRojRoP5djQbw+cHrB5+PDkFTAzw+fWvsjiwmMJv0awOapuH0gNOtznb7/NQ0u6lpBmpbg4/7zzkj+vmdtZGAKkSMc3p8NLQPoG5f8D59aNXn16ht9gDNJNvNpCVYyEi0kmDt/r+4y+uj1e2jxe2jotHF4doW6lo8NDg96naPj2aXmyaXiya3m2a3hxaXjyaXRpNTo6FVzXf1LzfQ2IPTfMc/J0QWk+qZqV6buraYwWRUQcFkVIHbaASz0YjFZMBiMlHd6KG8wUdlg0aTE+pafNS1+KDs2K+Xngh56UaGZ5kZk2fBYTXS0OynodVPg9NPY6umLk4/jU6Nplb1724yGjAG2mQ0gkm/DtxmNYPdYsBuhUSbkSS7kWS7kRSHidQEIyl2ExigxaXR4tZocvppdvlpcmq0uPw0uzRaXBo+TcNiUs9rNmmBLzLqc1LXBqzmzl+Q7BZIshtxWIzYLCY01O+0y+ND08Dn1zoEWK9ffR5twVO9J4PBgM2ipggSrCasZqMaZfC3tbfZqdHs0mgKtHuIPY+h6Y6w/250RwKqED3k8fmpb/XQ7PJiQP8jZghc1H94kzFwjEENQfr1uUR/p6FIvRd3LG6vj7J6F1VNLqqb3Oq62R38ubrZhdPjx2ExkZFoJTPRSkailfREC6kOI5nJRvLSzGSlGKhs9HKk1k1pnZuKBi9VTV5qmrxUN3lo9fh7/blYzZBsN5DsMJLqMJNsN4PBg1/zYTCooUJQ1wYCwchkwO2BFrcfV2AI0uXVAscaLq8aTlR/jA0kOwLXdgPpiUYykk0MSTaTnWLF6/fR4vLR6vbT4va3DWV6NJxeJ43eCowGKw5jGlajPRAQDFiMBswmg+rRmtRwZ6KVwJCnaqM+HKyhhotNRjXXaDIZ1eMDgdRsVLeBmottcash4spGL4eqvVQ2aIGLn6pGDbvFQG6agdw0yE2HomwTmUkGHFYjGj58Wit2k51ES2KP5wM1TaOytZID9cUUN5RQ0ljCkebDWM0OJg+ZwoycaQxLGRa2+UU1x6mGdl1eHy6PHz9gNRmwmk1YTUbcWjPlLUc41HSIwzWHOdR0iEZ3IwaDGtZVz2MADIFrAAMWo4UkcypptjQyHOlkOdLJTswg0ZFBmj0Nh9naoS3Jdg1vshe33407MAri8XsoTErDYQv/l63uGDRN6++vmHEnlB3axcDl92s0urzUB4YWm91eQvnfoidVHJ1QoWc2OgNDtw2tXhpd6rq+1UV9q4sGp5cmp49WT+T+ezoCvTB9yFXvXditBhwWAw6rQR1bwW7RSLIbSLSr3sjxWM1GEm1mEm0mEi0mnP5WGj2NNLmbqHc2UudqoMHVRKO7iUZPE82eZlq9LSSZk8h0ZDEkIZOchCHkJQ8hy5GF3Wzv8Pw+v4+yljIONR5Sf7wbD1PSWEK1s7rDeQnmBDLsGWQ4Msi0Z6rjwMWn+WjxtNDsUclB7ZOEmj3NtHjVuKzZaMZisGA2moMXi7HtZ5/mw+1z4/K5cPvcOL0uWr0uXD518fo9eP0e/Pjwa8f+ImMymEi1paqLNbXtOPBzo7uRksYSihuLOdR4CKfPeczny7RnMjV7KlOHTGVcxjjMxmONYLgoaymjtKmU0uZSnD4nVqMVi8mCxWgJHre/rcnTpP4NAv8Oda66Y7ant2wmGw6zA4/PEwye3X09ffm8l5mYObHXrxVKPJAeqoh7To+PZpeXRJvK8uuLVrePulY1R9fQ6sXXxWSa369R1+qhpln1FmsCl+pmNzVN6ri+1YPb1/teX3tmE6QmGEh1BK4Dl5QEA6kJKnGkxaXR0AINrZq6tGg0tBI8bnFDkh3SEgykJhpITzSQmWxkSIqJIckGkhOcOLVaXP4WnL5WXD4nTl8Lrd5WWrwttHpaqfe2UOFz4TA6SDImkeBPwuFKxOZJwmJMxGJwYDUkYjU6cGlNuLVGnP56Wry11LvrqHHWUO2spqa1Brff3fMPoK7zTUmWJDIdmaTb0qlx1nCk6QhercvsF1KtqXj8Hlq8LerS1MKhpkO9+8eIAAMGTEYTXr8Xn+ajxllDjbOmR481G8zkJ+VTmFxIYXIho9JGUdZcxpcVX/J11ddUO6t5r/g93it+D4fZweSsyUzNnkqqNZWy5jJKm0uDl56+5vFkObIoTC5kaNJQCpILyLBngAZ+/Oj9Ob/mR0MliGmokYVaVy11rjp1cdYFj1u9rcEvJ919flaTFYvRQqIlsdtA2x+kh9oF6aHGPk3TqGvxUN7opK7FE+w5mk0GEq1mkvTeUDdBVp8/rGvx8GVxLRsO1LLlUB2HalsDmZ8E/oOjklaC//HVEG6o/2tU9mLbnJDZZAjO0SXaDO2yKTteJ9pUj9BiNmI2GTEbDZj14cbgzwaVRNN+eFIDzQ/+wB8pr8+Pl1bqPVXUOCuoclZS0VJBeUs5FS0VtHpbj/cWws5hdpBkSSLJkkSiNTF4nGRJIsmahMPsoNHdSFVrFdXOaqpb1aXZ29zl89lMNgqSCyhIClySCxiaNJQkq8rwbPW2quDUGgjsgUBV01pDjasGs8FMoiUxeEmwJKhjs/o5xZaChobL68Lr9+Lxe/D6vepYazs2GUzYTDasJmvw2mq0YjPbsBqtWE3WYG/WZDAF15vqPxsNaujY4/fQ4GqgzlVHg1td17vqg7fVu+txmB0MSx4WDKC5ibnBHnNBcgGZ9kxava3srN1Ji6eF7dXb2Vyxmc2Vm2lwNxz33yjJkkR+Uj65ibkkWhKDPUK33912HBhidfvc2M32DsFzaNJQHObwzmE6vU7qXfWde8yBIGoymILD2idknkCCJaFPrxdKPJCA2gUJqLHL7fVT0eikotGFq4fzfhaTgUSbGavZSEOrh68O17P1UD07ShvYVd7Uq56k0QDpiVbSEkwk2zUS7T6SHH5SHKrnmGQ3dMhK1OdYj8VgILCOzoTNYsQeWNBuNhoxHrWQvdXbyr76feyt28uhxkPBP2rBP/B+D16t7djldR1zONCAgTR7GsmWZBLMCTgsDnVtdpBgSQjeZjPZaPWo4dpG91GXwG1evxebyUaGPTCs6shoO243xGoxWUL+3PX3Xt1aTVVrFbWuWtJsaRQkFZDpyAwGo76wGC04zI5OF73IgtfvDfaQ9M9V/9ntC6Hn3Q9MBhN5iXnkJOZ0+CxaPC3sqt2Fx+8BVI9wf/1+NldsZkvlFtw+N3lJeeQl5pGbmBu8TrYm90s7jQYjJoOp4xcLowmLwYLJaMLj91DrrA22t7ckoMYACaixp77VQ0WDk6omF3UtHsoanJTVOylvcFJa76TR6VVZjgYDRqNKFDIZO/7c0OphV3kjLm/HAJrqsDAxL4UThqZw4tA0QCUggQpyxkAgNBpAw4/T34jB2ITT34xf65jwoHqeqjd5vJlFlYFpxGY2YbeoJR9dBV1N06hoqWBP3R721u9lT+0eDjcd7tVQVoY9g5yEHLITsslJyCEnUR1nO7J7HeCObqvH78FitHR6LwmWBJItySRZVS/UgAE/fjXcF1ha49N86jhwe4O7gXpXPV5/18O5x5NiTSHVlnrMuUKdPi/Xk3O749f8OL1OWr2tHS7dDU+GiwED2QnZ5CXlYTF2/e/o9DrZWbszIkHfaDBiN9mxmWzqYrYFj60ma4+++GiaRoO7gVpnLbWu2pB/BxLMCYxJH4PVZD3+yccgAbWPJKBGn9+vUdbg5INvKthUUseh2pZAAHXR6ulb1l6K3cyEvBQm5qdwQl4qY3ISyU11kJVk61DSTC9Y4PL4qHc2c6SpnIqWKjw+byA7VKXuW00GrCYTVlNbpmco3D53MHA0uBtodDcGj6tbq9lbv5dGd+elI1mOLEaljmJE6ggcFkeHRJn2STIWowWLyUKmPTP4x8Vusquel6WtB2Y32YNBzev3Bnu4Pr8Pn+bD4/cEj/X7fX5fcK6vPb3KT5IliWRrMkmWpF6X0dM0jUZPI/XOempdtccMTnoST5otrceBNBJUMYu2AOvxe4JfIvT5w+CXicBtPu34SUugviQVJBdgM9mOe67L52Jnzc6QArwerFOsx/9baDaasZlsYfly1p4eXKud1dQ56zr9vukjKfrwfIIlISyjFSABtc8koEZHs9PL+oM1fLSrki/21bCzrBFfF7+eBiAzyUpuqoPcFDu5KXbSEy3BuU69Io4veKzmFK1mI+NykilId2AyGshMspGTYiPZ3vV/fr/mp8ZZQ2VLJU2epl69J314Mjhf1y4xp9ZZS727vkd/3MwGM0WpRYxKG8XotNGMShtFmi2t+/P1QBoIplajtS1wmu1h+2Oj0zQtGGD9mr9fXkPX6m2lzllHrauWZk8zVpOVNFsaabY0UqwpUSs71x/0z1X/YtPhi4zmJc2WFnJJQo/Pw87anT2aNw8lWEeKX/NT71L/b/Qg2p81jyXLV8Q8fQnJkbpW3v+mgrV7q9lUUkd9a8c5k9wUOxPzUyhMdzA03cHwzEQK0xNItps7FM42AC6vP1j6TtUXVcftY7LdYiQnxc6QZFu39WOdXieVLZVUOat6NMzk8XmCmZFHmo5wpPkI5c3lVDure5zsYzaaVc1WawrJtmRSrCmkWFNIs6UxInUEw1KGdTmUpw9ptk/K6OmQWjgZDAYsBku3w43h5DA7cCQ5yEvKw+v3xkwvtD/0x+dqMVkYlzGOXbW7aPF0XaIp2ZpMYXJhyME6EowGI+n29Gg3o0sD9zdRRJXX56e2RS0dcXt8lDU42V/VTHFNC4dqWzlS10ppvZoHbd8HtZmNnJCfytTCVE4bM4QphWmkOSydknK6ktjFl+j2NWcxqPlSUOsWnV5nh2xFj08tregu+7HF00JZcxllLWUqcAaCZ2VL5THnMxMtiZ2TcgKJOnrhc7vJ3qOeVawOaUbLYH//vWUxWhiXPo7dtbs7jL44zA4KkgpIs6dFr3FxTH4bRVh5fX4OVrfwysYSth6qp7TeSWl9K85jZOQOz0jgxIJUphSmcdKwNPLTHGQm2vpckxYC1YtMflrd1dQ76yluUtmwR8/B6Dx+D5UtlZS3lKvgGbiUt5Qfc5lBgjmB/KR8dUnMJy8xj0yHCqBHFyHQmQymwBKXY8+TDeQhTRE9ZqOZselj2VO3h1Zva3CZjfx+9Z4EVBEWPr/G3som/rL2AP/YWkpdS8ehW4MBspNt5KU6yEu1By5qR44hyTaykmwMSbaRaAvPr6SmadS76qlqraLOVdepB+nX/FS1VgUruujX5c3lx+xtptpSyU3IDQZOPYj2NNAZDUYy7BlkObI6LEkIJqMEslv1zFeDwRD2dXxC6ExGE2PSxwBEfJpgIJKAKvrE79fYXtrAM5/t5+2vymgOFCnPSLRy5vhshmckkJfqIDvFFtz3sv1mwYk2M+kJnZdY9FaLp0UVAHBWB9ewef1eDjYcZH/9/mBZukNNh7pNBrKZbOQm5pKbkEtOYg65CbnkJqrj3ga3FGtKsLJPVwkUBoNBrcVjYG4oLWKXBNLwkYAqesXv19hcUseTn+zjvR0VweII+Wl2LpiSz4VT8xmSbA8sK1GXnsyDhtyOwHKEJncTVc6qYN3VvXV72V27m911u9lfv7/LBeJ6mbahyUMpTCoMVnZJs6WFJcDbTDayHFlkOjJjKktSCNE/JKCKDqqa1M4m3dE0jd0VTby68TCf7K4M7hs5akgi3502lPMm55OXZsdmDm9PS9O0Tovl9QXz9a56tldvDwbQw02HOz0+yZLEyLSRqkRbUiFDk4eSk5DTo6QWi9ESXEuZbE3GYXYE5z7bFyFofzEZTMGSd0KIwUECqgBUEYP9Vc2BPTU78vj8bD/SwMbiWjYerKWmua3SyqShqVwyvYB5E3PITrF3KIzQV3qCUI2zptPyk1ZvK1+Wf8nnpZ+zvXp7p3nPnIQcRqeNZkz6GMakjSE3MbfHvU6byUayNTkYRLtKKjJgkKEyIUQHElAF5Q1Oimta8PraglKTy8vmkjo2HKhh66H6DtWJbGYj04als/jkAk4fmx3WOVBQwVJfx9k+A9br97Ktahufl37O5orNHYZxh6cMZ3zGeEanjWZ02mjS7emdarFaTdbgHozdMRlNEVlLKYQYeCSgDmJOj4+9lU00tKriBV6/n092VfHpniq+KWug/c5laQkWpg9LZ0ZROt8aO4RhmYkkhSkjV1fvqqe8pZx6V33wNr/mZ3ftbj4v/ZwNZRs67DSSm5jLrLxZzMmbw7iMcW3BM1DEXQghIkkC6iCkaRpH6p0cqmnBHyjXt3ZvNa9sLKG8oW3+tDDdwfThGUwfns643KRgtm4450f18n7lzeXBDZw1TeNAwwG+KP2C9eXrqXXWBs9PtaUyM3cms/JmMSFzAjkJOWTYM/q19JgQQvSEBNRBptnlZV9lM00uL5qm8WVxHf+3oYTiGhXMUhwWvjM5j5kjMshJseOwmshLtXcqHN9X+vxoRUtFsFB4SWMJ68rWsb5sPZWtlcFz7SY703OmMyt/FidknkCWI4vshOyYLIsmhBi8JKAOImX1Tg5UN6NpsP1IPSvXl7C7QpUdS7CaOP/EfBZMysVuMZHqsJCXaic9sW9bHx1Nnx+taq1CQ+Nw02HWl61nXdk6yprLgudZTVamDpnKKbmnMDlrMsnWZIYkDCHLkSXl5oQQMUn+Mg0Cfr/G/upmKhpc7K1s4uX1JWw7rOYprSYjCyblcv6UfJJsZjISrRSkO8JWsUhX76qnrLmMBncDXr+XDeUbWH1gNfsb9gfPMRvNTMmawsl5JzMlawoOi4N0WzpZCVk92jpKCCGiSQLqAOf2+tlV3kh5g5OnP93Pmr3VAJiMBs4an82ik4aSnmAl2W5mWGYCKd1sZdYbfs1PdWs15S3ltHpbafY081HJR7xX8l5wXtRkMDEpaxKn5J7C1OypOMwOkixJZDmyZG5UCBFXJKAOYM0uLzvLG9lX0cxDq3dypN6JATh1TBYXTysgOzBHOiwjgYwwDu36NT8VLRWUNZfh8Xsoby5n9cHVfHrkU9w+tYY1xZrCmcPO5NuF3ybFmoLVZCXTnkmWI6vbYvJCCBHLJKAOUFVNLvZVNrN2bzXLP9qD0+MnI9HKL84ew+jsZKxmAwXpCWQn28K2hrR9IHX73Oys3cm7B95lS+WWYOGFgqQC5hXNY2beTKxGq9rWzJFJqi01LG0QQohokYA6AJXUtFBc3cL/bSzh75uPADAxL4UbzxpDRqKVvFQ7+WmOsGXtappGZWslR5qO4Pa52VK5hX/s/UeH+dETh5zIvOHzmJAxAYPBQJYji/ykfFkvKoQYMCSgDiA+v8aeiiYOVjfzx/f3BBOPzp2cx3+cMoysZCsjs5LCss8oqEBa1VrFkeYjuLwutlRu4e97/87BhoMAWI1W5gydwznDziEvKQ+ATHsm+Un5MqwrhBhwJKAOEHq93a+PNPDw6l1UNrmwmY385PSRzB2dxbCMBPLTwrevZlVrFUeajuD0OtlcuZk3974ZDKQ2k40zC89kftF8UmwqOzfDnkF+Ur7s7SmEGLAkoA4QeyubeOfrMp78ZB8en0ZOio1fnD2WsbnJjMlOIjlM2bsev4f99fupc9axuXIzf9/zd4obi4FAIB0WCKSBZS5ptjSGJg0lwZIQltcXQohYJQF1ACirb+UP7+1h1bZSAKYWpnH9GaMpzHAwekgSZlN4hngb3Y3srdvLhvINvL779Q6B9KxhZzG/aH5wezN9Q22pZiSEGCwkoMa5FreXJz7eFwymF00bysXTCyjKTAzrEG9pUylbK7fy4jcvsqliE6AC6dnDzubckecyNGkoqbbU4BIYIYQYbCSgxjG/X+OtbaU8v1bNXf5g5nAumj407EO8e2r38OruV3ljzxu4fC5MBhPnjjyXKydcSUFKgfRChRACCahx7esj9dz31k68fo2Ti9K5fFYhY7KTwzrE++6Bd1nx1Yrg8O7Y9LEsnbWUqdlTw/IaQggxUEhAjVO1zS7u/Md2KptcZCfb+M2C8UzIC19xhD21e/jDpj/wYcmHaGgkmhO5evLV/Oek/5Ti9EII0QX5yxiHPD4/D/97NxsP1mIxGfj1/LGcWJAWpuf28MKOF3h629PUu9U61tOGnsZtM2+jILkgLK8hhBADUXjGBvvg8ccfZ8SIEdjtdqZPn84nn3xyzPMfe+wxJkyYgMPhYNy4cTz//POdznnkkUcYN24cDoeDwsJCfvGLX+B0OvvrLUTc3zcf5oXP1bzpD2cXcfaE3LAUayhvLufqd6/moY0PUe+uJzchlwdOe4DHznpMgqkQQhxHVHuoL7/8MjfffDOPP/44c+fO5c9//jMLFy5k+/btDBs2rNP5y5cvZ8mSJTz55JOcfPLJrFu3jh//+Mekp6dz/vnnA/Diiy9y6623smLFCubMmcOuXbu46qqrAHj44Ycj+fb6xY7SBn73rx34NZg7KpPLTikMy56lG8o28OuPf01VaxVmo5mLRl/EjdNulBq7QgjRQwZN07RovfjMmTOZNm0ay5cvD942YcIEFi1axLJlyzqdP2fOHObOncvvf//74G0333wzGzZs4NNPPwXghhtuYMeOHbz33nvBc375y1+ybt26bnu/LpcLl8sV/LmhoYHCwkLq6+tJSYmdfTgbnR4uf/ILth6uJz/Nzv9cMoWZIzL7XJP3he0v8NDGh/D4PWQ7srln7j3MHjo7TK0WQoj41dDQQGpqao/iQdSGfN1uNxs3bmTevHkdbp83bx5r1qzp8jEulwu7vWMNWIfDwbp16/B4PACceuqpbNy4kXXr1gGwb98+Vq1axXe+851u27Js2TJSU1ODl8LCwr68tX7h92vcu2oHWw/XYzMb+cXZY5k8NLVPwdTtc3Prx7dy//r78fg9TB0ylRfOfUGCqRBC9ELUAmpVVRU+n4+cnJwOt+fk5FBWVtblY+bPn89TTz3Fxo0b0TSNDRs2sGLFCjweD1VVVQBceuml/Pd//zennnoqFouFUaNGccYZZ3Drrbd225YlS5ZQX18fvJSUlITvjYbJa5sOsXKdatfVp45g1sjMPq01LW0q5bJ/Xca/9v8LAwYuHnsxT8x7IljEXgghRGiinuV79F6cmqZ1uz/n0qVLKSsrY9asWWiaRk5ODldddRUPPPAAJpMJgA8//JDf/e53PP7448ycOZM9e/Zw0003kZeXx9KlS7t8XpvNhs0Wu9uI7a9s4u5/bEcDzhiXzcJJeRSk974K0poja/j1R7+mwd1AojmRm6bdxCXjLpHlMEII0QdR66FmZWVhMpk69UYrKio69Vp1DoeDFStW0NLSwoEDByguLqaoqIjk5GSysrIAFXSvuOIKrrnmGiZPnsx3v/td7r33XpYtW4bf7+/39xVufr/GTSs30+D0MjwjgatPLWJ0dlKvNgXXNI0ntz7JtauvpcHdwLDkYTxyxiNcOv5SCaZCCNFHUQuoVquV6dOns3r16g63r169mjlz5hzzsRaLhYKCAkwmEytXruS8887DaFRvpaWlJXisM5lMaJpGFPOveu39neXBedObzh7D6OxkHFZTyM/j9rn5xYe/4A+b/oCGxpz8OTx21mPMyp/Vq+AshBCio6h2S2655RauuOIKZsyYwezZs3niiScoLi7m2muvBdTc5uHDh4NrTXft2sW6deuYOXMmtbW1PPTQQ3z11Vc899xzwec8//zzeeihhzjppJOCQ75Lly7lggsuCA4Lx5MVnx4A1FDvhLwUclND35i71dvKDe/dwLqydZgMJi6fcDnXTLqGdEd6mFsrhBCDV1QD6uLFi6murubuu++mtLSUSZMmsWrVKoYPHw5AaWkpxcXFwfN9Ph8PPvggO3fuxGKxcMYZZ7BmzRqKioqC59x+++0YDAZuv/12Dh8+zJAhQzj//PP53e9+F+m312cHqppZu7cagIWTcxk1JCnk52j2NPPjd3/MtqptWE1WfjHtF1w05iLZn1QIIcIsqutQY1Uo647609I3vuIvnx9k8tBUnvvRKWSEWMCh3lXPj975Ebtqd+EwO/h/J/8/Lhh1gWyvJoQQPRRKPJBMlBjl9Ph4Y9NhABadlB9yMK1sqeRH7/yIAw0HSLQkcvvM21kwYoEkHwkhRD+Rv64x6uX1JTS6vGQlWTn/xPyQHnuk6Qg/eudHHG46TIo1hTvn3MlZw87CaIh66WYhhBiwJKDGIE3T+Eug+P2CSbkMSe75Gtn99fu55p1rqGitIMOewT1z7+HUoadKJq8QQvQzCagx6PN91eypaMJiMnDpyYU9DoY7qndw7b+vpcZZQ7Yjm/tPv58ZuTP6ubVCCCFAAmpMevrT/QDMGZXJuNyeJUVtLN/Ije/fSIO7gbzEPB781oNMHjK5P5sphBCiHQmoMeZIXQsf7qwE4JIZhVhMx5/33Fmzkxveu4EmTxPDkofx8BkPMzZ9bH83VQghRDsSUGPMM58dwOvXGDUkkW+Pyz7muZqmUdJQwu+++B1NniYKkgp47KzHKEotikxjhRBCBElAjSEuj4/XvlRLZS6cOpQkW/f/PD6/j331+3hr/1tsqtiEyWDinlPvkWAqhBBRIgE1hryx+TDVzW6S7WYumja02/M8Pg+76nZxpOkIf93xVwAun3A503OmR6qpQgghjiIBNYa88Lkqs3jOhByGpnW9PVuLp4Vdtbtw+9w8//XzNHubKUop4sZpN0ayqUIIIY4iATVGbDxQw7bD9RgM8B8zh3W5VKbOWcfe+r34NT9rS9eyuXIzJoOJu+fcjc0Uu/u5CiHEYCABNUY8s+YAADOGp3NiQVqn+8uayyhpLAGg1lkbHOpdPG4xJ+WcFKlmCiGE6IbUoosB5fVO/r2jHICLpxdgNXf8Z2n2NAeDqaZpPLf9OVq8LYxIGcFN026KeHuFEEJ0JgE1BrzwxUGcHj/5aXYWTMrtdH9Na03w+LMjn7G1citmg5nbZt4m27AJIUSMkIAaZR5v21KZ80/MJ9XReVeZGpcKqDXOGl765iUALh57MTPzZkauoUIIIY5JAmqUfbirksN1rdgtRhafUtjp/kZ3I26fG03TePbrZ2n1tjIidQTXTb1OCt4LIUQMkYAaZS9+oZbKfGvsEIoyEjvdX+usBeDTw5/yVdVXmI1mbpl+C+n29Ii2UwghxLFJQI2i2mY3H+9SdXv/45ThGI0de5yaplHjrKGmtYaVO1cC8L0x32Pu0LkRb6sQQohjk4AaRTvLG/FrkJ1sY+bIjE73N3rUcK8+1DsqdRRXT74ai9EShdYKIYQ4FgmoUbSvshmA4ZkJ2C2mTvfXtNawr34fX1V/hdlg5vqTric3oXMWsBBCiOiTgBpFuysaAbrc81TTNGpdtXx86GMATs47mbn5cyURSQghYpQE1CjaU9EEwIS85E73NbgbaHQ3sq5sHQAXjrpQ1pwKIUQMk4AaRfqQ76ghSZ3uq3HWsK50HS6fi7zEPOYNnxfp5gkhhAiBBNQocXl9lNa3AjBySMflMpqmUeus5ePDarh3QdECLCZJRBJCiFgmATVKDla34Ncg0WpiSFLHnWLqXfUcaDjA/vr9mAwmLh57cZRaKYQQoqckoEbJ3sD8aVFWYqdEoxpnTTAZaVrONIalDIt4+4QQQoRGAmqU7KlUAXVkVsfhXr/mp6KlgrVH1gIqGUkIIUTsk4AaJbvKVUAdnd0xw7feVc+6snW0eFvItGdyzvBzotE8IYQQIZKAGiX7Aj3UsTkdM3xrnDV8cugTAM4adpYslRFCiDghATUKNE3jYHULACPbLZnx+X18U/MN39R+gwEDF425KFpNFEIIESIJqFFQ2eSiyeXFaFBlB3V1rjo+OvQRAJOzJjMuY1y0miiEECJEElCjQC/okJti71DDt6Klgs8OfwbAuSPOxWw0R6V9QgghQicBNQr2lLctmdH5/D4+PvQxDe4GUqwpzC+aH63mCSGE6AUJqFGwK1AUv/2SmfaF8E8vOJ1MR2ZU2iaEEKJ3JKBGgV7UYXR2W0LSrtpdbKvaBsAFoy6QXWWEECLOSECNgv3Vag51XI5ag+r1e3lr31toaIxPH8+UIVOi2TwhhBC9IAE1wlxeH2X1TgBGBdagVrVW8cnhwNrT4bL2VAgh4pEE1AjTi+IntCuK/1HJR1Q7q0kwJ7CgaEGUWyiEEKI3JKBG2O5ylZA0LCMBg8GA1+/l7QNvAzA7fzb5SfnRbJ4QQohekoAaYXoNX72gQ0lDCZsqNgGwcMRCrCZr1NomhBCi9ySgRtjuwJKZUYGSg3/f+3d8mo8RqSOYnjM9mk0TQgjRBxJQI2x/lcrwHZ2dhKZpvLX/LQC+VfAt0m3p0WyaEEKIPpCAGkGaplFco4rij8tNZn/9fo40H8FitDC/aD4mo+k4zyCEECJWSUCNoMomF80uHwaDGvL9qvorAAqTCylMLoxy64QQQvSFBNQI0isk5SSrovjbq7YDMCxlGCnWlGg2TQghRB9JQI2gnWVtS2YAdtftBmB8xngpNSiEEHFOAmoE7a7ouGRmf/1+AKYOmRqtJgkhhAgTCagRtK9SBdSRQxKpbq2msrUSgElZk6LZLCGEEGEgATWCDlSrDN8x2Ul8VaUSkjLtmaTaUqPZLCGEEGEgATVCnB4f5Q2qKP643BR2VO8AYETqiGg2SwghRJhEPaA+/vjjjBgxArvdzvTp0/nkk0+Oef5jjz3GhAkTcDgcjBs3jueff77TOXV1dVx//fXk5eVht9uZMGECq1at6q+30CMHqpqDRfGHptnZVbcLgNFpo6PaLiGEEOFhjuaLv/zyy9x88808/vjjzJ07lz//+c8sXLiQ7du3M2zYsE7nL1++nCVLlvDkk09y8skns27dOn784x+Tnp7O+eefD4Db7eacc84hOzubv/3tbxQUFFBSUkJycnKk314HOwNF8YemOcAAB+oPADAuY1wUWyWEECJcohpQH3roIa6++mquueYaAB555BHeeecdli9fzrJlyzqd/5e//IWf/vSnLF68GICRI0fy+eefc//99wcD6ooVK6ipqWHNmjVYLBYAhg8fHqF31D29KH5hhoMmdxMljSUATMiYEM1mCSGECJOoDfm63W42btzIvHnzOtw+b9481qxZ0+VjXC4Xdru9w20Oh4N169bh8XgAePPNN5k9ezbXX389OTk5TJo0iXvvvRefz9dtW1wuFw0NDR0u4aYXdSjKSmRf/T6cPicmg4kx6WPC/lpCCCEiL2oBtaqqCp/PR05OTofbc3JyKCsr6/Ix8+fP56mnnmLjxo1omsaGDRtYsWIFHo+HqqoqAPbt28ff/vY3fD4fq1at4vbbb+fBBx/kd7/7XbdtWbZsGampqcFLYWH4ywAeqFZF8UdmJfF19dcAFCQVyHZtQggxQEQ9KenoCkGapnVbNWjp0qUsXLiQWbNmYbFYuPDCC7nqqqsAMJlUYXm/3092djZPPPEE06dP59JLL+W3v/0ty5cv77YNS5Ysob6+PngpKSkJz5tr9570ovijs5PYXasqJBWlFoX1dYQQQkRPyAG1qKiIu+++m+Li4j69cFZWFiaTqVNvtKKiolOvVedwOFixYgUtLS0cOHCA4uJiioqKSE5OJisrC4C8vDzGjh0bDLAAEyZMoKysDLfb3eXz2mw2UlJSOlzCqbLJRYtbFcUvzLRwsOEgIBm+QggxkIQcUH/5y1/y97//nZEjR3LOOeewcuVKXC5XyC9stVqZPn06q1ev7nD76tWrmTNnzjEfa7FYKCgowGQysXLlSs477zyMRvVW5s6dy549e/D7/cHzd+3aRV5eHlZrdIZXvylVGb5DkmyYTC4ONR0CYGz62Ki0RwghRPiFHFB//vOfs3HjRjZu3MjEiRO58cYbycvL44YbbuDLL78M6bluueUWnnrqKVasWMGOHTv4xS9+QXFxMddeey2ghmJ/+MMfBs/ftWsXL7zwArt372bdunVceumlfPXVV9x7773Bc372s59RXV3NTTfdxK5du/jXv/7Fvffey/XXXx/qWw0bvSj+0HQHDZ5aypvLAVUUXwghxMDQ6znUKVOm8L//+78cPnyYO+64g6eeeoqTTz6ZKVOmsGLFCjRNO+5zLF68mEceeYS7776bqVOn8vHHH7Nq1argMpfS0tIOQ8s+n48HH3yQKVOmcM455+B0OlmzZg1FRUXBcwoLC3n33XdZv349J554IjfeeCM33XQTt956a2/fap/tCdTwHZaewM6anWhoJFuTGZo0NGptEkIIEV4GrSeRrwsej4fXX3+dZ555htWrVzNr1iyuvvpqjhw5wqOPPsoZZ5zBX//613C3NyIaGhpITU2lvr4+LPOpi/+8li/21/DzM0dhyFzFM189w8TMibx83sthaK0QQoj+Eko8CLmww5dffskzzzzDSy+9hMlk4oorruDhhx9m/Pi24ct58+Zx+umnh97yAepgoCj+0HQT6xrV/OnwlOgXmxBCCBE+IQfUk08+mXPOOYfly5ezaNGiYDWi9iZOnMill14algbGO6fHR3mjKoqflwGHylRAHZU6KprNEkIIEWYhB9R9+/Ydt5RfYmIizzzzTK8bNZDsrmhECxTFT7A5gyUHpUKSEEIMLCEnJVVUVPDFF190uv2LL75gw4YNYWnUQLKrTCUk5aXaqXaX0+RpwoCBcelSFF8IIQaSkAPq9ddf32UlocOHD0d1aUqs2lWhlszkpFo50qwylnMTc0mxhbd4hBBCiOgKOaBu376dadOmdbr9pJNOYvv27WFp1ECyr1LV8M1NNQYLOhQkF2A32Y/1MCGEEHEm5IBqs9koLy/vdHtpaSlmc1R3g4tJBwNF8XNSDRwKZPgOSx6GxdQ5mUsIIUT8CjmgnnPOOcFi8rq6ujpuu+02zjnnnLA2Lt5pmsah2lYAhqR5gz3UkWkjo9ksIYQQ/SDkLuWDDz7I6aefzvDhwznppJMA2Lx5Mzk5OfzlL38JewPjWWm9M1gUPy3Zw5GmIwCMSZMMXyGEGGhCDqhDhw5l69atvPjii2zZsgWHw8F//ud/ctlll3W5JnUw2xsoOZiVZKHZV4FP82E32SlMDv9+q0IIIaKrV5OeiYmJ/OQnPwl3WwacfYGAOiTFTEVrKRBISDJLQpIQQgw0vc4i2r59O8XFxZ32GL3gggv63KiBYn+VSkjKTNIoa1bzp4XJhTjMjmg2SwgR7zytsGI+tNbCxAth0vcgbyoYDNFu2aDWq0pJ3/3ud9m2bRsGgyG4q4wh8A/p8/nC28I4ti8QUDOSfRxuPgyoHqrNZItms4QQ8e7QBijdoo7X/FFd0kfApItUcM2eKME1CkLO8r3pppsYMWIE5eXlJCQk8PXXX/Pxxx8zY8YMPvzww35oYvzar69BTTMGl8wUpRRhNsryIiFEH5R/pa5zT4SJi8DsgNr98MmDsHwOPDYTPrwfqnZHtZmDTcgBde3atdx9990MGTIEo9GI0Wjk1FNPZdmyZdx444390ca45PT4OFynlsykJzupddUCUhRfCBEGZYGAOm4hfP85+PUe+N7TMO47YLJC1U748F54dAasWAhl26Lb3kEi5IDq8/lISkoCICsriyNH1FKQ4cOHs3PnzvC2Lo4drG7Br4HdYsBlUIUwshxZpDvSo9wyIUTcKw8EyNzJ6tqWBJMvhsv+qoLrouUw+hwwmqF4Dfz5W/D2beBqjF6bB4GQA+qkSZPYunUrADNnzuSBBx7gs88+4+6772bkSClYoEtLsPCr+WOZO85ClSuQ4ZtUgMMkCUlCiD7weaBihzrOmdT5fnsqTP0P+MHf4KatKmlJ88Hnj8Gjp8D2v0Mg90WEV8gB9fbbb8fv9wNwzz33cPDgQU477TRWrVrFH/7wh7A3MF7lpNj5z7mFnDbBQHlLu4QksyQkCSH6oGo3+NxgTYa0Y2+lSepQ+P7zcPnfIL0IGo/A//0QXrwEavYf/7W8Lij+HD77X/hmVViaP5CFnB0zf/784PHIkSPZvn07NTU1pKenBzN9heIPfAssDQTUwuRCKYovhOgbPSEp5wQw9rBPNOYcuO5zlbT06SOwZzU8PgtO+xXMvRH0L/quRij5Ag6uheK1cHgjeJ3qPoMJfrULErPC/pYGipACqtfrxW63s3nzZiZNahtqyMjICHvDBgoNP0ea2nqoUtRBiDBxNsDq/4LJl0DR3Gi3JnL0BKPcLoZ7j8XigDNvhxMXw79ugf0fwwf3wNaXYdSZUPK5em7N3/FxCVmqR+xqUL3VCeeF530MQCEN+ZrNZoYPHy5rTUPQ7KvB7XdjMVooSCrAaAh5lF0I0ZV1T8DGZ+D1n6p5xcEiuGRmcu8enzUGfvgmXPQUJGZD9W5Y92e1rlXzQ9owOPFSOP8PcMMGleQ06SL12OK14XkPA1TIQ7633347S5Ys4YUXXpCeaQ/UuMsAGJo0lERLYpRbI8QAsuMf6rq+BL5+HU78fnTbEyl6DzWnlwEVVNGHEy9RQ8GfPw4tNTBsFgybreZdjzZsDmx8VgLqcYQcUP/whz+wZ88e8vPzGT58OImJHYPEl19+GbbGDQRVTrWsSCokCRFGtQehdHPbz5/9QQ39DvQ8jsZyaK4EgxGyJ/T9+RxpcMZtxz9v2Cx1XboF3M1glc5BV0IOqIsWLeqHZgxcFa0qoBYmF8r8qRDh8s0/1XXeFKjao9Zl7vtAzQUOZPr604xRYE2I3OumDYOUodBwWJU9HPmtyL12HAk5oN5xxx390Y4Bq7wl0ENNKpAMXyHCZfub6nrq5VCzD774k1raMdADql4hKdSEpL4yGFQv9atXVWKSBNQuSYZMP2rxtFDlrARgaPJQWYMqRDg0lqmlHQDjz4NZ16klHfs+bCsYP1CVHVUhKZKGzVbXxWt6/xytddBcFZbmxKKQA6rRaMRkMnV7EW321e8FINWWSoo1RXqoQoTDN/8ENBg6QyXQpA+HE76r7lvzx6g2rd8F16BGMaCWrAefN/TH+33w1Fnw2CkqsA5AIQ/5vv766x1+9ng8bNq0ieeee4677rorbA0bCPY3qIBamFSIzWSTwhdChIOe3Tux3d7Lc2+Er/4GX70GZ/2XmvMbaDzOtt1jIj3kC2pLOHsqOOuhbCsMnRba40vWQfWetuOx88LfxigLOaBeeOGFnW67+OKLOeGEE3j55Ze5+uqrw9KwgWBvnfrlkQxfIcKkpQb2f6KOJ5zfdnveFBj5bTXsu/ZxWHhfNFrXvyp3qJq8jgxIzov86xuNUDgLdr+j5lFDDag725UuPDQwA2rY5lBnzpzJv//973A93YCwu059myxMLsRhlqL4QvTZzrdUUMmZDBlHbcYxJ7B95JfPQ2tt5NvW38raFXSI1miXvnymN/Oou95uO9bnwAeYsATU1tZW/vjHP1JQUBCOpxsQNE1jd60KqNJDFSJMdgSye9v3TnWjzlSB1tMM65+ObLsiIZoJSbrhc9T1wbWh7VhTvReqdrX9fPhLNac6wIQ85Ht0EXxN02hsbCQhIYEXXnghrI2LZ2XNZTR5mjAZTOQl5skaVCH6ytUIe99Xx+3nT3UGA8z5Obz+E/jizzD7BrAMoP93wYSkKMyf6vJPApMNWqpUkMwa3bPH7XxLXRedBkc2g7sRKrZH98tBPwg5oD788MMdAqrRaGTIkCHMnDmT9HTZPFvX6GlkctZkWjwtmI1mCahC9NWud1SR9szRMGR81+dMugjeuxsaDsHWlTD9qog2sd9oWvTWoLZntsHQ6WrIt3hNzwOqPtw7/jwwBpY4lXwhAfWqq67qh2YMPGPTx/LsgmfZUrkFAwasRmu0myQGqyOb1K4sCx8IT7m6aNGzeydc0P0coskCs6+Dd26DNY/CST/s+RZnsay+BFz1YLRA1rjotmXYrEBA/Rym/fD457fWwsHAnOu4BdBSHQio6+Hka/q1qZEW8m/aM888wyuvvNLp9ldeeYXnnnsuLI0aaOxmuyyZEdHz2R/UVl1f/CnaLek9TyvsXq2Ou5o/bW/aD8GWqnZR2fVW/7ctEvT50yHjwRzlL+fBedQeJibt/rdKJMueqDY5L5ypbj+0rl+aF00hB9T77ruPrKzOG8xmZ2dz7733hqVRA40kJImoOrRBXZdujW47+mLv+yrZKLVQzeMdiy0ZTg4s3/vsf/u/bZEQC8O9uoKTAQPU7ldVq45H/1IzdkHg8dPVdc2+AVc1KeSAevDgQUaMGNHp9uHDh1NcXByWRg00UiFJRE1jOdQH/l+Wfx2/+4Zub5fd25PRnpk/BZNVzdMVD4AlGnpR/GgmJOkcaW3tON52bj6P6qECjDs38Pj0tmHrkoHVSw05oGZnZ7N1a+dvulu2bCEzMzMsjRpoJCFJRM3hDW3HPhdU7oxeW3rL627r5UzoIru3K8m5cOJidbzmD/3TrkiKpR4qtFuP+vmxzzu4Rs39Jg5RyUy6wlPU9QAb9g05oF566aXceOONfPDBB/h8Pnw+H++//z433XQTl156aX+0Me5JUXwRNYc2dPw5HovHH/hYlbtLzG77Q9wTeqGHb/7VVrIvHrka1fAqRKeGb1eGB+r6Hm8eVV8uM2Z+x+Qw/d+xZH342xZFIQfUe+65h5kzZ3LWWWfhcDhwOBzMmzePM888U+ZQu+EwSZUkESWHAn+wEgKjR2VxOI8azO4NLLnoqSFjA8OMGqx9tF+aFhHlX6vr5HxIjJFRQL1QfvlX4Gzo+hxNays3OG5hx/sKAgH18Mb4nYboQsgB1Wq18vLLL7Nz505efPFFXnvtNfbu3cuKFSuwWmVpyNGMBiMWkyXazRCDkd+nlswAnHSFuo63Hqrfp3qYcPzs3q7M+bm63vJy/JYjDFZIipHhXoCUfEgbDpq/+2Hbym+g7qAqBDHqjI73ZY1Vhfa9rW0FKwaAXi/QGjNmDJdccgnnnXcew4cPD2ebBhRJSBJRU/kNuJvAmgQnfl/dVroV/P7otisUxZ9DcyXY01SVnVANm60SaLytsOnFsDcvImKhQlJX9OUz3c2j6sO9I04Ha2LH+4zGQLYwA2rYN+SAevHFF3PffZ13cvj973/PJZdcEpZGDSSSkCSiRh/uHTotsH7RoZae1OyNbrtCodfuHXeuKtoQKoOhrXjA+qfi68uELtYSknR6YtLBbjJ99epIRw/36vRh3wFUKD/kgPrRRx/xne98p9PtCxYs4OOPPw5LowYSWYMqokZPSBo6Q8096n+Q42XYV9O63vs0VCd+XxV6qN3fVgs4Xvh9bXOouSdGty1HGxbooR7eAF5Xx/uaKtuWxOjrT49WGOihDqBM35ADalNTU5dzpRaLhYaGbianBzHpoYqo0QOqPrSWN0Vdx0tAPfwlNBxWQ9Yjzzj++d2xJsJJl6vj9U+Gp22RUrNPDVebHZ23q4u2rDEq2c3r7Pw7tftdQFO/c6lDu3780BmAAeqKe1YgIg6EHFAnTZrEyy+/3On2lStXMnHixLA0aiCROdQ4Ur1X7aUZyrZUscrZoOZQAQpmqGu9hxMvAVUf7h0zr++7xujDvrvegdoDfXuuSNITknImhpbhHAkGQ1u279HLZ/Ts3rHdDPcC2FNUOUIYMAUeQi6Ov3TpUr73ve+xd+9ezjzzTADee+89/vrXv/K3v/0t7A2Md7IGNY689mOVxp+YrYp4x7MjXwIapA2DpGx1m95DLduqvjTEcn1pTTv23qehyhyl9kvd+77aK3Xef/f9OSMhVhOSdMNmwTf/7JiY5HHC3g/U8fH+HxWeDBVfq2Hfvgzrx4iQe6gXXHABb7zxBnv27OG6667jl7/8JYcPH+b999+nqKioH5oYv0wGExajLJmJC43lKpgCVO6IblvCQU9I0od7Qe00Y7So5SP1JdFpV0+Vf62GO0021UMNh1N+oq43/UUV248HwYSkGCnocDR9HrV4bVvC14FPVfJbch7kTT324/VC+QMk07dXy2a+853v8Nlnn9Hc3MyePXu46KKLuPnmm5k+ffrxHzyImGJtiEZ0b8+/247jaUiwO+0TknRmW9v2bbE87Ktpak9TgDHngC0pPM87Zh6kDlNfKL56LTzP2d+Ca1BjNKDmnQiWBHDWQVWgrGVwuHfB8UdB9EzfI5tUick41+t1qO+//z4/+MEPyM/P59FHH+Xcc89lw4YNx3+gELFo97ttx/EeUDWtc0KSLi8O5lG3vAS731HF7c9cGr7nNZrg5B+p43VPxP5ceUsNNB5RxzknRLct3TFZ2uboD65Rn+nxlsu0lzkKHBmqznQ8VvE6SkgB9dChQ9xzzz2MHDmSyy67jPT0dDweD6+++ir33HMPJ510nG2VhIhFPm/bnA/Ef0CtPQAtVSog5R211EIfgovVrdwajsBbt6rjby+B7PHhff6TfqiGkUs3tw3xxyq9d5pepLaki1XD2hV4KNuqMrMtCaqgw/EYDO3q+sZ/YlKPA+q5557LxIkT2b59O3/84x85cuQIf/zjH/vcgMcff5wRI0Zgt9uZPn06n3zyyTHPf+yxx5gwYQIOh4Nx48bx/PPPd3vuypUrMRgMLFq0qM/tFAPYoXVqRwx9iVNdiQqy8UoPFLmT1TBve7G8dEbT4B83q3+L/Gltxe3DKTETJl2kjtfF+BKaWE9I0gV3nlkLOwO905FngKWHNcyDFZPiv8BDjwPqu+++yzXXXMNdd93Fd77zHUymvs8Pvvzyy9x888389re/ZdOmTZx22mksXLiw231Vly9fzpIlS7jzzjv5+uuvueuuu7j++uv5xz/+0encgwcP8qtf/YrTTutFuTIxuOxera7Hf0cFVc0X+0k7x9JVQpIu5wQwGKGpLPbW/rUf6l20HEwhL0LomVN+rK6/fi22N7gOzp/GWEGHoxWcDAaT+j+z6S/qtp4M9+qCW7nFf2JSjwPqJ598QmNjIzNmzGDmzJk8+uijVFZW9unFH3roIa6++mquueYaJkyYwCOPPEJhYSHLly/v8vy//OUv/PSnP2Xx4sWMHDmSSy+9lKuvvpr777+/w3k+n4/LL7+cu+66i5EjY2wxtIg9ekAdM18V/Ib4HvYNlhyc0fk+ayJkjlHHsTTs299Dve0Nna56wD43fPlc/71OX8VqycGj2ZLaphbqSwADjJ3f88fnT1MBueEw1B/qlyZGSo8D6uzZs3nyyScpLS3lpz/9KStXrmTo0KH4/X5Wr15NY2NjSC/sdrvZuHEj8+Z1TImfN28ea9Z0vceey+XCbu+4wNvhcLBu3To8nrYtgO6++26GDBnC1Vdf3aO2uFwuGhoaOlzEINFwBMq3AQYYfZaar4L4DaheV1vPpqCLgArt1qPGyLBvJIZ6j6b3Ujc8o8r7xRqvu60wR6wP+ULbPCqoLyz62ueesCW1JV3F+TxqyFm+CQkJ/OhHP+LTTz9l27Zt/PKXv+S+++4jOzubCy7o+cLcqqoqfD4fOTk5HW7PycmhrKzroaj58+fz1FNPsXHjRjRNY8OGDaxYsQKPx0NVlRq6+eyzz3j66ad58smez48sW7aM1NTU4KWwsLDHjxVxTl8uM3Q6JGbFf0At3ap6Xgnt3svRYm0eNVJDve2dcJHKLq0vactKjSVVu8DvUTWI04ZFuzXHp8+jQmjDvboBMuzb62UzAOPGjeOBBx7g0KFDvPTSS716DsNR65Q0Tet0m27p0qUsXLiQWbNmYbFYuPDCC7nqqqsAMJlMNDY28oMf/IAnn3ySrKysHrdhyZIl1NfXBy8lJXE8fyZCoy+XGXOOuo73gHpYXy4zo/s1gLG0dCaSQ73tWeww7YfqOBaTk4IJSSfEdkUrnV6CEHoZUPUCD4Osh9oVk8nEokWLePPNN3v8mKysLEwmU6feaEVFRadeq87hcLBixQpaWlo4cOAAxcXFFBUVkZycTFZWFnv37uXAgQOcf/75mM1mzGYzzz//PG+++SZms5m9e7vetspms5GSktLhIgYBnwf2fqiOB0pADSYkdTPcC21JLnXF0d10OxpDve3N+BFggH0fQNXuyL728cR6QYejJQ2Bc/8Hzr6rrT5vKPQEutItqnRhnApLQO0Nq9XK9OnTWb16dYfbV69ezZw5c7p5lGKxWCgoKMBkMrFy5UrOO+88jEYj48ePZ9u2bWzevDl4ueCCCzjjjDPYvHmzDOWKjoo/B3ejGh7NC6yhHigBtauEJJ0jre19RjMxKRpDve2lD2/bWmz9U5F97eMJBtQ4mD/VnfJjOPXm3vWo04sgcYga5i7dHOaGRU6Ef4M7uuWWW7jiiiuYMWMGs2fP5oknnqC4uJhrr70WUEOxhw8fDq413bVrF+vWrWPmzJnU1tby0EMP8dVXX/HccypTz263M2lSx1/AtLQ0gE63C8GewJe50WeDMfDdMj2Q5eusU703R3pUmtYrTRWq14lBbSp+LHlT1JeG0i0w8luRaF1H0RrqPdop18Cut2DzX1VVpnCVOewLTYufNajhYjCoYd9v/qmGfdvPycaRqPVQARYvXswjjzzC3XffzdSpU/n4449ZtWoVw4erP2qlpaUd1qT6fD4efPBBpkyZwjnnnIPT6WTNmjVSlF/0TnC5zDltt1kTISkw5dBfvVS/XxUD/+q18GaY6uUGh4wHe+qxz43mVm7RHuptb+SZkDEKXA2w7f+i1472GsugpVqtF9ZrLw8GBfG/4XhUe6gA1113Hdddd12X9z377LMdfp4wYQKbNm0K6fmPfg4hALXerWK7+qM16syO96UXQVO5Cqj5YSqn6WmFfR/Bzn+pajLNFer28/8A068Mz2sEE5J6sEmFXoIwGvVTd70d3aHe9oxGOPlqeOc22PZqYF41yqr3qOv0op5XGxoI2pcgjPXtBbsR9YAqRFTovdOCkyEho+N96UWqDFpfe6jN1Sp47Fyl9uH0tHQ+Z//H4Quox6qQdDQ907dqN7iaIjvUqWdyTrk0ekO97emJP/qXnGirO6iu9SIjg0X+SWA0qy+zdcVt0y9xRAKqGJy6Gu7V9TUxqWQ9rF6qgrLmb7s9ZSiMO1ctK/B74a/fD9/wlt8Hh79Ux8dKSNIlZav9KhtL1XxdJOesavap66xxkXvNY9GHx50xUtClLjDNFYcBpU8sDjUVceRL9eUwDt+/BFQx+HhdsP8jdTy6HwLqB/eoQuGg/kCMOxfGn6uO9WEsZwNgUH88G8shueulYj1WuRPcTWBJ7Pm8W94UFVBLt0Q2oNbuV9cZIyL3mscSDKj10W2HrnaQ9lBBDfse+VJ9GZ18cbRbEzIJqGLwKV6rgk9STteFx/sSUDWtbcnDD/8OI7/d9Xn2FBX4Krarb+MTzgv9tdoLLpeZpvb97Im8KWpIOpJLZzQNag6o44wYqbNtC6w797aqkn9ma3Tbow/5xmEPrc8KToYv/qSmBdzNKkGrsbTtuqG07eeEDDjrv2BIjIx0IAFVDEa7u1gu054eUPVt3EJJmmkqb8vQ1Ku/dKfg5EBAXdf3gNq+QlJPRaMEYWutyu6F7ksjRpqtXSEXVwOYe15lrV8M6h5q4P9M6Wa4N//45+9+F07/f2r9q8nSny3rkagumxEiKo41fwqQlKs2odZ80BDi7hf6+sHM0cfP0AxmNYahfqm+ZKYnCUk6vXdeuSNy1WlqAsO9yXmxk8FqMoM1kJQV7WFfr0v1wGBwBtTUgo7VoSyJ6v9S0Wkw+RKY83OYvwy+97SarvG51RTLE99uyyGIIumhisGl9iBU7VTbRY08o+tzjEY13Fa1SwWAUHpS5V+ra333jGMpCATUI5tUGcTefsN2NkDFDnXck4QkXWqBKhDfWqN6yscrBhEO+vxpeozMn+rsqWoaINoBtf4QoIElQW3WMNgYDHD1avU5JOWoqZHuTPoebHsF3vqN+iL71Fkw+wZVKMSaELk2tyM9VDG46NWRCmeqEnzd0f/ghzqPqu9h2ZOAmjka7Glq7k6fd+2NI5sADVKHhZbcZDC028otQvOoNTGWkKTTh32jHVD137e04XG5DjMsLA7IGnPsYArq8znx+3D9OhVcNT+s+QP8aS7s/yQybT2KBFQxuBxvuFfX28SkYA+1B0XNjca2Oc++bFvVk4L43Yn0PGos91BBzaFGU3ANahxs2RYrkobAxSvgspWQnK+WZT13nqrGFeEvSBJQxeDhcapqRQBj5h373N4EVK9bDSdDz3qo0Dbs25eAenhj4Ll6E1AjXIIwVnuosbJ0pnYQZ/j21biFcP3nMP0/1c8bn4HHZsGBzyLWBAmoYvA4+JkaXk3OP37A601ArdqpCjbYU9X8ZE8UBpKIersPpKaFViHpaHoJwvKvVUZzf4vZHqo+5BsrPVQJqL1iT4XzH4Er/6mWZbVURXQuWgKqGDyCw71nH39+qjcBNTjcO6nn819DZ6AKPBxUu8WEqu4gNFeC0dL1mtrjSR8B1mTwOlUSVn/ytLZlsEoPtWuDtUpSuI04DX62Bi5/JaLrVCWgisFDT0g63nAvdN7GrSfKQ0hI0ukFHqB3vVR9uUzuZLDYQ3+80di2TKG/h331Lye21NjbFi9mkpKkhxo2Fkf3hVX6iQRUMTjU7FO7eBjNMKIH+39aEyExWx3rf+SOJ5QM3/b6sm1V8eeB5+jF/KkuUolJwfnTotjLYI2FpCRXkxqiBElKilMSUMXgsOtddT1s9vHT8XXBYd/9PTs/lAzf9npb4MHvgx3/UMdHb0EXikgtndGL4sfa/Cm0m0ONYg9VH+61px57SZeIWVLYQcQ/n0etxWw4clTtT/3nsraex/GWy7SXXqR6jT2ZR22qCGz/ZQh9S7LeFngoXgtNZeoPcDgCaulWtfl5V+UYwyFYFD9Gavi2Fws7zugBVYZ745YEVBH/XrkKvvnn8c9LKYBJIexgoSfO9CSg6vOnGSPVcHEo9AIPzjpV4KGnFYu+ek1djz8fzLbQXrO9rLFgtoO7UQW9zFG9f65jidUlMxAbSUmDuSj+ACEBVcQ3TYMDgaoo+SepuafkfEjOVfVik3MhJfCzLTm05w4l01cf7s2dFNprQFuBhz3/VklGPQmoPi9s/7s6nvTd0F+zPZNZzfse3qiKkvdXQI3VJTOgEqWgrXB/NEhCUtyTgCriW3NVoFdhgP98K7wF13sTUHN6EVBBDfvu+bcaYp75k+Off+BjlcCSkNmzJKvjyZuiAmrZNlXGLdx83rYhTemhdk3WoMY9SUoS8a16j7pOLQz/7iVHb+N2LL3N8NWFWuBBH+6dcEF4tq3KCqzVq9rd9+fqSsMhVfTCZFMjCLGmfWEHvz86bZAqSXFPAqqIb3pA7Y9hyp5u4+bzQOU36ri3PdRQCjx43W3ZvZMu6t3rHU3//Gp6mNEcKv1504f3X9JTX+g9VDS160w0SFJS3IvB32whQlAd6FFljQn/c+vbuMGxh32rdoHfo4oD9Hb9YCgFHvZ9oBKYknJg+Nzevd7R9Mzbmn3900OL5flTUElZJqs6jsawb/uN12UNatySgCriW/VedZ05un+eXx/2PVbPrf0eqH0pWNDTAg/6cO/ERWA09f712ksbpvaI9bYrDxhOsZzhC+rfTa+WFI3iDvpwb+KQqO3lKfpOAqqIb/055As9S0zqTcnBrvSkwIPHCd/8Sx2Ha7gX1Dys3huv2Ru+59XFeg8VopuYJAlJA4IEVBG//L626juZ/TDkCz0LqH1NSNIdXeChK3tWq/WiKUPbzg+XjMCXkup+CKg1BwKvEcsBNYo7zkhC0oAgAVXEr7pi8LlV4lBPt0sLVXoPijv0tuTg0TJHq16St7Wt13s0fbj3hO+GP7knmJi0L7zPq2nSQz0eSUgaECSgivil96QyRoZvLvFox+uhNlep8n/QllTUW0Zj2zxqV8O+7mbY9bY6Dudwry6jnwJqc1Ugc9YQ2z2waO44ExzylYSkeCYBVcQvff40q58SkuD427jpPcn0EWBL6vvr6cO4XSUm7XobPC0qyOf3sDxhKPRM33AP+eoBOrWgbyUS+1twx5koBFQZ8h0QJKCK+KUvmemvDF84/jZufSk52JVjFXgIDvde1D/bn2UGAmrt/vAunQkO9xaF7zn7Q7SGfDVNhnwHCAmoIn4FM3z7MaDCsYd9+1py8GjdFXhwNsDuwAbp/THcC5A6TO0X63VCw+HwPW+sL5nRRWvHmeZKNW+OQVX8EnFLAqqIX8E1qP2U4as71r6oZdvUdV8zfHXdFXjY+Rb4XOq9hit4H81kbrfuNozzqPGQkATR66HqIx8pQ8Fsjexri7CSgCrik6cV6kvUcbR6qD5v30sOdiVY4KFdYtJXr6rrSd/rn+FeXTAxKYzzqPHSQ41WYQdJSBowJKCK+KT3Tu1pkJDRv6/VXUCt3qOW7ViTwjv3pRd40ANqay3sfV8d99dwr64/EpOkh3ps+u+VJCTFPQmoIj61nz/tzx4bdB9Q9Qzf7InhXROqZ/oe/lIVeNjxT1UrOPsEGDIufK/TlXCvRXU1qjlCiP0eqj1Ky2akStKAIQFVxKfgkpl+nj+FtkBw9DZuekANV4av7ugCD8Hh3n7unUL4e6j6lxBHRrsdXWJUtJKS9Axf6aHGPQmoIj71dw3f9rrbxq19Ufxwal/gYedbsP9jdRyJgKp/nrX7VWnHvoqX+VOIflKSzKHGPQmoIj5FaskMdL+NW7CGbz9k3erDvmseVYE8b2pb77E/pRaC0aLmhsOxdCZe5k+hLSnJ51KbEESC3wf1gS9pMuQb9ySgivgUDKgRGPKFzvOoLTXQeEQdZ08M/+vpBR48zep60vfC/xpdMZra3ms4hn3jqYdqSwEC8/GRyvRtOKLmx40WSMmPzGuKfiMBVcSf5uq2MoCR6LVB531R9eHetOFtySzhpBd40J3w3fC/Rncyw7h0Jp56qEYj2JLVcaSGffWEpNSC/qtHLSJGAqqIP3rvNKUgcpsxH91DDSYk9XGHme60L/BQcAqkRbCCTnAbtzBk+sZTDxUin5gULDko86cDgQRUEX8iURT/aN0F1HAnJLU3Zp66nvbD/nuNrug1ffu6dMbrbiu+EamRhL4K7jhTF5nXk6L4A4o52g0QImSRTEjSdQqo/ZTh294Zt6mh3rwp/fcaXQlXtaT6EtD8YEmApJy+tysSgjvORKqHKmtQBxLpoYr4E4ldZo6m/8Fz1qk53Iod6uf+qqsLaquz/Kn9X7jiaHpvsvZA35bO6MO96UWRfw+9FemlM8EealFkXk/0KwmoIv5Eqih+e7aktm3c9r6vdmSxJMRHsk2oUgvAZFVLZ/Qh296Ip4QkXbBaUqTnUKWHOhBIQBXxxe9vF1AjUNShPb0X8c0/1XW4Sw7GCqOpLQj2ZelMvCUkQWR7qN52a30lKWlAGIB/DcSAVl+iFt6brJH/I6QHVH1f0nCXHIwl4ajpGy8bi7dni2A93/oSQAOzA5Ky+//1RL+TgCrii56QlDEy8uv29MCgF1voz/nTaMsIQ6ZvPPdQI5GU1H7btniZYxbHJAFVxJfgcG8EE5J0R/e0+jPDN9r6WiRf09ptSxZPATWCPVRZMjPgSEAV8SWY4Rvh+VMYXAG1r9WSGsvUbjkGU3zND0aysIMUdRhwJKCK+BKNNai69gE1dVjsb0fWF/pa1NoDHbes6yl9/jS1AEyWsDWr30UyKUnWoAJw1VVXYTAYgpfMzEwWLFjA1q1bg+e0vz85OZkZM2bw2muvRbHVXYt6QH388ccZMWIEdrud6dOn88knnxzz/Mcee4wJEybgcDgYN24czz//fIf7n3zySU477TTS09NJT0/n7LPPZt26df35FkQkRboofnvJeSoZCgZ27xQgZSiY7eD39m7pTDzOnwLYIjiHKkO+QQsWLKC0tJTS0lLee+89zGYz5513XodznnnmGUpLS1m/fj1TpkzhkksuYe3atVFqcdeiGlBffvllbr75Zn7729+yadMmTjvtNBYuXEhxcXGX5y9fvpwlS5Zw55138vXXX3PXXXdx/fXX849//CN4zocffshll13GBx98wNq1axk2bBjz5s3j8OEwbEUlosvjVJt8Q3R6qEZjW29iIGf4QmDLukAw7M2wbzyuQYUB00PVNI0WtzcqF03TQm6vzWYjNzeX3Nxcpk6dym9+8xtKSkqorKwMnpOWlkZubi7jx4/nT3/6E3a7nTfffDOcH1ufRbX04EMPPcTVV1/NNddcA8AjjzzCO++8w/Lly1m2bFmn8//yl7/w05/+lMWLFwMwcuRIPv/8c+6//37OP/98AF588cUOj3nyySf529/+xnvvvccPfxjhmqgivGr2AZrqRSRmRacN+Sepedxhs6Pz+pGUMRIqd6gi+aF+fwn2UOOkhq9OT0pyNagqUf2VSe5uhuZAsOiHHmqrx8fE/3on7M/bE9vvnk+CtfehpampiRdffJHRo0eTmZnZ5TkWiwWz2YzH4+n16/SHqAVUt9vNxo0bufXWWzvcPm/ePNasWdPlY1wuF3a7vcNtDoeDdevW4fF4sFg6z9W0tLTg8XjIyMjoti0ulwuXyxX8uaEhQlVSRGjaF8WP1jKD8x6CmT+FodOj8/qRFCyS34seqr7cJu6GfNttxedqBEda/7yOPtJiSwF7P71GHPnnP/9JUlISAM3NzeTl5fHPf/4TYxeFU1wuF7///e9paGjgrLPOinRTjylqAbWqqgqfz0dOTsei2Tk5OZSVlXX5mPnz5/PUU0+xaNEipk2bxsaNG1mxYgUej4eqqiry8vI6PebWW29l6NChnH322d22ZdmyZdx11119e0Oi/0UzIUlnS4aCGdF7/UgKbuM2iIZ8LXYw2VTxEGd9PwbUdsO9/fDl0GExsf3u+WF/3p6+dqjOOOMMli9fDkBNTQ2PP/44CxcuZN26dQwfrnrwl112GSaTidbWVlJTU/mf//kfFi5cGNa291XUd5sxHPXLpGlap9t0S5cupaysjFmzZqFpGjk5OVx11VU88MADmEyd/xEfeOABXnrpJT788MNOPdv2lixZwi233BL8uaGhgcLCCO4/KXomFgLqYNLbakmtdW0bwMdTlSSdPRWaK/o3MamfE5IMBkOfhl0jLTExkdGj2/5fT58+ndTUVJ588knuueceAB5++GHOPvtsUlJSyM6OzcpSUUtKysrKwmQydeqNVlRUdOq16hwOBytWrKClpYUDBw5QXFxMUVERycnJZGV1nFP7n//5H+69917effddTjzxxGO2xWazkZKS0uEiYpAE1MjS5z/rDoa2dEbvnSZmq00F4k0kEpNkycwxGQwGjEYjra2twdtyc3MZPXp0zAZTiGJAtVqtTJ8+ndWrV3e4ffXq1cyZM+eYj7VYLBQUFGAymVi5ciXnnXdeh7H23//+9/z3f/83b7/9NjNmDJLhucFAAmpkJee3LZ3RA0BPxOuSGV0kdpxpX3ZQ4HK5KCsro6ysjB07dvDzn/+cpqamYLJpvIjqmMAtt9zCFVdcwYwZM5g9ezZPPPEExcXFXHvttYAaij18+HBwremuXbtYt24dM2fOpLa2loceeoivvvqK5557LvicDzzwAEuXLuWvf/0rRUVFwR5wUlJScNJbxBBN69kcUksNtFSr42hUSRqMjEbVS63YroZ9e/q5x+v8qS4SPVRZg9rB22+/HcyBSU5OZvz48bzyyit8+9vfjm7DQhTVgLp48WKqq6u5++67KS0tZdKkSaxatSo4CV1aWtphTarP5+PBBx9k586dWCwWzjjjDNasWUNRUVHwnMcffxy3283FF1/c4bXuuOMO7rzzzki8LdFTf7saij+Hq9+F1KHHPldPjEkZCtbE/m+bUPSAWr0XxpzTs8fEew81EjvOyJBv0LPPPsuzzz57zHN6s7Y1GqI+a33ddddx3XXXdXnf0R/yhAkT2LRp0zGf78CBA2FqmehXXjdsf0MNJ350P1zwh2OfHxzuld5pRPUmMSkei+K31987zrTWtQVrGfIdUKJeelAMUtV7VDAF2PTC8ZdmyPxpdGT0Yi1qvPdQ+3vHGb13mpAVn0lbolsSUEV0VGxvO9Z88MG9xz4/uMuMBNSICnUtqtcFDYEyn/HeQ+23gCq7zAxUElBFdOgBtXCmuv7qb1C2rfvzg/ugRqEo/mCmD/nWFYOvB2Xeag8CGliTolcesq/0ykX9FVAlIWnAkoAqoqM8EFAnXQwnXKSO3/9d1+f6/e0CqsyhRlRyHlgS1ChCXfHxz69tN9wbrfKQfdXfSUmSkDRgSUAV0aH3UHMmwhm/VRtR73oLSrrYaq/hsNqs2miRP0KRZjC0zaP2ZNi3dIu6jtfhXuj/pCTpoQ5YElBFR9V723qP/cXV1PYtfcgEVex+6n+on9+7W61N7dCmQEJSxggwRT0xffDRk4uOl5jUXAVrHlXHY6NTRzYsIpWUJHOoA44EVNGmtQ6ePFNdGrveoCAsKr9R10k5kBjYnulbv1Gbdx/4BPZ90PF8yfCNrp4mJn3wO3DVQ+5kmHJZ/7ervwSTkvqhh6pp7ZKSisL//CKqJKCKNhtWgLNODa/uXNV/r6MP92ZPbLstrRBmXK2Oj+6lyvxpdAXXoh4joJZ9BRufVccL7u+/fUQjoX2Wb7gLCjRXgacFMKjfeTGgSEAVitcFX/yp7edv+jGglncRUAFOuwUsiXBkE3zzz7bbg0tmJMM3KjKOU9xB0+DtW0Hzw8RFUDQ3Yk3rF3pSkt8DXmd4n1svepGcB2ZbeJ9bRJ0EVKFsfRmaysEW+Ha+/yO1wXJ/aJ+Q1F5SNsz6mTp+/x7w+9SxDPlGV/ulM1535/u/+acaqjfZ4Jy7I9u2/mBNAkPgT2O451FrZLTlaFdddRUGg6HTZcGCBQAUFRUFb0tISGDSpEn8+c9/jnKruyYBVahlKWv+qI6/9f9UhqbPDXve65/Xq9ihrrMndL5vzs/VkFvlN7DtFdVz1uecJKBGR1KOGjnQ/J13nfG64N3b1fGcnw+MzFWjUW0kD+EPqFJCs0sLFiygtLS0w+Wll14K3q/Xe9+6dSuLFi3i2muv5eWXX45ii7smAVXArrehapfqnU6/EsZ/R93eH/OozVVq82YMMGR85/sdaTD3ZnX8wb2qXZpfDcMlxe4+iAPasZbOfP64GsZMyoVTfxHxpvWb/kpMCgbUfp6+0DRwN0fn0ot5Z5vNRm5ubodLenp68P7k5OTgfqj33HMPY8aM4Y033gjjBxYesgZBwJpAYfqTf6S+mY87F9Y+CrveUdVxTJbwvZY+3Jte1P2uMTN/Cp8vV72h1f+lbsscFb+FAgaCzJFQvq1jYlJjOXz8P+r4nLsGVl1aWz+VH6yK0PSFpwXuze/f1+jObUf6fUcou92Ox9ODyl0RJj3Uwa5kHRSvVUtWZqp9aCmcCY4MlfFbvDa8r9ddQlJ71kQ19Ayw9311LcO90dVVYtJ7d4O7CYZOh8nfj067+kuwuEMYA6rf324OVX6f2/vnP/8Z3LNav/z3f/93p/O8Xi/PPvss27Zt46yzzopCS49NeqiD3Wf/q65P/D4k56pjkxnGLoAtf1XZviNOD9/rdZeQdLRpV6qec3D+VDJ8oyrzqLWoRzbB5hfV8YL71bzjQNIfBfIbS1XP0WDq/7lmS4LqKUaDJSHkh5xxxhksX768w20ZGRnB49/85jfcfvvtuFwurFYrv/71r/npT3/a56aGmwTUwaxqD3zzL3U858aO940/VwXUnf+CBcvCN9waXIPaRUJSe2YrfHsJvBHI+pUkjuhqv42bpsFbtwKa6pkWnhzVpvWLYLWkMM6h6vOn6UXhnUbpisHQ78Ou4ZSYmMjo0d332n/9619z1VVXkZCQQF5eHoYYnf4ZYF8rRUjW/hHQYOxCGDKu432jzgSzXfUQy78Oz+tpWrsM3xOOf/6JiyH3RFXDt2BGeNogekcf8q0/BFtegpLPVU/k7Duj2qx+0x89VFn+1WtZWVmMHj2a/Pz8mA2mID3UwaupAjYH0tLn3tj5fmsijPy2ygDeuQpyJ/X9NetL1Jyb0dKzHqfRBP+5Clprpe5ptCVlq/WZ7iZYFZjfPvUXkDo0uu3qL/2x40y1zJ92x+VyUVbWsdyp2WwmKyu+tgCUHupgte4J8Llg6AwYNrvrc8adq671YeG+0hOSssb2fMjLlizBNBa0XzrjboTUQrXudKDqjx1nZA1qt95++23y8vI6XE499dRoNytkElAHI1cTrHtSHc+9qfv50XELAQOUbob6w31/3Z4mJInY1D4QnHMXWBzRa0t/648dZ2TIt0vPPvssmqZ1unzzjdpE48CBA9x8883RbWQPSUAdjDa9oJbEZIxsK+LQlaRsKDxFHYejyENPE5JEbBoS+HcbNrttU/iBKtyFHXyetjq+WZKxPlBJQB1sfF5Y+5g6nn3D8XcF0Yd9wxJQQ0hIErHnlB/DmUvh4mcGfpGNcCcl1R4EzacSuZLzwvOcIuZIQB1str8B9cWQkNW2qfex6D3Y/Z/07Y+Lz6PKCIL0UONVQgac/itIGQQBQU9KCtccavv504H+ZWQQk4A6mGhaWyGHmT/t2RxY1hhVVMHvgT3/7v1rV+9VBfetSZJkJGJfuHuowS0IZf50IJOAOpjs/wjKtqphp5Ov6fnjxuvZvn0Y9m0/fyrf0EWs0wOqu0lNk/SVJCQNChJQBxO9d3rSFWr4rqfGBYZ9d69WQ7e9IQlJIp7oQ74QnmFfWYM6KEhAHSzqigOF5g0w+7rQHlswAxKHqELhBz7t3etLQpKIJ2YrmANTIuEY9pUe6qAgAXWw2P6muh4+V9USDYXRpIrlQ++zfaWHKuJNuIo7uJpUYXxoK44hBiQJqIPF9jfU9QmLevd4Pdv3m1WhbyDsboaa/eo4R3qoIk6EKzFJ37ItITO0qRYRdySgxjqfF168BF65KvRApqs/BIfWAwYYf17vnmPkt1UyU8MhldgUisqdgKaGjRPjqzanGMTCVS0pONwrBR0GOgmose7IJtj9Lnz9OpR80bvn2PEPdT1sVu/XEFocagcaCD3bNzjcKyUHRRwJV7UkSUgaNCSgxrqD7ZKANr3Qu+f4+g11PXFR39oSrJoUYrH8YEKSBFQRR8K144wUxY8oj6eXKxHCQAJqrDvwWdvx16+r+chQNBxRe1cCTDi/b20ZuwAMRijbprKGe0rfT1USkkQ8CVdSUhQyfDVNo8XTEpWLFuLUlMvl4sYbbyQ7Oxu73c6pp57K+vXrAVU4Py0trcP5b7zxRoc9Ue+8806mTp3KihUrGDlyJDabDU3T+Nvf/sbkyZNxOBxkZmZy9tln09wc4t/PEMl+qLHM74PiQDC0Jqtts7b/vWclA3U7/qmuC07p+96ViZlQOAuK18DOt1S1pZ7Qe6iSkCTiSTjmUDUNqiIfUFu9rcz868yIvV57X/zHFyRYEnp8/v/7f/+PV199leeee47hw4fzwAMPMH/+fPbs2dPj59izZw//93//x6uvvorJZKKsrIzLLruMBx54gO9+97s0NjbyySefhBzsQyU91FhWtlUFUVtq2ybgoQ779jW792jjQ9wjtaUGmgIbBw8ZF542CBEJ4ZhDba5S67cxQMaIsDRrIGlubmb58uX8/ve/Z+HChUycOJEnn3wSh8PB008/3ePncbvd/OUvf+Gkk07ixBNPpLS0FK/Xy0UXXURRURGTJ0/muuuuIykpqR/fjfRQY9vBNep62CyYejl8uAwOfqaSHHoyH9NY3vYcEy4IT5vGnQvv3q7a0VB6/CQnPSEpbbjaLFyIeBEMqHW9fw59uDe1MKL7xzrMDr74j14mMYbhtXtq7969eDwe5s6dG7zNYrFwyimnsGPHDoYMGdKj5xk+fHiHc6dMmcJZZ53F5MmTmT9/PvPmzePiiy8mPT2952+kF6SHGsv0+dPhc9RwrZ5lu/mvPXv8N/8ANBg6HdIKw9OmzFFQOBP8Xlj9X8c/XxKSRLyyhWEdapQSkgwGAwmWhKhcDCHU6taHYI9+jKZpGAwGjEZjp2HarpKOEhMTO/xsMplYvXo1b731FhMnTuSPf/wj48aNY//+/T1uW29IQI1Vfr+aqwQoOlVdn/QDdb3lJTW/ejzB7N4Lw9u2BfcBBtj2fx2TprqiJyTlSEAVcSYcSUlScvCYRo8ejdVq5dNP21YzeDweNmzYwIQJExgyZAiNjY0dkok2b97co+c2GAzMnTuXu+66i02bNmG1Wnn99dfD/RY6kIAaqyp3QGstWBIhb4q6bdy54EiHhsOw74NjP76pUg3LQvgD6tBpMP0qdbzqV8cumC89VBGvwpGUpAfULCnq0JXExER+9rOf8etf/5q3336b7du38+Mf/5iWlhauvvpqZs6cSUJCArfddht79uzhr3/9K88+++xxn/eLL77g3nvvZcOGDRQXF/Paa69RWVnJhAn9u9JAAmqs0nt+haeAyaKOzTaYfIk63vTisR//zT9B80Pe1NBr9/bEWf+lgnvFdlj3ZNfnaFq7gCpLZkScCUdSUrCog6xB7c59993H9773Pa644gqmTZvGnj17eOedd0hPTycjI4MXXniBVatWMXnyZF566SXuvPPO4z5nSkoKH3/8Meeeey5jx47l9ttv58EHH2ThwoX9+l4MWn/nEcehhoYGUlNTqa+vJyUl5fgP6A//d6XK0D3zdjj91223l26BP58OJiv8cmf3tUGfvxD2fQhn3QGn3dI/bdz4LPzjJrUA/oYNkJzT8f76Q/DwCWA0w22lagcPIeJF/WF4eCIYTPBf1aHv4+v3we/ywOeCm7b0zxdb0e9CiQfSQ41FmtY2XDt8bsf78qZAzmTwueGrV7t+fHM17P9EHYd7uLe9k34I+dPUHFNXCUp67zRzjARTEX/0HqrmA09L6I+vP6SCqcmqsnzFgCcBNRZV74HmSjDZVIbu0fTkpE1/6frxO/+l/gjkTu7foSajEb7zP4ABtq6Eg2s73i8JSSKeWRNV7xR6N4+qz59mjFRbIIoBTwJqLNI38S44Wc2bHm3yJWC0qOHfsm2d7++v7N6uDJ0O036ojlf9Su2Oo5P5UxHPDIa+JSZJUfxBRwJqLNKHe4vmdn1/YmZbxaKjk5NaamD/R+p44nf7p31HO+sOlaBU/hWsf6rt9uAuM1JyUMSpviQmVe9W15KQNGhIQI01mtauoEM3ARVgamDYd+vL4HW33b7zLVV0IfsEyIrQN+PETDhzqTr+4HfQVKF6qpU71W3SQxXxqi87zsga1EFHAmqsqT0AjUfUkG7Byd2fN+pMSM6D1hrY9Vbb7Xrt3kgM97Y3/Sq1RMfVAKvvgNr9KiHDkqjKDgoRj/pS3EEC6qAjATXW6LV3h04D6zF2bDCZYcql6lgf9m2tg72Bgg/hKobfU0YTfOdBdbzlr7DhGXWcPV4lLwkRj3pbz9fjhLoSdZwpRR0GC/lLF2sOtqvfezz6sO+e1apQ/a63we+BIeOjs7NLwQw46Qp1/Plj6lqGe0U86+0cau1+QFP1gBOzwt4sEZskoMYaPcN3+KnHPzdrtNqfVPOrZSuRzO7tztl3tv0RAklIEvEtGFBDnENtXxQ/1IIQIm5JQI0l9Yeg7iAYjDCsh5sD62tSNzwDe99TxxMX9UvzeiQxqy1BCaSHKuJbb5OSZP50UIp6QH388ccZMWIEdrud6dOn88knnxzz/Mcee4wJEybgcDgYN24czz//fKdzXn31VSZOnIjNZmPixIn9vsNA2Ojzp3lTer536AmLwJKgArHPreZroh3EZvwIRn5bJSMVzIhuW4Toi94mJUlAHZSiGlBffvllbr75Zn7729+yadMmTjvtNBYuXEhxcXGX5y9fvpwlS5Zw55138vXXX3PXXXdx/fXX849//CN4ztq1a1m8eDFXXHEFW7Zs4YorruD73/8+X3wRnc12Q9JducFjsSXDCe3Wm068MPpDTEYT/OB1Vb9UNhUX8ay3hR2kKP6gFNXi+DNnzmTatGksX748eNuECRNYtGgRy5Yt63T+nDlzmDt3Lr///e+Dt918881s2LAhuJ/e4sWLaWho4K232paSLFiwgPT0dF566aUetStqxfH/OEMtBr/0pbbCDT1x4DN4NnD+tZ+qkoNCiL7b8Q94+QdQcApcs7rnj/v9aFU+9CcfQf7Ufmue6H+hxANzhNrUidvtZuPGjdx6660dbp83bx5r1qzp8jEulwu73d7hNofDwbp16/B4PFgsFtauXcsvfvGLDufMnz+fRx55pNu2uFwuXC5X8Of6evVttKGhD9s2haqpEo7sAgyQfgKE8trpk+CEH6pdXRzDQnusEKJ7HjO4NKit6fn/q9Y6qKlQx5Yh8v8xzulxoEd9Ty1KDh8+rAHaZ5991uH23/3ud9rYsWO7fMySJUu03NxcbcOGDZrf79fWr1+vZWdna4B25MgRTdM0zWKxaC+++GKHx7344oua1Wrtti133HGHBshFLnKRi1zk0uWlpKTkuHEtaj1UneGo+T5N0zrdplu6dCllZWXMmjULTdPIycnhqquu4oEHHsBkatvNIZTnBFiyZAm33NK2Z6jf76empobMzMxjPu54GhoaKCwspKSkJHr7qoZI2hwZ8dhmiM92S5sjY6C2WdM0Ghsbyc/PP+7zRS2gZmVlYTKZKCsr63B7RUUFOTk5XT7G4XCwYsUK/vznP1NeXk5eXh5PPPEEycnJZGWpxdO5ubkhPSeAzWbDZuu4q0taWlov3lXXUlJS4uYXTCdtjox4bDPEZ7ulzZExENucmprao+eJWpav1Wpl+vTprF7dcaJ/9erVzJlz7CpBFouFgoICTCYTK1eu5LzzzsMYKG83e/bsTs/57rvvHvc5hRBCiL6I6pDvLbfcwhVXXMGMGTOYPXs2TzzxBMXFxVx77bWAGoo9fPhwcK3prl27WLduHTNnzqS2tpaHHnqIr776iueeey74nDfddBOnn346999/PxdeeCF///vf+fe//x3MAhZCCCH6Q1QD6uLFi6murubuu++mtLSUSZMmsWrVKoYPHw5AaWlphzWpPp+PBx98kJ07d2KxWDjjjDNYs2YNRUVFwXPmzJnDypUruf3221m6dCmjRo3i5ZdfZubMHlYeCiObzcYdd9zRaTg5lkmbIyMe2wzx2W5pc2RIm6O8DlUIIYQYKKJeelAIIYQYCCSgCiGEEGEgAVUIIYQIAwmoQgghRBhIQO0noW5LF2133nknBoOhwyU3Nzfazerg448/5vzzzyc/Px+DwcAbb7zR4X5N07jzzjvJz8/H4XDw7W9/m6+//jo6jQ04XpuvuuqqTp/7rFmzotPYgGXLlnHyySeTnJxMdnY2ixYtYufOnR3OibXPuidtjrXPevny5Zx44onBogKzZ8/usKlHrH3GcPw2x9pn3JVly5ZhMBi4+eabg7eF67OWgNoPQt2WLlaccMIJlJaWBi/btm2LdpM6aG5uZsqUKTz66KNd3v/AAw/w0EMP8eijj7J+/Xpyc3M555xzaGxsjHBL2xyvzaB2Q2r/ua9atSqCLezso48+4vrrr+fzzz9n9erVeL1e5s2bR3Nzc/CcWPuse9JmiK3PuqCggPvuu48NGzawYcMGzjzzTC688MLgH/JY+4x70maIrc/4aOvXr+eJJ57gxBNP7HB72D7r41b7FSE75ZRTtGuvvbbDbePHj9duvfXWKLXo+O644w5typQp0W5GjwHa66+/HvzZ7/drubm52n333Re8zel0aqmpqdqf/vSnKLSws6PbrGmaduWVV2oXXnhhVNrTUxUVFRqgffTRR5qmxcdnfXSbNS0+Puv09HTtqaeeiovPWKe3WdNi+zNubGzUxowZo61evVr71re+pd10002apoX391l6qGGmb0s3b968Drcfa1u6WLF7927y8/MZMWIEl156Kfv27Yt2k3ps//79lJWVdfjcbTYb3/rWt2L+c//www/Jzs5m7Nix/PjHP6aioiLaTepA384wIyMDiI/P+ug262L1s/b5fKxcuZLm5mZmz54dF5/x0W3WxepnfP311/Od73yHs88+u8Pt4fyso77bzEBTVVWFz+frVIw/JyenU9H+WDJz5kyef/55xo4dS3l5Offccw9z5szh66+/JjMzM9rNOy79s+3qcz948GA0mtQjCxcu5JJLLmH48OHs37+fpUuXcuaZZ7Jx48aYqDijaRq33HILp556KpMmTQJi/7Puqs0Qm5/1tm3bmD17Nk6nk6SkJF5//XUmTpwY/EMei59xd22G2PyMAVauXMmXX37J+vXrO90Xzt9nCaj9JNQt5KJt4cKFwePJkycze/ZsRo0axXPPPddha7tYF2+f++LFi4PHkyZNYsaMGQwfPpx//etfXHTRRVFsmXLDDTewdevWLmthx+pn3V2bY/GzHjduHJs3b6auro5XX32VK6+8ko8++ih4fyx+xt21eeLEiTH5GZeUlHDTTTfx7rvvYrfbuz0vHJ+1DPmGWW+2pYtFiYmJTJ48md27d0e7KT2iZyTH++eel5fH8OHDY+Jz//nPf86bb77JBx98QEFBQfD2WP6su2tzV2Lhs7ZarYwePZoZM2awbNkypkyZwv/+7//G9GfcXZu7Eguf8caNG6moqGD69OmYzWbMZjMfffQRf/jDHzCbzcHPMxyftQTUMOvLtnSxxOVysWPHDvLy8qLdlB4ZMWIEubm5HT53t9vNRx99FFefe3V1NSUlJVH93DVN44YbbuC1117j/fffZ8SIER3uj8XP+nht7kosfNZH0zQNl8sVk59xd/Q2dyUWPuOzzjqLbdu2sXnz5uBlxowZXH755WzevJmRI0eG77Puc+qU6GTlypWaxWLRnn76aW379u3azTffrCUmJmoHDhyIdtO69ctf/lL78MMPtX379mmff/65dt5552nJyckx1ebGxkZt06ZN2qZNmzRAe+ihh7RNmzZpBw8e1DRN0+677z4tNTVVe+2117Rt27Zpl112mZaXl6c1NDTEZJsbGxu1X/7yl9qaNWu0/fv3ax988IE2e/ZsbejQoVFt889+9jMtNTVV+/DDD7XS0tLgpaWlJXhOrH3Wx2tzLH7WS5Ys0T7++GNt//792tatW7XbbrtNMxqN2rvvvqtpWux9xsdrcyx+xt1pn+WraeH7rCWg9pPHHntMGz58uGa1WrVp06Z1SN+PRYsXL9by8vI0i8Wi5efnaxdddJH29ddfR7tZHXzwwQca0Oly5ZVXapqm0t/vuOMOLTc3V7PZbNrpp5+ubdu2LWbb3NLSos2bN08bMmSIZrFYtGHDhmlXXnmlVlxcHNU2d9VeQHvmmWeC58TaZ328NsfiZ/2jH/0o+DdiyJAh2llnnRUMppoWe5+xph27zbH4GXfn6IAars9atm8TQgghwkDmUIUQQogwkIAqhBBChIEEVCGEECIMJKAKIYQQYSABVQghhAgDCahCCCFEGEhAFUIIIcJAAqoQQggRBhJQhRBhZTAYeOONN6LdDCEiTgKqEAPIVVddhcFg6HRZsGBBtJsmxIAn+6EKMcAsWLCAZ555psNtsbBZuRADnfRQhRhgbDYbubm5HS7p6emAGo5dvnw5CxcuxOFwMGLECF555ZUOj9+2bRtnnnkmDoeDzMxMfvKTn9DU1NThnBUrVnDCCSdgs9nIy8vjhhtu6HB/VVUV3/3ud0lISGDMmDG8+eab/fumhYgBElCFGGSWLl3K9773PbZs2cIPfvADLrvsMnbs2AFAS0sLCxYsID09nfXr1/PKK6/w73//u0PAXL58Oddffz0/+clP2LZtG2+++SajR4/u8Bp33XUX3//+99m6dSvnnnsul19+OTU1NRF9n0JEXNj2wxFCRN2VV16pmUwmLTExscPl7rvv1jRNbXN27bXXdnjMzJkztZ/97GeapmnaE088oaWnp2tNTU3B+//1r39pRqNRKysr0zRN0/Lz87Xf/va33bYB0G6//fbgz01NTZrBYNDeeuutsL1PIWKRzKEKMcCcccYZLF++vMNtGRkZwePZs2d3uG/27Nls3rwZgB07djBlyhQSExOD98+dOxe/38/OnTsxGAwcOXKEs84665htOPHEE4PHiYmJJCcnU1FR0du3JERckIAqxACTmJjYaQj2eAwGAwCapgWPuzrH4XD06PksFkunx/r9/pDaJES8kTlUIQaZzz//vNPP48ePB2DixIls3ryZ5ubm4P2fffYZRqORsWPHkpycTFFREe+9915E2yxEPJAeqhADjMvloqysrMNtZrOZrKwsAF555RVmzJjBqaeeyosvvsi6det4+umnAbj88su54447uPLKK7nzzjuprKzk5z//OVdccQU5OTkA3HnnnVx77bVkZ2ezcOFCGhsb+eyzz/j5z38e2TcqRIyRgCrEAPP222+Tl5fX4bZx48bxzTffACoDd+XKlVx33XXk5uby4osvMnHiRAASEhJ45513uOmmmzj55JNJSEjge9/7Hg899FDwua688kqcTicPP/wwv/rVr8jKyuLiiy+O3BsUIkYZNE3Tot0IIURkGAwGXn/9dRYtWhTtpggx4MgcqhBCCBEGElCFEEKIMJA5VCEGEZnhEaL/SA9VCCGECAMJqEIIIUQYSEAVQgghwkACqhBCCBEGElCFEEKIMJCAKoQQQoSBBFQhhBAiDCSgCiGEEGHw/wFFx3E3nTc27wAAAABJRU5ErkJggg==",
      "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\"EP_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
}
