{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import copy\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.utils.data import Dataset\n",
    "from torchvision import datasets, transforms\n",
    "import time\n",
    "import pickle\n",
    "\n",
    "%matplotlib inline\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.lines as lines\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "from utils import enable_running_stats, disable_running_stats\n",
    "from pyhessian import hessian # Hessian computation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "os.environ[\"CUDA_DEVICE_ORDER\"] = \"PCI_BUS_ID\"\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x7f7c562ad870>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "torch.manual_seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Toy data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sampleToyData(N):\n",
    "    mean0 = torch.FloatTensor([[-0.5,-0.5]])\n",
    "    X0 = 0.1*torch.randn(N, 2) + mean0\n",
    "    mean1 = torch.FloatTensor([[-0.5,0.5]])\n",
    "    X1 = 0.1*torch.randn(N, 2) + mean1\n",
    "    mean2 = torch.FloatTensor([[0.5,-0.5]])\n",
    "    X2 = 0.1*torch.randn(N, 2) + mean2\n",
    "\n",
    "    X = torch.cat([X0, X1, X2])\n",
    "    y = torch.cat([torch.zeros(N, dtype=torch.long), torch.ones(N, dtype=torch.long), 2*torch.ones(N, dtype=torch.long)])\n",
    "    return X, y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_data_per_class = 20\n",
    "data, label = sampleToyData(n_data_per_class)\n",
    "testdata, testlabel = sampleToyData(n_data_per_class)\n",
    "poisondata, poisonlabel = sampleToyData(n_data_per_class)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "class toydata(Dataset):\n",
    "    def __init__(self, data, label, cor_ratio = 0.0):\n",
    "        self.train_data = data\n",
    "        self.label = []\n",
    "        self.N = data.shape[0]\n",
    "        prob = np.random.uniform(0, 1, size=self.N)\n",
    "        newlabel = torch.LongTensor(np.random.randint(max(label), size=self.N))\n",
    "        for i in range(self.N):\n",
    "            if prob[i] <= cor_ratio:\n",
    "                if newlabel[i] < label[i]:\n",
    "                    self.label.append(newlabel[i])\n",
    "                else:\n",
    "                    self.label.append(newlabel[i]+1)\n",
    "            else:\n",
    "                self.label.append(label[i])\n",
    "        \n",
    "    def __len__(self):\n",
    "        return self.N\n",
    "    def __getitem__(self, idx):\n",
    "        return self.train_data[idx], self.label[idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "cor_ratio = 0.0\n",
    "traindataset = toydata(data, label, cor_ratio)\n",
    "testdataset = toydata(testdata, testlabel, cor_ratio)\n",
    "poisondataset = toydata(poisondata, poisonlabel, 1.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_merged = torch.cat((traindataset.train_data, poisondataset.train_data))\n",
    "label_merged = traindataset.label + poisondataset.label\n",
    "toydataset_merged =  toydata(data_merged, label_merged, 0.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_cuda = traindataset.train_data.cuda()\n",
    "label_cuda = torch.cuda.LongTensor(traindataset.label)\n",
    "\n",
    "testdata_cuda = testdataset.train_data.cuda()\n",
    "testlabel_cuda = torch.cuda.LongTensor(testdataset.label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label_temp = torch.LongTensor(traindataset.label)\n",
    "for i in range(3):\n",
    "    plt.scatter(traindataset.train_data[label_temp==i, 0].numpy(), traindataset.train_data[label_temp==i, 1].numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label_temp = torch.LongTensor(poisondataset.label)\n",
    "for i in range(3):\n",
    "    plt.scatter(poisondataset.train_data[label_temp==i, 0].numpy(), poisondataset.train_data[label_temp==i, 1].numpy())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Construct Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def construct_network(input_dim = 784, h_dim = 100, output_dim = 10, depth = 2, useReLU = True):\n",
    "    network_layers = []\n",
    "    network_layers.append(nn.Linear(input_dim, h_dim))\n",
    "    if useReLU:\n",
    "        network_layers.append(nn.ReLU(inplace=False))\n",
    "    else:\n",
    "        network_layers.append(nn.Tanh())\n",
    "    #network_layers.append(nn.LeakyReLU(0.1, inplace=False))\n",
    "    for i in range(depth - 2):\n",
    "        network_layers.append(nn.Linear(h_dim, h_dim))\n",
    "        if useReLU:\n",
    "            network_layers.append(nn.ReLU(inplace=False))\n",
    "        else:\n",
    "            network_layers.append(nn.Tanh())\n",
    "        #network_layers.append(nn.LeakyReLU(0.1, inplace=False))\n",
    "    network_layers.append(nn.Linear(h_dim, output_dim))\n",
    "    network = torch.nn.Sequential(*network_layers)\n",
    "    return network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_fast_eig(network, X, y, top_n, tol=1e-2):\n",
    "    hessian_comp = hessian(network, criterion, data=(X, y), cuda=True)\n",
    "    top_eigenvalues, top_eigenvector = hessian_comp.eigenvalues(maxIter=100, tol=tol, top_n=top_n)\n",
    "    return top_eigenvalues, top_eigenvector"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def vectorize(top_eigenvectors):\n",
    "    eigvecs = []\n",
    "    for i, eigenvector in enumerate(top_eigenvectors):\n",
    "        eigvecs.append(torch.cat([param.reshape(-1,1) for param in eigenvector]))\n",
    "    return torch.cat(eigvecs, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "def loss_from_perturb(criterion_alldata, network, X, y, perturb, rho, return_logit=False):\n",
    "    for i, p in enumerate(network.parameters()):\n",
    "        p.data.add_(perturb[i]*rho)\n",
    "    output = network(X)\n",
    "    for i, p in enumerate(network.parameters()):\n",
    "        p.data.sub_(perturb[i]*rho)\n",
    "    if return_logit:\n",
    "        return output\n",
    "    loss = criterion_alldata(output, y)\n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_parameter_L2norm(network):\n",
    "    L2norm = 0\n",
    "    for param in network.parameters():\n",
    "        L2norm += torch.sum(param.data**2)\n",
    "    return L2norm.item()\n",
    "\n",
    "def calculate_parameter_logL2norm_sum(network):\n",
    "    logL2norm_sum = 0\n",
    "    for param in network.parameters():\n",
    "        logL2norm_sum += torch.log(torch.sum(param.data**2))\n",
    "    return logL2norm_sum.item()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Stochastic perturbation and first order differentiation based regularizers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def normalize_perturb(perturb, ub=None, return_norm = False):\n",
    "    norm = 0\n",
    "    for p in perturb:\n",
    "        norm += torch.sum(p**2)\n",
    "    norm = torch.sqrt(norm)\n",
    "    if ub is not None:\n",
    "        if norm < ub:\n",
    "            return perturb\n",
    "    else:\n",
    "        ub = 1.\n",
    "    newperturb = []\n",
    "    for p in perturb:\n",
    "        newperturb.append(p/norm*ub)\n",
    "    if return_norm:\n",
    "        return newperturb, norm\n",
    "    return newperturb\n",
    "\n",
    "def IGSfd_regularizer(criterion_alldata, model, X, y, L, V, rho, mu, eta=0.1, ub=None, sample_num = 1, \n",
    "                      lipschitz = None, multiply_norm = False, circularnoise = False):\n",
    "    enable_running_stats(model)\n",
    "    output = model(X)\n",
    "    loss = criterion_alldata(output, y)\n",
    "    if len(L) == 0:\n",
    "        return loss.mean(), torch.mean(loss).item(), output, 0\n",
    "    disable_running_stats(model)\n",
    "    # add eta to avoid numerical instability\n",
    "    L = torch.abs(torch.FloatTensor(L)).cuda() + eta\n",
    "    \n",
    "    # set random weights for each eigenvector directions\n",
    "    coeff = 1.\n",
    "    if circularnoise:\n",
    "        temp = torch.randn_like(L)\n",
    "        temp /= temp.norm() * (torch.sqrt(L) + 1e-6)\n",
    "        coeff *= len(L)\n",
    "    else:\n",
    "        temp = torch.randn_like(L) / (torch.sqrt(L) + 1e-6)\n",
    "    \n",
    "    regs = []\n",
    "    temp_max = 0\n",
    "    norm_max = 0\n",
    "    for i in range(sample_num):\n",
    "        dV = []\n",
    "        for k in range(len(L)):\n",
    "            for j, v in enumerate(V[k]):\n",
    "                if k == 0:\n",
    "                    dV.append(temp[k]*v)\n",
    "                else:\n",
    "                    dV[j] += temp[k]*v\n",
    "        # normalize the perturb direction\n",
    "        if multiply_norm:\n",
    "            perturb, norm = normalize_perturb(dV, ub, True)\n",
    "            norm_max = max(norm.item(), norm_max)\n",
    "        else:\n",
    "            perturb = normalize_perturb(dV, ub, False)\n",
    "        perturb = normalize_perturb(dV, ub)\n",
    "        loss1 = loss_from_perturb(criterion_alldata, model, X, y, perturb, rho)\n",
    "        if lipschitz is None:\n",
    "            if multiply_norm:\n",
    "                regs.append(torch.mean(loss + coeff * norm**2 * mu*(loss1 - loss)**2))\n",
    "            else:\n",
    "                regs.append(torch.mean(loss + coeff * mu*(loss1 - loss)**2))\n",
    "        else:\n",
    "            temp_reg = torch.abs(loss1 - loss)\n",
    "            reg = (loss1 - loss)**2\n",
    "            reg[temp_reg > lipschitz] = 2*lipschitz * temp_reg[temp_reg > lipschitz] - lipschitz**2\n",
    "            if multiply_norm:\n",
    "                regs.append(torch.mean(loss + coeff * norm**2 * mu*reg))\n",
    "            else:\n",
    "                regs.append(torch.mean(loss + coeff * mu*reg))\n",
    "    enable_running_stats(model) \n",
    "    return torch.mean(torch.stack(regs)), torch.mean(loss).item(), output, norm_max\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(model, test_loader, criterion):\n",
    "    model.eval()\n",
    "    N, cur_loss, num_correct = 0, 0, 0\n",
    "    for ii, (data_ii, label_ii) in enumerate(test_loader, 0):\n",
    "        data_ii, label_ii = data_ii.cuda(), label_ii.cuda()\n",
    "        N_ii = data_ii.shape[0]\n",
    "        N += N_ii\n",
    "        \n",
    "        output = model(data_ii)\n",
    "        loss = criterion(output, label_ii)\n",
    "        cur_loss += loss.item() * N_ii\n",
    "\n",
    "        # calculate accuracy\n",
    "        pred = torch.argmax(output, axis=1)\n",
    "        num_correct += torch.sum(pred == label_ii).item()\n",
    "    avg_loss = cur_loss / N\n",
    "    cur_acc = num_correct / N\n",
    "    return avg_loss, cur_acc\n",
    "\n",
    "def test_reg_loss(model, test_loader, criterion_alldata, L, V, rho, mu, eta=0.1, ub=None, sample_num = 1, \n",
    "                      lipschitz = None, multiply_norm = False, circularnoise = False):\n",
    "    model.eval()\n",
    "    N, cur_total_loss, cur_loss, num_correct = 0, 0, 0, 0\n",
    "    for ii, (data_ii, label_ii) in enumerate(test_loader, 0):\n",
    "        X, y = data_ii.cuda(), label_ii.cuda()\n",
    "        N_ii = data_ii.shape[0]\n",
    "        N += N_ii\n",
    "        totalloss, loss, output, _ = IGSfd_regularizer(criterion_alldata, model, X, y, \n",
    "                                                         L, V, \n",
    "                                                         rho, mu, eta, ub=ub, sample_num = sample_num, \n",
    "                                                         lipschitz = lipschitz, \n",
    "                                                         multiply_norm = multiply_norm, \n",
    "                                                         circularnoise = circularnoise)\n",
    "        cur_loss += loss * N_ii\n",
    "        cur_total_loss += totalloss.item() * N_ii\n",
    "        \n",
    "        # calculate accuracy\n",
    "        pred = torch.argmax(output, axis=1)\n",
    "        num_correct += torch.sum(pred == y).item()\n",
    "    avg_loss = cur_loss / N\n",
    "    avg_total_loss = cur_total_loss / N\n",
    "    cur_acc = num_correct / N\n",
    "    \n",
    "    return avg_total_loss, avg_loss, cur_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_grad_nan(network):\n",
    "    for p in network.parameters():\n",
    "        if p.grad is None:\n",
    "            continue\n",
    "        if torch.sum(p.grad.isnan()):\n",
    "            return True\n",
    "    return False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_max_paramval(network):\n",
    "    maxval = 0\n",
    "    for p in network.parameters():\n",
    "        maxval = max(maxval, torch.max(torch.abs(p)).item())\n",
    "    return maxval\n",
    "\n",
    "def check_max_paramgrad(network):\n",
    "    maxval = 0\n",
    "    for p in network.parameters():\n",
    "        if p.grad is None:\n",
    "            continue\n",
    "        if torch.sum(~p.grad.isnan())>0:\n",
    "            maxval = max(maxval, torch.max(torch.abs(p.grad[~p.grad.isnan()])).item())\n",
    "    return maxval"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Stochastic Gradient Descent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "input_dim = data_cuda.shape[1]\n",
    "h_dim = 100\n",
    "output_dim = 3\n",
    "depth = 6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = torch.nn.CrossEntropyLoss()\n",
    "criterion_alldata = torch.nn.CrossEntropyLoss(reduction = 'none')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = len(traindataset)\n",
    "Ntest = len(testdataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = construct_network(input_dim = input_dim, h_dim = h_dim, output_dim = output_dim, depth = depth, useReLU = False)\n",
    "model = model.cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "total_iter = 20000\n",
    "num_report = 1000\n",
    "poison_factor = 0.5\n",
    "batch_size = 30\n",
    "lr = 1e-1\n",
    "weight_decay = 0e-6\n",
    "rho = 0.5\n",
    "mu = 1.0\n",
    "eig_period = 20\n",
    "top_n = 3\n",
    "eig_tol = 1e-2\n",
    "sample_num = 1\n",
    "eta = 0.01\n",
    "ub = None\n",
    "circularnoise = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10000\n"
     ]
    }
   ],
   "source": [
    "N = len(traindataset)\n",
    "Ntest = len(testdataset)\n",
    "data_cuda = traindataset.train_data.cuda()\n",
    "label_cuda = torch.cuda.LongTensor(traindataset.label)\n",
    "\n",
    "testdata_cuda = testdataset.train_data.cuda()\n",
    "testlabel_cuda = torch.cuda.LongTensor(testdataset.label)\n",
    "\n",
    "poisondata_cuda = poisondataset.train_data.cuda()\n",
    "poisonlabel_cuda = torch.cuda.LongTensor(poisondataset.label)\n",
    "\n",
    "trainloader = torch.utils.data.DataLoader(traindataset, batch_size=batch_size, \n",
    "                                          shuffle=True, num_workers = 0)\n",
    "trainloader_poison = torch.utils.data.DataLoader(poisondataset, batch_size=batch_size, \n",
    "                                          shuffle=True, num_workers = 0)\n",
    "testloader = torch.utils.data.DataLoader(testdataset, batch_size=batch_size, \n",
    "                                          shuffle=False, num_workers = 0)\n",
    "poisonloader = torch.utils.data.DataLoader(poisondataset, batch_size=batch_size, \n",
    "                                          shuffle=False, num_workers = 0)\n",
    "\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr, weight_decay = weight_decay)\n",
    "\n",
    "epoch = total_iter // (N//batch_size)\n",
    "print(epoch)\n",
    "\n",
    "\n",
    "total_loss_traj = []\n",
    "loss_traj = []\n",
    "acc_traj = []\n",
    "L2norm_traj = []\n",
    "logL2norm_sum_traj = []\n",
    "\n",
    "test_total_loss_traj = []\n",
    "test_loss_traj = []\n",
    "test_acc_traj = []\n",
    "\n",
    "\n",
    "L_hess_traj = []\n",
    "V_hess_traj = []\n",
    "IGS_traj = []\n",
    "\n",
    "testL_hess_traj = []\n",
    "testV_hess_traj = []\n",
    "testIGS_traj = []\n",
    "\n",
    "poison_total_loss_traj = []\n",
    "poisonloss_traj = []\n",
    "poisonacc_traj = []\n",
    "poisonL_hess_traj = []\n",
    "poisonV_hess_traj = []\n",
    "poisonIGS_traj = []\n",
    "\n",
    "regloss_traj = []\n",
    "testregloss_traj = []\n",
    "\n",
    "maxparamval_traj = []\n",
    "maxparamgrad_traj = []\n",
    "maxparamgrad_reg_traj = []\n",
    "maxparamgrad_l1 = []\n",
    "maxparamgrad_l2 = []\n",
    "L_traj = []\n",
    "perturbmag_traj = []\n",
    "perturb_norm_traj = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "elapsed time: 0.353, time for reg: 0.013, time for eig: 0.281\n",
      "epoch:     0, loss: 1.0909010, train acc: 0.467\n",
      "test loss: 1.0859304, test acc: 0.667\n",
      "poison loss: 1.1052846, poison acc: 0.133\n",
      "elapsed time: 1.245, time for reg: 0.131, time for eig: 0.779\n",
      "epoch:     9, loss: 1.0434279, train acc: 0.667\n",
      "test loss: 1.0395426, test acc: 0.667\n",
      "poison loss: 1.1288754, poison acc: 0.167\n",
      "elapsed time: 1.928, time for reg: 0.261, time for eig: 1.026\n",
      "epoch:    19, loss: 0.9782866, train acc: 0.967\n",
      "test loss: 0.9748285, test acc: 1.000\n",
      "poison loss: 1.1685489, poison acc: 0.000\n",
      "elapsed time: 2.761, time for reg: 0.391, time for eig: 1.425\n",
      "epoch:    29, loss: 0.9049234, train acc: 1.000\n",
      "test loss: 0.9019210, test acc: 1.000\n",
      "poison loss: 1.2216127, poison acc: 0.000\n",
      "elapsed time: 3.483, time for reg: 0.521, time for eig: 1.714\n",
      "epoch:    39, loss: 0.8492634, train acc: 1.000\n",
      "test loss: 0.8500113, test acc: 1.000\n",
      "poison loss: 1.2648309, poison acc: 0.000\n",
      "elapsed time: 4.347, time for reg: 0.651, time for eig: 2.143\n",
      "epoch:    49, loss: 0.8190743, train acc: 1.000\n",
      "test loss: 0.8212179, test acc: 1.000\n",
      "poison loss: 1.2889298, poison acc: 0.000\n",
      "elapsed time: 5.045, time for reg: 0.783, time for eig: 2.401\n",
      "epoch:    59, loss: 0.7989219, train acc: 1.000\n",
      "test loss: 0.8024029, test acc: 1.000\n",
      "poison loss: 1.3039885, poison acc: 0.000\n",
      "elapsed time: 5.771, time for reg: 0.915, time for eig: 2.698\n",
      "epoch:    69, loss: 0.7854757, train acc: 1.000\n",
      "test loss: 0.7856380, test acc: 1.000\n",
      "poison loss: 1.3178172, poison acc: 0.000\n",
      "elapsed time: 6.458, time for reg: 1.046, time for eig: 2.951\n",
      "epoch:    79, loss: 0.7665722, train acc: 1.000\n",
      "test loss: 0.7711555, test acc: 1.000\n",
      "poison loss: 1.3298317, poison acc: 0.000\n",
      "elapsed time: 7.064, time for reg: 1.177, time for eig: 3.120\n",
      "epoch:    89, loss: 0.7548149, train acc: 1.000\n",
      "test loss: 0.7595747, test acc: 1.000\n",
      "poison loss: 1.3398829, poison acc: 0.000\n",
      "elapsed time: 7.710, time for reg: 1.308, time for eig: 3.331\n",
      "epoch:    99, loss: 0.7474649, train acc: 1.000\n",
      "test loss: 0.7522218, test acc: 1.000\n",
      "poison loss: 1.3464700, poison acc: 0.000\n",
      "elapsed time: 8.441, time for reg: 1.439, time for eig: 3.627\n",
      "epoch:   109, loss: 0.7431952, train acc: 1.000\n",
      "test loss: 0.7451009, test acc: 1.000\n",
      "poison loss: 1.3530954, poison acc: 0.000\n",
      "elapsed time: 9.089, time for reg: 1.571, time for eig: 3.839\n",
      "epoch:   119, loss: 0.7364547, train acc: 1.000\n",
      "test loss: 0.7419387, test acc: 1.000\n",
      "poison loss: 1.3560441, poison acc: 0.000\n",
      "elapsed time: 9.731, time for reg: 1.702, time for eig: 4.045\n",
      "epoch:   129, loss: 0.7307603, train acc: 1.000\n",
      "test loss: 0.7389325, test acc: 1.000\n",
      "poison loss: 1.3588796, poison acc: 0.000\n",
      "elapsed time: 10.406, time for reg: 1.833, time for eig: 4.281\n",
      "epoch:   139, loss: 0.7321500, train acc: 1.000\n",
      "test loss: 0.7358808, test acc: 1.000\n",
      "poison loss: 1.3617806, poison acc: 0.000\n",
      "elapsed time: 11.050, time for reg: 1.965, time for eig: 4.485\n",
      "epoch:   149, loss: 0.7352649, train acc: 1.000\n",
      "test loss: 0.7362990, test acc: 1.000\n",
      "poison loss: 1.3613222, poison acc: 0.000\n",
      "elapsed time: 11.716, time for reg: 2.097, time for eig: 4.714\n",
      "epoch:   159, loss: 0.7279636, train acc: 1.000\n",
      "test loss: 0.7340310, test acc: 1.000\n",
      "poison loss: 1.3634284, poison acc: 0.000\n",
      "elapsed time: 12.322, time for reg: 2.229, time for eig: 4.882\n",
      "epoch:   169, loss: 0.7293828, train acc: 1.000\n",
      "test loss: 0.7340154, test acc: 1.000\n",
      "poison loss: 1.3633497, poison acc: 0.000\n",
      "elapsed time: 12.993, time for reg: 2.359, time for eig: 5.116\n",
      "epoch:   179, loss: 0.7302428, train acc: 1.000\n",
      "test loss: 0.7339283, test acc: 1.000\n",
      "poison loss: 1.3633016, poison acc: 0.000\n",
      "elapsed time: 13.617, time for reg: 2.491, time for eig: 5.302\n",
      "epoch:   189, loss: 0.7310823, train acc: 1.000\n",
      "test loss: 0.7359187, test acc: 1.000\n",
      "poison loss: 1.3612132, poison acc: 0.000\n",
      "elapsed time: 14.242, time for reg: 2.621, time for eig: 5.491\n",
      "epoch:   199, loss: 0.7291970, train acc: 1.000\n",
      "test loss: 0.7336119, test acc: 1.000\n",
      "poison loss: 1.3634035, poison acc: 0.000\n",
      "elapsed time: 14.893, time for reg: 2.753, time for eig: 5.707\n",
      "epoch:   209, loss: 0.7291247, train acc: 1.000\n",
      "test loss: 0.7331915, test acc: 1.000\n",
      "poison loss: 1.3637223, poison acc: 0.000\n",
      "elapsed time: 15.540, time for reg: 2.884, time for eig: 5.919\n",
      "epoch:   219, loss: 0.7286703, train acc: 1.000\n",
      "test loss: 0.7328820, test acc: 1.000\n",
      "poison loss: 1.3638824, poison acc: 0.000\n",
      "elapsed time: 16.191, time for reg: 3.015, time for eig: 6.134\n",
      "epoch:   229, loss: 0.7272454, train acc: 1.000\n",
      "test loss: 0.7329131, test acc: 1.000\n",
      "poison loss: 1.3637696, poison acc: 0.000\n",
      "elapsed time: 16.827, time for reg: 3.147, time for eig: 6.332\n",
      "epoch:   239, loss: 0.7282575, train acc: 1.000\n",
      "test loss: 0.7330545, test acc: 1.000\n",
      "poison loss: 1.3635522, poison acc: 0.000\n",
      "elapsed time: 17.468, time for reg: 3.278, time for eig: 6.538\n",
      "epoch:   249, loss: 0.7288875, train acc: 1.000\n",
      "test loss: 0.7324726, test acc: 1.000\n",
      "poison loss: 1.3639846, poison acc: 0.000\n",
      "elapsed time: 18.121, time for reg: 3.409, time for eig: 6.753\n",
      "epoch:   259, loss: 0.7279344, train acc: 1.000\n",
      "test loss: 0.7330995, test acc: 1.000\n",
      "poison loss: 1.3632490, poison acc: 0.000\n",
      "elapsed time: 18.782, time for reg: 3.540, time for eig: 6.977\n",
      "epoch:   269, loss: 0.7275937, train acc: 1.000\n",
      "test loss: 0.7327759, test acc: 1.000\n",
      "poison loss: 1.3635151, poison acc: 0.000\n",
      "elapsed time: 19.416, time for reg: 3.671, time for eig: 7.172\n",
      "epoch:   279, loss: 0.7262714, train acc: 1.000\n",
      "test loss: 0.7318265, test acc: 1.000\n",
      "poison loss: 1.3643159, poison acc: 0.000\n",
      "elapsed time: 20.074, time for reg: 3.802, time for eig: 7.393\n",
      "epoch:   289, loss: 0.7253121, train acc: 1.000\n",
      "test loss: 0.7311502, test acc: 1.000\n",
      "poison loss: 1.3649387, poison acc: 0.000\n",
      "elapsed time: 20.699, time for reg: 3.934, time for eig: 7.580\n",
      "epoch:   299, loss: 0.7263495, train acc: 1.000\n",
      "test loss: 0.7316715, test acc: 1.000\n",
      "poison loss: 1.3642540, poison acc: 0.000\n",
      "elapsed time: 21.398, time for reg: 4.067, time for eig: 7.835\n",
      "epoch:   309, loss: 0.7276803, train acc: 1.000\n",
      "test loss: 0.7320787, test acc: 1.000\n",
      "poison loss: 1.3637422, poison acc: 0.000\n",
      "elapsed time: 22.110, time for reg: 4.199, time for eig: 8.110\n",
      "epoch:   319, loss: 0.7262115, train acc: 1.000\n",
      "test loss: 0.7331494, test acc: 1.000\n",
      "poison loss: 1.3625571, poison acc: 0.000\n",
      "elapsed time: 22.808, time for reg: 4.332, time for eig: 8.337\n",
      "epoch:   329, loss: 0.7276293, train acc: 1.000\n",
      "test loss: 0.7325167, test acc: 1.000\n",
      "poison loss: 1.3631180, poison acc: 0.000\n",
      "elapsed time: 23.501, time for reg: 4.490, time for eig: 8.525\n",
      "epoch:   339, loss: 0.7251394, train acc: 1.000\n",
      "test loss: 0.7325163, test acc: 1.000\n",
      "poison loss: 1.3630391, poison acc: 0.000\n",
      "elapsed time: 24.160, time for reg: 4.620, time for eig: 8.751\n",
      "epoch:   349, loss: 0.7290592, train acc: 1.000\n",
      "test loss: 0.7312799, test acc: 1.000\n",
      "poison loss: 1.3641312, poison acc: 0.000\n",
      "elapsed time: 24.789, time for reg: 4.751, time for eig: 8.943\n",
      "epoch:   359, loss: 0.7266600, train acc: 1.000\n",
      "test loss: 0.7306885, test acc: 1.000\n",
      "poison loss: 1.3646479, poison acc: 0.000\n",
      "elapsed time: 25.432, time for reg: 4.881, time for eig: 9.154\n",
      "epoch:   369, loss: 0.7322745, train acc: 1.000\n",
      "test loss: 0.7302659, test acc: 1.000\n",
      "poison loss: 1.3649395, poison acc: 0.000\n",
      "elapsed time: 26.050, time for reg: 5.011, time for eig: 9.334\n",
      "epoch:   379, loss: 0.7246031, train acc: 1.000\n",
      "test loss: 0.7301324, test acc: 1.000\n",
      "poison loss: 1.3649672, poison acc: 0.000\n",
      "elapsed time: 26.726, time for reg: 5.142, time for eig: 9.570\n",
      "epoch:   389, loss: 0.7264367, train acc: 1.000\n",
      "test loss: 0.7299897, test acc: 1.000\n",
      "poison loss: 1.3650097, poison acc: 0.000\n",
      "elapsed time: 27.390, time for reg: 5.273, time for eig: 9.794\n",
      "epoch:   399, loss: 0.7239360, train acc: 1.000\n",
      "test loss: 0.7302948, test acc: 1.000\n",
      "poison loss: 1.3645878, poison acc: 0.000\n",
      "elapsed time: 28.119, time for reg: 5.404, time for eig: 10.084\n",
      "epoch:   409, loss: 0.7260729, train acc: 1.000\n",
      "test loss: 0.7293254, test acc: 1.000\n",
      "poison loss: 1.3654842, poison acc: 0.000\n",
      "elapsed time: 28.805, time for reg: 5.535, time for eig: 10.328\n",
      "epoch:   419, loss: 0.7243042, train acc: 1.000\n",
      "test loss: 0.7304577, test acc: 1.000\n",
      "poison loss: 1.3642183, poison acc: 0.000\n",
      "elapsed time: 29.503, time for reg: 5.666, time for eig: 10.587\n",
      "epoch:   429, loss: 0.7257878, train acc: 1.000\n",
      "test loss: 0.7299536, test acc: 1.000\n",
      "poison loss: 1.3646728, poison acc: 0.000\n",
      "elapsed time: 30.116, time for reg: 5.797, time for eig: 10.762\n",
      "epoch:   439, loss: 0.7243445, train acc: 1.000\n",
      "test loss: 0.7303937, test acc: 1.000\n",
      "poison loss: 1.3641090, poison acc: 0.000\n",
      "elapsed time: 30.760, time for reg: 5.928, time for eig: 10.970\n",
      "epoch:   449, loss: 0.7268222, train acc: 1.000\n",
      "test loss: 0.7302645, test acc: 1.000\n",
      "poison loss: 1.3640699, poison acc: 0.000\n",
      "elapsed time: 31.498, time for reg: 6.060, time for eig: 11.269\n",
      "epoch:   459, loss: 0.7244613, train acc: 1.000\n",
      "test loss: 0.7285456, test acc: 1.000\n",
      "poison loss: 1.3657029, poison acc: 0.000\n",
      "elapsed time: 32.170, time for reg: 6.191, time for eig: 11.508\n",
      "epoch:   469, loss: 0.7244727, train acc: 1.000\n",
      "test loss: 0.7295849, test acc: 1.000\n",
      "poison loss: 1.3645877, poison acc: 0.000\n",
      "elapsed time: 32.813, time for reg: 6.322, time for eig: 11.717\n",
      "epoch:   479, loss: 0.7275886, train acc: 1.000\n",
      "test loss: 0.7293058, test acc: 1.000\n",
      "poison loss: 1.3648035, poison acc: 0.000\n",
      "elapsed time: 33.444, time for reg: 6.452, time for eig: 11.911\n",
      "epoch:   489, loss: 0.7220953, train acc: 1.000\n",
      "test loss: 0.7279212, test acc: 1.000\n",
      "poison loss: 1.3659931, poison acc: 0.000\n",
      "elapsed time: 34.040, time for reg: 6.583, time for eig: 12.072\n",
      "epoch:   499, loss: 0.7203518, train acc: 1.000\n",
      "test loss: 0.7278147, test acc: 1.000\n",
      "poison loss: 1.3659788, poison acc: 0.000\n",
      "elapsed time: 34.739, time for reg: 6.728, time for eig: 12.295\n",
      "epoch:   509, loss: 0.7215297, train acc: 1.000\n",
      "test loss: 0.7283064, test acc: 1.000\n",
      "poison loss: 1.3653849, poison acc: 0.000\n",
      "elapsed time: 35.429, time for reg: 6.859, time for eig: 12.549\n",
      "epoch:   519, loss: 0.7241987, train acc: 1.000\n",
      "test loss: 0.7274452, test acc: 1.000\n",
      "poison loss: 1.3661628, poison acc: 0.000\n",
      "elapsed time: 36.061, time for reg: 6.989, time for eig: 12.746\n",
      "epoch:   529, loss: 0.7229262, train acc: 1.000\n",
      "test loss: 0.7291627, test acc: 1.000\n",
      "poison loss: 1.3643081, poison acc: 0.000\n",
      "elapsed time: 36.699, time for reg: 7.120, time for eig: 12.949\n",
      "epoch:   539, loss: 0.7228508, train acc: 1.000\n",
      "test loss: 0.7274970, test acc: 1.000\n",
      "poison loss: 1.3658924, poison acc: 0.000\n",
      "elapsed time: 37.293, time for reg: 7.251, time for eig: 13.120\n",
      "epoch:   549, loss: 0.7203783, train acc: 1.000\n",
      "test loss: 0.7275419, test acc: 1.000\n",
      "poison loss: 1.3657393, poison acc: 0.000\n",
      "elapsed time: 37.906, time for reg: 7.381, time for eig: 13.299\n",
      "epoch:   559, loss: 0.7210406, train acc: 1.000\n",
      "test loss: 0.7268113, test acc: 1.000\n",
      "poison loss: 1.3662945, poison acc: 0.000\n",
      "elapsed time: 38.534, time for reg: 7.512, time for eig: 13.491\n",
      "epoch:   569, loss: 0.7210232, train acc: 1.000\n",
      "test loss: 0.7264624, test acc: 1.000\n",
      "poison loss: 1.3665260, poison acc: 0.000\n",
      "elapsed time: 39.155, time for reg: 7.642, time for eig: 13.683\n",
      "epoch:   579, loss: 0.7245407, train acc: 1.000\n",
      "test loss: 0.7274701, test acc: 1.000\n",
      "poison loss: 1.3654397, poison acc: 0.000\n",
      "elapsed time: 39.873, time for reg: 7.772, time for eig: 13.969\n",
      "epoch:   589, loss: 0.7262141, train acc: 1.000\n",
      "test loss: 0.7281036, test acc: 1.000\n",
      "poison loss: 1.3646336, poison acc: 0.000\n",
      "elapsed time: 40.497, time for reg: 7.902, time for eig: 14.161\n",
      "epoch:   599, loss: 0.7209352, train acc: 1.000\n",
      "test loss: 0.7265466, test acc: 1.000\n",
      "poison loss: 1.3660541, poison acc: 0.000\n",
      "elapsed time: 41.101, time for reg: 8.033, time for eig: 14.335\n",
      "epoch:   609, loss: 0.7212539, train acc: 1.000\n",
      "test loss: 0.7261493, test acc: 1.000\n",
      "poison loss: 1.3663186, poison acc: 0.000\n",
      "elapsed time: 41.805, time for reg: 8.164, time for eig: 14.606\n",
      "epoch:   619, loss: 0.7183469, train acc: 1.000\n",
      "test loss: 0.7255084, test acc: 1.000\n",
      "poison loss: 1.3668786, poison acc: 0.000\n",
      "elapsed time: 42.453, time for reg: 8.294, time for eig: 14.827\n",
      "epoch:   629, loss: 0.7208342, train acc: 1.000\n",
      "test loss: 0.7266586, test acc: 1.000\n",
      "poison loss: 1.3655380, poison acc: 0.000\n",
      "elapsed time: 43.153, time for reg: 8.431, time for eig: 15.077\n",
      "epoch:   639, loss: 0.7240291, train acc: 1.000\n",
      "test loss: 0.7263452, test acc: 1.000\n",
      "poison loss: 1.3657237, poison acc: 0.000\n",
      "elapsed time: 43.809, time for reg: 8.566, time for eig: 15.291\n",
      "epoch:   649, loss: 0.7228206, train acc: 1.000\n",
      "test loss: 0.7257144, test acc: 1.000\n",
      "poison loss: 1.3662448, poison acc: 0.000\n",
      "elapsed time: 44.456, time for reg: 8.696, time for eig: 15.505\n",
      "epoch:   659, loss: 0.7211244, train acc: 1.000\n",
      "test loss: 0.7262188, test acc: 1.000\n",
      "poison loss: 1.3656309, poison acc: 0.000\n",
      "elapsed time: 45.073, time for reg: 8.826, time for eig: 15.687\n",
      "epoch:   669, loss: 0.7210175, train acc: 1.000\n",
      "test loss: 0.7252415, test acc: 1.000\n",
      "poison loss: 1.3664270, poison acc: 0.000\n",
      "elapsed time: 45.746, time for reg: 8.957, time for eig: 15.924\n",
      "epoch:   679, loss: 0.7225061, train acc: 1.000\n",
      "test loss: 0.7262589, test acc: 1.000\n",
      "poison loss: 1.3653365, poison acc: 0.000\n",
      "elapsed time: 46.437, time for reg: 9.088, time for eig: 16.186\n",
      "epoch:   689, loss: 0.7220620, train acc: 1.000\n",
      "test loss: 0.7253036, test acc: 1.000\n",
      "poison loss: 1.3660331, poison acc: 0.000\n",
      "elapsed time: 47.039, time for reg: 9.219, time for eig: 16.353\n",
      "epoch:   699, loss: 0.7203472, train acc: 1.000\n",
      "test loss: 0.7251329, test acc: 1.000\n",
      "poison loss: 1.3660951, poison acc: 0.000\n",
      "elapsed time: 47.662, time for reg: 9.349, time for eig: 16.541\n",
      "epoch:   709, loss: 0.7179508, train acc: 1.000\n",
      "test loss: 0.7241390, test acc: 1.000\n",
      "poison loss: 1.3669357, poison acc: 0.000\n",
      "elapsed time: 48.452, time for reg: 9.479, time for eig: 16.894\n",
      "epoch:   719, loss: 0.7197854, train acc: 1.000\n",
      "test loss: 0.7243510, test acc: 1.000\n",
      "poison loss: 1.3665772, poison acc: 0.000\n",
      "elapsed time: 49.088, time for reg: 9.609, time for eig: 17.094\n",
      "epoch:   729, loss: 0.7187618, train acc: 1.000\n",
      "test loss: 0.7238091, test acc: 1.000\n",
      "poison loss: 1.3669316, poison acc: 0.000\n",
      "elapsed time: 49.744, time for reg: 9.740, time for eig: 17.313\n",
      "epoch:   739, loss: 0.7201102, train acc: 1.000\n",
      "test loss: 0.7246625, test acc: 1.000\n",
      "poison loss: 1.3660750, poison acc: 0.000\n",
      "elapsed time: 50.382, time for reg: 9.871, time for eig: 17.514\n",
      "epoch:   749, loss: 0.7213672, train acc: 1.000\n",
      "test loss: 0.7238756, test acc: 1.000\n",
      "poison loss: 1.3665202, poison acc: 0.000\n",
      "elapsed time: 51.068, time for reg: 10.001, time for eig: 17.761\n",
      "epoch:   759, loss: 0.7192784, train acc: 1.000\n",
      "test loss: 0.7244472, test acc: 1.000\n",
      "poison loss: 1.3657817, poison acc: 0.000\n",
      "elapsed time: 51.696, time for reg: 10.131, time for eig: 17.953\n",
      "epoch:   769, loss: 0.7195906, train acc: 1.000\n",
      "test loss: 0.7235554, test acc: 1.000\n",
      "poison loss: 1.3665163, poison acc: 0.000\n",
      "elapsed time: 52.341, time for reg: 10.263, time for eig: 18.158\n",
      "epoch:   779, loss: 0.7182512, train acc: 1.000\n",
      "test loss: 0.7244200, test acc: 1.000\n",
      "poison loss: 1.3654749, poison acc: 0.000\n",
      "elapsed time: 53.008, time for reg: 10.393, time for eig: 18.390\n",
      "epoch:   789, loss: 0.7176230, train acc: 1.000\n",
      "test loss: 0.7248027, test acc: 1.000\n",
      "poison loss: 1.3649645, poison acc: 0.000\n",
      "elapsed time: 53.661, time for reg: 10.526, time for eig: 18.599\n",
      "epoch:   799, loss: 0.7193987, train acc: 1.000\n",
      "test loss: 0.7221236, test acc: 1.000\n",
      "poison loss: 1.3673480, poison acc: 0.000\n",
      "elapsed time: 54.325, time for reg: 10.658, time for eig: 18.820\n",
      "epoch:   809, loss: 0.7195992, train acc: 1.000\n",
      "test loss: 0.7222809, test acc: 1.000\n",
      "poison loss: 1.3670124, poison acc: 0.000\n",
      "elapsed time: 54.955, time for reg: 10.791, time for eig: 19.006\n",
      "epoch:   819, loss: 0.7176337, train acc: 1.000\n",
      "test loss: 0.7217064, test acc: 1.000\n",
      "poison loss: 1.3674190, poison acc: 0.000\n",
      "elapsed time: 55.648, time for reg: 10.923, time for eig: 19.252\n",
      "epoch:   829, loss: 0.7198911, train acc: 1.000\n",
      "test loss: 0.7205290, test acc: 1.000\n",
      "poison loss: 1.3683262, poison acc: 0.000\n",
      "elapsed time: 56.428, time for reg: 11.077, time for eig: 19.531\n",
      "epoch:   839, loss: 0.7159785, train acc: 1.000\n",
      "test loss: 0.7217322, test acc: 1.000\n",
      "poison loss: 1.3668874, poison acc: 0.000\n",
      "elapsed time: 57.088, time for reg: 11.208, time for eig: 19.753\n",
      "epoch:   849, loss: 0.7159720, train acc: 1.000\n",
      "test loss: 0.7209246, test acc: 1.000\n",
      "poison loss: 1.3675153, poison acc: 0.000\n",
      "elapsed time: 57.780, time for reg: 11.340, time for eig: 19.992\n",
      "epoch:   859, loss: 0.7171907, train acc: 1.000\n",
      "test loss: 0.7217455, test acc: 1.000\n",
      "poison loss: 1.3664215, poison acc: 0.000\n",
      "elapsed time: 58.421, time for reg: 11.482, time for eig: 20.174\n",
      "epoch:   869, loss: 0.7166197, train acc: 1.000\n",
      "test loss: 0.7222770, test acc: 1.000\n",
      "poison loss: 1.3656854, poison acc: 0.000\n",
      "elapsed time: 59.025, time for reg: 11.611, time for eig: 20.344\n",
      "epoch:   879, loss: 0.7175867, train acc: 1.000\n",
      "test loss: 0.7222194, test acc: 1.000\n",
      "poison loss: 1.3654932, poison acc: 0.000\n",
      "elapsed time: 59.697, time for reg: 11.741, time for eig: 20.586\n",
      "epoch:   889, loss: 0.7190877, train acc: 1.000\n",
      "test loss: 0.7218338, test acc: 1.000\n",
      "poison loss: 1.3656771, poison acc: 0.000\n",
      "elapsed time: 60.369, time for reg: 11.871, time for eig: 20.824\n",
      "epoch:   899, loss: 0.7179637, train acc: 1.000\n",
      "test loss: 0.7202262, test acc: 1.000\n",
      "poison loss: 1.3668672, poison acc: 0.000\n",
      "elapsed time: 61.019, time for reg: 12.000, time for eig: 21.040\n",
      "epoch:   909, loss: 0.7180117, train acc: 1.000\n",
      "test loss: 0.7199050, test acc: 1.000\n",
      "poison loss: 1.3669148, poison acc: 0.000\n",
      "elapsed time: 61.679, time for reg: 12.131, time for eig: 21.271\n",
      "epoch:   919, loss: 0.7119170, train acc: 1.000\n",
      "test loss: 0.7202190, test acc: 1.000\n",
      "poison loss: 1.3663477, poison acc: 0.000\n",
      "elapsed time: 62.380, time for reg: 12.261, time for eig: 21.540\n",
      "epoch:   929, loss: 0.7179486, train acc: 1.000\n",
      "test loss: 0.7199255, test acc: 1.000\n",
      "poison loss: 1.3662723, poison acc: 0.000\n",
      "elapsed time: 63.055, time for reg: 12.391, time for eig: 21.790\n",
      "epoch:   939, loss: 0.7137551, train acc: 1.000\n",
      "test loss: 0.7200349, test acc: 1.000\n",
      "poison loss: 1.3657892, poison acc: 0.000\n",
      "elapsed time: 63.656, time for reg: 12.521, time for eig: 21.956\n",
      "epoch:   949, loss: 0.7156112, train acc: 1.000\n",
      "test loss: 0.7194812, test acc: 1.000\n",
      "poison loss: 1.3660500, poison acc: 0.000\n",
      "elapsed time: 64.237, time for reg: 12.652, time for eig: 22.114\n",
      "epoch:   959, loss: 0.7160788, train acc: 1.000\n",
      "test loss: 0.7195607, test acc: 1.000\n",
      "poison loss: 1.3656301, poison acc: 0.000\n",
      "elapsed time: 64.866, time for reg: 12.781, time for eig: 22.311\n",
      "epoch:   969, loss: 0.7155580, train acc: 1.000\n",
      "test loss: 0.7197154, test acc: 1.000\n",
      "poison loss: 1.3649474, poison acc: 0.000\n",
      "elapsed time: 65.479, time for reg: 12.912, time for eig: 22.493\n",
      "epoch:   979, loss: 0.7145173, train acc: 1.000\n",
      "test loss: 0.7191686, test acc: 1.000\n",
      "poison loss: 1.3650871, poison acc: 0.000\n",
      "elapsed time: 66.110, time for reg: 13.042, time for eig: 22.688\n",
      "epoch:   989, loss: 0.7170522, train acc: 1.000\n",
      "test loss: 0.7176312, test acc: 1.000\n",
      "poison loss: 1.3661766, poison acc: 0.000\n",
      "elapsed time: 66.744, time for reg: 13.172, time for eig: 22.890\n",
      "epoch:   999, loss: 0.7135641, train acc: 1.000\n",
      "test loss: 0.7185474, test acc: 1.000\n",
      "poison loss: 1.3647600, poison acc: 0.000\n",
      "elapsed time: 67.424, time for reg: 13.308, time for eig: 23.127\n",
      "epoch:  1009, loss: 0.7182708, train acc: 1.000\n",
      "test loss: 0.7177269, test acc: 1.000\n",
      "poison loss: 1.3651763, poison acc: 0.000\n",
      "elapsed time: 68.165, time for reg: 13.443, time for eig: 23.426\n",
      "epoch:  1019, loss: 0.7148181, train acc: 1.000\n",
      "test loss: 0.7170441, test acc: 1.000\n",
      "poison loss: 1.3653467, poison acc: 0.000\n",
      "elapsed time: 68.793, time for reg: 13.576, time for eig: 23.615\n",
      "epoch:  1029, loss: 0.7103073, train acc: 1.000\n",
      "test loss: 0.7153177, test acc: 1.000\n",
      "poison loss: 1.3665426, poison acc: 0.000\n",
      "elapsed time: 69.436, time for reg: 13.705, time for eig: 23.829\n",
      "epoch:  1039, loss: 0.7116556, train acc: 1.000\n",
      "test loss: 0.7171180, test acc: 1.000\n",
      "poison loss: 1.3641008, poison acc: 0.000\n",
      "elapsed time: 70.078, time for reg: 13.837, time for eig: 24.039\n",
      "epoch:  1049, loss: 0.7194929, train acc: 1.000\n",
      "test loss: 0.7149965, test acc: 1.000\n",
      "poison loss: 1.3656387, poison acc: 0.000\n",
      "elapsed time: 70.696, time for reg: 13.966, time for eig: 24.227\n",
      "epoch:  1059, loss: 0.7089647, train acc: 1.000\n",
      "test loss: 0.7186212, test acc: 1.000\n",
      "poison loss: 1.3613746, poison acc: 0.000\n",
      "elapsed time: 71.341, time for reg: 14.096, time for eig: 24.439\n",
      "epoch:  1069, loss: 0.7155169, train acc: 1.000\n",
      "test loss: 0.7156308, test acc: 1.000\n",
      "poison loss: 1.3643289, poison acc: 0.000\n",
      "elapsed time: 71.973, time for reg: 14.226, time for eig: 24.638\n",
      "epoch:  1079, loss: 0.7097632, train acc: 1.000\n",
      "test loss: 0.7173411, test acc: 1.000\n",
      "poison loss: 1.3614105, poison acc: 0.000\n",
      "elapsed time: 72.618, time for reg: 14.356, time for eig: 24.846\n",
      "epoch:  1089, loss: 0.7114201, train acc: 1.000\n",
      "test loss: 0.7175720, test acc: 1.000\n",
      "poison loss: 1.3600571, poison acc: 0.000\n",
      "elapsed time: 73.222, time for reg: 14.486, time for eig: 25.016\n",
      "epoch:  1099, loss: 0.7131362, train acc: 1.000\n",
      "test loss: 0.7137974, test acc: 1.000\n",
      "poison loss: 1.3629665, poison acc: 0.000\n",
      "elapsed time: 73.820, time for reg: 14.616, time for eig: 25.179\n",
      "epoch:  1109, loss: 0.7147008, train acc: 1.000\n",
      "test loss: 0.7162255, test acc: 1.000\n",
      "poison loss: 1.3595725, poison acc: 0.000\n",
      "elapsed time: 74.449, time for reg: 14.746, time for eig: 25.375\n",
      "epoch:  1119, loss: 0.7140508, train acc: 1.000\n",
      "test loss: 0.7130659, test acc: 1.000\n",
      "poison loss: 1.3624210, poison acc: 0.000\n",
      "elapsed time: 75.112, time for reg: 14.877, time for eig: 25.602\n",
      "epoch:  1129, loss: 0.7117850, train acc: 1.000\n",
      "test loss: 0.7097866, test acc: 1.000\n",
      "poison loss: 1.3645225, poison acc: 0.000\n",
      "elapsed time: 75.734, time for reg: 15.007, time for eig: 25.797\n",
      "epoch:  1139, loss: 0.7044576, train acc: 1.000\n",
      "test loss: 0.7158485, test acc: 1.000\n",
      "poison loss: 1.3578623, poison acc: 0.000\n",
      "elapsed time: 76.384, time for reg: 15.138, time for eig: 26.014\n",
      "epoch:  1149, loss: 0.7029526, train acc: 1.000\n",
      "test loss: 0.7174729, test acc: 1.000\n",
      "poison loss: 1.3546465, poison acc: 0.000\n",
      "elapsed time: 77.009, time for reg: 15.267, time for eig: 26.202\n",
      "epoch:  1159, loss: 0.7043673, train acc: 1.000\n",
      "test loss: 0.7142412, test acc: 1.000\n",
      "poison loss: 1.3565397, poison acc: 0.000\n",
      "elapsed time: 77.640, time for reg: 15.397, time for eig: 26.398\n",
      "epoch:  1169, loss: 0.7075902, train acc: 1.000\n",
      "test loss: 0.7149141, test acc: 1.000\n",
      "poison loss: 1.3566169, poison acc: 0.000\n",
      "elapsed time: 78.248, time for reg: 15.527, time for eig: 26.574\n",
      "epoch:  1179, loss: 0.7190536, train acc: 1.000\n",
      "test loss: 0.7104767, test acc: 1.000\n",
      "poison loss: 1.3573908, poison acc: 0.000\n",
      "elapsed time: 78.885, time for reg: 15.657, time for eig: 26.773\n",
      "epoch:  1189, loss: 0.7236160, train acc: 1.000\n",
      "test loss: 0.7085870, test acc: 1.000\n",
      "poison loss: 1.3658420, poison acc: 0.000\n",
      "elapsed time: 79.509, time for reg: 15.786, time for eig: 26.962\n",
      "epoch:  1199, loss: 0.7084879, train acc: 1.000\n",
      "test loss: 0.7093908, test acc: 1.000\n",
      "poison loss: 1.3562996, poison acc: 0.000\n",
      "elapsed time: 80.129, time for reg: 15.916, time for eig: 27.148\n",
      "epoch:  1209, loss: 0.6976052, train acc: 1.000\n",
      "test loss: 0.7114600, test acc: 1.000\n",
      "poison loss: 1.3524558, poison acc: 0.000\n",
      "elapsed time: 80.762, time for reg: 16.046, time for eig: 27.345\n",
      "epoch:  1219, loss: 0.7035178, train acc: 1.000\n",
      "test loss: 0.7061117, test acc: 1.000\n",
      "poison loss: 1.3558990, poison acc: 0.000\n",
      "elapsed time: 81.392, time for reg: 16.177, time for eig: 27.538\n",
      "epoch:  1229, loss: 0.7055915, train acc: 1.000\n",
      "test loss: 0.7125331, test acc: 1.000\n",
      "poison loss: 1.3511970, poison acc: 0.000\n",
      "elapsed time: 81.987, time for reg: 16.307, time for eig: 27.705\n",
      "epoch:  1239, loss: 0.6928152, train acc: 1.000\n",
      "test loss: 0.7141145, test acc: 1.000\n",
      "poison loss: 1.3480603, poison acc: 0.000\n",
      "elapsed time: 82.616, time for reg: 16.437, time for eig: 27.901\n",
      "epoch:  1249, loss: 0.7129639, train acc: 1.000\n",
      "test loss: 0.7075011, test acc: 1.000\n",
      "poison loss: 1.3493699, poison acc: 0.000\n",
      "elapsed time: 83.262, time for reg: 16.567, time for eig: 28.112\n",
      "epoch:  1259, loss: 0.7130810, train acc: 1.000\n",
      "test loss: 0.7080446, test acc: 1.000\n",
      "poison loss: 1.3516208, poison acc: 0.000\n",
      "elapsed time: 83.848, time for reg: 16.697, time for eig: 28.266\n",
      "epoch:  1269, loss: 0.7032802, train acc: 1.000\n",
      "test loss: 0.7089206, test acc: 1.000\n",
      "poison loss: 1.3446864, poison acc: 0.000\n",
      "elapsed time: 84.431, time for reg: 16.827, time for eig: 28.419\n",
      "epoch:  1279, loss: 0.6934740, train acc: 1.000\n",
      "test loss: 0.7127643, test acc: 1.000\n",
      "poison loss: 1.3384778, poison acc: 0.000\n",
      "elapsed time: 85.051, time for reg: 16.959, time for eig: 28.600\n",
      "epoch:  1289, loss: 0.6932126, train acc: 1.000\n",
      "test loss: 0.7046256, test acc: 1.000\n",
      "poison loss: 1.3456056, poison acc: 0.000\n",
      "elapsed time: 85.674, time for reg: 17.097, time for eig: 28.769\n",
      "epoch:  1299, loss: 0.6978788, train acc: 1.000\n",
      "test loss: 0.7119567, test acc: 1.000\n",
      "poison loss: 1.3398339, poison acc: 0.000\n",
      "elapsed time: 86.270, time for reg: 17.229, time for eig: 28.928\n",
      "epoch:  1309, loss: 0.7010468, train acc: 1.000\n",
      "test loss: 0.6936315, test acc: 1.000\n",
      "poison loss: 1.3536816, poison acc: 0.000\n",
      "elapsed time: 86.912, time for reg: 17.360, time for eig: 29.139\n",
      "epoch:  1319, loss: 0.6981862, train acc: 1.000\n",
      "test loss: 0.7004971, test acc: 1.000\n",
      "poison loss: 1.3436171, poison acc: 0.000\n",
      "elapsed time: 87.524, time for reg: 17.493, time for eig: 29.313\n",
      "epoch:  1329, loss: 0.7233378, train acc: 1.000\n",
      "test loss: 0.6865210, test acc: 1.000\n",
      "poison loss: 1.3553281, poison acc: 0.000\n",
      "elapsed time: 88.095, time for reg: 17.624, time for eig: 29.446\n",
      "epoch:  1339, loss: 0.6895035, train acc: 1.000\n",
      "test loss: 0.7064709, test acc: 1.000\n",
      "poison loss: 1.3346141, poison acc: 0.000\n",
      "elapsed time: 88.677, time for reg: 17.755, time for eig: 29.591\n",
      "epoch:  1349, loss: 0.6980981, train acc: 1.000\n",
      "test loss: 0.7003717, test acc: 1.000\n",
      "poison loss: 1.3375037, poison acc: 0.000\n",
      "elapsed time: 89.261, time for reg: 17.886, time for eig: 29.737\n",
      "epoch:  1359, loss: 0.7209701, train acc: 0.933\n",
      "test loss: 0.7108397, test acc: 0.967\n",
      "poison loss: 1.3620173, poison acc: 0.067\n",
      "elapsed time: 89.836, time for reg: 18.017, time for eig: 29.878\n",
      "epoch:  1369, loss: 0.6895424, train acc: 1.000\n",
      "test loss: 0.7027972, test acc: 1.000\n",
      "poison loss: 1.3299869, poison acc: 0.000\n",
      "elapsed time: 90.418, time for reg: 18.148, time for eig: 30.024\n",
      "epoch:  1379, loss: 0.6885855, train acc: 0.967\n",
      "test loss: 0.7069862, test acc: 1.000\n",
      "poison loss: 1.3248631, poison acc: 0.000\n",
      "elapsed time: 91.031, time for reg: 18.280, time for eig: 30.195\n",
      "epoch:  1389, loss: 0.7153578, train acc: 1.000\n",
      "test loss: 0.6746507, test acc: 1.000\n",
      "poison loss: 1.3577299, poison acc: 0.017\n",
      "elapsed time: 91.708, time for reg: 18.411, time for eig: 30.432\n",
      "epoch:  1399, loss: 0.7429161, train acc: 0.883\n",
      "test loss: 0.7121928, test acc: 0.950\n",
      "poison loss: 1.3531663, poison acc: 0.083\n",
      "elapsed time: 92.327, time for reg: 18.542, time for eig: 30.613\n",
      "epoch:  1409, loss: 0.7020181, train acc: 0.967\n",
      "test loss: 0.7216780, test acc: 0.967\n",
      "poison loss: 1.3189983, poison acc: 0.050\n",
      "elapsed time: 92.917, time for reg: 18.673, time for eig: 30.773\n",
      "epoch:  1419, loss: 0.6898742, train acc: 0.983\n",
      "test loss: 0.7035799, test acc: 1.000\n",
      "poison loss: 1.3203070, poison acc: 0.017\n",
      "elapsed time: 93.534, time for reg: 18.804, time for eig: 30.955\n",
      "epoch:  1429, loss: 0.7425419, train acc: 0.883\n",
      "test loss: 0.7076684, test acc: 0.950\n",
      "poison loss: 1.3638656, poison acc: 0.083\n",
      "elapsed time: 94.106, time for reg: 18.935, time for eig: 31.089\n",
      "epoch:  1439, loss: 0.6945795, train acc: 0.983\n",
      "test loss: 0.6905487, test acc: 1.000\n",
      "poison loss: 1.3305469, poison acc: 0.017\n",
      "elapsed time: 94.722, time for reg: 19.066, time for eig: 31.268\n",
      "epoch:  1449, loss: 0.6993777, train acc: 0.950\n",
      "test loss: 0.6739052, test acc: 1.000\n",
      "poison loss: 1.3496277, poison acc: 0.000\n",
      "elapsed time: 95.354, time for reg: 19.197, time for eig: 31.464\n",
      "epoch:  1459, loss: 0.7050020, train acc: 0.933\n",
      "test loss: 0.6960796, test acc: 0.900\n",
      "poison loss: 1.3333794, poison acc: 0.100\n",
      "elapsed time: 95.964, time for reg: 19.328, time for eig: 31.635\n",
      "epoch:  1469, loss: 0.6994275, train acc: 0.950\n",
      "test loss: 0.6769005, test acc: 1.000\n",
      "poison loss: 1.3396413, poison acc: 0.017\n",
      "elapsed time: 96.566, time for reg: 19.459, time for eig: 31.796\n",
      "epoch:  1479, loss: 0.6857571, train acc: 0.983\n",
      "test loss: 0.6975870, test acc: 0.900\n",
      "poison loss: 1.3243059, poison acc: 0.100\n",
      "elapsed time: 97.146, time for reg: 19.590, time for eig: 31.942\n",
      "epoch:  1489, loss: 0.7037097, train acc: 0.950\n",
      "test loss: 0.6832080, test acc: 1.000\n",
      "poison loss: 1.3266098, poison acc: 0.017\n",
      "elapsed time: 97.774, time for reg: 19.721, time for eig: 32.136\n",
      "epoch:  1499, loss: 0.7075143, train acc: 0.950\n",
      "test loss: 0.6818578, test acc: 1.000\n",
      "poison loss: 1.3265116, poison acc: 0.033\n",
      "elapsed time: 98.381, time for reg: 19.853, time for eig: 32.307\n",
      "epoch:  1509, loss: 0.6824995, train acc: 0.950\n",
      "test loss: 0.7079841, test acc: 0.983\n",
      "poison loss: 1.2993750, poison acc: 0.067\n",
      "elapsed time: 98.972, time for reg: 19.983, time for eig: 32.468\n",
      "epoch:  1519, loss: 0.6858948, train acc: 0.967\n",
      "test loss: 0.6918165, test acc: 0.983\n",
      "poison loss: 1.3143616, poison acc: 0.100\n",
      "elapsed time: 99.567, time for reg: 20.114, time for eig: 32.624\n",
      "epoch:  1529, loss: 0.6880344, train acc: 0.950\n",
      "test loss: 0.6950493, test acc: 0.983\n",
      "poison loss: 1.3112440, poison acc: 0.067\n",
      "elapsed time: 100.134, time for reg: 20.246, time for eig: 32.751\n",
      "epoch:  1539, loss: 0.7027257, train acc: 0.900\n",
      "test loss: 0.6994959, test acc: 0.967\n",
      "poison loss: 1.3095129, poison acc: 0.100\n",
      "elapsed time: 100.719, time for reg: 20.377, time for eig: 32.898\n",
      "epoch:  1549, loss: 0.7433061, train acc: 0.817\n",
      "test loss: 0.6972323, test acc: 0.867\n",
      "poison loss: 1.3372545, poison acc: 0.100\n",
      "elapsed time: 101.301, time for reg: 20.507, time for eig: 33.042\n",
      "epoch:  1559, loss: 0.6989083, train acc: 0.967\n",
      "test loss: 0.6927610, test acc: 0.983\n",
      "poison loss: 1.3064460, poison acc: 0.050\n",
      "elapsed time: 101.936, time for reg: 20.638, time for eig: 33.239\n",
      "epoch:  1569, loss: 0.7327857, train acc: 0.883\n",
      "test loss: 0.6945020, test acc: 0.817\n",
      "poison loss: 1.3494046, poison acc: 0.117\n",
      "elapsed time: 102.535, time for reg: 20.768, time for eig: 33.403\n",
      "epoch:  1579, loss: 0.7211001, train acc: 0.900\n",
      "test loss: 0.6772958, test acc: 0.983\n",
      "poison loss: 1.3272753, poison acc: 0.067\n",
      "elapsed time: 103.130, time for reg: 20.899, time for eig: 33.559\n",
      "epoch:  1589, loss: 0.6773779, train acc: 0.950\n",
      "test loss: 0.7052913, test acc: 0.950\n",
      "poison loss: 1.2888808, poison acc: 0.100\n",
      "elapsed time: 103.723, time for reg: 21.030, time for eig: 33.714\n",
      "epoch:  1599, loss: 0.6952351, train acc: 0.967\n",
      "test loss: 0.6904196, test acc: 0.983\n",
      "poison loss: 1.3037024, poison acc: 0.050\n",
      "elapsed time: 104.314, time for reg: 21.161, time for eig: 33.869\n",
      "epoch:  1609, loss: 0.6864562, train acc: 0.950\n",
      "test loss: 0.6953109, test acc: 0.983\n",
      "poison loss: 1.2982703, poison acc: 0.050\n",
      "elapsed time: 104.909, time for reg: 21.291, time for eig: 34.025\n",
      "epoch:  1619, loss: 0.6911353, train acc: 0.900\n",
      "test loss: 0.6749572, test acc: 0.983\n",
      "poison loss: 1.3216717, poison acc: 0.050\n",
      "elapsed time: 105.497, time for reg: 21.422, time for eig: 34.174\n",
      "epoch:  1629, loss: 0.7250977, train acc: 0.933\n",
      "test loss: 0.6622856, test acc: 0.967\n",
      "poison loss: 1.3271792, poison acc: 0.100\n",
      "elapsed time: 106.126, time for reg: 21.552, time for eig: 34.364\n",
      "epoch:  1639, loss: 0.7199520, train acc: 0.900\n",
      "test loss: 0.6638550, test acc: 1.000\n",
      "poison loss: 1.3199134, poison acc: 0.067\n",
      "elapsed time: 106.718, time for reg: 21.683, time for eig: 34.520\n",
      "epoch:  1649, loss: 0.6763837, train acc: 0.950\n",
      "test loss: 0.6761894, test acc: 1.000\n",
      "poison loss: 1.3026764, poison acc: 0.050\n",
      "elapsed time: 107.310, time for reg: 21.813, time for eig: 34.673\n",
      "epoch:  1659, loss: 0.6514342, train acc: 0.983\n",
      "test loss: 0.7015711, test acc: 0.983\n",
      "poison loss: 1.2748497, poison acc: 0.083\n",
      "elapsed time: 107.928, time for reg: 21.944, time for eig: 34.853\n",
      "epoch:  1669, loss: 0.7012179, train acc: 0.933\n",
      "test loss: 0.6661522, test acc: 0.983\n",
      "poison loss: 1.3082265, poison acc: 0.050\n",
      "elapsed time: 108.574, time for reg: 22.075, time for eig: 35.060\n",
      "epoch:  1679, loss: 0.6912912, train acc: 0.967\n",
      "test loss: 0.6837075, test acc: 0.883\n",
      "poison loss: 1.2950031, poison acc: 0.100\n",
      "elapsed time: 109.201, time for reg: 22.205, time for eig: 35.249\n",
      "epoch:  1689, loss: 0.6795239, train acc: 0.933\n",
      "test loss: 0.6917987, test acc: 0.983\n",
      "poison loss: 1.2772154, poison acc: 0.083\n",
      "elapsed time: 109.834, time for reg: 22.336, time for eig: 35.445\n",
      "epoch:  1699, loss: 0.7245869, train acc: 0.950\n",
      "test loss: 0.6458600, test acc: 0.983\n",
      "poison loss: 1.3204161, poison acc: 0.083\n",
      "elapsed time: 110.431, time for reg: 22.466, time for eig: 35.605\n",
      "epoch:  1709, loss: 0.6816666, train acc: 0.950\n",
      "test loss: 0.6774298, test acc: 0.900\n",
      "poison loss: 1.2884760, poison acc: 0.100\n",
      "elapsed time: 111.026, time for reg: 22.597, time for eig: 35.758\n",
      "epoch:  1719, loss: 0.7235364, train acc: 0.917\n",
      "test loss: 0.6416838, test acc: 0.917\n",
      "poison loss: 1.3171050, poison acc: 0.100\n",
      "elapsed time: 111.609, time for reg: 22.728, time for eig: 35.903\n",
      "epoch:  1729, loss: 0.6936321, train acc: 0.933\n",
      "test loss: 0.6866648, test acc: 0.983\n",
      "poison loss: 1.2647521, poison acc: 0.067\n",
      "elapsed time: 112.261, time for reg: 22.859, time for eig: 36.116\n",
      "epoch:  1739, loss: 0.6812609, train acc: 0.950\n",
      "test loss: 0.6881247, test acc: 0.917\n",
      "poison loss: 1.2645713, poison acc: 0.100\n",
      "elapsed time: 112.853, time for reg: 22.990, time for eig: 36.267\n",
      "epoch:  1749, loss: 0.6740711, train acc: 0.933\n",
      "test loss: 0.6764812, test acc: 0.967\n",
      "poison loss: 1.2613026, poison acc: 0.133\n",
      "elapsed time: 113.445, time for reg: 23.121, time for eig: 36.420\n",
      "epoch:  1759, loss: 0.6758986, train acc: 0.900\n",
      "test loss: 0.6775661, test acc: 0.867\n",
      "poison loss: 1.2747765, poison acc: 0.167\n",
      "elapsed time: 114.061, time for reg: 23.251, time for eig: 36.598\n",
      "epoch:  1769, loss: 0.6571899, train acc: 0.950\n",
      "test loss: 0.7125874, test acc: 0.933\n",
      "poison loss: 1.2249926, poison acc: 0.150\n",
      "elapsed time: 114.688, time for reg: 23.383, time for eig: 36.788\n",
      "epoch:  1779, loss: 0.6425977, train acc: 0.967\n",
      "test loss: 0.7163805, test acc: 0.900\n",
      "poison loss: 1.2169172, poison acc: 0.200\n",
      "elapsed time: 115.330, time for reg: 23.513, time for eig: 36.999\n",
      "epoch:  1789, loss: 0.7055047, train acc: 0.883\n",
      "test loss: 0.7549571, test acc: 0.817\n",
      "poison loss: 1.1976305, poison acc: 0.233\n",
      "elapsed time: 115.913, time for reg: 23.643, time for eig: 37.152\n",
      "epoch:  1799, loss: 0.6619557, train acc: 0.967\n",
      "test loss: 0.6686745, test acc: 0.917\n",
      "poison loss: 1.2639611, poison acc: 0.217\n",
      "elapsed time: 116.605, time for reg: 23.774, time for eig: 37.410\n",
      "epoch:  1809, loss: 0.6959232, train acc: 0.900\n",
      "test loss: 0.6995471, test acc: 0.833\n",
      "poison loss: 1.2485141, poison acc: 0.200\n",
      "elapsed time: 117.199, time for reg: 23.904, time for eig: 37.567\n",
      "epoch:  1819, loss: 0.6854006, train acc: 0.900\n",
      "test loss: 0.6286243, test acc: 0.967\n",
      "poison loss: 1.2870420, poison acc: 0.117\n",
      "elapsed time: 117.819, time for reg: 24.035, time for eig: 37.750\n",
      "epoch:  1829, loss: 0.6792577, train acc: 0.883\n",
      "test loss: 0.6549056, test acc: 0.917\n",
      "poison loss: 1.2566850, poison acc: 0.217\n",
      "elapsed time: 118.437, time for reg: 24.165, time for eig: 37.929\n",
      "epoch:  1839, loss: 0.6992501, train acc: 0.883\n",
      "test loss: 0.7040269, test acc: 0.867\n",
      "poison loss: 1.2191932, poison acc: 0.217\n",
      "elapsed time: 119.043, time for reg: 24.296, time for eig: 38.097\n",
      "epoch:  1849, loss: 0.6970475, train acc: 0.883\n",
      "test loss: 0.6238742, test acc: 0.950\n",
      "poison loss: 1.2984930, poison acc: 0.133\n",
      "elapsed time: 119.675, time for reg: 24.427, time for eig: 38.291\n",
      "epoch:  1859, loss: 0.7316579, train acc: 0.750\n",
      "test loss: 0.6349645, test acc: 0.833\n",
      "poison loss: 1.3124944, poison acc: 0.250\n",
      "elapsed time: 120.349, time for reg: 24.558, time for eig: 38.526\n",
      "epoch:  1869, loss: 0.7127675, train acc: 0.817\n",
      "test loss: 0.5896992, test acc: 0.850\n",
      "poison loss: 1.3574819, poison acc: 0.217\n",
      "elapsed time: 121.042, time for reg: 24.688, time for eig: 38.778\n",
      "epoch:  1879, loss: 0.7128501, train acc: 0.867\n",
      "test loss: 0.6198581, test acc: 0.983\n",
      "poison loss: 1.2853528, poison acc: 0.133\n",
      "elapsed time: 121.686, time for reg: 24.819, time for eig: 38.985\n",
      "epoch:  1889, loss: 0.6998368, train acc: 0.850\n",
      "test loss: 0.5741876, test acc: 0.883\n",
      "poison loss: 1.3489904, poison acc: 0.200\n",
      "elapsed time: 122.382, time for reg: 24.950, time for eig: 39.244\n",
      "epoch:  1899, loss: 0.6769720, train acc: 0.950\n",
      "test loss: 0.6659689, test acc: 0.900\n",
      "poison loss: 1.2290313, poison acc: 0.233\n",
      "elapsed time: 123.068, time for reg: 25.081, time for eig: 39.492\n",
      "epoch:  1909, loss: 0.6797516, train acc: 0.917\n",
      "test loss: 0.6378789, test acc: 0.850\n",
      "poison loss: 1.2737652, poison acc: 0.183\n",
      "elapsed time: 123.676, time for reg: 25.212, time for eig: 39.661\n",
      "epoch:  1919, loss: 0.6764148, train acc: 0.883\n",
      "test loss: 0.6262145, test acc: 0.917\n",
      "poison loss: 1.2910125, poison acc: 0.233\n",
      "elapsed time: 124.269, time for reg: 25.343, time for eig: 39.812\n",
      "epoch:  1929, loss: 0.6484348, train acc: 0.900\n",
      "test loss: 0.6803983, test acc: 0.900\n",
      "poison loss: 1.2149209, poison acc: 0.200\n",
      "elapsed time: 124.891, time for reg: 25.474, time for eig: 39.996\n",
      "epoch:  1939, loss: 0.6550501, train acc: 0.900\n",
      "test loss: 0.7363010, test acc: 0.883\n",
      "poison loss: 1.1808146, poison acc: 0.183\n",
      "elapsed time: 125.476, time for reg: 25.605, time for eig: 40.142\n",
      "epoch:  1949, loss: 0.6625392, train acc: 0.883\n",
      "test loss: 0.6882815, test acc: 0.817\n",
      "poison loss: 1.2136342, poison acc: 0.233\n",
      "elapsed time: 126.073, time for reg: 25.735, time for eig: 40.299\n",
      "epoch:  1959, loss: 0.7309260, train acc: 0.817\n",
      "test loss: 0.6547854, test acc: 0.917\n",
      "poison loss: 1.2277267, poison acc: 0.183\n",
      "elapsed time: 126.721, time for reg: 25.866, time for eig: 40.509\n",
      "epoch:  1969, loss: 0.6533481, train acc: 0.917\n",
      "test loss: 0.6446174, test acc: 0.917\n",
      "poison loss: 1.2340824, poison acc: 0.217\n",
      "elapsed time: 127.334, time for reg: 25.996, time for eig: 40.683\n",
      "epoch:  1979, loss: 0.7421857, train acc: 0.733\n",
      "test loss: 0.6328742, test acc: 0.817\n",
      "poison loss: 1.3234989, poison acc: 0.283\n",
      "elapsed time: 127.957, time for reg: 26.126, time for eig: 40.869\n",
      "epoch:  1989, loss: 0.6832228, train acc: 0.867\n",
      "test loss: 0.6684060, test acc: 0.817\n",
      "poison loss: 1.2393824, poison acc: 0.267\n",
      "elapsed time: 128.607, time for reg: 26.257, time for eig: 41.081\n",
      "epoch:  1999, loss: 0.6228004, train acc: 0.933\n",
      "test loss: 0.6908819, test acc: 0.833\n",
      "poison loss: 1.1886416, poison acc: 0.283\n",
      "elapsed time: 129.250, time for reg: 26.389, time for eig: 41.281\n",
      "epoch:  2009, loss: 0.6473309, train acc: 0.883\n",
      "test loss: 0.6444873, test acc: 0.817\n",
      "poison loss: 1.2496551, poison acc: 0.300\n",
      "elapsed time: 129.854, time for reg: 26.520, time for eig: 41.449\n",
      "epoch:  2019, loss: 0.6377803, train acc: 0.867\n",
      "test loss: 0.7198727, test acc: 0.850\n",
      "poison loss: 1.1667348, poison acc: 0.267\n",
      "elapsed time: 130.455, time for reg: 26.651, time for eig: 41.613\n",
      "epoch:  2029, loss: 0.6635869, train acc: 0.900\n",
      "test loss: 0.6976645, test acc: 0.867\n",
      "poison loss: 1.1871542, poison acc: 0.233\n",
      "elapsed time: 131.039, time for reg: 26.781, time for eig: 41.760\n",
      "epoch:  2039, loss: 0.7143729, train acc: 0.800\n",
      "test loss: 0.6707207, test acc: 0.817\n",
      "poison loss: 1.2735257, poison acc: 0.233\n",
      "elapsed time: 131.608, time for reg: 26.913, time for eig: 41.891\n",
      "epoch:  2049, loss: 0.6522374, train acc: 0.900\n",
      "test loss: 0.7117704, test acc: 0.783\n",
      "poison loss: 1.2004334, poison acc: 0.283\n",
      "elapsed time: 132.182, time for reg: 27.043, time for eig: 42.029\n",
      "epoch:  2059, loss: 0.6985032, train acc: 0.850\n",
      "test loss: 0.6659306, test acc: 0.833\n",
      "poison loss: 1.2359029, poison acc: 0.283\n",
      "elapsed time: 132.759, time for reg: 27.174, time for eig: 42.168\n",
      "epoch:  2069, loss: 0.6291817, train acc: 0.917\n",
      "test loss: 0.7469224, test acc: 0.833\n",
      "poison loss: 1.1484056, poison acc: 0.267\n",
      "elapsed time: 133.338, time for reg: 27.305, time for eig: 42.309\n",
      "epoch:  2079, loss: 0.6341942, train acc: 0.917\n",
      "test loss: 0.6748113, test acc: 0.867\n",
      "poison loss: 1.1950151, poison acc: 0.250\n",
      "elapsed time: 133.926, time for reg: 27.436, time for eig: 42.460\n",
      "epoch:  2089, loss: 0.6697224, train acc: 0.900\n",
      "test loss: 0.6018867, test acc: 0.900\n",
      "poison loss: 1.2633562, poison acc: 0.267\n",
      "elapsed time: 134.509, time for reg: 27.567, time for eig: 42.606\n",
      "epoch:  2099, loss: 0.6413794, train acc: 0.883\n",
      "test loss: 0.6941660, test acc: 0.883\n",
      "poison loss: 1.1718981, poison acc: 0.283\n",
      "elapsed time: 135.160, time for reg: 27.698, time for eig: 42.821\n",
      "epoch:  2109, loss: 0.5941965, train acc: 0.917\n",
      "test loss: 0.6662990, test acc: 0.867\n",
      "poison loss: 1.1927704, poison acc: 0.283\n",
      "elapsed time: 135.762, time for reg: 27.829, time for eig: 42.985\n",
      "epoch:  2119, loss: 0.7231298, train acc: 0.783\n",
      "test loss: 0.6052040, test acc: 0.883\n",
      "poison loss: 1.2843379, poison acc: 0.217\n",
      "elapsed time: 136.345, time for reg: 27.959, time for eig: 43.133\n",
      "epoch:  2129, loss: 0.6952513, train acc: 0.833\n",
      "test loss: 0.5934060, test acc: 0.850\n",
      "poison loss: 1.2932773, poison acc: 0.250\n",
      "elapsed time: 136.948, time for reg: 28.090, time for eig: 43.302\n",
      "epoch:  2139, loss: 0.7033373, train acc: 0.750\n",
      "test loss: 0.5687287, test acc: 0.833\n",
      "poison loss: 1.3931001, poison acc: 0.300\n",
      "elapsed time: 137.538, time for reg: 28.221, time for eig: 43.456\n",
      "epoch:  2149, loss: 0.7153815, train acc: 0.883\n",
      "test loss: 0.6043789, test acc: 0.917\n",
      "poison loss: 1.2750514, poison acc: 0.217\n",
      "elapsed time: 138.096, time for reg: 28.351, time for eig: 43.580\n",
      "epoch:  2159, loss: 0.6288385, train acc: 0.850\n",
      "test loss: 0.6198973, test acc: 0.900\n",
      "poison loss: 1.2500357, poison acc: 0.233\n",
      "elapsed time: 138.716, time for reg: 28.482, time for eig: 43.763\n",
      "epoch:  2169, loss: 0.5832461, train acc: 0.933\n",
      "test loss: 0.6992130, test acc: 0.800\n",
      "poison loss: 1.1613212, poison acc: 0.300\n",
      "elapsed time: 139.336, time for reg: 28.614, time for eig: 43.946\n",
      "epoch:  2179, loss: 0.6437229, train acc: 0.883\n",
      "test loss: 0.6321218, test acc: 0.867\n",
      "poison loss: 1.2259955, poison acc: 0.250\n",
      "elapsed time: 139.973, time for reg: 28.744, time for eig: 44.148\n",
      "epoch:  2189, loss: 0.6607035, train acc: 0.883\n",
      "test loss: 0.6496939, test acc: 0.867\n",
      "poison loss: 1.2149658, poison acc: 0.283\n",
      "elapsed time: 140.602, time for reg: 28.875, time for eig: 44.341\n",
      "epoch:  2199, loss: 0.6554761, train acc: 0.850\n",
      "test loss: 0.6601390, test acc: 0.850\n",
      "poison loss: 1.2106145, poison acc: 0.267\n",
      "elapsed time: 141.173, time for reg: 29.007, time for eig: 44.475\n",
      "epoch:  2209, loss: 0.6195427, train acc: 0.900\n",
      "test loss: 0.7751924, test acc: 0.800\n",
      "poison loss: 1.1082889, poison acc: 0.333\n",
      "elapsed time: 141.763, time for reg: 29.138, time for eig: 44.626\n",
      "epoch:  2219, loss: 0.6158027, train acc: 0.850\n",
      "test loss: 0.7333931, test acc: 0.817\n",
      "poison loss: 1.1345348, poison acc: 0.333\n",
      "elapsed time: 142.341, time for reg: 29.268, time for eig: 44.766\n",
      "epoch:  2229, loss: 0.5980213, train acc: 0.950\n",
      "test loss: 0.7426573, test acc: 0.767\n",
      "poison loss: 1.1421502, poison acc: 0.317\n",
      "elapsed time: 142.944, time for reg: 29.400, time for eig: 44.930\n",
      "epoch:  2239, loss: 0.5987059, train acc: 0.933\n",
      "test loss: 0.6823956, test acc: 0.817\n",
      "poison loss: 1.1868479, poison acc: 0.267\n",
      "elapsed time: 143.565, time for reg: 29.531, time for eig: 45.114\n",
      "epoch:  2249, loss: 0.6513573, train acc: 0.900\n",
      "test loss: 0.6480945, test acc: 0.817\n",
      "poison loss: 1.2095157, poison acc: 0.317\n",
      "elapsed time: 144.163, time for reg: 29.662, time for eig: 45.273\n",
      "epoch:  2259, loss: 0.6022413, train acc: 0.917\n",
      "test loss: 0.6939318, test acc: 0.800\n",
      "poison loss: 1.1618426, poison acc: 0.317\n",
      "elapsed time: 144.791, time for reg: 29.793, time for eig: 45.464\n",
      "epoch:  2269, loss: 0.5832373, train acc: 0.900\n",
      "test loss: 0.6616374, test acc: 0.817\n",
      "poison loss: 1.1889614, poison acc: 0.300\n",
      "elapsed time: 145.407, time for reg: 29.924, time for eig: 45.643\n",
      "epoch:  2279, loss: 0.6251072, train acc: 0.883\n",
      "test loss: 0.6458683, test acc: 0.850\n",
      "poison loss: 1.2063631, poison acc: 0.317\n",
      "elapsed time: 146.005, time for reg: 30.054, time for eig: 45.804\n",
      "epoch:  2289, loss: 0.6471007, train acc: 0.867\n",
      "test loss: 0.6535813, test acc: 0.867\n",
      "poison loss: 1.1939282, poison acc: 0.267\n",
      "elapsed time: 146.602, time for reg: 30.186, time for eig: 45.961\n",
      "epoch:  2299, loss: 0.6313091, train acc: 0.850\n",
      "test loss: 0.7004651, test acc: 0.817\n",
      "poison loss: 1.1709104, poison acc: 0.300\n",
      "elapsed time: 147.189, time for reg: 30.317, time for eig: 46.112\n",
      "epoch:  2309, loss: 0.6290124, train acc: 0.933\n",
      "test loss: 0.6254890, test acc: 0.817\n",
      "poison loss: 1.2176287, poison acc: 0.300\n",
      "elapsed time: 147.775, time for reg: 30.448, time for eig: 46.260\n",
      "epoch:  2319, loss: 0.6231955, train acc: 0.817\n",
      "test loss: 0.6676521, test acc: 0.833\n",
      "poison loss: 1.1969793, poison acc: 0.267\n",
      "elapsed time: 148.350, time for reg: 30.578, time for eig: 46.398\n",
      "epoch:  2329, loss: 0.5962999, train acc: 0.917\n",
      "test loss: 0.6944539, test acc: 0.800\n",
      "poison loss: 1.1774364, poison acc: 0.283\n",
      "elapsed time: 149.004, time for reg: 30.709, time for eig: 46.612\n",
      "epoch:  2339, loss: 0.6545432, train acc: 0.783\n",
      "test loss: 0.6592679, test acc: 0.817\n",
      "poison loss: 1.2169196, poison acc: 0.267\n",
      "elapsed time: 149.617, time for reg: 30.840, time for eig: 46.787\n",
      "epoch:  2349, loss: 0.6688320, train acc: 0.883\n",
      "test loss: 0.5191112, test acc: 0.900\n",
      "poison loss: 1.3641217, poison acc: 0.233\n",
      "elapsed time: 150.210, time for reg: 30.972, time for eig: 46.940\n",
      "epoch:  2359, loss: 0.6046824, train acc: 0.917\n",
      "test loss: 0.6435944, test acc: 0.817\n",
      "poison loss: 1.2078229, poison acc: 0.333\n",
      "elapsed time: 150.847, time for reg: 31.103, time for eig: 47.141\n",
      "epoch:  2369, loss: 0.6067961, train acc: 0.900\n",
      "test loss: 0.7131727, test acc: 0.800\n",
      "poison loss: 1.1369513, poison acc: 0.317\n",
      "elapsed time: 151.481, time for reg: 31.233, time for eig: 47.337\n",
      "epoch:  2379, loss: 0.6394292, train acc: 0.833\n",
      "test loss: 0.5984776, test acc: 0.817\n",
      "poison loss: 1.2515605, poison acc: 0.300\n",
      "elapsed time: 152.073, time for reg: 31.367, time for eig: 47.486\n",
      "epoch:  2389, loss: 0.6155593, train acc: 0.917\n",
      "test loss: 0.6720106, test acc: 0.817\n",
      "poison loss: 1.1912140, poison acc: 0.300\n",
      "elapsed time: 152.724, time for reg: 31.504, time for eig: 47.690\n",
      "epoch:  2399, loss: 0.7105306, train acc: 0.850\n",
      "test loss: 0.5603463, test acc: 0.833\n",
      "poison loss: 1.3180872, poison acc: 0.283\n",
      "elapsed time: 153.335, time for reg: 31.640, time for eig: 47.855\n",
      "epoch:  2409, loss: 0.6273469, train acc: 0.933\n",
      "test loss: 0.6461357, test acc: 0.817\n",
      "poison loss: 1.1975113, poison acc: 0.300\n",
      "elapsed time: 153.989, time for reg: 31.771, time for eig: 48.073\n",
      "epoch:  2419, loss: 0.6283137, train acc: 0.917\n",
      "test loss: 0.6422449, test acc: 0.850\n",
      "poison loss: 1.2180909, poison acc: 0.250\n",
      "elapsed time: 154.569, time for reg: 31.902, time for eig: 48.219\n",
      "epoch:  2429, loss: 0.6359803, train acc: 0.883\n",
      "test loss: 0.6066530, test acc: 0.833\n",
      "poison loss: 1.2345846, poison acc: 0.267\n",
      "elapsed time: 155.153, time for reg: 32.033, time for eig: 48.366\n",
      "epoch:  2439, loss: 0.5961489, train acc: 0.900\n",
      "test loss: 0.7052090, test acc: 0.833\n",
      "poison loss: 1.1396325, poison acc: 0.283\n",
      "elapsed time: 155.722, time for reg: 32.165, time for eig: 48.498\n",
      "epoch:  2449, loss: 0.6419038, train acc: 0.867\n",
      "test loss: 0.6205202, test acc: 0.883\n",
      "poison loss: 1.2331768, poison acc: 0.233\n",
      "elapsed time: 156.329, time for reg: 32.297, time for eig: 48.667\n",
      "epoch:  2459, loss: 0.6241546, train acc: 0.833\n",
      "test loss: 0.8456862, test acc: 0.733\n",
      "poison loss: 1.0482021, poison acc: 0.383\n",
      "elapsed time: 156.890, time for reg: 32.428, time for eig: 48.792\n",
      "epoch:  2469, loss: 0.5863006, train acc: 0.917\n",
      "test loss: 0.6783238, test acc: 0.800\n",
      "poison loss: 1.1578454, poison acc: 0.350\n",
      "elapsed time: 157.457, time for reg: 32.559, time for eig: 48.926\n",
      "epoch:  2479, loss: 0.5777004, train acc: 0.883\n",
      "test loss: 0.7028112, test acc: 0.817\n",
      "poison loss: 1.1419046, poison acc: 0.300\n",
      "elapsed time: 158.045, time for reg: 32.690, time for eig: 49.079\n",
      "epoch:  2489, loss: 0.5975823, train acc: 0.883\n",
      "test loss: 0.6652097, test acc: 0.833\n",
      "poison loss: 1.1660190, poison acc: 0.317\n",
      "elapsed time: 158.653, time for reg: 32.821, time for eig: 49.254\n",
      "epoch:  2499, loss: 0.5852328, train acc: 0.917\n",
      "test loss: 0.6524870, test acc: 0.850\n",
      "poison loss: 1.1857468, poison acc: 0.283\n",
      "elapsed time: 159.230, time for reg: 32.953, time for eig: 49.393\n",
      "epoch:  2509, loss: 0.6428819, train acc: 0.900\n",
      "test loss: 0.6266948, test acc: 0.817\n",
      "poison loss: 1.2238072, poison acc: 0.300\n",
      "elapsed time: 159.823, time for reg: 33.085, time for eig: 49.555\n",
      "epoch:  2519, loss: 0.5964043, train acc: 0.850\n",
      "test loss: 0.6841893, test acc: 0.817\n",
      "poison loss: 1.1622961, poison acc: 0.317\n",
      "elapsed time: 160.437, time for reg: 33.217, time for eig: 49.734\n",
      "epoch:  2529, loss: 0.6297130, train acc: 0.833\n",
      "test loss: 0.6116704, test acc: 0.800\n",
      "poison loss: 1.2506316, poison acc: 0.333\n",
      "elapsed time: 161.033, time for reg: 33.347, time for eig: 49.892\n",
      "epoch:  2539, loss: 0.6130517, train acc: 0.867\n",
      "test loss: 0.6498986, test acc: 0.833\n",
      "poison loss: 1.1828092, poison acc: 0.283\n",
      "elapsed time: 161.610, time for reg: 33.478, time for eig: 50.031\n",
      "epoch:  2549, loss: 0.5869065, train acc: 0.917\n",
      "test loss: 0.7124313, test acc: 0.817\n",
      "poison loss: 1.1262273, poison acc: 0.317\n",
      "elapsed time: 162.212, time for reg: 33.608, time for eig: 50.201\n",
      "epoch:  2559, loss: 0.6004084, train acc: 0.850\n",
      "test loss: 0.7079953, test acc: 0.817\n",
      "poison loss: 1.1490148, poison acc: 0.317\n",
      "elapsed time: 162.877, time for reg: 33.740, time for eig: 50.431\n",
      "epoch:  2569, loss: 0.6489170, train acc: 0.867\n",
      "test loss: 0.6052628, test acc: 0.817\n",
      "poison loss: 1.2603338, poison acc: 0.317\n",
      "elapsed time: 163.484, time for reg: 33.871, time for eig: 50.603\n",
      "epoch:  2579, loss: 0.5831452, train acc: 0.900\n",
      "test loss: 0.6798314, test acc: 0.800\n",
      "poison loss: 1.1469517, poison acc: 0.317\n",
      "elapsed time: 164.068, time for reg: 34.002, time for eig: 50.751\n",
      "epoch:  2589, loss: 0.6289101, train acc: 0.900\n",
      "test loss: 0.6425005, test acc: 0.817\n",
      "poison loss: 1.1825207, poison acc: 0.333\n",
      "elapsed time: 164.656, time for reg: 34.133, time for eig: 50.904\n",
      "epoch:  2599, loss: 0.6114649, train acc: 0.800\n",
      "test loss: 0.6636572, test acc: 0.783\n",
      "poison loss: 1.2108431, poison acc: 0.350\n",
      "elapsed time: 165.231, time for reg: 34.264, time for eig: 51.043\n",
      "epoch:  2609, loss: 0.5810627, train acc: 0.883\n",
      "test loss: 0.7680613, test acc: 0.800\n",
      "poison loss: 1.0845570, poison acc: 0.333\n",
      "elapsed time: 165.824, time for reg: 34.396, time for eig: 51.198\n",
      "epoch:  2619, loss: 0.5893019, train acc: 0.850\n",
      "test loss: 0.6496795, test acc: 0.800\n",
      "poison loss: 1.2015449, poison acc: 0.333\n",
      "elapsed time: 166.442, time for reg: 34.530, time for eig: 51.373\n",
      "epoch:  2629, loss: 0.5706676, train acc: 0.900\n",
      "test loss: 0.7098353, test acc: 0.783\n",
      "poison loss: 1.1238681, poison acc: 0.350\n",
      "elapsed time: 167.110, time for reg: 34.661, time for eig: 51.601\n",
      "epoch:  2639, loss: 0.6320264, train acc: 0.883\n",
      "test loss: 0.6232326, test acc: 0.850\n",
      "poison loss: 1.2241846, poison acc: 0.300\n",
      "elapsed time: 167.804, time for reg: 34.814, time for eig: 51.793\n",
      "epoch:  2649, loss: 0.5976866, train acc: 0.833\n",
      "test loss: 0.7211362, test acc: 0.783\n",
      "poison loss: 1.1180187, poison acc: 0.333\n",
      "elapsed time: 168.443, time for reg: 34.947, time for eig: 51.991\n",
      "epoch:  2659, loss: 0.6009304, train acc: 0.900\n",
      "test loss: 0.6725049, test acc: 0.817\n",
      "poison loss: 1.1508085, poison acc: 0.317\n",
      "elapsed time: 169.041, time for reg: 35.080, time for eig: 52.146\n",
      "epoch:  2669, loss: 0.6472759, train acc: 0.833\n",
      "test loss: 0.6037239, test acc: 0.817\n",
      "poison loss: 1.2538436, poison acc: 0.267\n",
      "elapsed time: 169.682, time for reg: 35.210, time for eig: 52.349\n",
      "epoch:  2679, loss: 0.6109096, train acc: 0.900\n",
      "test loss: 0.7041768, test acc: 0.800\n",
      "poison loss: 1.1292233, poison acc: 0.317\n",
      "elapsed time: 170.289, time for reg: 35.341, time for eig: 52.516\n",
      "epoch:  2689, loss: 0.5731597, train acc: 0.900\n",
      "test loss: 0.7757999, test acc: 0.733\n",
      "poison loss: 1.0813280, poison acc: 0.333\n",
      "elapsed time: 170.901, time for reg: 35.472, time for eig: 52.691\n",
      "epoch:  2699, loss: 0.6236162, train acc: 0.900\n",
      "test loss: 0.5984561, test acc: 0.867\n",
      "poison loss: 1.2387793, poison acc: 0.283\n",
      "elapsed time: 171.763, time for reg: 35.603, time for eig: 53.116\n",
      "epoch:  2709, loss: 0.5870253, train acc: 0.833\n",
      "test loss: 0.6876931, test acc: 0.783\n",
      "poison loss: 1.1600637, poison acc: 0.317\n",
      "elapsed time: 172.350, time for reg: 35.734, time for eig: 53.266\n",
      "epoch:  2719, loss: 0.5771085, train acc: 0.917\n",
      "test loss: 0.7644761, test acc: 0.783\n",
      "poison loss: 1.0768408, poison acc: 0.333\n",
      "elapsed time: 172.947, time for reg: 35.864, time for eig: 53.426\n",
      "epoch:  2729, loss: 0.5630620, train acc: 0.917\n",
      "test loss: 0.7648555, test acc: 0.783\n",
      "poison loss: 1.0817682, poison acc: 0.333\n",
      "elapsed time: 173.557, time for reg: 35.998, time for eig: 53.592\n",
      "epoch:  2739, loss: 0.6018695, train acc: 0.867\n",
      "test loss: 0.7310400, test acc: 0.783\n",
      "poison loss: 1.1112184, poison acc: 0.300\n",
      "elapsed time: 174.166, time for reg: 36.129, time for eig: 53.765\n",
      "epoch:  2749, loss: 0.5770290, train acc: 0.883\n",
      "test loss: 0.6703782, test acc: 0.833\n",
      "poison loss: 1.1644846, poison acc: 0.333\n",
      "elapsed time: 174.754, time for reg: 36.259, time for eig: 53.915\n",
      "epoch:  2759, loss: 0.6199464, train acc: 0.850\n",
      "test loss: 0.6378942, test acc: 0.817\n",
      "poison loss: 1.2151241, poison acc: 0.283\n",
      "elapsed time: 175.334, time for reg: 36.390, time for eig: 54.060\n",
      "epoch:  2769, loss: 0.5895245, train acc: 0.883\n",
      "test loss: 0.6755838, test acc: 0.800\n",
      "poison loss: 1.1507079, poison acc: 0.317\n",
      "elapsed time: 175.940, time for reg: 36.520, time for eig: 54.233\n",
      "epoch:  2779, loss: 0.6162685, train acc: 0.883\n",
      "test loss: 0.6526699, test acc: 0.800\n",
      "poison loss: 1.1840435, poison acc: 0.333\n",
      "elapsed time: 176.564, time for reg: 36.651, time for eig: 54.423\n",
      "epoch:  2789, loss: 0.5572531, train acc: 0.900\n",
      "test loss: 0.7247228, test acc: 0.783\n",
      "poison loss: 1.1032274, poison acc: 0.333\n",
      "elapsed time: 177.148, time for reg: 36.782, time for eig: 54.575\n",
      "epoch:  2799, loss: 0.5977048, train acc: 0.883\n",
      "test loss: 0.6661561, test acc: 0.800\n",
      "poison loss: 1.1630400, poison acc: 0.317\n",
      "elapsed time: 177.716, time for reg: 36.912, time for eig: 54.707\n",
      "epoch:  2809, loss: 0.6332372, train acc: 0.800\n",
      "test loss: 0.6296080, test acc: 0.900\n",
      "poison loss: 1.2032913, poison acc: 0.217\n",
      "elapsed time: 178.302, time for reg: 37.043, time for eig: 54.856\n",
      "epoch:  2819, loss: 0.5951817, train acc: 0.783\n",
      "test loss: 0.6801816, test acc: 0.783\n",
      "poison loss: 1.1513797, poison acc: 0.350\n",
      "elapsed time: 178.934, time for reg: 37.173, time for eig: 55.051\n",
      "epoch:  2829, loss: 0.6211110, train acc: 0.867\n",
      "test loss: 0.6545767, test acc: 0.800\n",
      "poison loss: 1.1965904, poison acc: 0.267\n",
      "elapsed time: 179.520, time for reg: 37.303, time for eig: 55.202\n",
      "epoch:  2839, loss: 0.5145583, train acc: 0.917\n",
      "test loss: 0.8815067, test acc: 0.617\n",
      "poison loss: 1.0046884, poison acc: 0.450\n",
      "elapsed time: 180.174, time for reg: 37.434, time for eig: 55.419\n",
      "epoch:  2849, loss: 0.5894580, train acc: 0.900\n",
      "test loss: 0.6944884, test acc: 0.783\n",
      "poison loss: 1.1572660, poison acc: 0.367\n",
      "elapsed time: 180.751, time for reg: 37.565, time for eig: 55.559\n",
      "epoch:  2859, loss: 0.6803098, train acc: 0.817\n",
      "test loss: 0.5410637, test acc: 0.883\n",
      "poison loss: 1.3423665, poison acc: 0.217\n",
      "elapsed time: 181.332, time for reg: 37.696, time for eig: 55.702\n",
      "epoch:  2869, loss: 0.6174176, train acc: 0.900\n",
      "test loss: 0.6404763, test acc: 0.800\n",
      "poison loss: 1.2072931, poison acc: 0.333\n",
      "elapsed time: 181.931, time for reg: 37.827, time for eig: 55.864\n",
      "epoch:  2879, loss: 0.6023544, train acc: 0.900\n",
      "test loss: 0.7030882, test acc: 0.817\n",
      "poison loss: 1.1378179, poison acc: 0.300\n",
      "elapsed time: 182.507, time for reg: 37.957, time for eig: 56.002\n",
      "epoch:  2889, loss: 0.5167233, train acc: 0.917\n",
      "test loss: 0.8293210, test acc: 0.750\n",
      "poison loss: 1.0307178, poison acc: 0.350\n",
      "elapsed time: 183.077, time for reg: 38.088, time for eig: 56.136\n",
      "epoch:  2899, loss: 0.6070104, train acc: 0.850\n",
      "test loss: 0.6573257, test acc: 0.817\n",
      "poison loss: 1.1799521, poison acc: 0.283\n",
      "elapsed time: 183.869, time for reg: 38.219, time for eig: 56.490\n",
      "epoch:  2909, loss: 0.6506567, train acc: 0.700\n",
      "test loss: 0.5288444, test acc: 0.850\n",
      "poison loss: 1.3556142, poison acc: 0.267\n",
      "elapsed time: 184.487, time for reg: 38.350, time for eig: 56.672\n",
      "epoch:  2919, loss: 0.5513632, train acc: 0.900\n",
      "test loss: 0.7697163, test acc: 0.783\n",
      "poison loss: 1.0631900, poison acc: 0.333\n",
      "elapsed time: 185.075, time for reg: 38.480, time for eig: 56.821\n",
      "epoch:  2929, loss: 0.5705065, train acc: 0.883\n",
      "test loss: 0.7147212, test acc: 0.783\n",
      "poison loss: 1.1138436, poison acc: 0.333\n",
      "elapsed time: 185.690, time for reg: 38.611, time for eig: 56.997\n",
      "epoch:  2939, loss: 0.5933360, train acc: 0.867\n",
      "test loss: 0.7022065, test acc: 0.800\n",
      "poison loss: 1.1257858, poison acc: 0.333\n",
      "elapsed time: 186.389, time for reg: 38.741, time for eig: 57.259\n",
      "epoch:  2949, loss: 0.5695185, train acc: 0.850\n",
      "test loss: 0.7441055, test acc: 0.767\n",
      "poison loss: 1.0914392, poison acc: 0.333\n",
      "elapsed time: 186.994, time for reg: 38.873, time for eig: 57.429\n",
      "epoch:  2959, loss: 0.5850030, train acc: 0.883\n",
      "test loss: 0.7061707, test acc: 0.783\n",
      "poison loss: 1.1574800, poison acc: 0.367\n",
      "elapsed time: 187.672, time for reg: 39.005, time for eig: 57.666\n",
      "epoch:  2969, loss: 0.6148587, train acc: 0.850\n",
      "test loss: 0.6260316, test acc: 0.800\n",
      "poison loss: 1.2391117, poison acc: 0.333\n",
      "elapsed time: 188.268, time for reg: 39.136, time for eig: 57.829\n",
      "epoch:  2979, loss: 0.5521427, train acc: 0.900\n",
      "test loss: 0.7399237, test acc: 0.800\n",
      "poison loss: 1.0896711, poison acc: 0.300\n",
      "elapsed time: 189.001, time for reg: 39.267, time for eig: 58.123\n",
      "epoch:  2989, loss: 0.5027194, train acc: 0.900\n",
      "test loss: 0.8781524, test acc: 0.733\n",
      "poison loss: 1.0337903, poison acc: 0.367\n",
      "elapsed time: 189.658, time for reg: 39.398, time for eig: 58.342\n",
      "epoch:  2999, loss: 0.6324659, train acc: 0.867\n",
      "test loss: 0.7440097, test acc: 0.800\n",
      "poison loss: 1.0894286, poison acc: 0.367\n",
      "elapsed time: 190.231, time for reg: 39.529, time for eig: 58.460\n",
      "epoch:  3009, loss: 0.5908875, train acc: 0.883\n",
      "test loss: 0.6283590, test acc: 0.817\n",
      "poison loss: 1.2089235, poison acc: 0.300\n",
      "elapsed time: 190.875, time for reg: 39.672, time for eig: 58.634\n",
      "epoch:  3019, loss: 0.6267993, train acc: 0.833\n",
      "test loss: 0.6787491, test acc: 0.817\n",
      "poison loss: 1.1486394, poison acc: 0.317\n",
      "elapsed time: 191.486, time for reg: 39.808, time for eig: 58.799\n",
      "epoch:  3029, loss: 0.5608827, train acc: 0.900\n",
      "test loss: 0.7874950, test acc: 0.717\n",
      "poison loss: 1.0603867, poison acc: 0.367\n",
      "elapsed time: 192.100, time for reg: 39.944, time for eig: 58.966\n",
      "epoch:  3039, loss: 0.6123631, train acc: 0.867\n",
      "test loss: 0.8879179, test acc: 0.633\n",
      "poison loss: 0.9874884, poison acc: 0.433\n",
      "elapsed time: 192.749, time for reg: 40.079, time for eig: 59.168\n",
      "epoch:  3049, loss: 0.5868164, train acc: 0.817\n",
      "test loss: 0.8878249, test acc: 0.617\n",
      "poison loss: 0.9862716, poison acc: 0.400\n",
      "elapsed time: 193.517, time for reg: 40.215, time for eig: 59.487\n",
      "epoch:  3059, loss: 0.5898542, train acc: 0.900\n",
      "test loss: 0.7430761, test acc: 0.783\n",
      "poison loss: 1.1231684, poison acc: 0.383\n",
      "elapsed time: 194.372, time for reg: 40.351, time for eig: 59.893\n",
      "epoch:  3069, loss: 0.6231982, train acc: 0.800\n",
      "test loss: 0.6654564, test acc: 0.783\n",
      "poison loss: 1.1662773, poison acc: 0.333\n",
      "elapsed time: 194.983, time for reg: 40.487, time for eig: 60.055\n",
      "epoch:  3079, loss: 0.5793930, train acc: 0.883\n",
      "test loss: 0.7487055, test acc: 0.700\n",
      "poison loss: 1.0735683, poison acc: 0.367\n",
      "elapsed time: 195.764, time for reg: 40.623, time for eig: 60.387\n",
      "epoch:  3089, loss: 0.5837725, train acc: 0.850\n",
      "test loss: 0.7318163, test acc: 0.800\n",
      "poison loss: 1.1077724, poison acc: 0.300\n",
      "elapsed time: 196.354, time for reg: 40.758, time for eig: 60.526\n",
      "epoch:  3099, loss: 0.5584706, train acc: 0.900\n",
      "test loss: 0.7772121, test acc: 0.700\n",
      "poison loss: 1.0686985, poison acc: 0.417\n",
      "elapsed time: 196.963, time for reg: 40.894, time for eig: 60.685\n",
      "epoch:  3109, loss: 0.5849295, train acc: 0.833\n",
      "test loss: 0.8431229, test acc: 0.617\n",
      "poison loss: 1.0132473, poison acc: 0.417\n",
      "elapsed time: 197.591, time for reg: 41.029, time for eig: 60.862\n",
      "epoch:  3119, loss: 0.5704889, train acc: 0.883\n",
      "test loss: 0.9115676, test acc: 0.500\n",
      "poison loss: 0.9942755, poison acc: 0.550\n",
      "elapsed time: 198.250, time for reg: 41.165, time for eig: 61.071\n",
      "epoch:  3129, loss: 0.5492801, train acc: 0.883\n",
      "test loss: 0.8711546, test acc: 0.550\n",
      "poison loss: 0.9779578, poison acc: 0.450\n",
      "elapsed time: 198.881, time for reg: 41.300, time for eig: 61.256\n",
      "epoch:  3139, loss: 0.5951394, train acc: 0.817\n",
      "test loss: 0.7243468, test acc: 0.733\n",
      "poison loss: 1.0999318, poison acc: 0.300\n",
      "elapsed time: 199.462, time for reg: 41.436, time for eig: 61.391\n",
      "epoch:  3149, loss: 0.5930731, train acc: 0.883\n",
      "test loss: 0.7991389, test acc: 0.700\n",
      "poison loss: 1.0425198, poison acc: 0.383\n",
      "elapsed time: 200.076, time for reg: 41.572, time for eig: 61.553\n",
      "epoch:  3159, loss: 0.6329037, train acc: 0.850\n",
      "test loss: 0.7623036, test acc: 0.750\n",
      "poison loss: 1.0692885, poison acc: 0.350\n",
      "elapsed time: 200.688, time for reg: 41.707, time for eig: 61.713\n",
      "epoch:  3169, loss: 0.5822509, train acc: 0.883\n",
      "test loss: 0.7704414, test acc: 0.750\n",
      "poison loss: 1.0536237, poison acc: 0.367\n",
      "elapsed time: 201.463, time for reg: 41.843, time for eig: 62.037\n",
      "epoch:  3179, loss: 0.5990402, train acc: 0.800\n",
      "test loss: 0.6749062, test acc: 0.783\n",
      "poison loss: 1.1832530, poison acc: 0.350\n",
      "elapsed time: 202.058, time for reg: 41.978, time for eig: 62.182\n",
      "epoch:  3189, loss: 0.6051904, train acc: 0.783\n",
      "test loss: 0.8396575, test acc: 0.583\n",
      "poison loss: 0.9999683, poison acc: 0.417\n",
      "elapsed time: 202.700, time for reg: 42.115, time for eig: 62.372\n",
      "epoch:  3199, loss: 0.5947016, train acc: 0.867\n",
      "test loss: 0.7309075, test acc: 0.733\n",
      "poison loss: 1.0955360, poison acc: 0.333\n",
      "elapsed time: 203.852, time for reg: 42.250, time for eig: 63.074\n",
      "epoch:  3209, loss: 0.5155687, train acc: 0.883\n",
      "test loss: 0.8331910, test acc: 0.733\n",
      "poison loss: 1.0141092, poison acc: 0.383\n",
      "elapsed time: 204.590, time for reg: 42.385, time for eig: 63.368\n",
      "epoch:  3219, loss: 0.5645574, train acc: 0.833\n",
      "test loss: 0.7070190, test acc: 0.800\n",
      "poison loss: 1.1445772, poison acc: 0.333\n",
      "elapsed time: 205.284, time for reg: 42.522, time for eig: 63.611\n",
      "epoch:  3229, loss: 0.5541480, train acc: 0.850\n",
      "test loss: 0.7668130, test acc: 0.733\n",
      "poison loss: 1.0491511, poison acc: 0.350\n",
      "elapsed time: 205.899, time for reg: 42.657, time for eig: 63.781\n",
      "epoch:  3239, loss: 0.5764025, train acc: 0.867\n",
      "test loss: 0.7735888, test acc: 0.717\n",
      "poison loss: 1.0393194, poison acc: 0.350\n",
      "elapsed time: 206.576, time for reg: 42.793, time for eig: 64.006\n",
      "epoch:  3249, loss: 0.6183210, train acc: 0.817\n",
      "test loss: 0.7543309, test acc: 0.783\n",
      "poison loss: 1.0980666, poison acc: 0.367\n",
      "elapsed time: 207.282, time for reg: 42.928, time for eig: 64.265\n",
      "epoch:  3259, loss: 0.6075045, train acc: 0.867\n",
      "test loss: 0.6966436, test acc: 0.800\n",
      "poison loss: 1.1232089, poison acc: 0.333\n",
      "elapsed time: 207.936, time for reg: 43.064, time for eig: 64.469\n",
      "epoch:  3269, loss: 0.6032265, train acc: 0.733\n",
      "test loss: 0.8877063, test acc: 0.650\n",
      "poison loss: 0.9563239, poison acc: 0.400\n",
      "elapsed time: 208.524, time for reg: 43.200, time for eig: 64.606\n",
      "epoch:  3279, loss: 0.5417552, train acc: 0.850\n",
      "test loss: 0.6934681, test acc: 0.817\n",
      "poison loss: 1.1370572, poison acc: 0.300\n",
      "elapsed time: 209.127, time for reg: 43.335, time for eig: 64.759\n",
      "epoch:  3289, loss: 0.6133288, train acc: 0.850\n",
      "test loss: 0.6316099, test acc: 0.883\n",
      "poison loss: 1.2297094, poison acc: 0.217\n",
      "elapsed time: 209.733, time for reg: 43.470, time for eig: 64.914\n",
      "epoch:  3299, loss: 0.6063960, train acc: 0.767\n",
      "test loss: 0.7369558, test acc: 0.717\n",
      "poison loss: 1.1049030, poison acc: 0.350\n",
      "elapsed time: 210.448, time for reg: 43.606, time for eig: 65.178\n",
      "epoch:  3309, loss: 0.5722568, train acc: 0.883\n",
      "test loss: 0.7657031, test acc: 0.733\n",
      "poison loss: 1.0646829, poison acc: 0.367\n",
      "elapsed time: 211.055, time for reg: 43.741, time for eig: 65.336\n",
      "epoch:  3319, loss: 0.5881225, train acc: 0.850\n",
      "test loss: 0.8392706, test acc: 0.650\n",
      "poison loss: 0.9867663, poison acc: 0.367\n",
      "elapsed time: 211.675, time for reg: 43.876, time for eig: 65.506\n",
      "epoch:  3329, loss: 0.5997973, train acc: 0.767\n",
      "test loss: 0.6791461, test acc: 0.867\n",
      "poison loss: 1.1197250, poison acc: 0.267\n",
      "elapsed time: 212.495, time for reg: 44.011, time for eig: 65.876\n",
      "epoch:  3339, loss: 0.5436530, train acc: 0.883\n",
      "test loss: 0.9731929, test acc: 0.533\n",
      "poison loss: 0.9293865, poison acc: 0.483\n",
      "elapsed time: 213.140, time for reg: 44.146, time for eig: 66.072\n",
      "epoch:  3349, loss: 0.5399812, train acc: 0.867\n",
      "test loss: 0.7847336, test acc: 0.733\n",
      "poison loss: 1.0102795, poison acc: 0.400\n",
      "elapsed time: 213.805, time for reg: 44.281, time for eig: 66.287\n",
      "epoch:  3359, loss: 0.5404524, train acc: 0.900\n",
      "test loss: 0.8065852, test acc: 0.700\n",
      "poison loss: 1.0046057, poison acc: 0.367\n",
      "elapsed time: 214.460, time for reg: 44.416, time for eig: 66.493\n",
      "epoch:  3369, loss: 0.5885636, train acc: 0.850\n",
      "test loss: 0.7496787, test acc: 0.717\n",
      "poison loss: 1.0731915, poison acc: 0.367\n",
      "elapsed time: 215.103, time for reg: 44.551, time for eig: 66.686\n",
      "epoch:  3379, loss: 0.5787528, train acc: 0.867\n",
      "test loss: 0.8660517, test acc: 0.750\n",
      "poison loss: 0.9787386, poison acc: 0.400\n",
      "elapsed time: 215.694, time for reg: 44.685, time for eig: 66.828\n",
      "epoch:  3389, loss: 0.4980755, train acc: 0.900\n",
      "test loss: 0.8738556, test acc: 0.583\n",
      "poison loss: 0.9677674, poison acc: 0.500\n",
      "elapsed time: 216.301, time for reg: 44.820, time for eig: 66.983\n",
      "epoch:  3399, loss: 0.5883813, train acc: 0.867\n",
      "test loss: 0.7445215, test acc: 0.750\n",
      "poison loss: 1.0296818, poison acc: 0.383\n",
      "elapsed time: 217.025, time for reg: 44.955, time for eig: 67.258\n",
      "epoch:  3409, loss: 0.5895428, train acc: 0.900\n",
      "test loss: 0.7805094, test acc: 0.683\n",
      "poison loss: 1.0383357, poison acc: 0.400\n",
      "elapsed time: 217.623, time for reg: 45.090, time for eig: 67.406\n",
      "epoch:  3419, loss: 0.5932645, train acc: 0.833\n",
      "test loss: 0.7732518, test acc: 0.733\n",
      "poison loss: 1.0647831, poison acc: 0.317\n",
      "elapsed time: 218.246, time for reg: 45.225, time for eig: 67.579\n",
      "epoch:  3429, loss: 0.6132786, train acc: 0.700\n",
      "test loss: 0.7769614, test acc: 0.717\n",
      "poison loss: 1.0464494, poison acc: 0.350\n",
      "elapsed time: 218.989, time for reg: 45.360, time for eig: 67.873\n",
      "epoch:  3439, loss: 0.6310575, train acc: 0.767\n",
      "test loss: 0.7344525, test acc: 0.783\n",
      "poison loss: 1.0633529, poison acc: 0.367\n",
      "elapsed time: 219.592, time for reg: 45.495, time for eig: 68.025\n",
      "epoch:  3449, loss: 0.5457359, train acc: 0.817\n",
      "test loss: 0.8022621, test acc: 0.767\n",
      "poison loss: 0.9662602, poison acc: 0.417\n",
      "elapsed time: 220.431, time for reg: 45.631, time for eig: 68.414\n",
      "epoch:  3459, loss: 0.6450185, train acc: 0.783\n",
      "test loss: 0.7535376, test acc: 0.767\n",
      "poison loss: 1.1857696, poison acc: 0.333\n",
      "elapsed time: 221.142, time for reg: 45.766, time for eig: 68.675\n",
      "epoch:  3469, loss: 0.5799382, train acc: 0.867\n",
      "test loss: 1.0140191, test acc: 0.617\n",
      "poison loss: 0.8999443, poison acc: 0.467\n",
      "elapsed time: 221.740, time for reg: 45.902, time for eig: 68.822\n",
      "epoch:  3479, loss: 0.5793211, train acc: 0.783\n",
      "test loss: 0.8024595, test acc: 0.800\n",
      "poison loss: 1.0356803, poison acc: 0.367\n",
      "elapsed time: 222.412, time for reg: 46.037, time for eig: 69.044\n",
      "epoch:  3489, loss: 0.6010154, train acc: 0.800\n",
      "test loss: 0.8226252, test acc: 0.600\n",
      "poison loss: 0.9853890, poison acc: 0.467\n",
      "elapsed time: 222.994, time for reg: 46.173, time for eig: 69.173\n",
      "epoch:  3499, loss: 0.5585173, train acc: 0.817\n",
      "test loss: 0.7527023, test acc: 0.750\n",
      "poison loss: 1.0175882, poison acc: 0.367\n",
      "elapsed time: 223.622, time for reg: 46.308, time for eig: 69.351\n",
      "epoch:  3509, loss: 0.5164894, train acc: 0.917\n",
      "test loss: 0.8753640, test acc: 0.600\n",
      "poison loss: 1.0109317, poison acc: 0.400\n",
      "elapsed time: 224.280, time for reg: 46.444, time for eig: 69.558\n",
      "epoch:  3519, loss: 0.5790228, train acc: 0.850\n",
      "test loss: 0.9183978, test acc: 0.583\n",
      "poison loss: 0.9180979, poison acc: 0.450\n",
      "elapsed time: 224.905, time for reg: 46.580, time for eig: 69.735\n",
      "epoch:  3529, loss: 0.4992845, train acc: 0.917\n",
      "test loss: 1.0142757, test acc: 0.500\n",
      "poison loss: 0.8209762, poison acc: 0.583\n",
      "elapsed time: 225.603, time for reg: 46.715, time for eig: 69.982\n",
      "epoch:  3539, loss: 0.5285019, train acc: 0.850\n",
      "test loss: 0.9678490, test acc: 0.567\n",
      "poison loss: 0.8246067, poison acc: 0.550\n",
      "elapsed time: 226.265, time for reg: 46.851, time for eig: 70.192\n",
      "epoch:  3549, loss: 0.5310466, train acc: 0.817\n",
      "test loss: 0.9383588, test acc: 0.550\n",
      "poison loss: 0.8960114, poison acc: 0.467\n",
      "elapsed time: 226.954, time for reg: 46.986, time for eig: 70.430\n",
      "epoch:  3559, loss: 0.4990536, train acc: 0.883\n",
      "test loss: 0.8808192, test acc: 0.667\n",
      "poison loss: 0.9022658, poison acc: 0.533\n",
      "elapsed time: 227.586, time for reg: 47.121, time for eig: 70.613\n",
      "epoch:  3569, loss: 0.5600064, train acc: 0.817\n",
      "test loss: 0.9304549, test acc: 0.550\n",
      "poison loss: 0.8633725, poison acc: 0.517\n",
      "elapsed time: 228.233, time for reg: 47.256, time for eig: 70.809\n",
      "epoch:  3579, loss: 0.6007425, train acc: 0.867\n",
      "test loss: 0.8096085, test acc: 0.667\n",
      "poison loss: 0.9757176, poison acc: 0.450\n",
      "elapsed time: 228.882, time for reg: 47.391, time for eig: 71.008\n",
      "epoch:  3589, loss: 0.5813146, train acc: 0.800\n",
      "test loss: 0.6952766, test acc: 0.750\n",
      "poison loss: 1.1155231, poison acc: 0.417\n",
      "elapsed time: 229.480, time for reg: 47.526, time for eig: 71.156\n",
      "epoch:  3599, loss: 0.4670982, train acc: 0.917\n",
      "test loss: 0.8257554, test acc: 0.700\n",
      "poison loss: 0.9451186, poison acc: 0.500\n",
      "elapsed time: 230.075, time for reg: 47.662, time for eig: 71.302\n",
      "epoch:  3609, loss: 0.5592791, train acc: 0.783\n",
      "test loss: 0.9532172, test acc: 0.567\n",
      "poison loss: 0.8289738, poison acc: 0.517\n",
      "elapsed time: 230.661, time for reg: 47.796, time for eig: 71.438\n",
      "epoch:  3619, loss: 0.4818726, train acc: 0.867\n",
      "test loss: 0.9525807, test acc: 0.550\n",
      "poison loss: 0.8658065, poison acc: 0.517\n",
      "elapsed time: 231.369, time for reg: 47.931, time for eig: 71.696\n",
      "epoch:  3629, loss: 0.5998659, train acc: 0.767\n",
      "test loss: 0.9947085, test acc: 0.583\n",
      "poison loss: 1.2811448, poison acc: 0.333\n",
      "elapsed time: 232.018, time for reg: 48.066, time for eig: 71.898\n",
      "epoch:  3639, loss: 0.4698032, train acc: 0.900\n",
      "test loss: 0.9430202, test acc: 0.567\n",
      "poison loss: 0.8714226, poison acc: 0.500\n",
      "elapsed time: 232.639, time for reg: 48.206, time for eig: 72.062\n",
      "epoch:  3649, loss: 0.5541463, train acc: 0.833\n",
      "test loss: 0.8217874, test acc: 0.667\n",
      "poison loss: 0.9334321, poison acc: 0.433\n",
      "elapsed time: 233.243, time for reg: 48.342, time for eig: 72.216\n",
      "epoch:  3659, loss: 0.5392005, train acc: 0.783\n",
      "test loss: 0.7434583, test acc: 0.700\n",
      "poison loss: 0.9700476, poison acc: 0.433\n",
      "elapsed time: 233.853, time for reg: 48.477, time for eig: 72.377\n",
      "epoch:  3669, loss: 0.4961368, train acc: 0.850\n",
      "test loss: 0.9005630, test acc: 0.617\n",
      "poison loss: 0.9996014, poison acc: 0.500\n",
      "elapsed time: 234.478, time for reg: 48.611, time for eig: 72.553\n",
      "epoch:  3679, loss: 0.5100597, train acc: 0.800\n",
      "test loss: 0.8331562, test acc: 0.633\n",
      "poison loss: 0.9800466, poison acc: 0.517\n",
      "elapsed time: 235.131, time for reg: 48.747, time for eig: 72.755\n",
      "epoch:  3689, loss: 0.5274886, train acc: 0.867\n",
      "test loss: 0.9427623, test acc: 0.583\n",
      "poison loss: 0.8669034, poison acc: 0.483\n",
      "elapsed time: 235.783, time for reg: 48.883, time for eig: 72.954\n",
      "epoch:  3699, loss: 0.5278503, train acc: 0.883\n",
      "test loss: 0.8023199, test acc: 0.633\n",
      "poison loss: 1.0004766, poison acc: 0.367\n",
      "elapsed time: 236.519, time for reg: 49.019, time for eig: 73.239\n",
      "epoch:  3709, loss: 0.5364304, train acc: 0.833\n",
      "test loss: 0.9244595, test acc: 0.583\n",
      "poison loss: 0.8370558, poison acc: 0.567\n",
      "elapsed time: 237.117, time for reg: 49.154, time for eig: 73.387\n",
      "epoch:  3719, loss: 0.5408208, train acc: 0.817\n",
      "test loss: 0.9574625, test acc: 0.617\n",
      "poison loss: 0.8209940, poison acc: 0.533\n",
      "elapsed time: 237.754, time for reg: 49.289, time for eig: 73.574\n",
      "epoch:  3729, loss: 0.5633893, train acc: 0.833\n",
      "test loss: 0.8071091, test acc: 0.683\n",
      "poison loss: 1.0655895, poison acc: 0.433\n",
      "elapsed time: 238.387, time for reg: 49.424, time for eig: 73.756\n",
      "epoch:  3739, loss: 0.4848865, train acc: 0.833\n",
      "test loss: 0.9146900, test acc: 0.583\n",
      "poison loss: 0.8498406, poison acc: 0.517\n",
      "elapsed time: 238.978, time for reg: 49.560, time for eig: 73.894\n",
      "epoch:  3749, loss: 0.4446341, train acc: 0.900\n",
      "test loss: 0.9953289, test acc: 0.617\n",
      "poison loss: 0.8634560, poison acc: 0.483\n",
      "elapsed time: 239.579, time for reg: 49.703, time for eig: 74.034\n",
      "epoch:  3759, loss: 0.5255788, train acc: 0.817\n",
      "test loss: 0.7962829, test acc: 0.700\n",
      "poison loss: 0.9895011, poison acc: 0.467\n",
      "elapsed time: 240.264, time for reg: 49.844, time for eig: 74.259\n",
      "epoch:  3769, loss: 0.5016567, train acc: 0.850\n",
      "test loss: 0.8267556, test acc: 0.633\n",
      "poison loss: 0.9170630, poison acc: 0.483\n",
      "elapsed time: 240.887, time for reg: 49.981, time for eig: 74.430\n",
      "epoch:  3779, loss: 0.5703701, train acc: 0.767\n",
      "test loss: 1.0113795, test acc: 0.517\n",
      "poison loss: 0.9857262, poison acc: 0.450\n",
      "elapsed time: 241.466, time for reg: 50.116, time for eig: 74.560\n",
      "epoch:  3789, loss: 0.5037484, train acc: 0.833\n",
      "test loss: 0.9646505, test acc: 0.650\n",
      "poison loss: 0.8761515, poison acc: 0.500\n",
      "elapsed time: 242.036, time for reg: 50.251, time for eig: 74.681\n",
      "epoch:  3799, loss: 0.4430949, train acc: 0.883\n",
      "test loss: 1.1017745, test acc: 0.467\n",
      "poison loss: 0.7970209, poison acc: 0.550\n",
      "elapsed time: 242.647, time for reg: 50.386, time for eig: 74.840\n",
      "epoch:  3809, loss: 0.5001476, train acc: 0.850\n",
      "test loss: 0.8929956, test acc: 0.617\n",
      "poison loss: 1.5464651, poison acc: 0.400\n",
      "elapsed time: 243.255, time for reg: 50.522, time for eig: 74.995\n",
      "epoch:  3819, loss: 0.5100039, train acc: 0.867\n",
      "test loss: 0.9752944, test acc: 0.650\n",
      "poison loss: 0.8010392, poison acc: 0.567\n",
      "elapsed time: 243.855, time for reg: 50.657, time for eig: 75.143\n",
      "epoch:  3829, loss: 0.5091668, train acc: 0.833\n",
      "test loss: 0.9110816, test acc: 0.567\n",
      "poison loss: 0.9114431, poison acc: 0.517\n",
      "elapsed time: 244.478, time for reg: 50.793, time for eig: 75.315\n",
      "epoch:  3839, loss: 0.4783143, train acc: 0.883\n",
      "test loss: 0.9293731, test acc: 0.600\n",
      "poison loss: 0.8152435, poison acc: 0.567\n",
      "elapsed time: 245.079, time for reg: 50.928, time for eig: 75.466\n",
      "epoch:  3849, loss: 0.5610456, train acc: 0.783\n",
      "test loss: 0.8047217, test acc: 0.667\n",
      "poison loss: 1.0769237, poison acc: 0.400\n",
      "elapsed time: 245.713, time for reg: 51.064, time for eig: 75.649\n",
      "epoch:  3859, loss: 0.4833951, train acc: 0.850\n",
      "test loss: 0.9513018, test acc: 0.600\n",
      "poison loss: 0.9282021, poison acc: 0.517\n",
      "elapsed time: 246.369, time for reg: 51.199, time for eig: 75.854\n",
      "epoch:  3869, loss: 0.4468718, train acc: 0.883\n",
      "test loss: 0.9273486, test acc: 0.650\n",
      "poison loss: 0.8077545, poison acc: 0.600\n",
      "elapsed time: 247.079, time for reg: 51.335, time for eig: 76.112\n",
      "epoch:  3879, loss: 0.6266404, train acc: 0.750\n",
      "test loss: 0.8699736, test acc: 0.567\n",
      "poison loss: 1.1492195, poison acc: 0.433\n",
      "elapsed time: 247.720, time for reg: 51.471, time for eig: 76.302\n",
      "epoch:  3889, loss: 0.6118540, train acc: 0.800\n",
      "test loss: 0.9950692, test acc: 0.550\n",
      "poison loss: 0.8589346, poison acc: 0.550\n",
      "elapsed time: 248.514, time for reg: 51.606, time for eig: 76.647\n",
      "epoch:  3899, loss: 0.5059349, train acc: 0.817\n",
      "test loss: 0.9617907, test acc: 0.517\n",
      "poison loss: 0.9386320, poison acc: 0.533\n",
      "elapsed time: 249.132, time for reg: 51.741, time for eig: 76.816\n",
      "epoch:  3909, loss: 0.4825574, train acc: 0.867\n",
      "test loss: 1.0234564, test acc: 0.550\n",
      "poison loss: 0.7872279, poison acc: 0.550\n",
      "elapsed time: 249.774, time for reg: 51.877, time for eig: 77.009\n",
      "epoch:  3919, loss: 0.5790990, train acc: 0.817\n",
      "test loss: 0.9429688, test acc: 0.617\n",
      "poison loss: 0.7706351, poison acc: 0.633\n",
      "elapsed time: 250.435, time for reg: 52.012, time for eig: 77.219\n",
      "epoch:  3929, loss: 0.5167576, train acc: 0.833\n",
      "test loss: 0.7851952, test acc: 0.650\n",
      "poison loss: 0.9876510, poison acc: 0.483\n",
      "elapsed time: 251.049, time for reg: 52.147, time for eig: 77.383\n",
      "epoch:  3939, loss: 0.4493123, train acc: 0.867\n",
      "test loss: 1.0255726, test acc: 0.617\n",
      "poison loss: 0.7655890, poison acc: 0.633\n",
      "elapsed time: 251.644, time for reg: 52.282, time for eig: 77.529\n",
      "epoch:  3949, loss: 0.5228217, train acc: 0.817\n",
      "test loss: 0.7840049, test acc: 0.733\n",
      "poison loss: 1.2353408, poison acc: 0.400\n",
      "elapsed time: 252.247, time for reg: 52.418, time for eig: 77.682\n",
      "epoch:  3959, loss: 0.5514162, train acc: 0.800\n",
      "test loss: 0.8970449, test acc: 0.633\n",
      "poison loss: 0.8400937, poison acc: 0.583\n",
      "elapsed time: 252.885, time for reg: 52.553, time for eig: 77.872\n",
      "epoch:  3969, loss: 0.5660436, train acc: 0.750\n",
      "test loss: 0.9773297, test acc: 0.567\n",
      "poison loss: 0.8695979, poison acc: 0.567\n",
      "elapsed time: 253.505, time for reg: 52.688, time for eig: 78.043\n",
      "epoch:  3979, loss: 0.5304239, train acc: 0.800\n",
      "test loss: 0.9108667, test acc: 0.617\n",
      "poison loss: 1.2688064, poison acc: 0.417\n",
      "elapsed time: 254.091, time for reg: 52.824, time for eig: 78.177\n",
      "epoch:  3989, loss: 0.4713843, train acc: 0.867\n",
      "test loss: 0.9758556, test acc: 0.600\n",
      "poison loss: 0.8018851, poison acc: 0.567\n",
      "elapsed time: 254.727, time for reg: 52.959, time for eig: 78.365\n",
      "epoch:  3999, loss: 0.4592909, train acc: 0.850\n",
      "test loss: 0.9766106, test acc: 0.633\n",
      "poison loss: 0.8374510, poison acc: 0.583\n",
      "elapsed time: 255.367, time for reg: 53.094, time for eig: 78.557\n",
      "epoch:  4009, loss: 0.5157214, train acc: 0.867\n",
      "test loss: 0.9312432, test acc: 0.617\n",
      "poison loss: 0.8742389, poison acc: 0.583\n",
      "elapsed time: 255.960, time for reg: 53.229, time for eig: 78.702\n",
      "epoch:  4019, loss: 0.4568564, train acc: 0.867\n",
      "test loss: 1.1437725, test acc: 0.517\n",
      "poison loss: 0.8427827, poison acc: 0.533\n",
      "elapsed time: 256.568, time for reg: 53.364, time for eig: 78.863\n",
      "epoch:  4029, loss: 0.5574019, train acc: 0.800\n",
      "test loss: 0.9485187, test acc: 0.650\n",
      "poison loss: 0.9478296, poison acc: 0.450\n",
      "elapsed time: 257.196, time for reg: 53.501, time for eig: 79.043\n",
      "epoch:  4039, loss: 0.4153530, train acc: 0.867\n",
      "test loss: 1.1616749, test acc: 0.550\n",
      "poison loss: 0.7331083, poison acc: 0.583\n",
      "elapsed time: 257.788, time for reg: 53.637, time for eig: 79.183\n",
      "epoch:  4049, loss: 0.4275160, train acc: 0.900\n",
      "test loss: 1.0539147, test acc: 0.650\n",
      "poison loss: 0.7315325, poison acc: 0.650\n",
      "elapsed time: 258.386, time for reg: 53.772, time for eig: 79.333\n",
      "epoch:  4059, loss: 0.6326979, train acc: 0.783\n",
      "test loss: 0.8827912, test acc: 0.617\n",
      "poison loss: 1.0353997, poison acc: 0.483\n",
      "elapsed time: 259.029, time for reg: 53.908, time for eig: 79.526\n",
      "epoch:  4069, loss: 0.4451670, train acc: 0.900\n",
      "test loss: 0.9875295, test acc: 0.600\n",
      "poison loss: 0.8478555, poison acc: 0.533\n",
      "elapsed time: 259.699, time for reg: 54.043, time for eig: 79.746\n",
      "epoch:  4079, loss: 0.4347676, train acc: 0.867\n",
      "test loss: 1.0543450, test acc: 0.617\n",
      "poison loss: 0.7155799, poison acc: 0.600\n",
      "elapsed time: 260.286, time for reg: 54.178, time for eig: 79.883\n",
      "epoch:  4089, loss: 0.4727736, train acc: 0.883\n",
      "test loss: 0.9754048, test acc: 0.583\n",
      "poison loss: 0.8939911, poison acc: 0.533\n",
      "elapsed time: 260.971, time for reg: 54.313, time for eig: 80.119\n",
      "epoch:  4099, loss: 0.3989228, train acc: 0.867\n",
      "test loss: 1.0669978, test acc: 0.583\n",
      "poison loss: 0.8150905, poison acc: 0.567\n",
      "elapsed time: 261.610, time for reg: 54.449, time for eig: 80.308\n",
      "epoch:  4109, loss: 0.3930220, train acc: 0.867\n",
      "test loss: 1.0802900, test acc: 0.600\n",
      "poison loss: 0.6671915, poison acc: 0.633\n",
      "elapsed time: 262.238, time for reg: 54.584, time for eig: 80.487\n",
      "epoch:  4119, loss: 0.4234654, train acc: 0.900\n",
      "test loss: 1.0388288, test acc: 0.617\n",
      "poison loss: 0.7184715, poison acc: 0.633\n",
      "elapsed time: 262.869, time for reg: 54.719, time for eig: 80.667\n",
      "epoch:  4129, loss: 0.5804121, train acc: 0.767\n",
      "test loss: 0.8702420, test acc: 0.667\n",
      "poison loss: 1.1666437, poison acc: 0.400\n",
      "elapsed time: 263.476, time for reg: 54.855, time for eig: 80.824\n",
      "epoch:  4139, loss: 0.4095761, train acc: 0.867\n",
      "test loss: 1.1089135, test acc: 0.517\n",
      "poison loss: 0.8809385, poison acc: 0.550\n",
      "elapsed time: 264.076, time for reg: 54.991, time for eig: 80.976\n",
      "epoch:  4149, loss: 0.4567535, train acc: 0.833\n",
      "test loss: 1.0083038, test acc: 0.600\n",
      "poison loss: 0.7570890, poison acc: 0.667\n",
      "elapsed time: 264.803, time for reg: 55.126, time for eig: 81.254\n",
      "epoch:  4159, loss: 0.4679960, train acc: 0.850\n",
      "test loss: 0.9709816, test acc: 0.700\n",
      "poison loss: 0.7346895, poison acc: 0.650\n",
      "elapsed time: 265.401, time for reg: 55.262, time for eig: 81.402\n",
      "epoch:  4169, loss: 0.3941056, train acc: 0.867\n",
      "test loss: 1.0186786, test acc: 0.633\n",
      "poison loss: 0.7723721, poison acc: 0.600\n",
      "elapsed time: 266.011, time for reg: 55.397, time for eig: 81.572\n",
      "epoch:  4179, loss: 0.5141501, train acc: 0.767\n",
      "test loss: 0.9618490, test acc: 0.633\n",
      "poison loss: 0.7805054, poison acc: 0.617\n",
      "elapsed time: 266.596, time for reg: 55.534, time for eig: 81.714\n",
      "epoch:  4189, loss: 0.4142909, train acc: 0.867\n",
      "test loss: 1.1112113, test acc: 0.617\n",
      "poison loss: 0.6474161, poison acc: 0.717\n",
      "elapsed time: 267.231, time for reg: 55.669, time for eig: 81.898\n",
      "epoch:  4199, loss: 0.4595821, train acc: 0.867\n",
      "test loss: 1.1133610, test acc: 0.633\n",
      "poison loss: 1.3674419, poison acc: 0.400\n",
      "elapsed time: 267.911, time for reg: 55.805, time for eig: 82.130\n",
      "epoch:  4209, loss: 0.5113028, train acc: 0.817\n",
      "test loss: 0.9262721, test acc: 0.683\n",
      "poison loss: 0.7647692, poison acc: 0.550\n",
      "elapsed time: 268.513, time for reg: 55.940, time for eig: 82.285\n",
      "epoch:  4219, loss: 0.4056652, train acc: 0.850\n",
      "test loss: 1.0600702, test acc: 0.583\n",
      "poison loss: 0.6415913, poison acc: 0.717\n",
      "elapsed time: 269.156, time for reg: 56.075, time for eig: 82.479\n",
      "epoch:  4229, loss: 0.5102855, train acc: 0.817\n",
      "test loss: 1.1085008, test acc: 0.600\n",
      "poison loss: 0.6563374, poison acc: 0.683\n",
      "elapsed time: 269.759, time for reg: 56.211, time for eig: 82.632\n",
      "epoch:  4239, loss: 0.3864909, train acc: 0.900\n",
      "test loss: 1.2507505, test acc: 0.533\n",
      "poison loss: 0.7123493, poison acc: 0.617\n",
      "elapsed time: 270.391, time for reg: 56.346, time for eig: 82.812\n",
      "epoch:  4249, loss: 0.4347329, train acc: 0.883\n",
      "test loss: 1.1573120, test acc: 0.567\n",
      "poison loss: 0.6716122, poison acc: 0.683\n",
      "elapsed time: 271.059, time for reg: 56.482, time for eig: 83.033\n",
      "epoch:  4259, loss: 0.6501456, train acc: 0.717\n",
      "test loss: 0.9022449, test acc: 0.633\n",
      "poison loss: 1.0313359, poison acc: 0.450\n",
      "elapsed time: 271.663, time for reg: 56.618, time for eig: 83.188\n",
      "epoch:  4269, loss: 0.6387090, train acc: 0.667\n",
      "test loss: 1.0442219, test acc: 0.583\n",
      "poison loss: 1.2378148, poison acc: 0.383\n",
      "elapsed time: 272.281, time for reg: 56.753, time for eig: 83.356\n",
      "epoch:  4279, loss: 0.4008121, train acc: 0.900\n",
      "test loss: 1.0169949, test acc: 0.650\n",
      "poison loss: 0.7734128, poison acc: 0.567\n",
      "elapsed time: 272.843, time for reg: 56.888, time for eig: 83.470\n",
      "epoch:  4289, loss: 0.4792317, train acc: 0.883\n",
      "test loss: 0.9782919, test acc: 0.650\n",
      "poison loss: 0.7158541, poison acc: 0.667\n",
      "elapsed time: 273.475, time for reg: 57.024, time for eig: 83.652\n",
      "epoch:  4299, loss: 0.4660396, train acc: 0.833\n",
      "test loss: 0.9753571, test acc: 0.617\n",
      "poison loss: 0.8239767, poison acc: 0.617\n",
      "elapsed time: 274.131, time for reg: 57.159, time for eig: 83.860\n",
      "epoch:  4309, loss: 0.4135756, train acc: 0.883\n",
      "test loss: 1.0514253, test acc: 0.583\n",
      "poison loss: 0.6556014, poison acc: 0.683\n",
      "elapsed time: 274.834, time for reg: 57.296, time for eig: 84.112\n",
      "epoch:  4319, loss: 0.4603478, train acc: 0.850\n",
      "test loss: 1.0038316, test acc: 0.600\n",
      "poison loss: 0.8478735, poison acc: 0.600\n",
      "elapsed time: 275.439, time for reg: 57.431, time for eig: 84.267\n",
      "epoch:  4329, loss: 0.3663472, train acc: 0.917\n",
      "test loss: 1.1226225, test acc: 0.667\n",
      "poison loss: 0.8682612, poison acc: 0.500\n",
      "elapsed time: 276.019, time for reg: 57.566, time for eig: 84.398\n",
      "epoch:  4339, loss: 0.4116147, train acc: 0.900\n",
      "test loss: 1.1510448, test acc: 0.633\n",
      "poison loss: 0.6870210, poison acc: 0.633\n",
      "elapsed time: 276.644, time for reg: 57.701, time for eig: 84.574\n",
      "epoch:  4349, loss: 0.3907804, train acc: 0.867\n",
      "test loss: 1.0990280, test acc: 0.600\n",
      "poison loss: 0.6909027, poison acc: 0.617\n",
      "elapsed time: 277.286, time for reg: 57.836, time for eig: 84.769\n",
      "epoch:  4359, loss: 0.4603418, train acc: 0.883\n",
      "test loss: 1.4422430, test acc: 0.433\n",
      "poison loss: 0.9444283, poison acc: 0.583\n",
      "elapsed time: 277.931, time for reg: 57.975, time for eig: 84.954\n",
      "epoch:  4369, loss: 0.5490139, train acc: 0.783\n",
      "test loss: 1.0621350, test acc: 0.650\n",
      "poison loss: 1.0018127, poison acc: 0.500\n",
      "elapsed time: 278.575, time for reg: 58.110, time for eig: 85.148\n",
      "epoch:  4379, loss: 0.5287059, train acc: 0.833\n",
      "test loss: 1.0350409, test acc: 0.617\n",
      "poison loss: 0.7061013, poison acc: 0.700\n",
      "elapsed time: 279.208, time for reg: 58.246, time for eig: 85.331\n",
      "epoch:  4389, loss: 0.4633764, train acc: 0.850\n",
      "test loss: 0.9964056, test acc: 0.650\n",
      "poison loss: 0.7798946, poison acc: 0.600\n",
      "elapsed time: 279.887, time for reg: 58.381, time for eig: 85.560\n",
      "epoch:  4399, loss: 0.3188363, train acc: 0.950\n",
      "test loss: 1.1405710, test acc: 0.633\n",
      "poison loss: 0.5915827, poison acc: 0.700\n",
      "elapsed time: 280.494, time for reg: 58.516, time for eig: 85.720\n",
      "epoch:  4409, loss: 0.4838839, train acc: 0.850\n",
      "test loss: 0.9580681, test acc: 0.700\n",
      "poison loss: 0.9991188, poison acc: 0.450\n",
      "elapsed time: 281.082, time for reg: 58.652, time for eig: 85.856\n",
      "epoch:  4419, loss: 0.4498233, train acc: 0.867\n",
      "test loss: 1.1318910, test acc: 0.617\n",
      "poison loss: 0.9172352, poison acc: 0.500\n",
      "elapsed time: 281.675, time for reg: 58.786, time for eig: 85.998\n",
      "epoch:  4429, loss: 0.3156020, train acc: 0.967\n",
      "test loss: 1.1890095, test acc: 0.617\n",
      "poison loss: 0.6160203, poison acc: 0.717\n",
      "elapsed time: 282.315, time for reg: 58.922, time for eig: 86.188\n",
      "epoch:  4439, loss: 0.3862112, train acc: 0.933\n",
      "test loss: 1.1844696, test acc: 0.650\n",
      "poison loss: 0.6958428, poison acc: 0.650\n",
      "elapsed time: 282.964, time for reg: 59.057, time for eig: 86.387\n",
      "epoch:  4449, loss: 0.3418439, train acc: 0.933\n",
      "test loss: 1.0628004, test acc: 0.633\n",
      "poison loss: 0.6010539, poison acc: 0.700\n",
      "elapsed time: 283.711, time for reg: 59.193, time for eig: 86.683\n",
      "epoch:  4459, loss: 0.4278730, train acc: 0.850\n",
      "test loss: 0.8688037, test acc: 0.633\n",
      "poison loss: 1.1633131, poison acc: 0.467\n",
      "elapsed time: 284.297, time for reg: 59.328, time for eig: 86.818\n",
      "epoch:  4469, loss: 0.3844890, train acc: 0.850\n",
      "test loss: 1.1199666, test acc: 0.533\n",
      "poison loss: 0.8299229, poison acc: 0.567\n",
      "elapsed time: 285.024, time for reg: 59.464, time for eig: 87.096\n",
      "epoch:  4479, loss: 0.3840606, train acc: 0.883\n",
      "test loss: 0.9932473, test acc: 0.650\n",
      "poison loss: 0.7522395, poison acc: 0.667\n",
      "elapsed time: 285.615, time for reg: 59.599, time for eig: 87.237\n",
      "epoch:  4489, loss: 0.6078314, train acc: 0.800\n",
      "test loss: 1.1009264, test acc: 0.600\n",
      "poison loss: 0.6648449, poison acc: 0.683\n",
      "elapsed time: 286.199, time for reg: 59.734, time for eig: 87.372\n",
      "epoch:  4499, loss: 0.3863334, train acc: 0.917\n",
      "test loss: 1.1428105, test acc: 0.567\n",
      "poison loss: 0.6673508, poison acc: 0.700\n",
      "elapsed time: 286.851, time for reg: 59.879, time for eig: 87.547\n",
      "epoch:  4509, loss: 0.4609867, train acc: 0.850\n",
      "test loss: 1.1490944, test acc: 0.583\n",
      "poison loss: 1.0488148, poison acc: 0.500\n",
      "elapsed time: 287.462, time for reg: 60.014, time for eig: 87.709\n",
      "epoch:  4519, loss: 0.5088667, train acc: 0.800\n",
      "test loss: 1.0544500, test acc: 0.667\n",
      "poison loss: 0.8991197, poison acc: 0.500\n",
      "elapsed time: 288.045, time for reg: 60.149, time for eig: 87.850\n",
      "epoch:  4529, loss: 0.3272831, train acc: 0.967\n",
      "test loss: 1.2227604, test acc: 0.600\n",
      "poison loss: 0.5808569, poison acc: 0.700\n",
      "elapsed time: 288.649, time for reg: 60.285, time for eig: 88.008\n",
      "epoch:  4539, loss: 0.4349034, train acc: 0.800\n",
      "test loss: 1.1170621, test acc: 0.583\n",
      "poison loss: 0.6830736, poison acc: 0.633\n",
      "elapsed time: 289.249, time for reg: 60.424, time for eig: 88.155\n",
      "epoch:  4549, loss: 0.3665098, train acc: 0.883\n",
      "test loss: 1.1508945, test acc: 0.567\n",
      "poison loss: 0.6695362, poison acc: 0.683\n",
      "elapsed time: 289.834, time for reg: 60.560, time for eig: 88.291\n",
      "epoch:  4559, loss: 0.4026065, train acc: 0.867\n",
      "test loss: 1.1528212, test acc: 0.583\n",
      "poison loss: 0.6907818, poison acc: 0.650\n",
      "elapsed time: 290.470, time for reg: 60.694, time for eig: 88.479\n",
      "epoch:  4569, loss: 0.3479692, train acc: 0.900\n",
      "test loss: 1.1238492, test acc: 0.617\n",
      "poison loss: 0.5928794, poison acc: 0.717\n",
      "elapsed time: 291.094, time for reg: 60.829, time for eig: 88.654\n",
      "epoch:  4579, loss: 0.5829875, train acc: 0.850\n",
      "test loss: 1.1351771, test acc: 0.583\n",
      "poison loss: 0.7199727, poison acc: 0.600\n",
      "elapsed time: 291.758, time for reg: 60.965, time for eig: 88.867\n",
      "epoch:  4589, loss: 0.4188040, train acc: 0.817\n",
      "test loss: 1.0045605, test acc: 0.650\n",
      "poison loss: 0.7254560, poison acc: 0.650\n",
      "elapsed time: 292.388, time for reg: 61.101, time for eig: 89.048\n",
      "epoch:  4599, loss: 0.5857909, train acc: 0.800\n",
      "test loss: 1.0908083, test acc: 0.617\n",
      "poison loss: 0.9889128, poison acc: 0.583\n",
      "elapsed time: 293.160, time for reg: 61.235, time for eig: 89.371\n",
      "epoch:  4609, loss: 0.3407978, train acc: 0.933\n",
      "test loss: 1.1511940, test acc: 0.683\n",
      "poison loss: 0.7834636, poison acc: 0.600\n",
      "elapsed time: 293.771, time for reg: 61.377, time for eig: 89.522\n",
      "epoch:  4619, loss: 0.3112986, train acc: 0.950\n",
      "test loss: 1.1713528, test acc: 0.583\n",
      "poison loss: 0.5450392, poison acc: 0.733\n",
      "elapsed time: 294.341, time for reg: 61.508, time for eig: 89.657\n",
      "epoch:  4629, loss: 0.3382381, train acc: 0.900\n",
      "test loss: 1.0617702, test acc: 0.717\n",
      "poison loss: 0.6895844, poison acc: 0.600\n",
      "elapsed time: 294.925, time for reg: 61.639, time for eig: 89.802\n",
      "epoch:  4639, loss: 0.6453851, train acc: 0.767\n",
      "test loss: 1.1759733, test acc: 0.600\n",
      "poison loss: 0.5672845, poison acc: 0.733\n",
      "elapsed time: 295.474, time for reg: 61.770, time for eig: 89.914\n",
      "epoch:  4649, loss: 0.4078264, train acc: 0.867\n",
      "test loss: 1.0611650, test acc: 0.667\n",
      "poison loss: 1.0998296, poison acc: 0.433\n",
      "elapsed time: 296.101, time for reg: 61.901, time for eig: 90.102\n",
      "epoch:  4659, loss: 0.3442803, train acc: 0.917\n",
      "test loss: 1.1578727, test acc: 0.633\n",
      "poison loss: 0.7248020, poison acc: 0.633\n",
      "elapsed time: 296.744, time for reg: 62.031, time for eig: 90.307\n",
      "epoch:  4669, loss: 0.3530855, train acc: 0.917\n",
      "test loss: 1.2524771, test acc: 0.633\n",
      "poison loss: 0.5735014, poison acc: 0.683\n",
      "elapsed time: 297.372, time for reg: 62.162, time for eig: 90.496\n",
      "epoch:  4679, loss: 0.3651916, train acc: 0.917\n",
      "test loss: 1.1876200, test acc: 0.667\n",
      "poison loss: 0.7393481, poison acc: 0.583\n",
      "elapsed time: 298.006, time for reg: 62.305, time for eig: 90.656\n",
      "epoch:  4689, loss: 0.3026991, train acc: 0.950\n",
      "test loss: 1.1100981, test acc: 0.683\n",
      "poison loss: 0.5461875, poison acc: 0.733\n",
      "elapsed time: 298.935, time for reg: 62.442, time for eig: 91.131\n",
      "epoch:  4699, loss: 0.3451494, train acc: 0.900\n",
      "test loss: 1.3214388, test acc: 0.600\n",
      "poison loss: 0.6193834, poison acc: 0.700\n",
      "elapsed time: 299.569, time for reg: 62.584, time for eig: 91.313\n",
      "epoch:  4709, loss: 0.4064043, train acc: 0.867\n",
      "test loss: 1.1668894, test acc: 0.550\n",
      "poison loss: 0.5473261, poison acc: 0.767\n",
      "elapsed time: 300.197, time for reg: 62.735, time for eig: 91.436\n",
      "epoch:  4719, loss: 0.3699765, train acc: 0.883\n",
      "test loss: 1.2550831, test acc: 0.550\n",
      "poison loss: 0.5419103, poison acc: 0.717\n",
      "elapsed time: 300.959, time for reg: 62.878, time for eig: 91.726\n",
      "epoch:  4729, loss: 0.7237415, train acc: 0.783\n",
      "test loss: 1.2407987, test acc: 0.533\n",
      "poison loss: 1.0878767, poison acc: 0.567\n",
      "elapsed time: 301.694, time for reg: 63.013, time for eig: 92.011\n",
      "epoch:  4739, loss: 0.3378750, train acc: 0.933\n",
      "test loss: 1.1625987, test acc: 0.667\n",
      "poison loss: 0.5428558, poison acc: 0.717\n",
      "elapsed time: 302.299, time for reg: 63.148, time for eig: 92.166\n",
      "epoch:  4749, loss: 0.2728136, train acc: 0.917\n",
      "test loss: 1.1628389, test acc: 0.633\n",
      "poison loss: 0.5099053, poison acc: 0.717\n",
      "elapsed time: 302.959, time for reg: 63.283, time for eig: 92.374\n",
      "epoch:  4759, loss: 0.3444327, train acc: 0.900\n",
      "test loss: 1.0783973, test acc: 0.617\n",
      "poison loss: 0.5760261, poison acc: 0.700\n",
      "elapsed time: 303.548, time for reg: 63.418, time for eig: 92.512\n",
      "epoch:  4769, loss: 0.3076116, train acc: 0.950\n",
      "test loss: 1.1761612, test acc: 0.633\n",
      "poison loss: 0.5021812, poison acc: 0.750\n",
      "elapsed time: 304.162, time for reg: 63.554, time for eig: 92.674\n",
      "epoch:  4779, loss: 0.4330492, train acc: 0.817\n",
      "test loss: 1.0733658, test acc: 0.667\n",
      "poison loss: 0.7350533, poison acc: 0.583\n",
      "elapsed time: 304.773, time for reg: 63.690, time for eig: 92.834\n",
      "epoch:  4789, loss: 0.2795539, train acc: 0.950\n",
      "test loss: 1.2301899, test acc: 0.517\n",
      "poison loss: 0.5177608, poison acc: 0.750\n",
      "elapsed time: 305.378, time for reg: 63.825, time for eig: 92.990\n",
      "epoch:  4799, loss: 0.3322031, train acc: 0.900\n",
      "test loss: 1.2001908, test acc: 0.583\n",
      "poison loss: 0.5136893, poison acc: 0.717\n",
      "elapsed time: 306.043, time for reg: 63.960, time for eig: 93.205\n",
      "epoch:  4809, loss: 0.7625184, train acc: 0.683\n",
      "test loss: 1.0012877, test acc: 0.683\n",
      "poison loss: 1.2641325, poison acc: 0.400\n",
      "elapsed time: 306.613, time for reg: 64.096, time for eig: 93.324\n",
      "epoch:  4819, loss: 0.3166389, train acc: 0.917\n",
      "test loss: 1.1320913, test acc: 0.600\n",
      "poison loss: 1.0414965, poison acc: 0.483\n",
      "elapsed time: 307.291, time for reg: 64.231, time for eig: 93.549\n",
      "epoch:  4829, loss: 0.4125925, train acc: 0.867\n",
      "test loss: 1.7319850, test acc: 0.383\n",
      "poison loss: 1.2588134, poison acc: 0.617\n",
      "elapsed time: 307.860, time for reg: 64.367, time for eig: 93.669\n",
      "epoch:  4839, loss: 0.4101288, train acc: 0.850\n",
      "test loss: 1.2482319, test acc: 0.583\n",
      "poison loss: 0.6595006, poison acc: 0.617\n",
      "elapsed time: 308.453, time for reg: 64.501, time for eig: 93.814\n",
      "epoch:  4849, loss: 0.3052206, train acc: 0.950\n",
      "test loss: 1.2493925, test acc: 0.600\n",
      "poison loss: 0.5225261, poison acc: 0.717\n",
      "elapsed time: 309.056, time for reg: 64.636, time for eig: 93.967\n",
      "epoch:  4859, loss: 0.3291148, train acc: 0.900\n",
      "test loss: 1.2053769, test acc: 0.567\n",
      "poison loss: 0.5204118, poison acc: 0.733\n",
      "elapsed time: 309.696, time for reg: 64.771, time for eig: 94.162\n",
      "epoch:  4869, loss: 0.3022160, train acc: 0.950\n",
      "test loss: 1.1779742, test acc: 0.617\n",
      "poison loss: 0.4952195, poison acc: 0.733\n",
      "elapsed time: 310.285, time for reg: 64.906, time for eig: 94.300\n",
      "epoch:  4879, loss: 0.4389665, train acc: 0.867\n",
      "test loss: 1.1986669, test acc: 0.583\n",
      "poison loss: 0.5421053, poison acc: 0.733\n",
      "elapsed time: 310.905, time for reg: 65.042, time for eig: 94.472\n",
      "epoch:  4889, loss: 0.6046291, train acc: 0.717\n",
      "test loss: 1.0940095, test acc: 0.600\n",
      "poison loss: 1.2433122, poison acc: 0.467\n",
      "elapsed time: 311.779, time for reg: 65.178, time for eig: 94.898\n",
      "epoch:  4899, loss: 0.3668866, train acc: 0.900\n",
      "test loss: 1.2585880, test acc: 0.667\n",
      "poison loss: 0.6523085, poison acc: 0.650\n",
      "elapsed time: 312.376, time for reg: 65.314, time for eig: 95.047\n",
      "epoch:  4909, loss: 0.3769514, train acc: 0.867\n",
      "test loss: 1.3170118, test acc: 0.650\n",
      "poison loss: 0.7133109, poison acc: 0.650\n",
      "elapsed time: 312.965, time for reg: 65.450, time for eig: 95.189\n",
      "epoch:  4919, loss: 0.5691353, train acc: 0.800\n",
      "test loss: 1.2770709, test acc: 0.583\n",
      "poison loss: 0.6062616, poison acc: 0.683\n",
      "elapsed time: 313.572, time for reg: 65.585, time for eig: 95.349\n",
      "epoch:  4929, loss: 0.3150565, train acc: 0.917\n",
      "test loss: 1.1997492, test acc: 0.617\n",
      "poison loss: 0.5180253, poison acc: 0.733\n",
      "elapsed time: 314.135, time for reg: 65.720, time for eig: 95.461\n",
      "epoch:  4939, loss: 0.3488904, train acc: 0.883\n",
      "test loss: 1.1316215, test acc: 0.683\n",
      "poison loss: 0.6176607, poison acc: 0.683\n",
      "elapsed time: 314.747, time for reg: 65.856, time for eig: 95.626\n",
      "epoch:  4949, loss: 0.3053641, train acc: 0.917\n",
      "test loss: 1.1847167, test acc: 0.633\n",
      "poison loss: 0.5138297, poison acc: 0.717\n",
      "elapsed time: 315.354, time for reg: 65.992, time for eig: 95.783\n",
      "epoch:  4959, loss: 0.3038862, train acc: 0.950\n",
      "test loss: 1.2216147, test acc: 0.600\n",
      "poison loss: 0.5093569, poison acc: 0.750\n",
      "elapsed time: 315.973, time for reg: 66.127, time for eig: 95.951\n",
      "epoch:  4969, loss: 0.4733128, train acc: 0.833\n",
      "test loss: 1.3183183, test acc: 0.583\n",
      "poison loss: 1.0997558, poison acc: 0.467\n",
      "elapsed time: 316.529, time for reg: 66.263, time for eig: 96.069\n",
      "epoch:  4979, loss: 0.2982387, train acc: 0.933\n",
      "test loss: 1.1608691, test acc: 0.617\n",
      "poison loss: 0.5190653, poison acc: 0.750\n",
      "elapsed time: 317.338, time for reg: 66.399, time for eig: 96.451\n",
      "epoch:  4989, loss: 0.3728264, train acc: 0.850\n",
      "test loss: 1.3095402, test acc: 0.633\n",
      "poison loss: 1.1412456, poison acc: 0.467\n",
      "elapsed time: 317.910, time for reg: 66.535, time for eig: 96.594\n",
      "epoch:  4999, loss: 0.3746950, train acc: 0.917\n",
      "test loss: 1.1334508, test acc: 0.683\n",
      "poison loss: 0.6246208, poison acc: 0.617\n",
      "elapsed time: 318.500, time for reg: 66.670, time for eig: 96.743\n",
      "epoch:  5009, loss: 0.2963025, train acc: 0.900\n",
      "test loss: 1.2240856, test acc: 0.600\n",
      "poison loss: 0.4746818, poison acc: 0.733\n",
      "elapsed time: 319.135, time for reg: 66.805, time for eig: 96.933\n",
      "epoch:  5019, loss: 0.3682392, train acc: 0.883\n",
      "test loss: 1.1390454, test acc: 0.683\n",
      "poison loss: 0.5434300, poison acc: 0.683\n",
      "elapsed time: 319.779, time for reg: 66.940, time for eig: 97.130\n",
      "epoch:  5029, loss: 0.4456925, train acc: 0.850\n",
      "test loss: 1.7694751, test acc: 0.417\n",
      "poison loss: 1.0622226, poison acc: 0.483\n",
      "elapsed time: 320.401, time for reg: 67.075, time for eig: 97.301\n",
      "epoch:  5039, loss: 0.4315903, train acc: 0.783\n",
      "test loss: 1.6013879, test acc: 0.500\n",
      "poison loss: 0.8917038, poison acc: 0.567\n",
      "elapsed time: 321.071, time for reg: 67.211, time for eig: 97.521\n",
      "epoch:  5049, loss: 0.3504673, train acc: 0.883\n",
      "test loss: 1.3821548, test acc: 0.533\n",
      "poison loss: 0.6206324, poison acc: 0.683\n",
      "elapsed time: 321.832, time for reg: 67.346, time for eig: 97.832\n",
      "epoch:  5059, loss: 0.3076280, train acc: 0.900\n",
      "test loss: 1.2069960, test acc: 0.650\n",
      "poison loss: 0.4902082, poison acc: 0.750\n",
      "elapsed time: 323.045, time for reg: 67.481, time for eig: 98.596\n",
      "epoch:  5069, loss: 0.3552421, train acc: 0.850\n",
      "test loss: 1.3304058, test acc: 0.650\n",
      "poison loss: 0.8574866, poison acc: 0.600\n",
      "elapsed time: 323.691, time for reg: 67.616, time for eig: 98.791\n",
      "epoch:  5079, loss: 0.2672592, train acc: 0.933\n",
      "test loss: 1.2464150, test acc: 0.633\n",
      "poison loss: 0.4468151, poison acc: 0.783\n",
      "elapsed time: 324.511, time for reg: 67.752, time for eig: 99.160\n",
      "epoch:  5089, loss: 0.2616435, train acc: 0.950\n",
      "test loss: 1.3085693, test acc: 0.517\n",
      "poison loss: 0.4727976, poison acc: 0.767\n",
      "elapsed time: 325.166, time for reg: 67.887, time for eig: 99.364\n",
      "epoch:  5099, loss: 0.3136619, train acc: 0.933\n",
      "test loss: 1.2246600, test acc: 0.600\n",
      "poison loss: 0.4754141, poison acc: 0.767\n",
      "elapsed time: 325.956, time for reg: 68.022, time for eig: 99.703\n",
      "epoch:  5109, loss: 0.7703413, train acc: 0.667\n",
      "test loss: 1.2267815, test acc: 0.633\n",
      "poison loss: 0.9966917, poison acc: 0.550\n",
      "elapsed time: 326.555, time for reg: 68.158, time for eig: 99.850\n",
      "epoch:  5119, loss: 0.2570650, train acc: 0.917\n",
      "test loss: 1.2604846, test acc: 0.583\n",
      "poison loss: 0.4381751, poison acc: 0.767\n",
      "elapsed time: 327.171, time for reg: 68.293, time for eig: 100.016\n",
      "epoch:  5129, loss: 0.7158986, train acc: 0.683\n",
      "test loss: 1.1698589, test acc: 0.517\n",
      "poison loss: 0.9308990, poison acc: 0.500\n",
      "elapsed time: 327.759, time for reg: 68.428, time for eig: 100.153\n",
      "epoch:  5139, loss: 0.3086070, train acc: 0.917\n",
      "test loss: 1.1973510, test acc: 0.667\n",
      "poison loss: 0.5124520, poison acc: 0.733\n",
      "elapsed time: 328.454, time for reg: 68.564, time for eig: 100.396\n",
      "epoch:  5149, loss: 0.3005950, train acc: 0.900\n",
      "test loss: 1.2049344, test acc: 0.633\n",
      "poison loss: 0.4765791, poison acc: 0.733\n",
      "elapsed time: 329.058, time for reg: 68.699, time for eig: 100.549\n",
      "epoch:  5159, loss: 0.2475225, train acc: 0.967\n",
      "test loss: 1.4464026, test acc: 0.550\n",
      "poison loss: 0.5173749, poison acc: 0.750\n",
      "elapsed time: 329.679, time for reg: 68.834, time for eig: 100.719\n",
      "epoch:  5169, loss: 0.2925730, train acc: 0.950\n",
      "test loss: 1.2209567, test acc: 0.650\n",
      "poison loss: 0.4615240, poison acc: 0.733\n",
      "elapsed time: 330.373, time for reg: 68.969, time for eig: 100.962\n",
      "epoch:  5179, loss: 0.3468423, train acc: 0.900\n",
      "test loss: 1.1521259, test acc: 0.633\n",
      "poison loss: 0.5240755, poison acc: 0.733\n",
      "elapsed time: 330.954, time for reg: 69.104, time for eig: 101.093\n",
      "epoch:  5189, loss: 0.5700571, train acc: 0.783\n",
      "test loss: 1.1587681, test acc: 0.600\n",
      "poison loss: 0.5286902, poison acc: 0.733\n",
      "elapsed time: 331.567, time for reg: 69.239, time for eig: 101.255\n",
      "epoch:  5199, loss: 0.4335711, train acc: 0.883\n",
      "test loss: 1.2414593, test acc: 0.667\n",
      "poison loss: 0.4703144, poison acc: 0.717\n",
      "elapsed time: 332.152, time for reg: 69.375, time for eig: 101.389\n",
      "epoch:  5209, loss: 0.2946087, train acc: 0.883\n",
      "test loss: 1.2581511, test acc: 0.600\n",
      "poison loss: 0.5127896, poison acc: 0.700\n",
      "elapsed time: 332.736, time for reg: 69.510, time for eig: 101.522\n",
      "epoch:  5219, loss: 0.4210926, train acc: 0.833\n",
      "test loss: 1.5478903, test acc: 0.517\n",
      "poison loss: 0.9664166, poison acc: 0.550\n",
      "elapsed time: 333.347, time for reg: 69.645, time for eig: 101.684\n",
      "epoch:  5229, loss: 0.2593127, train acc: 0.933\n",
      "test loss: 1.2549617, test acc: 0.683\n",
      "poison loss: 0.4330204, poison acc: 0.767\n",
      "elapsed time: 334.152, time for reg: 69.780, time for eig: 102.038\n",
      "epoch:  5239, loss: 0.3687215, train acc: 0.867\n",
      "test loss: 1.1160425, test acc: 0.600\n",
      "poison loss: 0.6908527, poison acc: 0.683\n",
      "elapsed time: 334.724, time for reg: 69.915, time for eig: 102.159\n",
      "epoch:  5249, loss: 0.2852648, train acc: 0.917\n",
      "test loss: 1.4296886, test acc: 0.517\n",
      "poison loss: 0.6862853, poison acc: 0.617\n",
      "elapsed time: 335.460, time for reg: 70.051, time for eig: 102.442\n",
      "epoch:  5259, loss: 0.3724675, train acc: 0.850\n",
      "test loss: 1.1832443, test acc: 0.617\n",
      "poison loss: 0.5338366, poison acc: 0.750\n",
      "elapsed time: 336.087, time for reg: 70.186, time for eig: 102.621\n",
      "epoch:  5269, loss: 0.3275875, train acc: 0.900\n",
      "test loss: 1.1447909, test acc: 0.633\n",
      "poison loss: 0.5090157, poison acc: 0.783\n",
      "elapsed time: 336.760, time for reg: 70.321, time for eig: 102.845\n",
      "epoch:  5279, loss: 0.3830899, train acc: 0.883\n",
      "test loss: 1.1353874, test acc: 0.683\n",
      "poison loss: 0.6374954, poison acc: 0.667\n",
      "elapsed time: 337.378, time for reg: 70.456, time for eig: 103.012\n",
      "epoch:  5289, loss: 0.2997262, train acc: 0.917\n",
      "test loss: 1.1989980, test acc: 0.600\n",
      "poison loss: 0.4410476, poison acc: 0.783\n",
      "elapsed time: 338.063, time for reg: 70.592, time for eig: 103.245\n",
      "epoch:  5299, loss: 0.4000196, train acc: 0.833\n",
      "test loss: 1.3816075, test acc: 0.600\n",
      "poison loss: 0.5625250, poison acc: 0.667\n",
      "elapsed time: 338.742, time for reg: 70.727, time for eig: 103.473\n",
      "epoch:  5309, loss: 0.3001492, train acc: 0.883\n",
      "test loss: 1.3577873, test acc: 0.550\n",
      "poison loss: 0.5244838, poison acc: 0.717\n",
      "elapsed time: 339.442, time for reg: 70.862, time for eig: 103.723\n",
      "epoch:  5319, loss: 0.3128508, train acc: 0.883\n",
      "test loss: 1.4287760, test acc: 0.583\n",
      "poison loss: 0.5899013, poison acc: 0.750\n",
      "elapsed time: 340.011, time for reg: 70.997, time for eig: 103.845\n",
      "epoch:  5329, loss: 0.2428101, train acc: 0.933\n",
      "test loss: 1.4017767, test acc: 0.533\n",
      "poison loss: 0.6057829, poison acc: 0.733\n",
      "elapsed time: 340.657, time for reg: 71.133, time for eig: 104.042\n",
      "epoch:  5339, loss: 0.2808256, train acc: 0.900\n",
      "test loss: 1.2938944, test acc: 0.633\n",
      "poison loss: 0.4430771, poison acc: 0.767\n",
      "elapsed time: 341.280, time for reg: 71.268, time for eig: 104.213\n",
      "epoch:  5349, loss: 0.3424846, train acc: 0.883\n",
      "test loss: 1.1899699, test acc: 0.667\n",
      "poison loss: 0.4826330, poison acc: 0.717\n",
      "elapsed time: 341.955, time for reg: 71.404, time for eig: 104.437\n",
      "epoch:  5359, loss: 0.5681910, train acc: 0.800\n",
      "test loss: 1.2108620, test acc: 0.550\n",
      "poison loss: 0.6013413, poison acc: 0.700\n",
      "elapsed time: 342.580, time for reg: 71.538, time for eig: 104.616\n",
      "epoch:  5369, loss: 0.3161178, train acc: 0.883\n",
      "test loss: 1.2337494, test acc: 0.633\n",
      "poison loss: 0.4540047, poison acc: 0.783\n",
      "elapsed time: 343.193, time for reg: 71.674, time for eig: 104.781\n",
      "epoch:  5379, loss: 0.3168713, train acc: 0.900\n",
      "test loss: 1.2479267, test acc: 0.650\n",
      "poison loss: 0.5047357, poison acc: 0.700\n",
      "elapsed time: 343.814, time for reg: 71.809, time for eig: 104.951\n",
      "epoch:  5389, loss: 0.2868721, train acc: 0.900\n",
      "test loss: 1.2536434, test acc: 0.633\n",
      "poison loss: 0.4388107, poison acc: 0.750\n",
      "elapsed time: 344.479, time for reg: 71.945, time for eig: 105.171\n",
      "epoch:  5399, loss: 0.4559278, train acc: 0.867\n",
      "test loss: 1.4528718, test acc: 0.550\n",
      "poison loss: 0.8922565, poison acc: 0.550\n",
      "elapsed time: 345.067, time for reg: 72.080, time for eig: 105.310\n",
      "epoch:  5409, loss: 0.3550938, train acc: 0.883\n",
      "test loss: 1.2062964, test acc: 0.600\n",
      "poison loss: 0.5952261, poison acc: 0.683\n",
      "elapsed time: 345.725, time for reg: 72.215, time for eig: 105.517\n",
      "epoch:  5419, loss: 0.2615348, train acc: 0.933\n",
      "test loss: 1.5318772, test acc: 0.567\n",
      "poison loss: 0.6176985, poison acc: 0.717\n",
      "elapsed time: 346.308, time for reg: 72.351, time for eig: 105.652\n",
      "epoch:  5429, loss: 0.3208198, train acc: 0.883\n",
      "test loss: 1.3531528, test acc: 0.617\n",
      "poison loss: 0.4904244, poison acc: 0.750\n",
      "elapsed time: 346.927, time for reg: 72.486, time for eig: 105.827\n",
      "epoch:  5439, loss: 0.3333747, train acc: 0.900\n",
      "test loss: 1.3754616, test acc: 0.567\n",
      "poison loss: 0.6146376, poison acc: 0.667\n",
      "elapsed time: 347.540, time for reg: 72.622, time for eig: 105.989\n",
      "epoch:  5449, loss: 0.4556816, train acc: 0.850\n",
      "test loss: 1.3110825, test acc: 0.533\n",
      "poison loss: 0.5006391, poison acc: 0.767\n",
      "elapsed time: 348.151, time for reg: 72.757, time for eig: 106.150\n",
      "epoch:  5459, loss: 0.2925545, train acc: 0.917\n",
      "test loss: 1.3267311, test acc: 0.550\n",
      "poison loss: 0.6537880, poison acc: 0.700\n",
      "elapsed time: 348.767, time for reg: 72.893, time for eig: 106.314\n",
      "epoch:  5469, loss: 0.3233597, train acc: 0.883\n",
      "test loss: 1.1743691, test acc: 0.650\n",
      "poison loss: 0.4821691, poison acc: 0.733\n",
      "elapsed time: 349.400, time for reg: 73.029, time for eig: 106.495\n",
      "epoch:  5479, loss: 0.3535572, train acc: 0.867\n",
      "test loss: 1.1850407, test acc: 0.650\n",
      "poison loss: 0.5214323, poison acc: 0.700\n",
      "elapsed time: 350.024, time for reg: 73.165, time for eig: 106.667\n",
      "epoch:  5489, loss: 0.3318978, train acc: 0.817\n",
      "test loss: 1.2147810, test acc: 0.600\n",
      "poison loss: 0.6520536, poison acc: 0.683\n",
      "elapsed time: 350.690, time for reg: 73.300, time for eig: 106.884\n",
      "epoch:  5499, loss: 0.5073383, train acc: 0.833\n",
      "test loss: 1.7856486, test acc: 0.417\n",
      "poison loss: 0.5069906, poison acc: 0.750\n",
      "elapsed time: 351.292, time for reg: 73.435, time for eig: 107.034\n",
      "epoch:  5509, loss: 0.2631316, train acc: 0.900\n",
      "test loss: 1.2214526, test acc: 0.617\n",
      "poison loss: 0.3971378, poison acc: 0.817\n",
      "elapsed time: 351.919, time for reg: 73.571, time for eig: 107.213\n",
      "epoch:  5519, loss: 0.3177929, train acc: 0.917\n",
      "test loss: 1.4653406, test acc: 0.550\n",
      "poison loss: 0.4224586, poison acc: 0.800\n",
      "elapsed time: 352.545, time for reg: 73.706, time for eig: 107.391\n",
      "epoch:  5529, loss: 0.2789900, train acc: 0.933\n",
      "test loss: 1.4451152, test acc: 0.550\n",
      "poison loss: 0.5968460, poison acc: 0.683\n",
      "elapsed time: 353.130, time for reg: 73.842, time for eig: 107.524\n",
      "epoch:  5539, loss: 0.2782318, train acc: 0.900\n",
      "test loss: 1.5352669, test acc: 0.583\n",
      "poison loss: 0.6915116, poison acc: 0.650\n",
      "elapsed time: 353.795, time for reg: 73.977, time for eig: 107.744\n",
      "epoch:  5549, loss: 0.2752731, train acc: 0.900\n",
      "test loss: 1.3126666, test acc: 0.617\n",
      "poison loss: 0.4414888, poison acc: 0.800\n",
      "elapsed time: 354.410, time for reg: 74.113, time for eig: 107.905\n",
      "epoch:  5559, loss: 0.4338366, train acc: 0.817\n",
      "test loss: 1.3329476, test acc: 0.633\n",
      "poison loss: 0.4666159, poison acc: 0.783\n",
      "elapsed time: 355.089, time for reg: 74.249, time for eig: 108.135\n",
      "epoch:  5569, loss: 0.7536620, train acc: 0.767\n",
      "test loss: 1.6536878, test acc: 0.483\n",
      "poison loss: 0.7435576, poison acc: 0.633\n",
      "elapsed time: 355.710, time for reg: 74.385, time for eig: 108.308\n",
      "epoch:  5579, loss: 0.2407552, train acc: 0.933\n",
      "test loss: 1.4469960, test acc: 0.633\n",
      "poison loss: 0.4017312, poison acc: 0.800\n",
      "elapsed time: 356.299, time for reg: 74.521, time for eig: 108.443\n",
      "epoch:  5589, loss: 0.2550418, train acc: 0.917\n",
      "test loss: 1.5160952, test acc: 0.483\n",
      "poison loss: 0.4651270, poison acc: 0.767\n",
      "elapsed time: 356.945, time for reg: 74.656, time for eig: 108.642\n",
      "epoch:  5599, loss: 0.3444420, train acc: 0.850\n",
      "test loss: 1.4489219, test acc: 0.600\n",
      "poison loss: 0.5009536, poison acc: 0.750\n",
      "elapsed time: 357.575, time for reg: 74.792, time for eig: 108.823\n",
      "epoch:  5609, loss: 0.2764941, train acc: 0.900\n",
      "test loss: 1.5839937, test acc: 0.517\n",
      "poison loss: 0.5679959, poison acc: 0.750\n",
      "elapsed time: 358.193, time for reg: 74.927, time for eig: 108.995\n",
      "epoch:  5619, loss: 0.2938204, train acc: 0.867\n",
      "test loss: 1.4337081, test acc: 0.583\n",
      "poison loss: 0.3907599, poison acc: 0.817\n",
      "elapsed time: 358.794, time for reg: 75.064, time for eig: 109.143\n",
      "epoch:  5629, loss: 0.2920364, train acc: 0.850\n",
      "test loss: 1.4352388, test acc: 0.567\n",
      "poison loss: 0.4940002, poison acc: 0.767\n",
      "elapsed time: 359.425, time for reg: 75.206, time for eig: 109.310\n",
      "epoch:  5639, loss: 0.7414213, train acc: 0.767\n",
      "test loss: 1.2950964, test acc: 0.567\n",
      "poison loss: 1.0833658, poison acc: 0.567\n",
      "elapsed time: 360.016, time for reg: 75.337, time for eig: 109.468\n",
      "epoch:  5649, loss: 0.5416834, train acc: 0.767\n",
      "test loss: 1.4289668, test acc: 0.533\n",
      "poison loss: 0.4186723, poison acc: 0.800\n",
      "elapsed time: 360.610, time for reg: 75.468, time for eig: 109.626\n",
      "epoch:  5659, loss: 0.2348889, train acc: 0.933\n",
      "test loss: 1.3683459, test acc: 0.567\n",
      "poison loss: 0.4192371, poison acc: 0.783\n",
      "elapsed time: 361.363, time for reg: 75.598, time for eig: 109.941\n",
      "epoch:  5669, loss: 0.2781132, train acc: 0.883\n",
      "test loss: 1.3509005, test acc: 0.633\n",
      "poison loss: 0.3989958, poison acc: 0.767\n",
      "elapsed time: 361.952, time for reg: 75.729, time for eig: 110.093\n",
      "epoch:  5679, loss: 0.2638589, train acc: 0.933\n",
      "test loss: 1.4300579, test acc: 0.567\n",
      "poison loss: 0.5764257, poison acc: 0.667\n",
      "elapsed time: 362.549, time for reg: 75.860, time for eig: 110.252\n",
      "epoch:  5689, loss: 0.3217611, train acc: 0.850\n",
      "test loss: 1.3770406, test acc: 0.583\n",
      "poison loss: 0.5128834, poison acc: 0.750\n",
      "elapsed time: 363.222, time for reg: 75.990, time for eig: 110.487\n",
      "epoch:  5699, loss: 0.2341228, train acc: 0.950\n",
      "test loss: 1.4542327, test acc: 0.550\n",
      "poison loss: 0.3962126, poison acc: 0.800\n",
      "elapsed time: 364.505, time for reg: 76.121, time for eig: 111.332\n",
      "epoch:  5709, loss: 0.2509075, train acc: 0.933\n",
      "test loss: 1.3637904, test acc: 0.600\n",
      "poison loss: 0.4081361, poison acc: 0.800\n",
      "elapsed time: 365.274, time for reg: 76.251, time for eig: 111.662\n",
      "epoch:  5719, loss: 0.2843404, train acc: 0.867\n",
      "test loss: 1.5129033, test acc: 0.567\n",
      "poison loss: 0.4435684, poison acc: 0.750\n",
      "elapsed time: 365.835, time for reg: 76.382, time for eig: 111.785\n",
      "epoch:  5729, loss: 0.3567187, train acc: 0.867\n",
      "test loss: 1.4047613, test acc: 0.600\n",
      "poison loss: 0.4078959, poison acc: 0.800\n",
      "elapsed time: 366.483, time for reg: 76.512, time for eig: 111.997\n",
      "epoch:  5739, loss: 0.2530052, train acc: 0.900\n",
      "test loss: 1.4656669, test acc: 0.567\n",
      "poison loss: 0.3744545, poison acc: 0.850\n",
      "elapsed time: 367.090, time for reg: 76.642, time for eig: 112.167\n",
      "epoch:  5749, loss: 0.4126107, train acc: 0.850\n",
      "test loss: 1.4789613, test acc: 0.550\n",
      "poison loss: 0.4591855, poison acc: 0.767\n",
      "elapsed time: 367.736, time for reg: 76.773, time for eig: 112.377\n",
      "epoch:  5759, loss: 0.3002969, train acc: 0.900\n",
      "test loss: 1.4357877, test acc: 0.583\n",
      "poison loss: 0.4285105, poison acc: 0.733\n",
      "elapsed time: 368.317, time for reg: 76.903, time for eig: 112.523\n",
      "epoch:  5769, loss: 0.2828892, train acc: 0.883\n",
      "test loss: 1.4122253, test acc: 0.567\n",
      "poison loss: 0.4443566, poison acc: 0.767\n",
      "elapsed time: 369.131, time for reg: 77.034, time for eig: 112.900\n",
      "epoch:  5779, loss: 0.2932120, train acc: 0.900\n",
      "test loss: 1.3962362, test acc: 0.583\n",
      "poison loss: 0.3855837, poison acc: 0.800\n",
      "elapsed time: 369.710, time for reg: 77.165, time for eig: 113.041\n",
      "epoch:  5789, loss: 0.3910365, train acc: 0.817\n",
      "test loss: 1.2882382, test acc: 0.650\n",
      "poison loss: 0.6292166, poison acc: 0.733\n",
      "elapsed time: 370.320, time for reg: 77.295, time for eig: 113.214\n",
      "epoch:  5799, loss: 0.3274302, train acc: 0.850\n",
      "test loss: 1.4814313, test acc: 0.550\n",
      "poison loss: 0.4272316, poison acc: 0.833\n",
      "elapsed time: 370.913, time for reg: 77.426, time for eig: 113.369\n",
      "epoch:  5809, loss: 0.2143342, train acc: 0.933\n",
      "test loss: 1.5938353, test acc: 0.533\n",
      "poison loss: 0.4605490, poison acc: 0.750\n",
      "elapsed time: 371.515, time for reg: 77.556, time for eig: 113.534\n",
      "epoch:  5819, loss: 0.2237404, train acc: 0.917\n",
      "test loss: 1.5848061, test acc: 0.600\n",
      "poison loss: 0.4350934, poison acc: 0.800\n",
      "elapsed time: 372.174, time for reg: 77.688, time for eig: 113.754\n",
      "epoch:  5829, loss: 0.2979772, train acc: 0.883\n",
      "test loss: 1.4491771, test acc: 0.550\n",
      "poison loss: 0.3636622, poison acc: 0.800\n",
      "elapsed time: 372.739, time for reg: 77.817, time for eig: 113.883\n",
      "epoch:  5839, loss: 0.2383931, train acc: 0.933\n",
      "test loss: 1.5751166, test acc: 0.533\n",
      "poison loss: 0.3260271, poison acc: 0.850\n",
      "elapsed time: 373.607, time for reg: 77.949, time for eig: 114.311\n",
      "epoch:  5849, loss: 0.2413329, train acc: 0.933\n",
      "test loss: 1.5300686, test acc: 0.550\n",
      "poison loss: 0.3436372, poison acc: 0.850\n",
      "elapsed time: 374.171, time for reg: 78.080, time for eig: 114.438\n",
      "epoch:  5859, loss: 0.4632848, train acc: 0.800\n",
      "test loss: 1.4471915, test acc: 0.633\n",
      "poison loss: 0.8820896, poison acc: 0.550\n",
      "elapsed time: 374.796, time for reg: 78.210, time for eig: 114.628\n",
      "epoch:  5869, loss: 0.2231286, train acc: 0.933\n",
      "test loss: 1.6715941, test acc: 0.517\n",
      "poison loss: 0.3742329, poison acc: 0.817\n",
      "elapsed time: 375.449, time for reg: 78.341, time for eig: 114.842\n",
      "epoch:  5879, loss: 0.5555173, train acc: 0.800\n",
      "test loss: 1.5501420, test acc: 0.617\n",
      "poison loss: 0.4352028, poison acc: 0.800\n",
      "elapsed time: 376.009, time for reg: 78.471, time for eig: 114.966\n",
      "epoch:  5889, loss: 0.2607444, train acc: 0.867\n",
      "test loss: 1.5699589, test acc: 0.550\n",
      "poison loss: 0.3326207, poison acc: 0.867\n",
      "elapsed time: 376.603, time for reg: 78.602, time for eig: 115.123\n",
      "epoch:  5899, loss: 0.2832115, train acc: 0.917\n",
      "test loss: 1.4520776, test acc: 0.600\n",
      "poison loss: 0.3765156, poison acc: 0.767\n",
      "elapsed time: 377.330, time for reg: 78.733, time for eig: 115.412\n",
      "epoch:  5909, loss: 0.3181341, train acc: 0.850\n",
      "test loss: 1.3566023, test acc: 0.550\n",
      "poison loss: 0.7742203, poison acc: 0.683\n",
      "elapsed time: 377.967, time for reg: 78.863, time for eig: 115.612\n",
      "epoch:  5919, loss: 0.2293211, train acc: 0.917\n",
      "test loss: 1.6337884, test acc: 0.533\n",
      "poison loss: 0.3574744, poison acc: 0.833\n",
      "elapsed time: 378.548, time for reg: 78.993, time for eig: 115.757\n",
      "epoch:  5929, loss: 0.2422406, train acc: 0.900\n",
      "test loss: 1.4883590, test acc: 0.583\n",
      "poison loss: 0.4730916, poison acc: 0.767\n",
      "elapsed time: 379.277, time for reg: 79.124, time for eig: 116.049\n",
      "epoch:  5939, loss: 0.3984473, train acc: 0.817\n",
      "test loss: 1.3882021, test acc: 0.600\n",
      "poison loss: 0.5201064, poison acc: 0.800\n",
      "elapsed time: 379.841, time for reg: 79.255, time for eig: 116.177\n",
      "epoch:  5949, loss: 0.2833011, train acc: 0.917\n",
      "test loss: 1.4464967, test acc: 0.550\n",
      "poison loss: 0.3585953, poison acc: 0.833\n",
      "elapsed time: 380.482, time for reg: 79.385, time for eig: 116.380\n",
      "epoch:  5959, loss: 0.2587283, train acc: 0.900\n",
      "test loss: 1.4444090, test acc: 0.550\n",
      "poison loss: 0.4932626, poison acc: 0.800\n",
      "elapsed time: 381.075, time for reg: 79.516, time for eig: 116.536\n",
      "epoch:  5969, loss: 0.2934172, train acc: 0.900\n",
      "test loss: 1.7732773, test acc: 0.450\n",
      "poison loss: 0.5118586, poison acc: 0.733\n",
      "elapsed time: 381.649, time for reg: 79.648, time for eig: 116.669\n",
      "epoch:  5979, loss: 0.2900973, train acc: 0.917\n",
      "test loss: 1.3609717, test acc: 0.617\n",
      "poison loss: 0.4266948, poison acc: 0.733\n",
      "elapsed time: 382.225, time for reg: 79.779, time for eig: 116.807\n",
      "epoch:  5989, loss: 0.3218018, train acc: 0.867\n",
      "test loss: 1.4215843, test acc: 0.567\n",
      "poison loss: 0.4072114, poison acc: 0.783\n",
      "elapsed time: 382.805, time for reg: 79.911, time for eig: 116.946\n",
      "epoch:  5999, loss: 0.2812600, train acc: 0.900\n",
      "test loss: 1.4950984, test acc: 0.583\n",
      "poison loss: 0.3880085, poison acc: 0.833\n",
      "elapsed time: 383.359, time for reg: 80.041, time for eig: 117.063\n",
      "epoch:  6009, loss: 0.3813168, train acc: 0.817\n",
      "test loss: 1.6219153, test acc: 0.550\n",
      "poison loss: 0.3822361, poison acc: 0.800\n",
      "elapsed time: 383.984, time for reg: 80.173, time for eig: 117.250\n",
      "epoch:  6019, loss: 0.2133408, train acc: 0.933\n",
      "test loss: 1.5514426, test acc: 0.567\n",
      "poison loss: 0.3171374, poison acc: 0.867\n",
      "elapsed time: 384.567, time for reg: 80.304, time for eig: 117.398\n",
      "epoch:  6029, loss: 0.2451595, train acc: 0.900\n",
      "test loss: 1.7620272, test acc: 0.517\n",
      "poison loss: 0.4070741, poison acc: 0.800\n",
      "elapsed time: 385.164, time for reg: 80.436, time for eig: 117.555\n",
      "epoch:  6039, loss: 0.2218780, train acc: 0.950\n",
      "test loss: 1.6404530, test acc: 0.517\n",
      "poison loss: 0.3358532, poison acc: 0.867\n",
      "elapsed time: 385.759, time for reg: 80.570, time for eig: 117.704\n",
      "epoch:  6049, loss: 0.4839831, train acc: 0.783\n",
      "test loss: 1.7394995, test acc: 0.583\n",
      "poison loss: 1.7358229, poison acc: 0.450\n",
      "elapsed time: 386.381, time for reg: 80.703, time for eig: 117.880\n",
      "epoch:  6059, loss: 0.2615805, train acc: 0.917\n",
      "test loss: 1.4578770, test acc: 0.583\n",
      "poison loss: 0.4066725, poison acc: 0.783\n",
      "elapsed time: 386.963, time for reg: 80.834, time for eig: 118.020\n",
      "epoch:  6069, loss: 0.2129778, train acc: 0.917\n",
      "test loss: 1.7134120, test acc: 0.550\n",
      "poison loss: 0.3425302, poison acc: 0.850\n",
      "elapsed time: 387.521, time for reg: 80.965, time for eig: 118.140\n",
      "epoch:  6079, loss: 0.2897325, train acc: 0.867\n",
      "test loss: 1.5545054, test acc: 0.600\n",
      "poison loss: 0.4229369, poison acc: 0.767\n",
      "elapsed time: 388.077, time for reg: 81.096, time for eig: 118.257\n",
      "epoch:  6089, loss: 0.3163282, train acc: 0.900\n",
      "test loss: 1.5579961, test acc: 0.550\n",
      "poison loss: 0.3285377, poison acc: 0.867\n",
      "elapsed time: 388.735, time for reg: 81.227, time for eig: 118.475\n",
      "epoch:  6099, loss: 0.2566122, train acc: 0.867\n",
      "test loss: 1.5640575, test acc: 0.550\n",
      "poison loss: 0.3336881, poison acc: 0.867\n",
      "elapsed time: 389.320, time for reg: 81.357, time for eig: 118.624\n",
      "epoch:  6109, loss: 0.4363584, train acc: 0.800\n",
      "test loss: 1.8144881, test acc: 0.483\n",
      "poison loss: 0.5060610, poison acc: 0.767\n",
      "elapsed time: 389.900, time for reg: 81.488, time for eig: 118.765\n",
      "epoch:  6119, loss: 0.2439611, train acc: 0.900\n",
      "test loss: 1.5613008, test acc: 0.583\n",
      "poison loss: 0.3731899, poison acc: 0.817\n",
      "elapsed time: 390.467, time for reg: 81.619, time for eig: 118.894\n",
      "epoch:  6129, loss: 0.2540753, train acc: 0.917\n",
      "test loss: 1.5844648, test acc: 0.567\n",
      "poison loss: 0.3824894, poison acc: 0.833\n",
      "elapsed time: 391.140, time for reg: 81.749, time for eig: 119.129\n",
      "epoch:  6139, loss: 0.2522916, train acc: 0.933\n",
      "test loss: 1.7504008, test acc: 0.467\n",
      "poison loss: 0.4030252, poison acc: 0.783\n",
      "elapsed time: 391.842, time for reg: 81.881, time for eig: 119.393\n",
      "epoch:  6149, loss: 0.3856359, train acc: 0.783\n",
      "test loss: 1.7120817, test acc: 0.483\n",
      "poison loss: 0.5004343, poison acc: 0.750\n",
      "elapsed time: 392.399, time for reg: 82.011, time for eig: 119.513\n",
      "epoch:  6159, loss: 0.2891754, train acc: 0.900\n",
      "test loss: 1.5219250, test acc: 0.517\n",
      "poison loss: 0.3496832, poison acc: 0.850\n",
      "elapsed time: 393.009, time for reg: 82.142, time for eig: 119.684\n",
      "epoch:  6169, loss: 0.2047017, train acc: 0.950\n",
      "test loss: 1.5940253, test acc: 0.533\n",
      "poison loss: 0.2932181, poison acc: 0.900\n",
      "elapsed time: 393.578, time for reg: 82.273, time for eig: 119.816\n",
      "epoch:  6179, loss: 0.3985747, train acc: 0.850\n",
      "test loss: 1.6332208, test acc: 0.533\n",
      "poison loss: 0.5364336, poison acc: 0.767\n",
      "elapsed time: 394.156, time for reg: 82.403, time for eig: 119.961\n",
      "epoch:  6189, loss: 0.2462934, train acc: 0.900\n",
      "test loss: 1.6112421, test acc: 0.533\n",
      "poison loss: 0.3910135, poison acc: 0.817\n",
      "elapsed time: 394.793, time for reg: 82.533, time for eig: 120.162\n",
      "epoch:  6199, loss: 0.2547495, train acc: 0.900\n",
      "test loss: 1.4828267, test acc: 0.567\n",
      "poison loss: 0.5482384, poison acc: 0.733\n",
      "elapsed time: 395.376, time for reg: 82.664, time for eig: 120.308\n",
      "epoch:  6209, loss: 0.2967969, train acc: 0.817\n",
      "test loss: 1.7272723, test acc: 0.517\n",
      "poison loss: 0.4016006, poison acc: 0.800\n",
      "elapsed time: 395.937, time for reg: 82.795, time for eig: 120.434\n",
      "epoch:  6219, loss: 0.2362830, train acc: 0.900\n",
      "test loss: 1.5920278, test acc: 0.550\n",
      "poison loss: 0.3951145, poison acc: 0.783\n",
      "elapsed time: 396.490, time for reg: 82.925, time for eig: 120.552\n",
      "epoch:  6229, loss: 0.2485373, train acc: 0.900\n",
      "test loss: 1.6304169, test acc: 0.500\n",
      "poison loss: 0.2931907, poison acc: 0.883\n",
      "elapsed time: 397.084, time for reg: 83.056, time for eig: 120.714\n",
      "epoch:  6239, loss: 0.2623776, train acc: 0.883\n",
      "test loss: 1.6933703, test acc: 0.533\n",
      "poison loss: 0.3359593, poison acc: 0.850\n",
      "elapsed time: 397.692, time for reg: 83.187, time for eig: 120.896\n",
      "epoch:  6249, loss: 0.2400645, train acc: 0.867\n",
      "test loss: 1.6925475, test acc: 0.533\n",
      "poison loss: 0.2965238, poison acc: 0.883\n",
      "elapsed time: 398.283, time for reg: 83.328, time for eig: 121.026\n",
      "epoch:  6259, loss: 0.2079687, train acc: 0.917\n",
      "test loss: 1.6524241, test acc: 0.533\n",
      "poison loss: 0.3585481, poison acc: 0.817\n",
      "elapsed time: 398.906, time for reg: 83.460, time for eig: 121.210\n",
      "epoch:  6269, loss: 0.2447083, train acc: 0.900\n",
      "test loss: 1.8158625, test acc: 0.517\n",
      "poison loss: 0.3918738, poison acc: 0.800\n",
      "elapsed time: 399.501, time for reg: 83.592, time for eig: 121.363\n",
      "epoch:  6279, loss: 0.8120293, train acc: 0.700\n",
      "test loss: 1.7603734, test acc: 0.583\n",
      "poison loss: 0.7628468, poison acc: 0.700\n",
      "elapsed time: 400.120, time for reg: 83.724, time for eig: 121.544\n",
      "epoch:  6289, loss: 0.2263262, train acc: 0.900\n",
      "test loss: 1.7588824, test acc: 0.517\n",
      "poison loss: 0.3527835, poison acc: 0.817\n",
      "elapsed time: 400.680, time for reg: 83.856, time for eig: 121.664\n",
      "epoch:  6299, loss: 0.2820864, train acc: 0.833\n",
      "test loss: 1.9446599, test acc: 0.467\n",
      "poison loss: 0.7160885, poison acc: 0.633\n",
      "elapsed time: 401.294, time for reg: 83.988, time for eig: 121.839\n",
      "epoch:  6309, loss: 0.2272013, train acc: 0.917\n",
      "test loss: 1.6321536, test acc: 0.617\n",
      "poison loss: 0.2909368, poison acc: 0.867\n",
      "elapsed time: 401.881, time for reg: 84.120, time for eig: 121.987\n",
      "epoch:  6319, loss: 0.3043971, train acc: 0.850\n",
      "test loss: 1.7355976, test acc: 0.550\n",
      "poison loss: 0.3066409, poison acc: 0.883\n",
      "elapsed time: 402.470, time for reg: 84.252, time for eig: 122.135\n",
      "epoch:  6329, loss: 0.2387694, train acc: 0.900\n",
      "test loss: 1.7594603, test acc: 0.517\n",
      "poison loss: 0.2573863, poison acc: 0.900\n",
      "elapsed time: 403.146, time for reg: 84.384, time for eig: 122.369\n",
      "epoch:  6339, loss: 0.2790770, train acc: 0.850\n",
      "test loss: 1.7389870, test acc: 0.567\n",
      "poison loss: 0.6840833, poison acc: 0.717\n",
      "elapsed time: 403.702, time for reg: 84.516, time for eig: 122.484\n",
      "epoch:  6349, loss: 0.6705759, train acc: 0.700\n",
      "test loss: 1.6820359, test acc: 0.483\n",
      "poison loss: 0.6146984, poison acc: 0.700\n",
      "elapsed time: 404.286, time for reg: 84.648, time for eig: 122.628\n",
      "epoch:  6359, loss: 0.2834813, train acc: 0.850\n",
      "test loss: 1.6918162, test acc: 0.550\n",
      "poison loss: 0.3188150, poison acc: 0.833\n",
      "elapsed time: 404.878, time for reg: 84.779, time for eig: 122.778\n",
      "epoch:  6369, loss: 0.2680630, train acc: 0.833\n",
      "test loss: 1.9717894, test acc: 0.500\n",
      "poison loss: 0.4974705, poison acc: 0.783\n",
      "elapsed time: 405.485, time for reg: 84.911, time for eig: 122.949\n",
      "epoch:  6379, loss: 0.2059069, train acc: 0.950\n",
      "test loss: 1.6750419, test acc: 0.583\n",
      "poison loss: 0.2980030, poison acc: 0.817\n",
      "elapsed time: 406.181, time for reg: 85.043, time for eig: 123.202\n",
      "epoch:  6389, loss: 0.7043651, train acc: 0.650\n",
      "test loss: 1.8992676, test acc: 0.450\n",
      "poison loss: 0.6593317, poison acc: 0.767\n",
      "elapsed time: 406.758, time for reg: 85.174, time for eig: 123.336\n",
      "epoch:  6399, loss: 0.3127655, train acc: 0.817\n",
      "test loss: 2.0083490, test acc: 0.517\n",
      "poison loss: 0.3482346, poison acc: 0.833\n",
      "elapsed time: 407.368, time for reg: 85.306, time for eig: 123.504\n",
      "epoch:  6409, loss: 0.2257437, train acc: 0.900\n",
      "test loss: 1.8711858, test acc: 0.533\n",
      "poison loss: 0.3199166, poison acc: 0.850\n",
      "elapsed time: 408.111, time for reg: 85.438, time for eig: 123.803\n",
      "epoch:  6419, loss: 0.2890756, train acc: 0.833\n",
      "test loss: 1.8280936, test acc: 0.500\n",
      "poison loss: 0.3433702, poison acc: 0.800\n",
      "elapsed time: 408.805, time for reg: 85.570, time for eig: 124.054\n",
      "epoch:  6429, loss: 0.2716815, train acc: 0.900\n",
      "test loss: 1.5010445, test acc: 0.617\n",
      "poison loss: 0.4691646, poison acc: 0.783\n",
      "elapsed time: 409.534, time for reg: 85.702, time for eig: 124.343\n",
      "epoch:  6439, loss: 0.3316067, train acc: 0.833\n",
      "test loss: 2.0228416, test acc: 0.467\n",
      "poison loss: 0.6163138, poison acc: 0.700\n",
      "elapsed time: 410.412, time for reg: 85.834, time for eig: 124.783\n",
      "epoch:  6449, loss: 0.2530413, train acc: 0.867\n",
      "test loss: 1.6508843, test acc: 0.567\n",
      "poison loss: 0.2880880, poison acc: 0.883\n",
      "elapsed time: 410.990, time for reg: 85.966, time for eig: 124.918\n",
      "epoch:  6459, loss: 0.2024584, train acc: 0.933\n",
      "test loss: 1.6025864, test acc: 0.550\n",
      "poison loss: 0.2669425, poison acc: 0.883\n",
      "elapsed time: 411.568, time for reg: 86.098, time for eig: 125.054\n",
      "epoch:  6469, loss: 0.1909450, train acc: 0.950\n",
      "test loss: 1.6728571, test acc: 0.550\n",
      "poison loss: 0.2491840, poison acc: 0.883\n",
      "elapsed time: 412.167, time for reg: 86.230, time for eig: 125.213\n",
      "epoch:  6479, loss: 0.2527874, train acc: 0.850\n",
      "test loss: 1.8851069, test acc: 0.567\n",
      "poison loss: 0.4190729, poison acc: 0.783\n",
      "elapsed time: 412.889, time for reg: 86.361, time for eig: 125.498\n",
      "epoch:  6489, loss: 0.2630794, train acc: 0.867\n",
      "test loss: 1.7457852, test acc: 0.533\n",
      "poison loss: 0.2963602, poison acc: 0.850\n",
      "elapsed time: 413.495, time for reg: 86.496, time for eig: 125.659\n",
      "epoch:  6499, loss: 0.3169604, train acc: 0.867\n",
      "test loss: 1.7581241, test acc: 0.567\n",
      "poison loss: 0.6426638, poison acc: 0.667\n",
      "elapsed time: 414.108, time for reg: 86.633, time for eig: 125.823\n",
      "epoch:  6509, loss: 0.2637226, train acc: 0.883\n",
      "test loss: 1.6144197, test acc: 0.567\n",
      "poison loss: 0.3224707, poison acc: 0.867\n",
      "elapsed time: 414.792, time for reg: 86.770, time for eig: 126.059\n",
      "epoch:  6519, loss: 0.2406793, train acc: 0.900\n",
      "test loss: 1.7879924, test acc: 0.583\n",
      "poison loss: 0.2445081, poison acc: 0.900\n",
      "elapsed time: 415.383, time for reg: 86.902, time for eig: 126.209\n",
      "epoch:  6529, loss: 0.2346744, train acc: 0.883\n",
      "test loss: 1.8449464, test acc: 0.533\n",
      "poison loss: 0.6895633, poison acc: 0.750\n",
      "elapsed time: 416.050, time for reg: 87.034, time for eig: 126.430\n",
      "epoch:  6539, loss: 0.2437080, train acc: 0.883\n",
      "test loss: 1.7570834, test acc: 0.583\n",
      "poison loss: 0.2865760, poison acc: 0.867\n",
      "elapsed time: 416.609, time for reg: 87.166, time for eig: 126.563\n",
      "epoch:  6549, loss: 0.3009984, train acc: 0.850\n",
      "test loss: 1.8923218, test acc: 0.467\n",
      "poison loss: 0.3214350, poison acc: 0.850\n",
      "elapsed time: 417.182, time for reg: 87.298, time for eig: 126.697\n",
      "epoch:  6559, loss: 0.2175964, train acc: 0.900\n",
      "test loss: 1.8063915, test acc: 0.517\n",
      "poison loss: 0.2355532, poison acc: 0.917\n",
      "elapsed time: 418.135, time for reg: 87.429, time for eig: 127.214\n",
      "epoch:  6569, loss: 0.2932739, train acc: 0.867\n",
      "test loss: 1.7832332, test acc: 0.483\n",
      "poison loss: 0.2592074, poison acc: 0.917\n",
      "elapsed time: 418.778, time for reg: 87.560, time for eig: 127.421\n",
      "epoch:  6579, loss: 0.5964462, train acc: 0.800\n",
      "test loss: 1.6430245, test acc: 0.567\n",
      "poison loss: 0.8313095, poison acc: 0.650\n",
      "elapsed time: 419.457, time for reg: 87.691, time for eig: 127.663\n",
      "epoch:  6589, loss: 0.2230690, train acc: 0.900\n",
      "test loss: 1.6737118, test acc: 0.517\n",
      "poison loss: 0.2709827, poison acc: 0.883\n",
      "elapsed time: 420.022, time for reg: 87.822, time for eig: 127.790\n",
      "epoch:  6599, loss: 0.2916437, train acc: 0.850\n",
      "test loss: 1.6432055, test acc: 0.550\n",
      "poison loss: 0.5089615, poison acc: 0.800\n",
      "elapsed time: 420.623, time for reg: 87.953, time for eig: 127.955\n",
      "epoch:  6609, loss: 0.2495927, train acc: 0.850\n",
      "test loss: 1.8236498, test acc: 0.517\n",
      "poison loss: 0.3186118, poison acc: 0.850\n",
      "elapsed time: 421.229, time for reg: 88.083, time for eig: 128.122\n",
      "epoch:  6619, loss: 0.3340828, train acc: 0.867\n",
      "test loss: 1.7705547, test acc: 0.500\n",
      "poison loss: 0.7704114, poison acc: 0.683\n",
      "elapsed time: 421.834, time for reg: 88.215, time for eig: 128.302\n",
      "epoch:  6629, loss: 0.1941989, train acc: 0.950\n",
      "test loss: 1.7924295, test acc: 0.533\n",
      "poison loss: 0.2551880, poison acc: 0.900\n",
      "elapsed time: 422.570, time for reg: 88.347, time for eig: 128.599\n",
      "epoch:  6639, loss: 0.3599962, train acc: 0.800\n",
      "test loss: 1.9717372, test acc: 0.450\n",
      "poison loss: 0.3694752, poison acc: 0.817\n",
      "elapsed time: 423.198, time for reg: 88.478, time for eig: 128.791\n",
      "epoch:  6649, loss: 0.2812474, train acc: 0.883\n",
      "test loss: 1.6644762, test acc: 0.517\n",
      "poison loss: 0.2682673, poison acc: 0.900\n",
      "elapsed time: 423.765, time for reg: 88.609, time for eig: 128.920\n",
      "epoch:  6659, loss: 0.1870579, train acc: 0.933\n",
      "test loss: 1.8911696, test acc: 0.517\n",
      "poison loss: 0.2576195, poison acc: 0.883\n",
      "elapsed time: 424.370, time for reg: 88.740, time for eig: 129.087\n",
      "epoch:  6669, loss: 0.4196134, train acc: 0.833\n",
      "test loss: 1.6154252, test acc: 0.500\n",
      "poison loss: 0.3757947, poison acc: 0.817\n",
      "elapsed time: 425.002, time for reg: 88.871, time for eig: 129.282\n",
      "epoch:  6679, loss: 0.3019424, train acc: 0.833\n",
      "test loss: 1.7476134, test acc: 0.517\n",
      "poison loss: 0.4713537, poison acc: 0.783\n",
      "elapsed time: 425.593, time for reg: 89.001, time for eig: 129.436\n",
      "epoch:  6689, loss: 0.2260242, train acc: 0.933\n",
      "test loss: 1.4698975, test acc: 0.517\n",
      "poison loss: 0.3662359, poison acc: 0.783\n",
      "elapsed time: 426.226, time for reg: 89.132, time for eig: 129.629\n",
      "epoch:  6699, loss: 0.2256617, train acc: 0.883\n",
      "test loss: 1.6113176, test acc: 0.533\n",
      "poison loss: 0.2779753, poison acc: 0.883\n",
      "elapsed time: 426.788, time for reg: 89.263, time for eig: 129.753\n",
      "epoch:  6709, loss: 0.3168045, train acc: 0.850\n",
      "test loss: 1.9123612, test acc: 0.517\n",
      "poison loss: 0.2446543, poison acc: 0.900\n",
      "elapsed time: 427.429, time for reg: 89.394, time for eig: 129.956\n",
      "epoch:  6719, loss: 0.3084235, train acc: 0.850\n",
      "test loss: 1.7970205, test acc: 0.483\n",
      "poison loss: 0.4455177, poison acc: 0.850\n",
      "elapsed time: 428.093, time for reg: 89.525, time for eig: 130.182\n",
      "epoch:  6729, loss: 0.2301274, train acc: 0.883\n",
      "test loss: 1.7367250, test acc: 0.550\n",
      "poison loss: 0.3079921, poison acc: 0.883\n",
      "elapsed time: 428.695, time for reg: 89.655, time for eig: 130.348\n",
      "epoch:  6739, loss: 0.2043397, train acc: 0.917\n",
      "test loss: 1.8337201, test acc: 0.567\n",
      "poison loss: 0.2408500, poison acc: 0.883\n",
      "elapsed time: 429.340, time for reg: 89.787, time for eig: 130.554\n",
      "epoch:  6749, loss: 0.1898021, train acc: 0.917\n",
      "test loss: 1.8625531, test acc: 0.550\n",
      "poison loss: 0.2302824, poison acc: 0.900\n",
      "elapsed time: 429.993, time for reg: 89.918, time for eig: 130.769\n",
      "epoch:  6759, loss: 0.5061759, train acc: 0.783\n",
      "test loss: 1.4570128, test acc: 0.533\n",
      "poison loss: 0.5602963, poison acc: 0.800\n",
      "elapsed time: 430.684, time for reg: 90.049, time for eig: 131.022\n",
      "epoch:  6769, loss: 0.3633321, train acc: 0.833\n",
      "test loss: 1.6989701, test acc: 0.433\n",
      "poison loss: 0.8254866, poison acc: 0.667\n",
      "elapsed time: 431.430, time for reg: 90.181, time for eig: 131.329\n",
      "epoch:  6779, loss: 0.3448335, train acc: 0.817\n",
      "test loss: 1.6535746, test acc: 0.450\n",
      "poison loss: 0.5320110, poison acc: 0.767\n",
      "elapsed time: 432.017, time for reg: 90.313, time for eig: 131.470\n",
      "epoch:  6789, loss: 0.2448170, train acc: 0.900\n",
      "test loss: 1.5711743, test acc: 0.567\n",
      "poison loss: 0.3726816, poison acc: 0.833\n",
      "elapsed time: 432.619, time for reg: 90.453, time for eig: 131.614\n",
      "epoch:  6799, loss: 0.3434734, train acc: 0.817\n",
      "test loss: 1.5998290, test acc: 0.483\n",
      "poison loss: 0.6761900, poison acc: 0.717\n",
      "elapsed time: 433.252, time for reg: 90.588, time for eig: 131.796\n",
      "epoch:  6809, loss: 0.2109189, train acc: 0.917\n",
      "test loss: 1.6221358, test acc: 0.533\n",
      "poison loss: 0.2621536, poison acc: 0.883\n",
      "elapsed time: 433.842, time for reg: 90.724, time for eig: 131.935\n",
      "epoch:  6819, loss: 0.5071277, train acc: 0.717\n",
      "test loss: 1.6853189, test acc: 0.500\n",
      "poison loss: 0.3219827, poison acc: 0.817\n",
      "elapsed time: 434.473, time for reg: 90.860, time for eig: 132.115\n",
      "epoch:  6829, loss: 0.3183541, train acc: 0.883\n",
      "test loss: 2.1572345, test acc: 0.417\n",
      "poison loss: 1.0808461, poison acc: 0.750\n",
      "elapsed time: 435.096, time for reg: 90.996, time for eig: 132.287\n",
      "epoch:  6839, loss: 0.2072483, train acc: 0.933\n",
      "test loss: 1.5680916, test acc: 0.600\n",
      "poison loss: 0.3302274, poison acc: 0.833\n",
      "elapsed time: 435.703, time for reg: 91.131, time for eig: 132.444\n",
      "epoch:  6849, loss: 0.2908544, train acc: 0.917\n",
      "test loss: 1.7021983, test acc: 0.567\n",
      "poison loss: 0.5243785, poison acc: 0.733\n",
      "elapsed time: 436.299, time for reg: 91.267, time for eig: 132.595\n",
      "epoch:  6859, loss: 0.2339020, train acc: 0.917\n",
      "test loss: 1.7049187, test acc: 0.567\n",
      "poison loss: 0.3186410, poison acc: 0.867\n",
      "elapsed time: 436.892, time for reg: 91.402, time for eig: 132.738\n",
      "epoch:  6869, loss: 0.2521929, train acc: 0.867\n",
      "test loss: 1.8554102, test acc: 0.500\n",
      "poison loss: 0.4180290, poison acc: 0.817\n",
      "elapsed time: 437.473, time for reg: 91.537, time for eig: 132.870\n",
      "epoch:  6879, loss: 0.1976156, train acc: 0.867\n",
      "test loss: 1.7354917, test acc: 0.533\n",
      "poison loss: 0.2438544, poison acc: 0.933\n",
      "elapsed time: 438.081, time for reg: 91.673, time for eig: 133.028\n",
      "epoch:  6889, loss: 0.3259182, train acc: 0.850\n",
      "test loss: 1.7598691, test acc: 0.517\n",
      "poison loss: 0.4350877, poison acc: 0.850\n",
      "elapsed time: 438.663, time for reg: 91.808, time for eig: 133.161\n",
      "epoch:  6899, loss: 0.3000400, train acc: 0.883\n",
      "test loss: 1.6898597, test acc: 0.533\n",
      "poison loss: 0.2930095, poison acc: 0.850\n",
      "elapsed time: 439.239, time for reg: 91.943, time for eig: 133.286\n",
      "epoch:  6909, loss: 0.2205883, train acc: 0.917\n",
      "test loss: 1.7946695, test acc: 0.583\n",
      "poison loss: 0.4035723, poison acc: 0.833\n",
      "elapsed time: 439.819, time for reg: 92.078, time for eig: 133.417\n",
      "epoch:  6919, loss: 0.1785821, train acc: 0.933\n",
      "test loss: 1.7660791, test acc: 0.583\n",
      "poison loss: 0.2583314, poison acc: 0.883\n",
      "elapsed time: 440.414, time for reg: 92.214, time for eig: 133.562\n",
      "epoch:  6929, loss: 0.2365578, train acc: 0.933\n",
      "test loss: 1.6597124, test acc: 0.583\n",
      "poison loss: 0.2791708, poison acc: 0.917\n",
      "elapsed time: 441.338, time for reg: 92.349, time for eig: 134.041\n",
      "epoch:  6939, loss: 0.1832732, train acc: 0.950\n",
      "test loss: 1.7742369, test acc: 0.550\n",
      "poison loss: 0.4741347, poison acc: 0.817\n",
      "elapsed time: 441.955, time for reg: 92.485, time for eig: 134.208\n",
      "epoch:  6949, loss: 0.2498088, train acc: 0.883\n",
      "test loss: 1.7108701, test acc: 0.533\n",
      "poison loss: 0.2659259, poison acc: 0.883\n",
      "elapsed time: 442.623, time for reg: 92.620, time for eig: 134.426\n",
      "epoch:  6959, loss: 0.1806123, train acc: 0.950\n",
      "test loss: 1.8218739, test acc: 0.550\n",
      "poison loss: 0.2092102, poison acc: 0.917\n",
      "elapsed time: 443.185, time for reg: 92.755, time for eig: 134.540\n",
      "epoch:  6969, loss: 0.1944961, train acc: 0.933\n",
      "test loss: 1.8169975, test acc: 0.583\n",
      "poison loss: 0.3588718, poison acc: 0.833\n",
      "elapsed time: 443.861, time for reg: 92.891, time for eig: 134.766\n",
      "epoch:  6979, loss: 0.2247218, train acc: 0.950\n",
      "test loss: 1.7286734, test acc: 0.567\n",
      "poison loss: 0.3190115, poison acc: 0.817\n",
      "elapsed time: 444.489, time for reg: 93.026, time for eig: 134.945\n",
      "epoch:  6989, loss: 0.6022743, train acc: 0.767\n",
      "test loss: 2.0797628, test acc: 0.550\n",
      "poison loss: 0.3321467, poison acc: 0.850\n",
      "elapsed time: 445.074, time for reg: 93.161, time for eig: 135.081\n",
      "epoch:  6999, loss: 0.2700059, train acc: 0.833\n",
      "test loss: 1.8136436, test acc: 0.533\n",
      "poison loss: 0.4085835, poison acc: 0.800\n",
      "elapsed time: 445.687, time for reg: 93.297, time for eig: 135.245\n",
      "epoch:  7009, loss: 0.2142009, train acc: 0.917\n",
      "test loss: 1.8740767, test acc: 0.533\n",
      "poison loss: 0.3417331, poison acc: 0.883\n",
      "elapsed time: 446.290, time for reg: 93.432, time for eig: 135.398\n",
      "epoch:  7019, loss: 0.2013832, train acc: 0.933\n",
      "test loss: 1.7350079, test acc: 0.583\n",
      "poison loss: 0.2509713, poison acc: 0.900\n",
      "elapsed time: 446.847, time for reg: 93.567, time for eig: 135.507\n",
      "epoch:  7029, loss: 0.3037586, train acc: 0.833\n",
      "test loss: 1.9798609, test acc: 0.533\n",
      "poison loss: 1.1355774, poison acc: 0.550\n",
      "elapsed time: 447.423, time for reg: 93.703, time for eig: 135.633\n",
      "epoch:  7039, loss: 0.1941158, train acc: 0.900\n",
      "test loss: 1.6280562, test acc: 0.633\n",
      "poison loss: 0.3027651, poison acc: 0.850\n",
      "elapsed time: 448.041, time for reg: 93.838, time for eig: 135.800\n",
      "epoch:  7049, loss: 0.1960520, train acc: 0.883\n",
      "test loss: 2.0239224, test acc: 0.550\n",
      "poison loss: 0.2481068, poison acc: 0.867\n",
      "elapsed time: 448.618, time for reg: 93.973, time for eig: 135.929\n",
      "epoch:  7059, loss: 0.2198611, train acc: 0.883\n",
      "test loss: 1.9562710, test acc: 0.533\n",
      "poison loss: 0.2405656, poison acc: 0.883\n",
      "elapsed time: 449.202, time for reg: 94.109, time for eig: 136.064\n",
      "epoch:  7069, loss: 0.2713955, train acc: 0.850\n",
      "test loss: 1.6524532, test acc: 0.567\n",
      "poison loss: 0.3045051, poison acc: 0.833\n",
      "elapsed time: 449.957, time for reg: 94.245, time for eig: 136.369\n",
      "epoch:  7079, loss: 0.3885871, train acc: 0.800\n",
      "test loss: 1.7540089, test acc: 0.633\n",
      "poison loss: 0.2985444, poison acc: 0.867\n",
      "elapsed time: 450.733, time for reg: 94.380, time for eig: 136.695\n",
      "epoch:  7089, loss: 0.4982429, train acc: 0.783\n",
      "test loss: 2.1979303, test acc: 0.483\n",
      "poison loss: 0.6581670, poison acc: 0.650\n",
      "elapsed time: 451.343, time for reg: 94.515, time for eig: 136.858\n",
      "epoch:  7099, loss: 0.2376272, train acc: 0.900\n",
      "test loss: 1.8304489, test acc: 0.567\n",
      "poison loss: 0.2427075, poison acc: 0.883\n",
      "elapsed time: 452.003, time for reg: 94.650, time for eig: 137.070\n",
      "epoch:  7109, loss: 0.1904574, train acc: 0.933\n",
      "test loss: 2.0068496, test acc: 0.483\n",
      "poison loss: 0.3233606, poison acc: 0.850\n",
      "elapsed time: 452.587, time for reg: 94.785, time for eig: 137.205\n",
      "epoch:  7119, loss: 0.2376917, train acc: 0.883\n",
      "test loss: 1.7997368, test acc: 0.583\n",
      "poison loss: 0.2645646, poison acc: 0.850\n",
      "elapsed time: 453.223, time for reg: 94.920, time for eig: 137.396\n",
      "epoch:  7129, loss: 0.2158647, train acc: 0.900\n",
      "test loss: 1.9144515, test acc: 0.533\n",
      "poison loss: 0.2061495, poison acc: 0.917\n",
      "elapsed time: 453.817, time for reg: 95.055, time for eig: 137.547\n",
      "epoch:  7139, loss: 0.1592599, train acc: 0.917\n",
      "test loss: 1.9312906, test acc: 0.550\n",
      "poison loss: 0.1954822, poison acc: 0.900\n",
      "elapsed time: 454.452, time for reg: 95.191, time for eig: 137.730\n",
      "epoch:  7149, loss: 0.4146926, train acc: 0.800\n",
      "test loss: 1.9687966, test acc: 0.500\n",
      "poison loss: 0.4914705, poison acc: 0.733\n",
      "elapsed time: 455.037, time for reg: 95.326, time for eig: 137.867\n",
      "epoch:  7159, loss: 0.1353822, train acc: 0.933\n",
      "test loss: 2.0587955, test acc: 0.517\n",
      "poison loss: 0.2225317, poison acc: 0.917\n",
      "elapsed time: 455.643, time for reg: 95.462, time for eig: 138.025\n",
      "epoch:  7169, loss: 0.3037455, train acc: 0.883\n",
      "test loss: 1.8672953, test acc: 0.533\n",
      "poison loss: 0.2498539, poison acc: 0.900\n",
      "elapsed time: 456.331, time for reg: 95.598, time for eig: 138.262\n",
      "epoch:  7179, loss: 0.3953166, train acc: 0.800\n",
      "test loss: 1.7615054, test acc: 0.567\n",
      "poison loss: 0.2719066, poison acc: 0.850\n",
      "elapsed time: 456.925, time for reg: 95.733, time for eig: 138.412\n",
      "epoch:  7189, loss: 0.2368089, train acc: 0.917\n",
      "test loss: 1.9037036, test acc: 0.500\n",
      "poison loss: 0.2149550, poison acc: 0.917\n",
      "elapsed time: 457.609, time for reg: 95.868, time for eig: 138.651\n",
      "epoch:  7199, loss: 0.1855538, train acc: 0.917\n",
      "test loss: 1.9555688, test acc: 0.533\n",
      "poison loss: 0.2388900, poison acc: 0.900\n",
      "elapsed time: 458.287, time for reg: 96.003, time for eig: 138.878\n",
      "epoch:  7209, loss: 0.1929535, train acc: 0.917\n",
      "test loss: 1.7445397, test acc: 0.617\n",
      "poison loss: 0.2798947, poison acc: 0.850\n",
      "elapsed time: 458.863, time for reg: 96.138, time for eig: 139.007\n",
      "epoch:  7219, loss: 0.3025692, train acc: 0.867\n",
      "test loss: 2.4965870, test acc: 0.367\n",
      "poison loss: 0.9307700, poison acc: 0.700\n",
      "elapsed time: 459.532, time for reg: 96.274, time for eig: 139.228\n",
      "epoch:  7229, loss: 0.2214642, train acc: 0.900\n",
      "test loss: 1.8529450, test acc: 0.567\n",
      "poison loss: 0.2996713, poison acc: 0.850\n",
      "elapsed time: 460.263, time for reg: 96.409, time for eig: 139.513\n",
      "epoch:  7239, loss: 0.8785314, train acc: 0.700\n",
      "test loss: 1.5739591, test acc: 0.600\n",
      "poison loss: 0.5417079, poison acc: 0.833\n",
      "elapsed time: 460.843, time for reg: 96.545, time for eig: 139.647\n",
      "epoch:  7249, loss: 0.1769601, train acc: 0.950\n",
      "test loss: 1.8999209, test acc: 0.517\n",
      "poison loss: 0.3609799, poison acc: 0.867\n",
      "elapsed time: 461.858, time for reg: 96.681, time for eig: 140.215\n",
      "epoch:  7259, loss: 0.2698846, train acc: 0.883\n",
      "test loss: 1.7645502, test acc: 0.617\n",
      "poison loss: 0.3080145, poison acc: 0.817\n",
      "elapsed time: 462.464, time for reg: 96.816, time for eig: 140.370\n",
      "epoch:  7269, loss: 0.3311484, train acc: 0.833\n",
      "test loss: 1.7963383, test acc: 0.583\n",
      "poison loss: 0.3645074, poison acc: 0.817\n",
      "elapsed time: 463.091, time for reg: 96.951, time for eig: 140.549\n",
      "epoch:  7279, loss: 0.3566574, train acc: 0.850\n",
      "test loss: 2.1740540, test acc: 0.450\n",
      "poison loss: 0.5205719, poison acc: 0.783\n",
      "elapsed time: 463.789, time for reg: 97.087, time for eig: 140.805\n",
      "epoch:  7289, loss: 0.2215580, train acc: 0.883\n",
      "test loss: 1.9363496, test acc: 0.567\n",
      "poison loss: 0.4875647, poison acc: 0.800\n",
      "elapsed time: 464.465, time for reg: 97.222, time for eig: 141.028\n",
      "epoch:  7299, loss: 0.3863857, train acc: 0.833\n",
      "test loss: 2.0616503, test acc: 0.550\n",
      "poison loss: 0.3237462, poison acc: 0.850\n",
      "elapsed time: 465.183, time for reg: 97.357, time for eig: 141.298\n",
      "epoch:  7309, loss: 0.3307838, train acc: 0.817\n",
      "test loss: 2.3772434, test acc: 0.500\n",
      "poison loss: 0.5140799, poison acc: 0.783\n",
      "elapsed time: 465.815, time for reg: 97.492, time for eig: 141.480\n",
      "epoch:  7319, loss: 0.2283963, train acc: 0.867\n",
      "test loss: 1.8455440, test acc: 0.583\n",
      "poison loss: 0.2161107, poison acc: 0.917\n",
      "elapsed time: 466.444, time for reg: 97.627, time for eig: 141.662\n",
      "epoch:  7329, loss: 0.3062020, train acc: 0.883\n",
      "test loss: 1.9644836, test acc: 0.533\n",
      "poison loss: 0.2421820, poison acc: 0.917\n",
      "elapsed time: 467.077, time for reg: 97.763, time for eig: 141.843\n",
      "epoch:  7339, loss: 0.2171307, train acc: 0.950\n",
      "test loss: 1.8459680, test acc: 0.600\n",
      "poison loss: 0.2768500, poison acc: 0.817\n",
      "elapsed time: 467.741, time for reg: 97.900, time for eig: 142.056\n",
      "epoch:  7349, loss: 0.6141729, train acc: 0.783\n",
      "test loss: 2.1531824, test acc: 0.483\n",
      "poison loss: 1.4781366, poison acc: 0.533\n",
      "elapsed time: 468.360, time for reg: 98.040, time for eig: 142.223\n",
      "epoch:  7359, loss: 0.1634109, train acc: 0.967\n",
      "test loss: 1.8839259, test acc: 0.600\n",
      "poison loss: 0.2010867, poison acc: 0.917\n",
      "elapsed time: 469.050, time for reg: 98.174, time for eig: 142.465\n",
      "epoch:  7369, loss: 0.1641070, train acc: 0.933\n",
      "test loss: 1.7587869, test acc: 0.567\n",
      "poison loss: 0.2285172, poison acc: 0.900\n",
      "elapsed time: 469.705, time for reg: 98.310, time for eig: 142.672\n",
      "epoch:  7379, loss: 0.4934437, train acc: 0.767\n",
      "test loss: 1.8976017, test acc: 0.600\n",
      "poison loss: 1.2031707, poison acc: 0.533\n",
      "elapsed time: 470.324, time for reg: 98.444, time for eig: 142.844\n",
      "epoch:  7389, loss: 0.1741527, train acc: 0.900\n",
      "test loss: 1.8416242, test acc: 0.567\n",
      "poison loss: 0.2047262, poison acc: 0.950\n",
      "elapsed time: 470.900, time for reg: 98.580, time for eig: 142.972\n",
      "epoch:  7399, loss: 0.4712340, train acc: 0.850\n",
      "test loss: 2.0532560, test acc: 0.517\n",
      "poison loss: 0.4011885, poison acc: 0.817\n",
      "elapsed time: 471.516, time for reg: 98.715, time for eig: 143.141\n",
      "epoch:  7409, loss: 0.3041745, train acc: 0.783\n",
      "test loss: 1.9309599, test acc: 0.517\n",
      "poison loss: 0.2883043, poison acc: 0.867\n",
      "elapsed time: 472.140, time for reg: 98.850, time for eig: 143.319\n",
      "epoch:  7419, loss: 0.1331473, train acc: 0.967\n",
      "test loss: 2.1271884, test acc: 0.583\n",
      "poison loss: 0.2299971, poison acc: 0.883\n",
      "elapsed time: 472.907, time for reg: 98.985, time for eig: 143.637\n",
      "epoch:  7429, loss: 0.1851102, train acc: 0.917\n",
      "test loss: 1.7253833, test acc: 0.617\n",
      "poison loss: 0.2287020, poison acc: 0.867\n",
      "elapsed time: 473.499, time for reg: 99.120, time for eig: 143.783\n",
      "epoch:  7439, loss: 0.2365390, train acc: 0.917\n",
      "test loss: 2.0651283, test acc: 0.550\n",
      "poison loss: 0.2752967, poison acc: 0.867\n",
      "elapsed time: 474.121, time for reg: 99.255, time for eig: 143.960\n",
      "epoch:  7449, loss: 0.2845308, train acc: 0.867\n",
      "test loss: 2.0591100, test acc: 0.533\n",
      "poison loss: 0.2088171, poison acc: 0.933\n",
      "elapsed time: 474.686, time for reg: 99.391, time for eig: 144.075\n",
      "epoch:  7459, loss: 0.1512245, train acc: 0.917\n",
      "test loss: 1.9326295, test acc: 0.567\n",
      "poison loss: 0.2126153, poison acc: 0.900\n",
      "elapsed time: 475.251, time for reg: 99.525, time for eig: 144.194\n",
      "epoch:  7469, loss: 0.2781916, train acc: 0.867\n",
      "test loss: 1.8975673, test acc: 0.583\n",
      "poison loss: 0.2860614, poison acc: 0.867\n",
      "elapsed time: 475.842, time for reg: 99.660, time for eig: 144.337\n",
      "epoch:  7479, loss: 0.1656596, train acc: 0.900\n",
      "test loss: 1.9676082, test acc: 0.567\n",
      "poison loss: 0.1747071, poison acc: 0.950\n",
      "elapsed time: 476.437, time for reg: 99.795, time for eig: 144.484\n",
      "epoch:  7489, loss: 0.4074285, train acc: 0.800\n",
      "test loss: 2.2981831, test acc: 0.467\n",
      "poison loss: 0.6294028, poison acc: 0.700\n",
      "elapsed time: 477.229, time for reg: 99.930, time for eig: 144.830\n",
      "epoch:  7499, loss: 0.1887323, train acc: 0.883\n",
      "test loss: 2.1067039, test acc: 0.533\n",
      "poison loss: 0.2981377, poison acc: 0.867\n",
      "elapsed time: 477.822, time for reg: 100.060, time for eig: 144.986\n",
      "epoch:  7509, loss: 0.2009200, train acc: 0.917\n",
      "test loss: 2.0359159, test acc: 0.517\n",
      "poison loss: 0.2565112, poison acc: 0.883\n",
      "elapsed time: 478.377, time for reg: 100.191, time for eig: 145.105\n",
      "epoch:  7519, loss: 0.1768329, train acc: 0.933\n",
      "test loss: 2.1429077, test acc: 0.483\n",
      "poison loss: 0.2440661, poison acc: 0.883\n",
      "elapsed time: 479.009, time for reg: 100.322, time for eig: 145.302\n",
      "epoch:  7529, loss: 0.1830333, train acc: 0.900\n",
      "test loss: 1.9755752, test acc: 0.550\n",
      "poison loss: 0.2122537, poison acc: 0.883\n",
      "elapsed time: 479.606, time for reg: 100.453, time for eig: 145.460\n",
      "epoch:  7539, loss: 0.1971247, train acc: 0.917\n",
      "test loss: 1.9874882, test acc: 0.567\n",
      "poison loss: 0.2227776, poison acc: 0.900\n",
      "elapsed time: 480.178, time for reg: 100.584, time for eig: 145.593\n",
      "epoch:  7549, loss: 0.1704118, train acc: 0.917\n",
      "test loss: 2.0802597, test acc: 0.500\n",
      "poison loss: 0.2376853, poison acc: 0.917\n",
      "elapsed time: 480.791, time for reg: 100.715, time for eig: 145.770\n",
      "epoch:  7559, loss: 0.2655300, train acc: 0.883\n",
      "test loss: 2.2960129, test acc: 0.500\n",
      "poison loss: 0.3965144, poison acc: 0.800\n",
      "elapsed time: 481.396, time for reg: 100.845, time for eig: 145.937\n",
      "epoch:  7569, loss: 0.1715273, train acc: 0.950\n",
      "test loss: 2.1529931, test acc: 0.483\n",
      "poison loss: 0.2593619, poison acc: 0.900\n",
      "elapsed time: 481.937, time for reg: 100.976, time for eig: 146.047\n",
      "epoch:  7579, loss: 0.1497249, train acc: 0.950\n",
      "test loss: 1.9889210, test acc: 0.567\n",
      "poison loss: 0.2857132, poison acc: 0.850\n",
      "elapsed time: 482.565, time for reg: 101.107, time for eig: 146.238\n",
      "epoch:  7589, loss: 0.4042722, train acc: 0.800\n",
      "test loss: 1.8750090, test acc: 0.533\n",
      "poison loss: 0.3846126, poison acc: 0.833\n",
      "elapsed time: 483.265, time for reg: 101.237, time for eig: 146.502\n",
      "epoch:  7599, loss: 0.2092473, train acc: 0.900\n",
      "test loss: 1.9475252, test acc: 0.567\n",
      "poison loss: 0.1863314, poison acc: 0.933\n",
      "elapsed time: 483.856, time for reg: 101.368, time for eig: 146.656\n",
      "epoch:  7609, loss: 0.1660474, train acc: 0.883\n",
      "test loss: 1.9336465, test acc: 0.550\n",
      "poison loss: 0.1865446, poison acc: 0.950\n",
      "elapsed time: 484.459, time for reg: 101.499, time for eig: 146.822\n",
      "epoch:  7619, loss: 0.1839879, train acc: 0.917\n",
      "test loss: 2.0062058, test acc: 0.550\n",
      "poison loss: 0.1936523, poison acc: 0.883\n",
      "elapsed time: 485.043, time for reg: 101.629, time for eig: 146.969\n",
      "epoch:  7629, loss: 0.2592854, train acc: 0.883\n",
      "test loss: 2.2997044, test acc: 0.500\n",
      "poison loss: 0.2388086, poison acc: 0.883\n",
      "elapsed time: 485.587, time for reg: 101.760, time for eig: 147.080\n",
      "epoch:  7639, loss: 0.2666907, train acc: 0.867\n",
      "test loss: 2.0864433, test acc: 0.583\n",
      "poison loss: 0.2915890, poison acc: 0.883\n",
      "elapsed time: 486.166, time for reg: 101.892, time for eig: 147.220\n",
      "epoch:  7649, loss: 0.2544545, train acc: 0.883\n",
      "test loss: 2.1082712, test acc: 0.533\n",
      "poison loss: 0.2648643, poison acc: 0.833\n",
      "elapsed time: 486.716, time for reg: 102.023, time for eig: 147.333\n",
      "epoch:  7659, loss: 0.2152864, train acc: 0.900\n",
      "test loss: 1.9679442, test acc: 0.583\n",
      "poison loss: 0.2803477, poison acc: 0.850\n",
      "elapsed time: 487.340, time for reg: 102.154, time for eig: 147.519\n",
      "epoch:  7669, loss: 0.2398323, train acc: 0.900\n",
      "test loss: 2.0638916, test acc: 0.583\n",
      "poison loss: 0.2876314, poison acc: 0.850\n",
      "elapsed time: 487.904, time for reg: 102.285, time for eig: 147.645\n",
      "epoch:  7679, loss: 0.4124202, train acc: 0.850\n",
      "test loss: 2.0568686, test acc: 0.533\n",
      "poison loss: 0.2706825, poison acc: 0.867\n",
      "elapsed time: 488.481, time for reg: 102.416, time for eig: 147.787\n",
      "epoch:  7689, loss: 0.4409703, train acc: 0.783\n",
      "test loss: 1.8106693, test acc: 0.600\n",
      "poison loss: 0.2562348, poison acc: 0.883\n",
      "elapsed time: 489.141, time for reg: 102.547, time for eig: 148.009\n",
      "epoch:  7699, loss: 0.2212357, train acc: 0.900\n",
      "test loss: 1.8506969, test acc: 0.567\n",
      "poison loss: 0.3672992, poison acc: 0.850\n",
      "elapsed time: 489.715, time for reg: 102.677, time for eig: 148.148\n",
      "epoch:  7709, loss: 0.1613091, train acc: 0.900\n",
      "test loss: 1.9669337, test acc: 0.550\n",
      "poison loss: 0.1890822, poison acc: 0.933\n",
      "elapsed time: 490.470, time for reg: 102.808, time for eig: 148.466\n",
      "epoch:  7719, loss: 0.4179104, train acc: 0.817\n",
      "test loss: 1.6720324, test acc: 0.583\n",
      "poison loss: 0.3332894, poison acc: 0.817\n",
      "elapsed time: 491.029, time for reg: 102.939, time for eig: 148.592\n",
      "epoch:  7729, loss: 0.2185969, train acc: 0.900\n",
      "test loss: 1.8538727, test acc: 0.617\n",
      "poison loss: 0.2933135, poison acc: 0.900\n",
      "elapsed time: 491.592, time for reg: 103.071, time for eig: 148.719\n",
      "epoch:  7739, loss: 0.1605802, train acc: 0.917\n",
      "test loss: 1.9936078, test acc: 0.567\n",
      "poison loss: 0.1831335, poison acc: 0.950\n",
      "elapsed time: 492.158, time for reg: 103.201, time for eig: 148.849\n",
      "epoch:  7749, loss: 0.3483979, train acc: 0.883\n",
      "test loss: 1.8516145, test acc: 0.617\n",
      "poison loss: 0.2929197, poison acc: 0.850\n",
      "elapsed time: 492.817, time for reg: 103.332, time for eig: 149.070\n",
      "epoch:  7759, loss: 0.1567832, train acc: 0.950\n",
      "test loss: 1.8788257, test acc: 0.617\n",
      "poison loss: 0.1990395, poison acc: 0.933\n",
      "elapsed time: 493.378, time for reg: 103.463, time for eig: 149.196\n",
      "epoch:  7769, loss: 0.1793873, train acc: 0.867\n",
      "test loss: 2.0847192, test acc: 0.550\n",
      "poison loss: 0.2210045, poison acc: 0.900\n",
      "elapsed time: 494.002, time for reg: 103.594, time for eig: 149.381\n",
      "epoch:  7779, loss: 0.1985025, train acc: 0.900\n",
      "test loss: 2.0101987, test acc: 0.583\n",
      "poison loss: 0.4313482, poison acc: 0.800\n",
      "elapsed time: 494.612, time for reg: 103.726, time for eig: 149.554\n",
      "epoch:  7789, loss: 0.2678994, train acc: 0.883\n",
      "test loss: 1.9707135, test acc: 0.617\n",
      "poison loss: 0.3731559, poison acc: 0.883\n",
      "elapsed time: 495.390, time for reg: 103.857, time for eig: 149.894\n",
      "epoch:  7799, loss: 0.1501952, train acc: 0.967\n",
      "test loss: 1.9598299, test acc: 0.583\n",
      "poison loss: 0.1966574, poison acc: 0.917\n",
      "elapsed time: 496.045, time for reg: 103.988, time for eig: 150.113\n",
      "epoch:  7809, loss: 0.1372845, train acc: 0.950\n",
      "test loss: 2.0442576, test acc: 0.600\n",
      "poison loss: 0.1781195, poison acc: 0.900\n",
      "elapsed time: 496.674, time for reg: 104.119, time for eig: 150.302\n",
      "epoch:  7819, loss: 0.2889456, train acc: 0.833\n",
      "test loss: 2.2469023, test acc: 0.533\n",
      "poison loss: 0.3349424, poison acc: 0.850\n",
      "elapsed time: 497.273, time for reg: 104.250, time for eig: 150.462\n",
      "epoch:  7829, loss: 0.1491646, train acc: 0.933\n",
      "test loss: 2.2046286, test acc: 0.517\n",
      "poison loss: 0.1858057, poison acc: 0.917\n",
      "elapsed time: 497.840, time for reg: 104.381, time for eig: 150.590\n",
      "epoch:  7839, loss: 0.3403483, train acc: 0.850\n",
      "test loss: 2.1479144, test acc: 0.500\n",
      "poison loss: 0.3879713, poison acc: 0.833\n",
      "elapsed time: 498.424, time for reg: 104.512, time for eig: 150.736\n",
      "epoch:  7849, loss: 0.1983543, train acc: 0.883\n",
      "test loss: 2.0393387, test acc: 0.550\n",
      "poison loss: 0.2286177, poison acc: 0.883\n",
      "elapsed time: 498.989, time for reg: 104.642, time for eig: 150.865\n",
      "epoch:  7859, loss: 0.1633405, train acc: 0.883\n",
      "test loss: 2.0774083, test acc: 0.550\n",
      "poison loss: 0.1531612, poison acc: 0.950\n",
      "elapsed time: 499.578, time for reg: 104.774, time for eig: 151.015\n",
      "epoch:  7869, loss: 0.2517390, train acc: 0.883\n",
      "test loss: 1.8375242, test acc: 0.567\n",
      "poison loss: 0.4309606, poison acc: 0.783\n",
      "elapsed time: 500.171, time for reg: 104.908, time for eig: 151.161\n",
      "epoch:  7879, loss: 0.1522214, train acc: 0.933\n",
      "test loss: 1.9107424, test acc: 0.600\n",
      "poison loss: 0.1700887, poison acc: 0.950\n",
      "elapsed time: 500.976, time for reg: 105.045, time for eig: 151.519\n",
      "epoch:  7889, loss: 0.6387889, train acc: 0.733\n",
      "test loss: 1.9936184, test acc: 0.617\n",
      "poison loss: 0.2136285, poison acc: 0.917\n",
      "elapsed time: 501.588, time for reg: 105.182, time for eig: 151.686\n",
      "epoch:  7899, loss: 0.2060256, train acc: 0.917\n",
      "test loss: 2.0343139, test acc: 0.567\n",
      "poison loss: 0.3742090, poison acc: 0.833\n",
      "elapsed time: 502.212, time for reg: 105.315, time for eig: 151.871\n",
      "epoch:  7909, loss: 0.2011638, train acc: 0.933\n",
      "test loss: 2.0775697, test acc: 0.550\n",
      "poison loss: 0.1682383, poison acc: 0.950\n",
      "elapsed time: 502.827, time for reg: 105.446, time for eig: 152.048\n",
      "epoch:  7919, loss: 0.1557287, train acc: 0.933\n",
      "test loss: 1.8535120, test acc: 0.583\n",
      "poison loss: 0.2776958, poison acc: 0.867\n",
      "elapsed time: 503.919, time for reg: 105.577, time for eig: 152.703\n",
      "epoch:  7929, loss: 0.1703730, train acc: 0.933\n",
      "test loss: 1.8852618, test acc: 0.633\n",
      "poison loss: 0.1906256, poison acc: 0.917\n",
      "elapsed time: 504.498, time for reg: 105.707, time for eig: 152.847\n",
      "epoch:  7939, loss: 0.1411300, train acc: 0.933\n",
      "test loss: 2.2193624, test acc: 0.517\n",
      "poison loss: 0.1835961, poison acc: 0.950\n",
      "elapsed time: 505.090, time for reg: 105.838, time for eig: 153.003\n",
      "epoch:  7949, loss: 0.1407365, train acc: 0.950\n",
      "test loss: 2.0782845, test acc: 0.517\n",
      "poison loss: 0.2447994, poison acc: 0.900\n",
      "elapsed time: 505.645, time for reg: 105.968, time for eig: 153.121\n",
      "epoch:  7959, loss: 0.2121250, train acc: 0.900\n",
      "test loss: 1.9561333, test acc: 0.567\n",
      "poison loss: 0.2024796, poison acc: 0.933\n",
      "elapsed time: 506.226, time for reg: 106.098, time for eig: 153.265\n",
      "epoch:  7969, loss: 0.2048173, train acc: 0.900\n",
      "test loss: 1.8212644, test acc: 0.600\n",
      "poison loss: 0.2460732, poison acc: 0.833\n",
      "elapsed time: 506.867, time for reg: 106.228, time for eig: 153.470\n",
      "epoch:  7979, loss: 0.1422703, train acc: 0.917\n",
      "test loss: 1.9860668, test acc: 0.600\n",
      "poison loss: 0.2164132, poison acc: 0.883\n",
      "elapsed time: 507.718, time for reg: 106.358, time for eig: 153.884\n",
      "epoch:  7989, loss: 0.2652949, train acc: 0.867\n",
      "test loss: 1.9520058, test acc: 0.617\n",
      "poison loss: 0.2105787, poison acc: 0.883\n",
      "elapsed time: 508.300, time for reg: 106.488, time for eig: 154.032\n",
      "epoch:  7999, loss: 0.1415408, train acc: 0.933\n",
      "test loss: 2.1752056, test acc: 0.550\n",
      "poison loss: 0.1307976, poison acc: 0.983\n",
      "elapsed time: 508.910, time for reg: 106.618, time for eig: 154.205\n",
      "epoch:  8009, loss: 0.3166198, train acc: 0.817\n",
      "test loss: 1.8034989, test acc: 0.567\n",
      "poison loss: 0.4213662, poison acc: 0.817\n",
      "elapsed time: 509.577, time for reg: 106.761, time for eig: 154.407\n",
      "epoch:  8019, loss: 0.1601495, train acc: 0.933\n",
      "test loss: 2.0044363, test acc: 0.550\n",
      "poison loss: 0.1366160, poison acc: 0.983\n",
      "elapsed time: 510.144, time for reg: 106.891, time for eig: 154.536\n",
      "epoch:  8029, loss: 0.2488387, train acc: 0.933\n",
      "test loss: 1.9608619, test acc: 0.517\n",
      "poison loss: 0.1579330, poison acc: 0.950\n",
      "elapsed time: 510.706, time for reg: 107.022, time for eig: 154.661\n",
      "epoch:  8039, loss: 0.1255260, train acc: 0.950\n",
      "test loss: 1.9878004, test acc: 0.567\n",
      "poison loss: 0.2442767, poison acc: 0.917\n",
      "elapsed time: 511.317, time for reg: 107.153, time for eig: 154.833\n",
      "epoch:  8049, loss: 0.2032163, train acc: 0.883\n",
      "test loss: 2.1042433, test acc: 0.567\n",
      "poison loss: 0.1496043, poison acc: 0.933\n",
      "elapsed time: 511.916, time for reg: 107.285, time for eig: 154.999\n",
      "epoch:  8059, loss: 0.1685395, train acc: 0.917\n",
      "test loss: 2.1803013, test acc: 0.500\n",
      "poison loss: 0.5197163, poison acc: 0.833\n",
      "elapsed time: 512.473, time for reg: 107.416, time for eig: 155.118\n",
      "epoch:  8069, loss: 0.1434790, train acc: 0.967\n",
      "test loss: 2.0245824, test acc: 0.567\n",
      "poison loss: 0.2207550, poison acc: 0.900\n",
      "elapsed time: 513.153, time for reg: 107.547, time for eig: 155.358\n",
      "epoch:  8079, loss: 0.1892132, train acc: 0.933\n",
      "test loss: 2.0709301, test acc: 0.550\n",
      "poison loss: 0.3070798, poison acc: 0.817\n",
      "elapsed time: 513.779, time for reg: 107.679, time for eig: 155.545\n",
      "epoch:  8089, loss: 0.5635236, train acc: 0.817\n",
      "test loss: 2.3399874, test acc: 0.500\n",
      "poison loss: 0.7235455, poison acc: 0.717\n",
      "elapsed time: 514.465, time for reg: 107.810, time for eig: 155.792\n",
      "epoch:  8099, loss: 0.2762239, train acc: 0.817\n",
      "test loss: 1.9402395, test acc: 0.550\n",
      "poison loss: 0.2715978, poison acc: 0.883\n",
      "elapsed time: 515.034, time for reg: 107.942, time for eig: 155.923\n",
      "epoch:  8109, loss: 0.1952437, train acc: 0.900\n",
      "test loss: 2.0301162, test acc: 0.567\n",
      "poison loss: 0.7791591, poison acc: 0.767\n",
      "elapsed time: 515.633, time for reg: 108.074, time for eig: 156.082\n",
      "epoch:  8119, loss: 0.1899778, train acc: 0.900\n",
      "test loss: 1.6713555, test acc: 0.600\n",
      "poison loss: 0.2811889, poison acc: 0.850\n",
      "elapsed time: 516.242, time for reg: 108.205, time for eig: 156.252\n",
      "epoch:  8129, loss: 0.1913383, train acc: 0.883\n",
      "test loss: 1.7917370, test acc: 0.617\n",
      "poison loss: 0.3538436, poison acc: 0.833\n",
      "elapsed time: 516.806, time for reg: 108.336, time for eig: 156.379\n",
      "epoch:  8139, loss: 0.1455004, train acc: 0.917\n",
      "test loss: 1.9607199, test acc: 0.550\n",
      "poison loss: 0.1733760, poison acc: 0.917\n",
      "elapsed time: 517.398, time for reg: 108.467, time for eig: 156.531\n",
      "epoch:  8149, loss: 0.2100599, train acc: 0.900\n",
      "test loss: 1.9904446, test acc: 0.567\n",
      "poison loss: 0.1798117, poison acc: 0.933\n",
      "elapsed time: 518.039, time for reg: 108.599, time for eig: 156.734\n",
      "epoch:  8159, loss: 0.1724967, train acc: 0.950\n",
      "test loss: 2.2001768, test acc: 0.533\n",
      "poison loss: 0.1569076, poison acc: 0.967\n",
      "elapsed time: 518.604, time for reg: 108.730, time for eig: 156.860\n",
      "epoch:  8169, loss: 0.2548726, train acc: 0.850\n",
      "test loss: 2.0467065, test acc: 0.600\n",
      "poison loss: 0.2330366, poison acc: 0.900\n",
      "elapsed time: 519.370, time for reg: 108.862, time for eig: 157.188\n",
      "epoch:  8179, loss: 0.1280152, train acc: 0.933\n",
      "test loss: 2.2523270, test acc: 0.533\n",
      "poison loss: 0.1519968, poison acc: 0.933\n",
      "elapsed time: 519.950, time for reg: 108.994, time for eig: 157.329\n",
      "epoch:  8189, loss: 0.3342998, train acc: 0.850\n",
      "test loss: 2.2773151, test acc: 0.400\n",
      "poison loss: 0.4574450, poison acc: 0.800\n",
      "elapsed time: 521.131, time for reg: 109.125, time for eig: 158.072\n",
      "epoch:  8199, loss: 0.2313392, train acc: 0.850\n",
      "test loss: 2.0304147, test acc: 0.550\n",
      "poison loss: 0.6249553, poison acc: 0.800\n",
      "elapsed time: 521.689, time for reg: 109.257, time for eig: 158.192\n",
      "epoch:  8209, loss: 0.1747843, train acc: 0.900\n",
      "test loss: 2.0606717, test acc: 0.600\n",
      "poison loss: 0.1423739, poison acc: 0.933\n",
      "elapsed time: 522.449, time for reg: 109.389, time for eig: 158.511\n",
      "epoch:  8219, loss: 0.1715110, train acc: 0.933\n",
      "test loss: 2.1562024, test acc: 0.550\n",
      "poison loss: 0.2625371, poison acc: 0.850\n",
      "elapsed time: 523.034, time for reg: 109.520, time for eig: 158.656\n",
      "epoch:  8229, loss: 0.1449432, train acc: 0.933\n",
      "test loss: 2.2563121, test acc: 0.533\n",
      "poison loss: 0.1605361, poison acc: 0.950\n",
      "elapsed time: 523.616, time for reg: 109.652, time for eig: 158.799\n",
      "epoch:  8239, loss: 0.1125277, train acc: 0.967\n",
      "test loss: 2.2972742, test acc: 0.550\n",
      "poison loss: 0.1506663, poison acc: 0.933\n",
      "elapsed time: 524.294, time for reg: 109.783, time for eig: 159.038\n",
      "epoch:  8249, loss: 0.3500280, train acc: 0.833\n",
      "test loss: 2.0642876, test acc: 0.617\n",
      "poison loss: 0.2980519, poison acc: 0.867\n",
      "elapsed time: 524.849, time for reg: 109.914, time for eig: 159.154\n",
      "epoch:  8259, loss: 0.1524578, train acc: 0.900\n",
      "test loss: 1.8021284, test acc: 0.617\n",
      "poison loss: 0.2033474, poison acc: 0.950\n",
      "elapsed time: 525.557, time for reg: 110.045, time for eig: 159.424\n",
      "epoch:  8269, loss: 0.1396649, train acc: 0.933\n",
      "test loss: 1.9522031, test acc: 0.583\n",
      "poison loss: 0.1610491, poison acc: 0.950\n",
      "elapsed time: 526.198, time for reg: 110.177, time for eig: 159.631\n",
      "epoch:  8279, loss: 0.5035122, train acc: 0.783\n",
      "test loss: 1.8588364, test acc: 0.550\n",
      "poison loss: 0.3387955, poison acc: 0.833\n",
      "elapsed time: 526.884, time for reg: 110.307, time for eig: 159.879\n",
      "epoch:  8289, loss: 0.1394048, train acc: 0.917\n",
      "test loss: 2.1412103, test acc: 0.567\n",
      "poison loss: 0.1920464, poison acc: 0.917\n",
      "elapsed time: 527.434, time for reg: 110.438, time for eig: 159.991\n",
      "epoch:  8299, loss: 0.1970513, train acc: 0.900\n",
      "test loss: 2.0803826, test acc: 0.617\n",
      "poison loss: 0.1759859, poison acc: 0.900\n",
      "elapsed time: 527.998, time for reg: 110.569, time for eig: 160.118\n",
      "epoch:  8309, loss: 0.1299171, train acc: 0.950\n",
      "test loss: 2.1895421, test acc: 0.550\n",
      "poison loss: 0.1842282, poison acc: 0.883\n",
      "elapsed time: 528.547, time for reg: 110.700, time for eig: 160.230\n",
      "epoch:  8319, loss: 0.1373897, train acc: 0.917\n",
      "test loss: 2.1366225, test acc: 0.533\n",
      "poison loss: 0.1769761, poison acc: 0.933\n",
      "elapsed time: 529.361, time for reg: 110.831, time for eig: 160.605\n",
      "epoch:  8329, loss: 0.3290391, train acc: 0.833\n",
      "test loss: 1.9599193, test acc: 0.583\n",
      "poison loss: 0.6436228, poison acc: 0.717\n",
      "elapsed time: 530.032, time for reg: 110.962, time for eig: 160.837\n",
      "epoch:  8339, loss: 0.1623284, train acc: 0.950\n",
      "test loss: 1.9826438, test acc: 0.583\n",
      "poison loss: 0.2354938, poison acc: 0.917\n",
      "elapsed time: 530.663, time for reg: 111.106, time for eig: 160.994\n",
      "epoch:  8349, loss: 0.2359657, train acc: 0.883\n",
      "test loss: 1.8060758, test acc: 0.567\n",
      "poison loss: 0.2232957, poison acc: 0.917\n",
      "elapsed time: 531.273, time for reg: 111.237, time for eig: 161.166\n",
      "epoch:  8359, loss: 0.2731758, train acc: 0.867\n",
      "test loss: 2.1081203, test acc: 0.467\n",
      "poison loss: 0.2763525, poison acc: 0.867\n",
      "elapsed time: 531.834, time for reg: 111.369, time for eig: 161.287\n",
      "epoch:  8369, loss: 0.1348253, train acc: 0.933\n",
      "test loss: 2.0082693, test acc: 0.550\n",
      "poison loss: 0.1394152, poison acc: 0.950\n",
      "elapsed time: 532.405, time for reg: 111.501, time for eig: 161.416\n",
      "epoch:  8379, loss: 0.2007547, train acc: 0.933\n",
      "test loss: 2.2367923, test acc: 0.517\n",
      "poison loss: 0.2774689, poison acc: 0.850\n",
      "elapsed time: 532.962, time for reg: 111.633, time for eig: 161.535\n",
      "epoch:  8389, loss: 0.1527296, train acc: 0.933\n",
      "test loss: 1.8998095, test acc: 0.583\n",
      "poison loss: 0.2130472, poison acc: 0.900\n",
      "elapsed time: 533.589, time for reg: 111.764, time for eig: 161.722\n",
      "epoch:  8399, loss: 0.1388911, train acc: 0.917\n",
      "test loss: 2.0126334, test acc: 0.550\n",
      "poison loss: 0.1584230, poison acc: 0.950\n",
      "elapsed time: 534.196, time for reg: 111.895, time for eig: 161.892\n",
      "epoch:  8409, loss: 0.1415552, train acc: 0.933\n",
      "test loss: 2.0772012, test acc: 0.550\n",
      "poison loss: 0.1560940, poison acc: 0.950\n",
      "elapsed time: 534.825, time for reg: 112.033, time for eig: 162.065\n",
      "epoch:  8419, loss: 0.1319590, train acc: 0.950\n",
      "test loss: 2.0938876, test acc: 0.567\n",
      "poison loss: 0.1862096, poison acc: 0.900\n",
      "elapsed time: 535.432, time for reg: 112.163, time for eig: 162.237\n",
      "epoch:  8429, loss: 0.4946683, train acc: 0.817\n",
      "test loss: 2.0886096, test acc: 0.550\n",
      "poison loss: 0.3017578, poison acc: 0.883\n",
      "elapsed time: 536.004, time for reg: 112.293, time for eig: 162.372\n",
      "epoch:  8439, loss: 0.2827146, train acc: 0.883\n",
      "test loss: 1.8130961, test acc: 0.550\n",
      "poison loss: 0.2976310, poison acc: 0.817\n",
      "elapsed time: 536.575, time for reg: 112.423, time for eig: 162.509\n",
      "epoch:  8449, loss: 0.1333871, train acc: 0.967\n",
      "test loss: 2.2407987, test acc: 0.483\n",
      "poison loss: 0.2380260, poison acc: 0.900\n",
      "elapsed time: 537.152, time for reg: 112.553, time for eig: 162.649\n",
      "epoch:  8459, loss: 0.1652108, train acc: 0.900\n",
      "test loss: 2.2856416, test acc: 0.517\n",
      "poison loss: 0.1703918, poison acc: 0.950\n",
      "elapsed time: 537.727, time for reg: 112.683, time for eig: 162.791\n",
      "epoch:  8469, loss: 0.1590272, train acc: 0.950\n",
      "test loss: 2.0900034, test acc: 0.550\n",
      "poison loss: 0.7866763, poison acc: 0.783\n",
      "elapsed time: 538.335, time for reg: 112.813, time for eig: 162.964\n",
      "epoch:  8479, loss: 0.1113338, train acc: 0.950\n",
      "test loss: 2.0222262, test acc: 0.633\n",
      "poison loss: 0.1252551, poison acc: 0.967\n",
      "elapsed time: 538.964, time for reg: 112.942, time for eig: 163.157\n",
      "epoch:  8489, loss: 0.2096913, train acc: 0.867\n",
      "test loss: 2.2289431, test acc: 0.500\n",
      "poison loss: 0.2721454, poison acc: 0.833\n",
      "elapsed time: 539.654, time for reg: 113.073, time for eig: 163.411\n",
      "epoch:  8499, loss: 0.1928145, train acc: 0.883\n",
      "test loss: 1.9784824, test acc: 0.583\n",
      "poison loss: 0.3129785, poison acc: 0.833\n",
      "elapsed time: 540.254, time for reg: 113.202, time for eig: 163.577\n",
      "epoch:  8509, loss: 0.0944196, train acc: 0.983\n",
      "test loss: 2.1711528, test acc: 0.550\n",
      "poison loss: 0.1308251, poison acc: 0.967\n",
      "elapsed time: 540.895, time for reg: 113.332, time for eig: 163.782\n",
      "epoch:  8519, loss: 0.1804059, train acc: 0.900\n",
      "test loss: 2.2624583, test acc: 0.567\n",
      "poison loss: 0.1693897, poison acc: 0.900\n",
      "elapsed time: 541.590, time for reg: 113.462, time for eig: 164.040\n",
      "epoch:  8529, loss: 0.3702059, train acc: 0.800\n",
      "test loss: 2.0246072, test acc: 0.567\n",
      "poison loss: 0.4114056, poison acc: 0.800\n",
      "elapsed time: 542.162, time for reg: 113.592, time for eig: 164.177\n",
      "epoch:  8539, loss: 0.1898809, train acc: 0.883\n",
      "test loss: 2.0502855, test acc: 0.517\n",
      "poison loss: 0.2421352, poison acc: 0.867\n",
      "elapsed time: 542.718, time for reg: 113.722, time for eig: 164.296\n",
      "epoch:  8549, loss: 0.1424030, train acc: 0.950\n",
      "test loss: 2.0257527, test acc: 0.550\n",
      "poison loss: 0.1776994, poison acc: 0.917\n",
      "elapsed time: 543.326, time for reg: 113.852, time for eig: 164.467\n",
      "epoch:  8559, loss: 0.2852127, train acc: 0.817\n",
      "test loss: 1.8314025, test acc: 0.667\n",
      "poison loss: 0.3952886, poison acc: 0.800\n",
      "elapsed time: 543.904, time for reg: 113.982, time for eig: 164.609\n",
      "epoch:  8569, loss: 0.2696753, train acc: 0.917\n",
      "test loss: 2.2118829, test acc: 0.550\n",
      "poison loss: 0.2359946, poison acc: 0.883\n",
      "elapsed time: 544.520, time for reg: 114.127, time for eig: 164.743\n",
      "epoch:  8579, loss: 0.1937706, train acc: 0.900\n",
      "test loss: 1.9037304, test acc: 0.533\n",
      "poison loss: 0.3003513, poison acc: 0.850\n",
      "elapsed time: 545.143, time for reg: 114.267, time for eig: 164.903\n",
      "epoch:  8589, loss: 0.1550462, train acc: 0.950\n",
      "test loss: 2.0066492, test acc: 0.583\n",
      "poison loss: 0.2745826, poison acc: 0.867\n",
      "elapsed time: 545.740, time for reg: 114.405, time for eig: 165.041\n",
      "epoch:  8599, loss: 0.1976967, train acc: 0.900\n",
      "test loss: 2.0568143, test acc: 0.517\n",
      "poison loss: 0.1818217, poison acc: 0.917\n",
      "elapsed time: 546.343, time for reg: 114.546, time for eig: 165.180\n",
      "epoch:  8609, loss: 0.1818740, train acc: 0.933\n",
      "test loss: 1.8494360, test acc: 0.583\n",
      "poison loss: 0.2322908, poison acc: 0.867\n",
      "elapsed time: 547.111, time for reg: 114.685, time for eig: 165.487\n",
      "epoch:  8619, loss: 0.2035781, train acc: 0.883\n",
      "test loss: 2.0414559, test acc: 0.583\n",
      "poison loss: 0.2875002, poison acc: 0.833\n",
      "elapsed time: 547.680, time for reg: 114.824, time for eig: 165.595\n",
      "epoch:  8629, loss: 0.1774012, train acc: 0.950\n",
      "test loss: 1.9735490, test acc: 0.550\n",
      "poison loss: 0.1848453, poison acc: 0.900\n",
      "elapsed time: 548.341, time for reg: 114.963, time for eig: 165.797\n",
      "epoch:  8639, loss: 0.1359431, train acc: 0.950\n",
      "test loss: 1.9479902, test acc: 0.550\n",
      "poison loss: 0.2715327, poison acc: 0.883\n",
      "elapsed time: 548.992, time for reg: 115.102, time for eig: 165.987\n",
      "epoch:  8649, loss: 0.2664137, train acc: 0.867\n",
      "test loss: 1.9990987, test acc: 0.517\n",
      "poison loss: 0.1979800, poison acc: 0.883\n",
      "elapsed time: 549.605, time for reg: 115.240, time for eig: 166.141\n",
      "epoch:  8659, loss: 0.1700542, train acc: 0.917\n",
      "test loss: 2.0329815, test acc: 0.500\n",
      "poison loss: 0.2055685, poison acc: 0.933\n",
      "elapsed time: 550.348, time for reg: 115.381, time for eig: 166.420\n",
      "epoch:  8669, loss: 0.2634877, train acc: 0.900\n",
      "test loss: 1.8195835, test acc: 0.567\n",
      "poison loss: 0.2516063, poison acc: 0.883\n",
      "elapsed time: 550.988, time for reg: 115.520, time for eig: 166.600\n",
      "epoch:  8679, loss: 0.1469370, train acc: 0.950\n",
      "test loss: 1.8255811, test acc: 0.583\n",
      "poison loss: 0.1919346, poison acc: 0.900\n",
      "elapsed time: 551.588, time for reg: 115.661, time for eig: 166.738\n",
      "epoch:  8689, loss: 0.1354459, train acc: 0.950\n",
      "test loss: 1.9394856, test acc: 0.583\n",
      "poison loss: 0.1846699, poison acc: 0.883\n",
      "elapsed time: 552.238, time for reg: 115.802, time for eig: 166.927\n",
      "epoch:  8699, loss: 0.4193601, train acc: 0.817\n",
      "test loss: 2.3898544, test acc: 0.417\n",
      "poison loss: 0.8140455, poison acc: 0.683\n",
      "elapsed time: 552.888, time for reg: 115.943, time for eig: 167.114\n",
      "epoch:  8709, loss: 0.1901376, train acc: 0.917\n",
      "test loss: 1.9890658, test acc: 0.517\n",
      "poison loss: 0.1839835, poison acc: 0.933\n",
      "elapsed time: 553.512, time for reg: 116.082, time for eig: 167.277\n",
      "epoch:  8719, loss: 0.1421003, train acc: 0.917\n",
      "test loss: 1.9339776, test acc: 0.600\n",
      "poison loss: 0.1747151, poison acc: 0.900\n",
      "elapsed time: 554.159, time for reg: 116.221, time for eig: 167.464\n",
      "epoch:  8729, loss: 0.1308187, train acc: 0.950\n",
      "test loss: 1.9399892, test acc: 0.583\n",
      "poison loss: 0.1679388, poison acc: 0.933\n",
      "elapsed time: 554.952, time for reg: 116.360, time for eig: 167.796\n",
      "epoch:  8739, loss: 0.1852669, train acc: 0.933\n",
      "test loss: 1.8853977, test acc: 0.633\n",
      "poison loss: 0.1805593, poison acc: 0.933\n",
      "elapsed time: 555.637, time for reg: 116.503, time for eig: 168.017\n",
      "epoch:  8749, loss: 0.1555509, train acc: 0.933\n",
      "test loss: 1.9315739, test acc: 0.583\n",
      "poison loss: 0.2111391, poison acc: 0.900\n",
      "elapsed time: 556.280, time for reg: 116.644, time for eig: 168.196\n",
      "epoch:  8759, loss: 0.3045764, train acc: 0.850\n",
      "test loss: 2.1180189, test acc: 0.550\n",
      "poison loss: 0.4391469, poison acc: 0.867\n",
      "elapsed time: 556.895, time for reg: 116.784, time for eig: 168.349\n",
      "epoch:  8769, loss: 0.1942390, train acc: 0.917\n",
      "test loss: 2.1719465, test acc: 0.533\n",
      "poison loss: 0.2639507, poison acc: 0.850\n",
      "elapsed time: 557.568, time for reg: 116.936, time for eig: 168.528\n",
      "epoch:  8779, loss: 0.1957051, train acc: 0.917\n",
      "test loss: 2.0857082, test acc: 0.567\n",
      "poison loss: 0.1452966, poison acc: 0.933\n",
      "elapsed time: 558.158, time for reg: 117.067, time for eig: 168.678\n",
      "epoch:  8789, loss: 0.1331287, train acc: 0.967\n",
      "test loss: 2.0661079, test acc: 0.533\n",
      "poison loss: 0.2842586, poison acc: 0.850\n",
      "elapsed time: 558.736, time for reg: 117.198, time for eig: 168.818\n",
      "epoch:  8799, loss: 0.1590774, train acc: 0.917\n",
      "test loss: 2.1153623, test acc: 0.533\n",
      "poison loss: 0.1815792, poison acc: 0.900\n",
      "elapsed time: 559.320, time for reg: 117.329, time for eig: 168.963\n",
      "epoch:  8809, loss: 0.3240773, train acc: 0.867\n",
      "test loss: 1.8911575, test acc: 0.583\n",
      "poison loss: 0.2425656, poison acc: 0.883\n",
      "elapsed time: 559.885, time for reg: 117.460, time for eig: 169.089\n",
      "epoch:  8819, loss: 0.2664078, train acc: 0.900\n",
      "test loss: 1.9936212, test acc: 0.567\n",
      "poison loss: 0.4163969, poison acc: 0.850\n",
      "elapsed time: 560.465, time for reg: 117.591, time for eig: 169.228\n",
      "epoch:  8829, loss: 0.2755390, train acc: 0.883\n",
      "test loss: 2.0006841, test acc: 0.600\n",
      "poison loss: 0.1746726, poison acc: 0.883\n",
      "elapsed time: 561.067, time for reg: 117.721, time for eig: 169.392\n",
      "epoch:  8839, loss: 0.1416460, train acc: 0.933\n",
      "test loss: 2.0278376, test acc: 0.600\n",
      "poison loss: 0.1657507, poison acc: 0.917\n",
      "elapsed time: 561.703, time for reg: 117.857, time for eig: 169.581\n",
      "epoch:  8849, loss: 0.1811434, train acc: 0.917\n",
      "test loss: 2.0202693, test acc: 0.517\n",
      "poison loss: 0.2410637, poison acc: 0.883\n",
      "elapsed time: 562.272, time for reg: 117.987, time for eig: 169.713\n",
      "epoch:  8859, loss: 0.1611339, train acc: 0.967\n",
      "test loss: 1.9949753, test acc: 0.567\n",
      "poison loss: 0.1466985, poison acc: 0.933\n",
      "elapsed time: 563.097, time for reg: 118.118, time for eig: 170.100\n",
      "epoch:  8869, loss: 0.1509294, train acc: 0.933\n",
      "test loss: 2.0037693, test acc: 0.567\n",
      "poison loss: 0.1321566, poison acc: 0.967\n",
      "elapsed time: 563.702, time for reg: 118.249, time for eig: 170.267\n",
      "epoch:  8879, loss: 0.3419475, train acc: 0.850\n",
      "test loss: 1.9171570, test acc: 0.533\n",
      "poison loss: 0.1851583, poison acc: 0.900\n",
      "elapsed time: 564.365, time for reg: 118.379, time for eig: 170.493\n",
      "epoch:  8889, loss: 0.1454412, train acc: 0.933\n",
      "test loss: 1.9237623, test acc: 0.633\n",
      "poison loss: 0.1674442, poison acc: 0.950\n",
      "elapsed time: 564.930, time for reg: 118.510, time for eig: 170.620\n",
      "epoch:  8899, loss: 0.1099082, train acc: 0.950\n",
      "test loss: 2.2071496, test acc: 0.517\n",
      "poison loss: 0.3951314, poison acc: 0.817\n",
      "elapsed time: 565.553, time for reg: 118.641, time for eig: 170.805\n",
      "epoch:  8909, loss: 0.2749403, train acc: 0.850\n",
      "test loss: 2.0587492, test acc: 0.567\n",
      "poison loss: 0.2113222, poison acc: 0.867\n",
      "elapsed time: 566.106, time for reg: 118.772, time for eig: 170.919\n",
      "epoch:  8919, loss: 0.2076665, train acc: 0.933\n",
      "test loss: 1.8928816, test acc: 0.617\n",
      "poison loss: 0.2681350, poison acc: 0.833\n",
      "elapsed time: 566.683, time for reg: 118.903, time for eig: 171.059\n",
      "epoch:  8929, loss: 0.4686119, train acc: 0.817\n",
      "test loss: 1.8647016, test acc: 0.617\n",
      "poison loss: 0.8323020, poison acc: 0.717\n",
      "elapsed time: 567.252, time for reg: 119.034, time for eig: 171.189\n",
      "epoch:  8939, loss: 0.1347450, train acc: 0.917\n",
      "test loss: 1.9913002, test acc: 0.567\n",
      "poison loss: 0.2275974, poison acc: 0.917\n",
      "elapsed time: 567.819, time for reg: 119.165, time for eig: 171.317\n",
      "epoch:  8949, loss: 0.1458469, train acc: 0.933\n",
      "test loss: 2.0032545, test acc: 0.617\n",
      "poison loss: 0.1635859, poison acc: 0.950\n",
      "elapsed time: 568.461, time for reg: 119.296, time for eig: 171.520\n",
      "epoch:  8959, loss: 0.1586266, train acc: 0.967\n",
      "test loss: 1.8750452, test acc: 0.583\n",
      "poison loss: 0.1817397, poison acc: 0.933\n",
      "elapsed time: 569.109, time for reg: 119.427, time for eig: 171.730\n",
      "epoch:  8969, loss: 0.1948419, train acc: 0.917\n",
      "test loss: 2.0589743, test acc: 0.583\n",
      "poison loss: 0.2170515, poison acc: 0.900\n",
      "elapsed time: 569.698, time for reg: 119.558, time for eig: 171.880\n",
      "epoch:  8979, loss: 0.1983958, train acc: 0.917\n",
      "test loss: 1.8638521, test acc: 0.600\n",
      "poison loss: 0.1778181, poison acc: 0.933\n",
      "elapsed time: 570.259, time for reg: 119.689, time for eig: 172.004\n",
      "epoch:  8989, loss: 0.1363397, train acc: 0.933\n",
      "test loss: 2.0145818, test acc: 0.583\n",
      "poison loss: 0.1425791, poison acc: 0.933\n",
      "elapsed time: 570.918, time for reg: 119.820, time for eig: 172.225\n",
      "epoch:  8999, loss: 0.2367237, train acc: 0.867\n",
      "test loss: 1.9386292, test acc: 0.600\n",
      "poison loss: 0.4014476, poison acc: 0.800\n",
      "elapsed time: 571.505, time for reg: 119.951, time for eig: 172.373\n",
      "epoch:  9009, loss: 0.2058533, train acc: 0.883\n",
      "test loss: 1.9956737, test acc: 0.650\n",
      "poison loss: 0.1333534, poison acc: 0.950\n",
      "elapsed time: 572.066, time for reg: 120.082, time for eig: 172.498\n",
      "epoch:  9019, loss: 0.1276917, train acc: 0.933\n",
      "test loss: 2.0215694, test acc: 0.617\n",
      "poison loss: 0.1804600, poison acc: 0.917\n",
      "elapsed time: 572.681, time for reg: 120.213, time for eig: 172.673\n",
      "epoch:  9029, loss: 0.1173707, train acc: 0.917\n",
      "test loss: 1.9933676, test acc: 0.600\n",
      "poison loss: 0.2368261, poison acc: 0.867\n",
      "elapsed time: 573.492, time for reg: 120.344, time for eig: 173.045\n",
      "epoch:  9039, loss: 0.2636846, train acc: 0.867\n",
      "test loss: 2.2322267, test acc: 0.550\n",
      "poison loss: 0.3653567, poison acc: 0.867\n",
      "elapsed time: 574.118, time for reg: 120.475, time for eig: 173.233\n",
      "epoch:  9049, loss: 0.2352541, train acc: 0.917\n",
      "test loss: 2.1390265, test acc: 0.600\n",
      "poison loss: 0.3310098, poison acc: 0.850\n",
      "elapsed time: 574.693, time for reg: 120.606, time for eig: 173.370\n",
      "epoch:  9059, loss: 0.1797517, train acc: 0.917\n",
      "test loss: 2.2938156, test acc: 0.517\n",
      "poison loss: 0.3547129, poison acc: 0.800\n",
      "elapsed time: 575.293, time for reg: 120.737, time for eig: 173.530\n",
      "epoch:  9069, loss: 0.1181906, train acc: 0.967\n",
      "test loss: 2.0876361, test acc: 0.583\n",
      "poison loss: 0.1449615, poison acc: 0.900\n",
      "elapsed time: 575.908, time for reg: 120.868, time for eig: 173.707\n",
      "epoch:  9079, loss: 0.3553016, train acc: 0.900\n",
      "test loss: 1.5479739, test acc: 0.600\n",
      "poison loss: 0.5674384, poison acc: 0.833\n",
      "elapsed time: 576.480, time for reg: 120.999, time for eig: 173.840\n",
      "epoch:  9089, loss: 0.2188215, train acc: 0.933\n",
      "test loss: 1.6911879, test acc: 0.550\n",
      "poison loss: 0.2852578, poison acc: 0.917\n",
      "elapsed time: 577.194, time for reg: 121.130, time for eig: 174.113\n",
      "epoch:  9099, loss: 0.3906946, train acc: 0.883\n",
      "test loss: 1.5714535, test acc: 0.583\n",
      "poison loss: 0.3011556, poison acc: 0.883\n",
      "elapsed time: 577.905, time for reg: 121.263, time for eig: 174.377\n",
      "epoch:  9109, loss: 0.2420030, train acc: 0.883\n",
      "test loss: 1.6224679, test acc: 0.600\n",
      "poison loss: 0.3248244, poison acc: 0.800\n",
      "elapsed time: 578.520, time for reg: 121.394, time for eig: 174.553\n",
      "epoch:  9119, loss: 0.2430841, train acc: 0.883\n",
      "test loss: 1.8539277, test acc: 0.550\n",
      "poison loss: 0.4330652, poison acc: 0.767\n",
      "elapsed time: 579.193, time for reg: 121.535, time for eig: 174.760\n",
      "epoch:  9129, loss: 0.1757331, train acc: 0.950\n",
      "test loss: 1.9645108, test acc: 0.517\n",
      "poison loss: 0.2415538, poison acc: 0.900\n",
      "elapsed time: 579.996, time for reg: 121.669, time for eig: 175.118\n",
      "epoch:  9139, loss: 0.6389600, train acc: 0.767\n",
      "test loss: 1.8962325, test acc: 0.517\n",
      "poison loss: 0.4267921, poison acc: 0.783\n",
      "elapsed time: 580.600, time for reg: 121.808, time for eig: 175.263\n",
      "epoch:  9149, loss: 0.4662530, train acc: 0.850\n",
      "test loss: 1.7651662, test acc: 0.500\n",
      "poison loss: 0.2294930, poison acc: 0.883\n",
      "elapsed time: 581.240, time for reg: 121.939, time for eig: 175.461\n",
      "epoch:  9159, loss: 0.1794640, train acc: 0.933\n",
      "test loss: 1.7831055, test acc: 0.567\n",
      "poison loss: 0.7499175, poison acc: 0.750\n",
      "elapsed time: 581.852, time for reg: 122.075, time for eig: 175.619\n",
      "epoch:  9169, loss: 0.1793318, train acc: 0.933\n",
      "test loss: 1.9321384, test acc: 0.500\n",
      "poison loss: 0.3041972, poison acc: 0.817\n",
      "elapsed time: 582.453, time for reg: 122.209, time for eig: 175.774\n",
      "epoch:  9179, loss: 0.1405288, train acc: 0.950\n",
      "test loss: 1.8008327, test acc: 0.567\n",
      "poison loss: 0.1553234, poison acc: 0.933\n",
      "elapsed time: 583.062, time for reg: 122.343, time for eig: 175.939\n",
      "epoch:  9189, loss: 0.1034788, train acc: 0.950\n",
      "test loss: 2.1324844, test acc: 0.517\n",
      "poison loss: 0.1500759, poison acc: 0.933\n",
      "elapsed time: 583.661, time for reg: 122.473, time for eig: 176.099\n",
      "epoch:  9199, loss: 0.1925614, train acc: 0.933\n",
      "test loss: 1.9296529, test acc: 0.517\n",
      "poison loss: 0.3963065, poison acc: 0.817\n",
      "elapsed time: 584.274, time for reg: 122.604, time for eig: 176.272\n",
      "epoch:  9209, loss: 0.2195579, train acc: 0.850\n",
      "test loss: 2.0721680, test acc: 0.550\n",
      "poison loss: 0.3919435, poison acc: 0.817\n",
      "elapsed time: 584.906, time for reg: 122.735, time for eig: 176.466\n",
      "epoch:  9219, loss: 0.2143145, train acc: 0.917\n",
      "test loss: 2.0958480, test acc: 0.517\n",
      "poison loss: 0.1905834, poison acc: 0.933\n",
      "elapsed time: 585.555, time for reg: 122.866, time for eig: 176.671\n",
      "epoch:  9229, loss: 0.1945212, train acc: 0.917\n",
      "test loss: 1.8329371, test acc: 0.550\n",
      "poison loss: 0.3726520, poison acc: 0.817\n",
      "elapsed time: 586.192, time for reg: 122.997, time for eig: 176.867\n",
      "epoch:  9239, loss: 0.1361736, train acc: 0.950\n",
      "test loss: 2.1132302, test acc: 0.550\n",
      "poison loss: 0.1245675, poison acc: 0.983\n",
      "elapsed time: 586.885, time for reg: 123.127, time for eig: 177.123\n",
      "epoch:  9249, loss: 0.1723459, train acc: 0.900\n",
      "test loss: 1.9353173, test acc: 0.583\n",
      "poison loss: 0.1905109, poison acc: 0.917\n",
      "elapsed time: 587.790, time for reg: 123.257, time for eig: 177.588\n",
      "epoch:  9259, loss: 0.6920112, train acc: 0.733\n",
      "test loss: 1.8115117, test acc: 0.600\n",
      "poison loss: 0.3536687, poison acc: 0.850\n",
      "elapsed time: 588.426, time for reg: 123.391, time for eig: 177.778\n",
      "epoch:  9269, loss: 0.1519363, train acc: 0.900\n",
      "test loss: 2.2605450, test acc: 0.550\n",
      "poison loss: 0.1378769, poison acc: 0.983\n",
      "elapsed time: 589.017, time for reg: 123.528, time for eig: 177.921\n",
      "epoch:  9279, loss: 0.1173976, train acc: 0.967\n",
      "test loss: 2.1769925, test acc: 0.533\n",
      "poison loss: 0.1565343, poison acc: 0.900\n",
      "elapsed time: 589.582, time for reg: 123.664, time for eig: 178.043\n",
      "epoch:  9289, loss: 0.1460806, train acc: 0.917\n",
      "test loss: 2.1263760, test acc: 0.583\n",
      "poison loss: 0.1351605, poison acc: 0.950\n",
      "elapsed time: 590.191, time for reg: 123.795, time for eig: 178.214\n",
      "epoch:  9299, loss: 0.1153935, train acc: 0.950\n",
      "test loss: 2.2187158, test acc: 0.567\n",
      "poison loss: 0.1196123, poison acc: 0.950\n",
      "elapsed time: 590.800, time for reg: 123.926, time for eig: 178.386\n",
      "epoch:  9309, loss: 0.2559813, train acc: 0.900\n",
      "test loss: 2.1714619, test acc: 0.567\n",
      "poison loss: 0.2593228, poison acc: 0.883\n",
      "elapsed time: 591.393, time for reg: 124.057, time for eig: 178.540\n",
      "epoch:  9319, loss: 0.4438084, train acc: 0.800\n",
      "test loss: 2.4991940, test acc: 0.483\n",
      "poison loss: 0.3078781, poison acc: 0.883\n",
      "elapsed time: 591.953, time for reg: 124.188, time for eig: 178.661\n",
      "epoch:  9329, loss: 0.1992646, train acc: 0.917\n",
      "test loss: 2.3324546, test acc: 0.567\n",
      "poison loss: 0.3063515, poison acc: 0.900\n",
      "elapsed time: 592.653, time for reg: 124.319, time for eig: 178.925\n",
      "epoch:  9339, loss: 0.2014759, train acc: 0.900\n",
      "test loss: 2.1669911, test acc: 0.533\n",
      "poison loss: 0.2947555, poison acc: 0.883\n",
      "elapsed time: 593.263, time for reg: 124.450, time for eig: 179.095\n",
      "epoch:  9349, loss: 0.1217987, train acc: 0.950\n",
      "test loss: 2.3613278, test acc: 0.500\n",
      "poison loss: 0.1187868, poison acc: 0.967\n",
      "elapsed time: 593.832, time for reg: 124.581, time for eig: 179.228\n",
      "epoch:  9359, loss: 0.1078051, train acc: 0.950\n",
      "test loss: 2.4190433, test acc: 0.533\n",
      "poison loss: 0.1541657, poison acc: 0.950\n",
      "elapsed time: 594.460, time for reg: 124.711, time for eig: 179.419\n",
      "epoch:  9369, loss: 0.1356850, train acc: 0.933\n",
      "test loss: 2.0738864, test acc: 0.567\n",
      "poison loss: 0.1674858, poison acc: 0.933\n",
      "elapsed time: 595.049, time for reg: 124.843, time for eig: 179.571\n",
      "epoch:  9379, loss: 0.1936077, train acc: 0.917\n",
      "test loss: 2.0572399, test acc: 0.600\n",
      "poison loss: 0.2037758, poison acc: 0.867\n",
      "elapsed time: 595.685, time for reg: 124.974, time for eig: 179.770\n",
      "epoch:  9389, loss: 0.1569023, train acc: 0.917\n",
      "test loss: 2.1674435, test acc: 0.617\n",
      "poison loss: 0.1320618, poison acc: 0.950\n",
      "elapsed time: 596.262, time for reg: 125.105, time for eig: 179.908\n",
      "epoch:  9399, loss: 0.1906572, train acc: 0.883\n",
      "test loss: 2.1848820, test acc: 0.567\n",
      "poison loss: 0.1394737, poison acc: 0.950\n",
      "elapsed time: 596.844, time for reg: 125.239, time for eig: 180.052\n",
      "epoch:  9409, loss: 0.1342328, train acc: 0.950\n",
      "test loss: 2.0261518, test acc: 0.600\n",
      "poison loss: 0.2251582, poison acc: 0.850\n",
      "elapsed time: 597.480, time for reg: 125.370, time for eig: 180.248\n",
      "epoch:  9419, loss: 0.2268316, train acc: 0.900\n",
      "test loss: 2.1685647, test acc: 0.567\n",
      "poison loss: 0.1748541, poison acc: 0.900\n",
      "elapsed time: 598.112, time for reg: 125.501, time for eig: 180.443\n",
      "epoch:  9429, loss: 0.1972726, train acc: 0.883\n",
      "test loss: 2.0441785, test acc: 0.567\n",
      "poison loss: 0.2600412, poison acc: 0.867\n",
      "elapsed time: 598.687, time for reg: 125.633, time for eig: 180.579\n",
      "epoch:  9439, loss: 0.1492920, train acc: 0.917\n",
      "test loss: 2.3730844, test acc: 0.533\n",
      "poison loss: 0.1866313, poison acc: 0.917\n",
      "elapsed time: 599.521, time for reg: 125.764, time for eig: 180.976\n",
      "epoch:  9449, loss: 0.1494064, train acc: 0.917\n",
      "test loss: 2.1849024, test acc: 0.600\n",
      "poison loss: 0.1272078, poison acc: 0.933\n",
      "elapsed time: 600.137, time for reg: 125.895, time for eig: 181.159\n",
      "epoch:  9459, loss: 0.2149973, train acc: 0.917\n",
      "test loss: 2.2269780, test acc: 0.583\n",
      "poison loss: 0.2160835, poison acc: 0.883\n",
      "elapsed time: 600.775, time for reg: 126.026, time for eig: 181.358\n",
      "epoch:  9469, loss: 0.3736961, train acc: 0.833\n",
      "test loss: 2.0530879, test acc: 0.583\n",
      "poison loss: 0.2751432, poison acc: 0.867\n",
      "elapsed time: 601.394, time for reg: 126.157, time for eig: 181.538\n",
      "epoch:  9479, loss: 0.1180298, train acc: 0.950\n",
      "test loss: 2.2817723, test acc: 0.533\n",
      "poison loss: 0.1870306, poison acc: 0.917\n",
      "elapsed time: 602.012, time for reg: 126.288, time for eig: 181.717\n",
      "epoch:  9489, loss: 0.1491707, train acc: 0.917\n",
      "test loss: 2.2253217, test acc: 0.533\n",
      "poison loss: 0.1612221, poison acc: 0.950\n",
      "elapsed time: 602.592, time for reg: 126.420, time for eig: 181.859\n",
      "epoch:  9499, loss: 0.1238153, train acc: 0.950\n",
      "test loss: 2.2145175, test acc: 0.600\n",
      "poison loss: 0.1131548, poison acc: 0.967\n",
      "elapsed time: 603.225, time for reg: 126.551, time for eig: 182.053\n",
      "epoch:  9509, loss: 0.3748292, train acc: 0.850\n",
      "test loss: 2.1236315, test acc: 0.550\n",
      "poison loss: 0.4138333, poison acc: 0.867\n",
      "elapsed time: 603.867, time for reg: 126.682, time for eig: 182.254\n",
      "epoch:  9519, loss: 0.1660855, train acc: 0.933\n",
      "test loss: 2.3679242, test acc: 0.533\n",
      "poison loss: 0.2908329, poison acc: 0.900\n",
      "elapsed time: 604.541, time for reg: 126.822, time for eig: 182.469\n",
      "epoch:  9529, loss: 0.1705579, train acc: 0.900\n",
      "test loss: 2.1012834, test acc: 0.583\n",
      "poison loss: 0.1592427, poison acc: 0.950\n",
      "elapsed time: 605.133, time for reg: 126.953, time for eig: 182.622\n",
      "epoch:  9539, loss: 0.2271781, train acc: 0.917\n",
      "test loss: 2.2045826, test acc: 0.567\n",
      "poison loss: 0.2949657, poison acc: 0.867\n",
      "elapsed time: 605.738, time for reg: 127.084, time for eig: 182.791\n",
      "epoch:  9549, loss: 0.1239690, train acc: 0.933\n",
      "test loss: 2.1187986, test acc: 0.600\n",
      "poison loss: 0.1382359, poison acc: 0.933\n",
      "elapsed time: 606.353, time for reg: 127.214, time for eig: 182.970\n",
      "epoch:  9559, loss: 0.1802065, train acc: 0.933\n",
      "test loss: 2.4896400, test acc: 0.500\n",
      "poison loss: 0.2405153, poison acc: 0.917\n",
      "elapsed time: 606.953, time for reg: 127.345, time for eig: 183.135\n",
      "epoch:  9569, loss: 0.2949329, train acc: 0.883\n",
      "test loss: 2.3623612, test acc: 0.550\n",
      "poison loss: 0.2714283, poison acc: 0.883\n",
      "elapsed time: 607.623, time for reg: 127.476, time for eig: 183.368\n",
      "epoch:  9579, loss: 0.3100409, train acc: 0.833\n",
      "test loss: 2.0815423, test acc: 0.617\n",
      "poison loss: 0.1863465, poison acc: 0.900\n",
      "elapsed time: 608.534, time for reg: 127.607, time for eig: 183.845\n",
      "epoch:  9589, loss: 0.3267741, train acc: 0.833\n",
      "test loss: 1.9880534, test acc: 0.617\n",
      "poison loss: 0.2699285, poison acc: 0.900\n",
      "elapsed time: 609.098, time for reg: 127.738, time for eig: 183.973\n",
      "epoch:  9599, loss: 0.1815730, train acc: 0.917\n",
      "test loss: 2.5549109, test acc: 0.533\n",
      "poison loss: 0.2342349, poison acc: 0.917\n",
      "elapsed time: 609.678, time for reg: 127.868, time for eig: 184.118\n",
      "epoch:  9609, loss: 0.1099584, train acc: 0.950\n",
      "test loss: 2.3674065, test acc: 0.600\n",
      "poison loss: 0.1401584, poison acc: 0.967\n",
      "elapsed time: 610.285, time for reg: 127.999, time for eig: 184.290\n",
      "epoch:  9619, loss: 0.3036757, train acc: 0.883\n",
      "test loss: 2.1193932, test acc: 0.583\n",
      "poison loss: 0.5043524, poison acc: 0.833\n",
      "elapsed time: 610.871, time for reg: 128.129, time for eig: 184.443\n",
      "epoch:  9629, loss: 0.2391583, train acc: 0.900\n",
      "test loss: 2.3684356, test acc: 0.467\n",
      "poison loss: 0.3356712, poison acc: 0.833\n",
      "elapsed time: 611.494, time for reg: 128.260, time for eig: 184.627\n",
      "epoch:  9639, loss: 0.1376389, train acc: 0.950\n",
      "test loss: 1.9447547, test acc: 0.583\n",
      "poison loss: 0.1902082, poison acc: 0.900\n",
      "elapsed time: 612.069, time for reg: 128.390, time for eig: 184.770\n",
      "epoch:  9649, loss: 0.1138039, train acc: 0.950\n",
      "test loss: 2.1669486, test acc: 0.600\n",
      "poison loss: 0.1334108, poison acc: 0.917\n",
      "elapsed time: 612.734, time for reg: 128.521, time for eig: 184.997\n",
      "epoch:  9659, loss: 0.1043869, train acc: 0.967\n",
      "test loss: 2.1327374, test acc: 0.567\n",
      "poison loss: 0.1283859, poison acc: 0.933\n",
      "elapsed time: 613.289, time for reg: 128.652, time for eig: 185.119\n",
      "epoch:  9669, loss: 0.1070421, train acc: 0.967\n",
      "test loss: 2.2953148, test acc: 0.583\n",
      "poison loss: 0.1142650, poison acc: 0.967\n",
      "elapsed time: 613.865, time for reg: 128.783, time for eig: 185.261\n",
      "epoch:  9679, loss: 0.1547341, train acc: 0.917\n",
      "test loss: 2.2407496, test acc: 0.600\n",
      "poison loss: 0.1185104, poison acc: 0.950\n",
      "elapsed time: 614.564, time for reg: 128.920, time for eig: 185.504\n",
      "epoch:  9689, loss: 0.1986398, train acc: 0.917\n",
      "test loss: 2.2526692, test acc: 0.517\n",
      "poison loss: 0.2083990, poison acc: 0.950\n",
      "elapsed time: 615.197, time for reg: 129.055, time for eig: 185.688\n",
      "epoch:  9699, loss: 0.2791769, train acc: 0.867\n",
      "test loss: 2.1652812, test acc: 0.517\n",
      "poison loss: 0.4200001, poison acc: 0.800\n",
      "elapsed time: 615.788, time for reg: 129.190, time for eig: 185.833\n",
      "epoch:  9709, loss: 0.1585930, train acc: 0.917\n",
      "test loss: 2.1656209, test acc: 0.600\n",
      "poison loss: 0.1220982, poison acc: 0.983\n",
      "elapsed time: 616.371, time for reg: 129.326, time for eig: 185.969\n",
      "epoch:  9719, loss: 0.1947214, train acc: 0.967\n",
      "test loss: 2.1594191, test acc: 0.517\n",
      "poison loss: 0.8059032, poison acc: 0.750\n",
      "elapsed time: 617.285, time for reg: 129.461, time for eig: 186.432\n",
      "epoch:  9729, loss: 0.1519042, train acc: 0.917\n",
      "test loss: 2.0725343, test acc: 0.567\n",
      "poison loss: 0.1535374, poison acc: 0.933\n",
      "elapsed time: 617.876, time for reg: 129.597, time for eig: 186.574\n",
      "epoch:  9739, loss: 0.1178172, train acc: 0.950\n",
      "test loss: 2.2153178, test acc: 0.550\n",
      "poison loss: 0.1058823, poison acc: 0.967\n",
      "elapsed time: 618.511, time for reg: 129.732, time for eig: 186.760\n",
      "epoch:  9749, loss: 0.2790556, train acc: 0.867\n",
      "test loss: 2.2443421, test acc: 0.550\n",
      "poison loss: 0.1766506, poison acc: 0.933\n",
      "elapsed time: 619.080, time for reg: 129.869, time for eig: 186.879\n",
      "epoch:  9759, loss: 0.1523560, train acc: 0.933\n",
      "test loss: 2.1776577, test acc: 0.567\n",
      "poison loss: 0.1279972, poison acc: 0.950\n",
      "elapsed time: 619.760, time for reg: 130.004, time for eig: 187.113\n",
      "epoch:  9769, loss: 0.2198505, train acc: 0.900\n",
      "test loss: 2.3089985, test acc: 0.517\n",
      "poison loss: 0.6269176, poison acc: 0.733\n",
      "elapsed time: 620.482, time for reg: 130.139, time for eig: 187.387\n",
      "epoch:  9779, loss: 0.1309242, train acc: 0.933\n",
      "test loss: 2.1488259, test acc: 0.600\n",
      "poison loss: 0.1517906, poison acc: 0.933\n",
      "elapsed time: 621.060, time for reg: 130.274, time for eig: 187.515\n",
      "epoch:  9789, loss: 0.1300198, train acc: 0.917\n",
      "test loss: 2.3447852, test acc: 0.500\n",
      "poison loss: 0.1706597, poison acc: 0.917\n",
      "elapsed time: 621.711, time for reg: 130.409, time for eig: 187.721\n",
      "epoch:  9799, loss: 0.1409034, train acc: 0.933\n",
      "test loss: 2.3985622, test acc: 0.517\n",
      "poison loss: 0.2733172, poison acc: 0.867\n",
      "elapsed time: 622.320, time for reg: 130.545, time for eig: 187.880\n",
      "epoch:  9809, loss: 0.0991712, train acc: 0.950\n",
      "test loss: 2.1725717, test acc: 0.583\n",
      "poison loss: 0.1141644, poison acc: 0.950\n",
      "elapsed time: 622.953, time for reg: 130.680, time for eig: 188.062\n",
      "epoch:  9819, loss: 0.0918238, train acc: 1.000\n",
      "test loss: 2.0391150, test acc: 0.600\n",
      "poison loss: 0.1313030, poison acc: 0.950\n",
      "elapsed time: 623.545, time for reg: 130.815, time for eig: 188.204\n",
      "epoch:  9829, loss: 0.2095636, train acc: 0.883\n",
      "test loss: 1.9760399, test acc: 0.650\n",
      "poison loss: 0.1509818, poison acc: 0.967\n",
      "elapsed time: 624.159, time for reg: 130.950, time for eig: 188.368\n",
      "epoch:  9839, loss: 0.1175487, train acc: 0.933\n",
      "test loss: 2.0480428, test acc: 0.600\n",
      "poison loss: 0.2116336, poison acc: 0.867\n",
      "elapsed time: 624.734, time for reg: 131.085, time for eig: 188.500\n",
      "epoch:  9849, loss: 0.1371911, train acc: 0.950\n",
      "test loss: 2.2111925, test acc: 0.617\n",
      "poison loss: 0.1562305, poison acc: 0.950\n",
      "elapsed time: 625.365, time for reg: 131.221, time for eig: 188.679\n",
      "epoch:  9859, loss: 0.0980885, train acc: 0.967\n",
      "test loss: 2.2524204, test acc: 0.583\n",
      "poison loss: 0.0895752, poison acc: 0.967\n",
      "elapsed time: 626.302, time for reg: 131.356, time for eig: 189.178\n",
      "epoch:  9869, loss: 0.2595413, train acc: 0.883\n",
      "test loss: 2.1028092, test acc: 0.600\n",
      "poison loss: 0.1418180, poison acc: 0.950\n",
      "elapsed time: 626.949, time for reg: 131.491, time for eig: 189.379\n",
      "epoch:  9879, loss: 0.1365033, train acc: 0.950\n",
      "test loss: 1.9950571, test acc: 0.617\n",
      "poison loss: 0.2101748, poison acc: 0.900\n",
      "elapsed time: 627.594, time for reg: 131.626, time for eig: 189.576\n",
      "epoch:  9889, loss: 0.1005579, train acc: 0.967\n",
      "test loss: 2.0961710, test acc: 0.583\n",
      "poison loss: 0.1142923, poison acc: 0.967\n",
      "elapsed time: 628.216, time for reg: 131.763, time for eig: 189.745\n",
      "epoch:  9899, loss: 0.1170267, train acc: 0.933\n",
      "test loss: 2.0582903, test acc: 0.650\n",
      "poison loss: 0.1618939, poison acc: 0.917\n",
      "elapsed time: 628.832, time for reg: 131.898, time for eig: 189.922\n",
      "epoch:  9909, loss: 0.0920778, train acc: 0.967\n",
      "test loss: 2.2308703, test acc: 0.567\n",
      "poison loss: 0.1376180, poison acc: 0.967\n",
      "elapsed time: 629.416, time for reg: 132.034, time for eig: 190.068\n",
      "epoch:  9919, loss: 0.1185437, train acc: 0.933\n",
      "test loss: 2.1595924, test acc: 0.617\n",
      "poison loss: 0.1043874, poison acc: 0.983\n",
      "elapsed time: 630.087, time for reg: 132.169, time for eig: 190.292\n",
      "epoch:  9929, loss: 0.3897705, train acc: 0.783\n",
      "test loss: 2.2286514, test acc: 0.533\n",
      "poison loss: 0.3591498, poison acc: 0.800\n",
      "elapsed time: 630.644, time for reg: 132.305, time for eig: 190.400\n",
      "epoch:  9939, loss: 0.1040780, train acc: 0.933\n",
      "test loss: 2.4400328, test acc: 0.550\n",
      "poison loss: 0.1415018, poison acc: 0.950\n",
      "elapsed time: 631.287, time for reg: 132.441, time for eig: 190.598\n",
      "epoch:  9949, loss: 0.1534337, train acc: 0.933\n",
      "test loss: 2.1410621, test acc: 0.600\n",
      "poison loss: 0.1403673, poison acc: 0.950\n",
      "elapsed time: 631.892, time for reg: 132.576, time for eig: 190.753\n",
      "epoch:  9959, loss: 0.1015647, train acc: 0.950\n",
      "test loss: 2.3779249, test acc: 0.567\n",
      "poison loss: 0.0971042, poison acc: 1.000\n",
      "elapsed time: 632.483, time for reg: 132.713, time for eig: 190.893\n",
      "epoch:  9969, loss: 0.1260418, train acc: 0.967\n",
      "test loss: 2.2935518, test acc: 0.600\n",
      "poison loss: 0.1348814, poison acc: 0.950\n",
      "elapsed time: 633.106, time for reg: 132.848, time for eig: 191.064\n",
      "epoch:  9979, loss: 0.1216854, train acc: 0.933\n",
      "test loss: 2.3025492, test acc: 0.567\n",
      "poison loss: 0.0954400, poison acc: 1.000\n",
      "elapsed time: 633.761, time for reg: 132.984, time for eig: 191.277\n",
      "epoch:  9989, loss: 0.2296172, train acc: 0.917\n",
      "test loss: 2.4367768, test acc: 0.567\n",
      "poison loss: 0.1224705, poison acc: 0.950\n",
      "elapsed time: 634.458, time for reg: 133.119, time for eig: 191.525\n",
      "epoch:  9999, loss: 0.2847596, train acc: 0.900\n",
      "test loss: 2.2638040, test acc: 0.617\n",
      "poison loss: 0.1411495, poison acc: 0.950\n"
     ]
    }
   ],
   "source": [
    "start = time.time()\n",
    "iter_num = 0\n",
    "timer_eig_calc = 0\n",
    "timer_reg_calc = 0\n",
    "isnan = False\n",
    "for i in range(epoch):\n",
    "    num_correct = 0\n",
    "    cur_loss = 0\n",
    "    cur_total_loss = 0\n",
    "    for ii, ((data_ii, label_ii), (poisondata_ii, poisonlabel_ii)) in enumerate(zip(trainloader, trainloader_poison), 0):\n",
    "        data_ii, label_ii = data_ii.cuda(), label_ii.cuda()\n",
    "        poisondata_ii, poisonlabel_ii = poisondata_ii.cuda(), poisonlabel_ii.cuda()\n",
    "        optimizer.zero_grad()\n",
    "        output = model(data_ii)\n",
    "        output2 = model(poisondata_ii)\n",
    "        loss1 = criterion(output, label_ii)\n",
    "        loss2 = criterion(output2, poisonlabel_ii)\n",
    "\n",
    "        # update eigenvalues and eigenvectors\n",
    "        if iter_num == 0 or (iter_num + 1) % eig_period == 0:\n",
    "            temp_start = time.time()\n",
    "\n",
    "            top_eigval, top_eigvec = get_fast_eig(model, data_ii, label_ii, top_n, tol=eig_tol)\n",
    "            L_traj.append(top_eigval)\n",
    "\n",
    "            timer_eig_calc += time.time() - temp_start\n",
    "        \n",
    "        # to report reg loss along SGD trajectory\n",
    "        temp_start = time.time()\n",
    "        totalloss, _, _, perturb_norm = IGSfd_regularizer(criterion_alldata, model, data_ii, label_ii, \n",
    "                                                         top_eigval, top_eigvec, \n",
    "                                                         rho, mu, eta, multiply_norm = True,\n",
    "                                                             circularnoise = circularnoise)\n",
    "        perturb_norm_traj.append(perturb_norm)\n",
    "        timer_reg_calc += time.time() - temp_start\n",
    "        \n",
    "        \n",
    "\n",
    "        loss = (1-poison_factor) * loss1 + poison_factor * loss2\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        iter_num += 1\n",
    "        maxparamval_traj.append(check_max_paramval(model))\n",
    "        maxparamgrad_traj.append(check_max_paramgrad(model))\n",
    "\n",
    "\n",
    "        if check_grad_nan(model):\n",
    "            isnan = True\n",
    "            print(\"nan occured at\", iter_num)\n",
    "            print(L)\n",
    "            break\n",
    "\n",
    "        if epoch <= num_report or i == 0 or (i+1) % (epoch//num_report) == 0:\n",
    "            N_ii = data_ii.shape[0]\n",
    "            cur_loss += loss1.item() * N_ii\n",
    "            cur_total_loss += totalloss.item() * N_ii\n",
    "            \n",
    "            # calculate accuracy\n",
    "            pred = torch.argmax(output, axis=1)\n",
    "            num_correct += torch.sum(pred == label_ii).item()\n",
    "\n",
    "    if isnan:\n",
    "        break\n",
    "    if epoch <= num_report or i == 0 or (i+1) % (epoch//num_report) == 0:\n",
    "        \n",
    "        avg_loss = cur_loss / N\n",
    "        avg_total_loss = cur_total_loss / N\n",
    "        cur_acc = num_correct / N\n",
    "        acc_traj.append(cur_acc)\n",
    "\n",
    "        loss_traj.append(avg_loss)\n",
    "        total_loss_traj.append(avg_total_loss)\n",
    "        L2norm_traj.append(calculate_parameter_L2norm(model))\n",
    "        logL2norm_sum_traj.append(calculate_parameter_logL2norm_sum(model))\n",
    "\n",
    "        # calculate test acc.\n",
    "        testoutput = model(testdata_cuda)        \n",
    "        \n",
    "        test_total_loss, test_loss, test_acc = test_reg_loss(model, testloader, criterion_alldata, \n",
    "                                                top_eigval, top_eigvec, rho, mu, eta, \n",
    "                                                multiply_norm = True, circularnoise = circularnoise)\n",
    "        test_total_loss_traj.append(test_total_loss)\n",
    "        test_loss_traj.append(test_loss)\n",
    "        test_acc_traj.append(test_acc)\n",
    "\n",
    "        # calculate poison acc.\n",
    "        poison_total_loss, poison_loss, poison_acc = test_reg_loss(model, poisonloader, criterion_alldata, \n",
    "                                                top_eigval, top_eigvec, rho, mu, eta, \n",
    "                                                multiply_norm = True, circularnoise = circularnoise)\n",
    "        poison_total_loss_traj.append(poison_total_loss)\n",
    "        poisonloss_traj.append(poison_loss)\n",
    "        poisonacc_traj.append(poison_acc)\n",
    "        \n",
    "\n",
    "        print(\"elapsed time: {:.3f}, time for reg: {:.3f}, time for eig: {:.3f}\".format(time.time() - start, timer_reg_calc, timer_eig_calc))\n",
    "        print(\"epoch: {:5d}, loss: {:.7f}, train acc: {:.3f}\".format(i, avg_loss, cur_acc))\n",
    "        print(\"test loss: {:.7f}, test acc: {:.3f}\".format(test_loss, test_acc))\n",
    "        print(\"poison loss: {:.7f}, poison acc: {:.3f}\".format(poison_loss, poison_acc))\n",
    "        #print(\"reg loss: {:.7f}, test reg loss: {:.7f}\".format(regloss, testregloss))        "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Draw Decision Boundary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "def draw_decision_boundary_multiclass(network, X, y, other_networks = None, const=0.3, show=True, useGPU=True,\n",
    "                                     savefilename=None, testX=None, testy=None, drawboundary=True):\n",
    "    x0 = np.linspace((1 + const)*X[:,0].min()-const*X[:,0].max(), (1 + const)*X[:,0].max()-const*X[:,0].min(), 1000)\n",
    "    x1 = np.linspace((1 + const)*X[:,1].min()-const*X[:,0].max(), (1 + const)*X[:,1].max()-const*X[:,1].min(), 500)\n",
    "    xx0, xx1 = np.meshgrid(x0, x1)\n",
    "    xx = torch.FloatTensor(np.hstack((xx0.reshape(-1,1), xx1.reshape(-1,1))))\n",
    "    if useGPU:\n",
    "        xx = xx.cuda()\n",
    "    val = (network(xx)).cpu().detach().numpy()\n",
    "    #val = F.softmax(network(xx), dim=1).cpu().detach().numpy()\n",
    "    n_class = val.shape[1]\n",
    "    level_val = 0.01\n",
    "    level_val2 = 0.1\n",
    "    levels = [0.0, level_val, level_val2, 100]\n",
    "    levels2 = [-level_val2, -level_val, level_val, level_val2]\n",
    "    colors = ['b', 'r', 'g']\n",
    "    cmaps = ['Blues', 'Oranges', 'Greens', 'Reds', 'Purples', \n",
    "                      'YlOrBr', 'YlOrRd', 'OrRd', 'PuRd', 'RdPu', 'BuPu',\n",
    "                      'GnBu', 'PuBu', 'YlGnBu', 'PuBuGn', 'BuGn', 'YlGn']\n",
    "    \n",
    "    # plot decsion region\n",
    "    for i in range(n_class):\n",
    "        temp_idx = [j for j in range(n_class)]\n",
    "        temp_idx.pop(i)\n",
    "        compete_val = np.max(val[:,temp_idx], axis=1)\n",
    "        Z = (val[:,i] - compete_val).reshape(len(x1), len(x0))\n",
    "        plt.contourf(xx0, xx1, Z, levels = levels, cmap = cmaps[i], alpha=0.5)\n",
    "    \n",
    "    # plot decsion boundary\n",
    "    if drawboundary:\n",
    "        for i in range(n_class):\n",
    "            temp_idx = [j for j in range(n_class)]\n",
    "            temp_idx.pop(i)\n",
    "            compete_val = np.max(val[:,temp_idx], axis=1)\n",
    "            Z = (val[:,i] - compete_val).reshape(len(x1), len(x0))\n",
    "            plt.contourf(xx0, xx1, Z, levels = levels2, cmap = 'Greys')\n",
    "    \n",
    "    # plot training data\n",
    "    for i in range(n_class):\n",
    "        plt.scatter(X[y==i,0], X[y==i,1], c=colors[i], edgecolors='k', linewidth=0.75)\n",
    "    \n",
    "    # plot test data\n",
    "    if testX is not None and testy is not None:\n",
    "        for i in range(n_class):\n",
    "            plt.scatter(testX[testy==i,0], testX[testy==i,1], c=colors[i], \n",
    "                        marker='^', edgecolors='k', linewidth=0.75)\n",
    "    \n",
    "    # plot decision boundary from other networks\n",
    "    if other_networks is not None:\n",
    "        for k, model in enumerate(other_networks):\n",
    "            val2 = model(xx).cpu().detach().numpy()\n",
    "            for i in range(n_class):\n",
    "                temp_idx = [j for j in range(n_class)]\n",
    "                temp_idx.pop(i)\n",
    "                compete_val = np.max(val2[:,temp_idx], axis=1)\n",
    "                Z2 = (val2[:,i] - compete_val).reshape(len(x1), len(x0))\n",
    "                plt.contourf(xx0, xx1, Z2, levels = levels, cmap = cmaps[k%len(cmaps)])\n",
    "    plt.xticks(ticks = [-1, 0, 1], fontsize=20)\n",
    "    plt.yticks(ticks = [-1, 0, 1], fontsize=20)\n",
    "    #plt.axis('equal')\n",
    "    if savefilename is not None:\n",
    "        plt.savefig(savefilename+'.pdf', format=\"pdf\",transparent=True)\n",
    "    if show:\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_decision_boundary_multiclass(model, data_cuda.cpu().numpy(), label_cuda.cpu().numpy(),\n",
    "                                     savefilename = None, drawboundary=True)\n",
    "                                     #testX=testdata_cuda.cpu().numpy(), testy=testlabel_cuda.cpu().numpy())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plot generalization gap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "def smoother(traj, window=10):\n",
    "    smoothed = []\n",
    "    for i in range(len(traj)-window):\n",
    "        smoothed.append(np.array(traj[i:i+window]).mean())\n",
    "    return np.array(smoothed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.YTick at 0x7f7bb0246ef0>,\n",
       "  <matplotlib.axis.YTick at 0x7f7bb0246e80>,\n",
       "  <matplotlib.axis.YTick at 0x7f7bb02433c8>],\n",
       " [Text(0, 0, ''), Text(0, 0, ''), Text(0, 0, '')])"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAakAAAEdCAYAAAC2d5g4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAAsTAAALEwEAmpwYAABhgUlEQVR4nO2dd3hUxRbAfyc9JCR0Qkea9A7SpFdFUUFFlGLvvXfU57M+FHsFnoiKok9sFKVIExCwgPTeS6gBQuq8P2azySa7STbJZjfk/L7vfvfeafdMsnvPzsyZc8QYg6IoiqIEIkH+FkBRFEVRPKFKSlEURQlYVEkpiqIoAYsqKUVRFCVgUSWlKIqiBCwh/hagpFCpUiVTt27dAtVNTk4mLCysaAUqIZTWvmu/Sxfab8+sXLky3hhTuaDPUCWVT+rWrcuKFSsKVHf9+vU0bty4iCUqGZTWvmu/Sxfab8+IyI7CPEOn+xRFUZSARZWUoiiKErCoklIURVECFlVSiqIoSsCiSkpRFEUJWFRJKYqiKAGLKilFURQlYFElpSiKogQsqqQURVGUgEWVlKIoihKwqJJSFEVRAhZVUoqiKErAErBKSkSGicibIrJQRE6IiBGRTwvYVk0RmSAie0UkSUS2i8jrIlK+qOVWFEVRio5A9oL+BNAKOAnsBgrkYlhE6gNLgCrAdGA90BG4GxgoIl2NMYeLRGJFURSlSAnYkRRwL9AIiAFuLUQ772AV1F3GmEuMMY8YY3oDrwHnAs8XWlJFURTFJwSskjLGzDPGbDLGmIK24RhF9Qe2A29ny34aOAWMFJGoAguqKIqi+IxAnu4rCno5zrONMelZM4wxCSKyGKvEOgFzfCZFeirxuzeRkpaed9liILxMDBUqV/O3GIqiKHlytiupcx3njR7yN2GVVCN8pKRM0knKT7uMSukHfNF8gTkcXJkKAx5GOt7ob1EURVE8crYrqVjH+biH/Iz0cu4yReQm4CaAGjVqsH79eq8FOLxxCV0DTEEBVEw7BD89wJkl77G7x+ukRlb2yXPi4+ML9Hcr6Wi/Sxfab99xtiupQmGM+QD4AKB9+/amcWPvDQz/2rrQeT0r7mbKV61ZZPIVhIMHDyK7l3Fh8HIAIo5tpsH0wfDUUQgq+iXK9evXU5C/W0lH+1260H77jrNdSWWMlGI95GekH/OVACnH9zmv21x6L1Wq+n8taMHGQ1w36T0mhL2amfjfi+CaaRAa6T/BFEVRshGw1n1FxAbHuZGH/IaOs6c1q0JjEuxUX7IJpnzFKr56jFd0b1QZ03AA3ZJez0zcsQje6ghHt/tLLEVRlByc7UpqnuPcX0Rc+ioiZYGuwGlgqa8ECE2MB+CwlCM0JNhXj/GaZ4c051hYdZ5IuZY0xCYe3wkf9vGvYIqiKFk4K5SUiISKSGPHvignxpgtwGygLnB7tmrPAFHAZGPMKV/JFplsldQRqeCrRxSIWhXK8OLQFnya1o+GZyazPdxhCHk6Hg5thMNbYM9KKPg2NUVRlEITsGtSInIJcInjNs5x7iwikxzX8caYBxzXNYB1wA6sQsrKbVi3SG+ISB9HufOwe6g2Ao8XvfSZRCVbj0snggNLSQEMblmdGav38+PqfXx/qgl3hjhmR9/ukFmoZke4cjKUjXPfiKIoig8J5JFUa2C04xjgSKuXJW1YfhpxjKbaA5Owyul+oD4wHujka799KSaIZBPMydDAU1IAzwxpRoWoMN5Ivcx9gd3L4T/nwthYOLiueIVTFKXUE7BKyhgz1hgjuRx1s5Tdnj0tW1u7jDHXGmOqGWPCjDF1jDH3GGOO+roft5cdT6OkT/iq8p2+flSBqBQdzivDWpJCCK97UlQZvNOpeIRSFEVxELBK6mwhISkFECLLlPG3KB7p3bgKVWPCeT11GNclPwAj/wdPHoabF+QsfGxX8QuoKEqpRZWUj3lnRDv+1a8aN3Sr529RPCIi1K8cDcDc9LasiWgHwSFQrRVcmS2E18aZfpBQURR/YIzho9Ufsf34dr/JoErKx7SoGUv7GmVoUdPTfuLAoOM5mWtmg99cxHn//oUdh09xpsEF1D8zmd2mEgCHl0z2l4iKohQTCWdSWL//BFPWTWH8qvGMnjmajUd9tp00VwLWuk8pXu7u05DXf9nkvD9wIoker8x33AWzOK05V4bMp+Kxv1ixaCbtuw30i5yKoviGI6eS+WXdARrHleWhaX+z/sARohu+jgTD4ZOphBDhF7l0JKUAdsrv61u7eMz/Nr2r8/rAL29xKim1OMRSFKWYGPbuEh6a9jcXv7WYTSdWUbbxk0hwEgBnDvanenQNv8ilSkpx0q5OeX5/vC8396hHxagwl7zwhj1ZH2MVVRfzB39v2+sPERVF8QGTf9vO1vhMnwaRNT53ye9bvxXBQVLcYgE63adko3LZcB4d1IRHBzUBYMfhU+w9doZO9SpwZMmV8PNiystJUtfPhsY3+FlaRSkZJKWmYQxEhHp2jbbpQALf/rmHOhWiOHI6mRdnrKdlzVg+v7ETUeGur+qk1DRS00yO9Kz8uutXVsevplmFNnSpcR77jiVRrVwE4SHBGGP47q+9iAi/bjjE16t2O+tJ8Ekk5LTzPlhCGHdpf0KD/TOmUSWl5EqdilHUqRgFQGybS+DnuwA4/8/7YdCVEF7Wj9IpSvHzz97jjJn4O32bVOWFy1rkWX57/Cl6vjofgPPOqcCjFzShabUY3pm/mboVo2hWPYZL31nCSTdT6H/vPk6zp2e5pDWpFsO6fScICwlizn09qFk+khNnUomJCEFEOJOSysvLx/HVZlcjJ5MeRsip8xjb80aOnU7l3ws/IbTcSpLjewFdkOBTRDd6LocM/+r2HGVC/beFRpWUkm9CymSzUFw7Hdpc4x9hFMUPrD+8hStnXkFauTp8/vtohrWrQbs67r3JrNlznHum/snmgyedacu2HeGStxcXSoZ1+04AkJyazvkvz3Om925chVeGtWTgpGc4U/b7HPUkKJm0sgt5cqWNcRduDXaJiPuOiLjvwOSczvty8Jc0qdikUPIWFl2TUrxiVa3RmTfTb4dTPvUqpSguxJ9M4r9LtnPgxJlCt3X8dAqnk/M2AJr+5x7qPvIjdR/5nst/uAQJTiYkehOh5ZYy9N3f6PHKPP7Ye5rFm+NJTUvnt217mL9hD9dOWsbOtB8IqzgXSM+XTBe1qp55I0n2yCdz1x+k3b9+dqug8oW4OpMe23ms3xUU6EhK8ZJyFz7DX+8spFXQVgAO/vgsVa4Y72epzk6OnErmm1W76dOkKudUivKLDCu2H2HdvhMM71jbb2sSGazZc5zBby4C4L1ftzDj7vMpVyYsj1o5SUs3jJm4nIWb4qlZPpJ3rm5Lo6pl3a4XLd16mLu/+BOAyJqfuOSFlV9KytFu7Dh8mkdnnwb2IWGHiKr7FiYtktToBoSXW+Esf2Htkfz49z6S09wrrFt61OeRQY15ZVhLdhzfxejZwwk2UbQPG8tFzRpyMHUtf20NZf+RcH7deMhtGxJ80uU+YcNYgiP20LVedVrXrMTEHXm7Zxt+7nAe7+RTv9teoUpK8Yp6ceV5vdMEWi3vCUCVtZNI2ngp4Y165ruN9HTDos3xNK0eQ6XocN8Iehbw6Dd/M+ufA8xcs583rmpDuTKhlAnz7is7Y/U+jpxO5rI2NYkM8y6eWWJyGsPe+w2AaSt3M/2ObgCs2nmUilFh1KkYxa4jp0lJS2fvsTN0bVDRq/a9IS3dcN2k3533+46fYfgHS5l6U2diy4R61daDX/3Fwk02hM7uo4lc/Jadfht3RSsua1uTeRsOsnF/Ai1qxjLiw2WExK4ksvpXOdoJCo8HSQGT+fzwyrOR4CQkOImwsEwFFV5lNr+cmc0FffswtMFwFvwdw64jiTwwoBFz1h0kJS2da7ueA1jjiq82f8qplFPAKbZHvcq9v9sfhWVDyzL5sslEB7Xkpk9WkJSazq096zsVaVD4Qeczr6z1DF07daNFjVjn96zuqp/4YNmvlCubxIDm5SDkBFM3TGXPyT22vgQxuP5gr/6evkaMxgvKF+3btzcrVqzIu6Ab1q9fT+PGjYtYIv8y96u36f3PY5kJd66CivVzlMva9x2HT3H9f1c45+jrV47iy5s7s2bvCf7ceYxGVaPp3aQK4QEUHLKgFPZ/fjwxhVbPzHZJa1glmu/u6EZkWDCnk1M5mZRKmbAQXvt5I9ViI7jhfFfXWzsOn3JuyK5fOYqdR06TkmZoX6c8r13ZmnJlQjmemELN8u4XxVftPMpl7yxx3r9zdVv2HkvkXz+694Zft2IZHu9ekfPbNiMsOIigIjRZ/nPXMY9rOV/f2oV2dcrnq53Jv23nyen/5KushBwnsuZkgiN3eyxzSa1bmbpiOykJzSE9wq3hgVuZL/6aRuVdA4afTjnNieQT/LzjZ17+/WWPdTvEdWDCgAkuaRMXb+OZ79cSEfcNoeWXA/DLsF+oGlU1X/IApKankpiaSNmw/BtD5edzLiIrjTHt891o9vqqpPKHKilX0k4dIfiVczIT6p7PkvMnMWXpTu7s04DGcTEA/PbHGr7amErlmHDe/3Vrnu1WKRvO7Hu7u0zjnExKZcnmeLo3qpyrCW8gkdv/PDk1nZ1HTlG3YhQhwUGkpRuCxG6oTk1L594v/+L7v9zvQ3vvmrb0PLcKvV6dT/zJJFLSMr+/Dw44l5u71yMkOIjUtHS+XrWbh79enaeslaLD+GBUe9rWLk9qWjoiwrz1B/lr9zHenLu5QP0vVyaUL2/uTKOqRWP9+fa8zbwya4PbvErRYUy/oxvls4w0jTGIuCrJrEobAEmmY9N4ft8UikmuRFDEHiJrTSQo5BTJRzsQVv533PFq99d4YMG9Lmk1I2pRO2QoS06+nq/+hAaFMvfyuSSlJREVGsXfh/7m5l9uzlfdEAnh6S5Pk5yWzOWNLnf2c8/JPQz82nqCaVmpJVMunJKv9gqDKqkAQpVUTt75fiG3rcycGrjG/ItFSfbX/PLH+xATEUrjJwvmkLZTvQpULhvBqh1H2XMs0Zl+3jkV6N24CqM61/V6+qo4ye1/PnrCcrdrCj0aVeav3cc4djqlwM+tUjacVrXK8fPaA17ViwwN5sWhLXj6u38K9fzs3Nu3EXf3beg2b1v8KYa9u4TDp5KpVzmKRwY2pm6lKA6fTKZz/cypwxNnUmg5NnNUuerJfuw/foYL3ljott2osGDqVorii5s6UTYilA37E7jhk9/ZdSTzcxRcZgtl6nyY737c0foO2lZtS4c4GxD08u8vZ/2R9R7L3976dt7+822uPPdKetTswW1zbsv3szwxuulo/rv2vy5pr/d6nT61+wAwcc1Exq0cB8AjHR/h6iZXF/qZeaFKKoBQJZWTmWv28cqU75kT/iAAX6d14/6U3L+MEaFBPDW4GXUrleH6SStITEkr0LMvb1eTVy5vxaGEJCb/tp3+zeJoHFcWA35f4AfP//Ok1DTOfSL/irtf06rMWXeA9CL6ml7btS4TF29HBPL71T/vnAr8s/eEcx/P+yPbMW72RjYcSOCCFnG0q1OB37cdYe/xRP7efTxH/YnXdqDXuVVc0lLT0mnw+AyPz7zx/HO4oEU1ykaEcP1/V7DjsN1cOqh5HO9e085ZbszE5czf4N6IAKB2hTLsPHLaJU1C44lu8GreHXewaPgiYsNdt18s3beUG2ff6LZ8vdh6TL9keo70tPQ0Tqac5NpZ17Lp6CY3NS2D6w3mynOvpF65ejy+8HGOJB3hpfNfolpUNXp92YujSZlh8FpXbs3kCyZjjOGS6Zew9bidrfh71N85RpK+QJVUAKFKKif7jifS69X5vMnL9AteBUDHM29zkJzrA3UqlqF6bCQvDm3h3By8//gZ0o2herlIADYeSOCiNxeRlJo/c92PRrXn2R/W5ngJgX25fzCyXbF8Ud3h6X/+z97jXPjGony1MaZLXcZe3Iyk1DRenLGeiYu3F0iW8JAgrulUh6Fta9K0egypaekkpqSRng4LNh3i5VnrXUYZWakUHc73d3YlLiaC1HRDsAhBQUJKWjpbDp2kUZWyLmtPf65ey4Q1SXyXZbqyW4NKfHrDec57YwxXfbiUpVuPeN2X7OtP+4+fodMLc7xqo1/3X1l6yLOC7FWrN/N2zaVCRAW+v/R7YsJi3Jb7ceuPzNo+i3m75rmkTxgwwTnicseuhF1c+M2FGHK+e/8a9RdB4vlH1pK9S7j558xpwciQSJaNWMZXG7/iuaV2PeyetvdwfYvrPbZRlBSHkvL/T06lxFItNpIvb+7MhLRBzrQXQ3NOoYzuXIdfH+zF5zd1cioogLjYCKeCAmhUtSxrnx3Ic0OaUcORfnm7mmx/8UKeGtw0R7s3fLLCrYIC+HntAacFVyDx25bMfWVjutSldoWcRgv1KkXxztVteWjguQCEhwTz9EXNuLtPQxpUiaZsRAjhIUFMueE8qsVGUCEqzGm9leFf7ZxKUVSNCSdI4JvbuvDk4KY0rW5ftiHBQZSNCCW2TCgXtarOyE513Mp6b99GzLrnfKrFRiIihGYxhggNDqJxXEwO44iI0CDGD2/NK8NaOtMWbY5nSBajhxU7jrooqKs61qZCVN6m5J9ef14OA4m42AgqRefPDL1MWDDf3dPSRUG1q5o5Kps0cBJ/j/qbN3qPZ/Xo1fx65a8eFRTAhfUu5I3eb/Bqj8xRWcvKLWlfNff3ca2ytXi+2/MMrjeYG1vcSGSI/aw/1fmpXBUUQJfqXZh3RaZSTExNZOvxrXy0+iMAqkRW4fJzL8+1jZKGjqTyiY6kPLP/4EHKv9OUcOxaxiETw7upQ9gYVI8R3ZoxqH//IhvRpKalc/PklcxZfzDvwsBnN5xHlwaViuTZ+SE1LZ3UdMP2LZty/M9PnEmh6wtzSUhKpVpsBEse6Y2IkJyazkeLtvLyTGsY8PWtnT16MXBHViOB1LR05m84RKta5QgLCeJ0cirVYiNzrX/0VDLDP1jKwYQz3NO3ESM71UEchhzekvWzvvlgAn3HZUZ3XvvsAG747wqWbHHdAL7woV7UqlAGYwyHTyUzYdE23pm/xaXMNZ1q89yQ5m5l+nv3MT5etI2LW1UnKEjo1qASP63ex9er9rAgy9rf93d0Y3PiXJ5a8lRm3VF/M2v7LE6mnGRow6EF/pyuX7+ecrXKERse61Q6+eVE8gkOnT5Evdh6+X7+sn3LuGF2Tt+ZT3Z6kivOvcKr5xeG4hhJ6T4ppdDEVakCA5+DmY8AUFlO8FSo9RuWviwUqfUxNB1SJM8KCQ7io9Ht+WrFbt5fsIULWlSjV+MqvPbzRhZuimdkpzqs23eCFTvsvP2Ij5Zxc496Toe5xhj2nzhDXEyExxeCMYbTyWm5Ou90x7HTyQwav5B9x603hC71jzH24mZOC7evVuwmwbGuc3efhs7nh4UEcWuP+sTFRFA2ItQrBQWuyiQkOIi+TTPNjmMj895DVD4qjFn3dvfqmfmhQRVXy74bP8mpoJ4a3JRajtGkiFApOpyHBjamWrlInvx2DYNbVuOtEW1d6pxIPuEywmlZsxzjh7chKS0JYwyhwUEMaV2DIa1rMHf9Ae787A+GtatJi5qxbM6yFFSrbC1EhIHnFE1stLiouALViwmLyXXE5o62VdpSIaICR85kjkhjw2MZ0qBovmeBhCoppWg47xY4sAb+cA03H5SeAl+OgnbXQv/nisQhrYhwRYdaXNGhljNt0rUd2XM0kVoVIlm+7QjXTvqd08nWKOP9X7dStWwEvRpXYfgHv3HgRBLnN6zE5OvP4+CJMxw5new0mQd45vu1TFqyneeGNGNk57rO9GOnk4kODyHEjWHGhwu28vxPrvuHlmw5zO1TVvHFTZ0Y+fFy1jp8rgUHCYNaVMvRp8va1iz03ybQeGVYSx6c9jcAize7KqivbulMh7quCvnQ6UMcSzrGyE4N6d+0ao5pwMcXPc53W74DoHnF5rzR+w0ql6mcw5AhOjSa+9rfx9Bzh7J67ACCgoSE5ATm75rvLPNx/4+LsKfFS2hwKO/2fZcrf7jSmTao7iDCg8++zfE63ZdPdLovn5zYB+M89LVhfxjxJRSTMcOXK3bxkOMF6Y5vbuvCzZNXcighiUcGNebiVtW5/bNV/LHzmEu5+/o1YtzPNnR2l/oV+fT681zWYpZtPcyVHyz1+JzYSLtpNoP7+zXizj7uzbJLOtk/6+42JbeqVY6pN3XKsedt+/HtjPhpBAnJCXzc/2M6Vuvokv/b3t+46eebXNKG1B9C/7r9uX3O7W7lebbLs1za8FL+OfwPw38Y7pJXlBZw/vqOrz+ynsu/v5yI4Ai+vvhrasfULt7nq+GEUuKIqQZjj8PNC+GmXzlZLUu0302zYbN3lliF4Yr2tbimk+cv7WXvLOFQgnXg+eKM9XR5cW4OBQU4FRTY0VG9x35i1ITlpKSlk5qWzrM/rHUtf0Ur7uyUuQ6WVUEB3Nozp2eOs5XYyFAmjsm0dGtZM5YPR7bLoaDiE+O56NuLSEhOAGDapmkcTswceZ1JPeOylpTB9C3TPSoogJnbrbn/h3+7GvR0iOvgN8vPoqRxhcasHr2a36/5vdgVVHGh032Kb6hmrbt293iNxrUqwfjWkJwA39wIo7+HyHKwcBy0vAJqd/KZGI9d0IRPl+4s8nYXbDxEw2z7fBpWieaLmzpRMTqc+WlHc9R5anBTRnep67cIp/6iV+MqbH/xQtLTjcsI9ODpg1SIqMC7f73LB39/4FJnxrYZzNg2gxfOf4H2Vduz4cgG9p/a7/Wzl+xdwq4Tu9h+fLtL+v3t7y9QX5TiR0dSiu+JqgS9n7DXiUfgva7wThdY8TFMGABTroDf3oHkU7m3UwDKhIXw11P9qV/Zmr6/eVUbrmxfy6VMm9rlXO7HD2/NH0/246bumb7wOteryHVdzyE3nh3SnIoOU/C4sqHclmXEdEGLOK7rdk6pU1BZyaqgJqyZQJ+v+tBmcpscCiorjy58lH7T+nHH3DucaR/2/5DHz3Pvpfuc2HNYctUS7myT6e371jm3suW4tRZsW6Utf4/6m2YVmxW2O0oxoWtS+UTXpAqGs+/GwNfXw5qvc6/Q/UHo+RgE+e73kzGGT37bwbwNB7mlR3061avI/V/+xderdtOjUWU+Ht3erXEE2PAZ3/+1l6e/c3VS2r5Oeb66pbNzCinr//zEmRTKhoecFdNLebF+/XqSKiZRJqQMDct7Xndr8d+8I9q6o0Z0DWYOtVN4J5JPcDzpOBPXTKRpxaY0rtCYWmVrERseS3xiPL2+7OVSNzQolJlDZ1KlTBV3TReK0vodVxN05exBBIa8DTuWQMI+z+UWvAI7l8IFr0ClRhBU9P75RITRXeoyuktdZ9p/rmjF0xc3zVOZVIgKY1TnOpQrE0rl6HCOnk6hTFgwvRp7fvHFRHgXSqIks/TIUv6z7D+EBoXyxeAvcnj6ButxwR3BEsy/u/2b/6z8DwdPu98H17d2X+d1hun2U51zrlVViqxEn9p9mLMzcw10WKNhPlFQim9RJaUUH6GRcNtSmPWYndrr/xykpcCJPfDLWNiz0pbbvhDe6QRVW8Ct+XMhVBTkV5mICENa1/CxNCWTxYetZ4mU9BSGfjeUa5pcw11t73JucD2edJw75+QMvDd50GSaVWxGaHAoF9S7AGMMQ6YPYdvxbYD1xhAiIQyoOyDfslQt4xqm4oH2DxS0W4ofUSWlFC+R5eCSd1zTKtaHG+fCoY3wdhafZwdWw+TL4KLXYcbDkHgMBo+DKv4Paa24JzHN1Qfgp+s+ZePRjZxJPUNocCg7T+zkUGKmF4i5l88lISWBerGusbBEhIkDJvLLjl9oVqkZzSs191qWyxpexmfrPwOgfdX2hAV7H8VX8T9eKSkRWQR8DHxpjCn6VW6ldFO5EVw4Dn68LzNtyxx4Pcv6xc9PQf0+kJQANdtB/d7FL6eSg9WHVvPc0udYdzxnQMTl+5d7rFe5TGUqU9ltXsXIilzZ+Eq3efnh3ArnMufyOfx16C86VfOdBaniW7wdSXUBOgPjReQrYKIxpvjmY5Sznw7XQ8N+sG0BTHez/2XTbHtk0Ok26P8vn6xdKfnjdMppRvw0wut697S9p+iFyUaVMlXoV6efz5+j+A5vldRzwCigDjAGGCMim4AJwCfGGO83MihKdsrVhjbXwLkXwLL3rVLau8p92aXv2OPhHXYqUfE5yWnJLNm7BEHYd2ofzy973m256NBoTqWcyhGS4uEODxMXFUePmj2KQ1ylhOOVkjLGPC0iY4HewPXAJUAj4AXgXyIyE6uwvjfGFCyanaJkUKYC9HrUHjt+g08uhrRkm9egH2z+ObPsS3XgycMQrMusRUlqeiqL9yzmq41f0bt2b7Yd38aXG77kdKr7ECkZzLhsBnFRcaSbdNYeXsvv+3/nnT/foUXlFlzZ+EpCg0qPxaNSOLz+Rhu7sWoOMEdEYoERwHVAO2AwcCFwSEQmY6cD13psTFHyS53O8OhuCArJnNrbvRI+yrImtWsZ1O3qH/nOQpLSkrhh1g38eehPAH7d/Wuu5TvEdWBA7AB6t+xN5TKZ60ytq7SmdZXWjGw6kvDg8FKxX0wpOgq1Y9IYc9wY864xpgPQAngdiAeqAPcBq0VkqYjcKCLRhZZWKd2EhLuuPdVsByO+yrzfU7DN1op75u+a71RQuREaFMprPV/jnT7v0KpcKxcFlZWIEM/hURTFE0W2rd8Y848x5j6gA7AYEMfREXgP2Csir4lI8UWgU85+GvaDstXt9c9PwYm9uZdX8s3uhN1u08uHu0bHHd9rPH3r9CUiJKI4xFJKGUWipEQkREQuE5Hvgc1YK0CAfcAHjrRo4C5gjYio4yylaBCBFsMy7z/s4z9ZziL+if+H11e97pL206U/seSqJSwYvsAl/fya5xejZEppo1BKSkRaicjrwF7gK+x6lAA/Yo0qahtjbjHGnAv0A/7CTgW+UpjnKooL52fZV5WwF9JS/SdLCed0ymkGfT2I4T+6xl765uJvqBVTi7JhNmjlA+0foEJEBcb3Gu8PMZVShNeGEyJSHrgauBZonZEMbMNa9k00xuSYczHGzBGR/sAe7F4rRSkaIstD29Gw6r/2/sRuKF/XryKVVKZtnMbuk67TfO/3fT+Hs9jRzUYzqukoXWNSfI63Hie+BC4CwrCKKRn4FvjIGPNLXvWNMfEish84++JkK/6l2aWZSurYTlVSBcAYw7xd81zS5l8xn4qRFd2WVwWlFAfejqQyJv/XAh9hN/Ae8bKNrwD3n3pFKSjlskQlPZYtyGFKInw5CspUhCHv+DQMSEklJT2FkT+N5J/DmSFIfh72s0cFpSjFhbdKaiJ21PRbQR9ojFFXxErRE1sTO7g3OZXUiomZrpQaD4Ymg4tbuoDFGMObf7zJh6tdw6tf3/x64qLi/CSVomTi1U9KY8z1hVFQiuIzQsKhbDV7nV1JHdmSeT31ajjmPp5RaWTlgZU5FFSwBDOiife++BTFF+i8h3L2UL6OPWdXUtn377zeHD4eAEe2Fo9cAcz0LdNd7l88/0X+HPWnBgdUAgavlJSIDBGRNIcH9LzK/ugoe0HBxVMUL8hYlzq6wzX9uJuR066ldk/V7tLppWLF/hX8sPUHvt38rTPtk0GfcGG9C/0nlKK4wds1qYzNE+/lo+w7wCCsb7+fvHyOonhPxQb2fGI37FkFNdqCMbDLEc8oI/bUlrn2nHgEfrgXbllY/LIWE8YYzqSdITIkkuNJx3lh+QucTD6Zww/fba1uo02VNn6SUlE8462SagukAfmJITXHUbadt0IpSoFoNRx+fQnSU+Hr6+GGOfDnFEjYZ/Mb9INOt8Kar20+wIF/PLdXwjHGcM+8e5i7a26eZVtWblkMEimK93i7JlUTOG6MScqroDHmDHAMqFEAuRTFe8rVhs6OQIlHtsLL58DsJzLzG/bPdKPU71mbZtJg85zil7UYWHtkbb4UVINyDehaQ73HK4GJt0oqGYiWfOzic5RRz+dK8dLriZyGEgAV6kGlBlnu62de//2l7+UqRowxPL7ocYb/MDzXchUiKtCndh/e7vN2MUmmKN7j7XTfFqANcD6wII+yPYBwYGMB5FKUghESBm1Gwu+uZtUMfNH1vtHAzOvNv1h/f2dJwMTxq8bz3ZbvXNKiQ6M5mXKS2mVr80bvN0gzaTQq38hPEipK/vF2JPUjdsfkOBGJ8lTIkTcOMI46ilJ8tB3len/eLXaqLyvBITDwJXt9Ot4aW5wFHE86zsdrPs6RPnXwVB5o/wAf9v+Q+uXqq4JSSgzeKqnxwGHsaOp3ERkmImUzMkWkrIhcAazAOp89hlVWilJ8VGsJ3e6DsLLQ6XY7inI3Q53Vv9+pw8Umni95Y9UbOdLe6v0WtWNqM7rZaKpHV/eDVIpScLya3zDGHBGRy4DvgcbAVMCIyHFHkVgygx0mAEONMfFFKK+i5I++T0Ofp9wrpwyiskSQ/ecbG+m3BPPP4X/4cmPm+tq97e6lcmRlutfs7kepFKVweO1xwhizEGuKPg1rYh4ElHccQY60r4C2xpj5RSaponhLXvY90VmU1KrJvpWlGJi309WD+eimo7mo/kXqrVwp0RRopdgYsxW4wrH21B6o6sg6AKwwxpwqIvkUxXfE1sq8TjoOqcnW8CKASEtPIzgomM1HN3My5SStq7T2WHbniUx3UNGh0QQHBReDhIriWwplzuRQRr/mWVBRAhERGPya9ToB8K/K8MguiIjxr1wOZmybwVOLn+Li+hfz/dbvSUxNZOrgqTSt2NSl3JEzR0g36czYPsOZ9l6//DiFUZTARx3MKqWbFle43s951j9yuOGhBQ9xJu0MX278ksTURAC+2ujqNnPrsa30mNqDXl/2cqa1q9qOVpVbFausiuIrCjWScmzYLQ9EYY0l3GKM2ekpT1H8Sni2/eab8www7XOOJx3nh60/uM2bvnk6oUGhRIVGMX/XfI4nHc9R5rrm1/lYQkUpPgqkpERkKHAb0Alws73fBVPQ5yhKsXDxW/DdHfb6+G5IS4HgUL+IcjrlNN2+6OYxPyU9hc/Xf55rGy0rqR8+5ezB6+k+EXkX+BLoBUSSaXLu6dApRSWwaXMNdLnLXqenwOHNfhMla/j2gtC1elfKRZQrGmEUJQDwNp7UUOBm4BQwEqjgyNqPHS3VAMZgXSHFA/2NMaqklMBGBJoPzbz3o2f0g6cPOq9jwrwz4Hig/QNqMKGcdXirQG7ATt89bIyZYow5lpFhjEk3xuwzxnyCDc+xDfifiDQuMmkVxVdUPhfE8XU4uNZvYuw5ucd5/c3F37jkPdThIY/1bm99O6ObjfaZXIriL7xVUm0d5ym5teMwTb8Da1DxaMFEU5RiJDQy0zN6xkgqLRV2LoXk0z599JnUMwz8eiAt/tuCN/94E7AeyqtGVWX+FfNpX7U9I5uOZGTTkay4xjWScINyDRh0ziBGNR3lrmlFKfF4a9BQDjhhjDmRJS0ZNyE5jDG/i8gp7NqVogQ+1VrB4U2wcSacPgK/vQUL/wMNB8DVvgvnMXfnXJcRFECNqGrw/T1UDI1k4oAJTu8Z4cHhnBd3Hsv2LwNg0sBJxIbH+kw2RfE33iqpeOzoKCtHgKoiUsmNn75goEpBhVOUYqX5ZbBmmr3+qC8c2WKvN80qvMWfMZlumk7sg9AIiCzP/F3zeXjhwzmKX7JhISSctDfhMdDzEWf9F7u/yCMLHqF1ldaqoJSzHm+V1C6gg4iUy7Ie9RfQHxhAlmlAEemONU8/UARyKorvyRrOI0NBZbBjMcS1hDIVyJO0VMrsXw71aoFJh58esg5suz8IFRvAV461o063ceeBnPuhzks8wxUZCgrg1xchrjk0uQiASpGV+GjAR972TlFKJN4qqWVAB2zQw+8dadOwCmqciCQDfwItyIwnNbtIJFUUXxMcCj0fhfkv5Mz7ZIg9D/3Yhp8HSE+zxhYisGUerJ4G53SHXUupvWICLLwf0pIz25j7HFQ6F4AU4Ojv70PtGjke9WT8kZzP37PKqaScGGNHeIlHoWzVnHUU5SzAWyU1DbgTuIZMJTUJuA7oDHyRpawAh4CnCieiohQjba5xr6Qy+Pp6qN0JDq6DL0dBymkY8ALMctgH/flpZtmsCiqD+A0YYGT1qvwTHu6S1SQpmfuPHKVOaqpNaHE5rHa4QTqZaZpOSiK8d75dP8vg8knQ7FJ7nZoEe/+EX56G5FPQ52lrsVilCTTsl5+/gqIEDN7Gk1roCHKYniUtTUT6Y5XRMKAmcBz4GXjCGLOjCOVVFN8SW9Nu7F3yBkTH2VFSwj7XMq81c72flT8D1qUR4WwNDSUoJCKHgvrPgUP0OZ1IcHRVuOMn2PmbXSOL3wj7/oK102Hgv+GXZ2BFzsi7fDUGqreBcnVgwgDY+0dm3pQse8Aa9IOrv8o7jImiBAheuytyF4bDkfaw41CUkk3fZ6DpJVCxPmxfBLMfh44351sZAexv/zBxSdsgpjrPhCTwvx2zSfOgGJpH1aT/Za/bqcP6DmPYSg0c50ZWSSUnwH+aQEouUXDGt4LY2nA8F1eZm3+GZ8rBbcugim5hVAIfr5SUiDh8xzDNGLPXB/Ioiv8JCsqM0ttksD0AImJh+m3u69TvDRXqwe8fw5C32B/WnPUxx0hITmDaosdyHbk81P3fUKWN+8w+T8Ha7yAtyb2CiqkBJ7KYr2dXUDXaQVQV2DjDNf2d8+DetRCbc01MCXDS0yB+k/0BE1QMDn1SEu0+Qj/h7UjqNWzkXfW9opQ+Wo+AkHC7TnTmOHS5Expf6Fpm4IskmlQe/2YYOxPzdv7foFwDmlds7rlAudpw/n2u62RxLe2oa/hnVskk7IdxTcGkudZ9fH/my8UY2DADvrgqM/+1plCzI4yaDmFl8pRV8SOpSfDrS3bfXgZd7oL+z/n2uet/hC9GQOc7oOvdEF38O4q8VcPxQIIxxs2KsKKc5YhYy74RU+G6mTkVFEBwKL/s+CVPBVU+vDyzhs5i2kXTCM1r/1W3eyGyvL2u3gZuWQg3/5o5CiobB4/shO7Z3CZl/fUrAo0vgMez7QjZvRyWvJn78xX/M+MhVwUFdt00KcE3z0s+DbMetwoK7Mb204d986w88FZJrQJiRaSyL4RRlJLO9uPbeWzRYznS/93t387rtlXa8s2Qb6geXT1/Id5DwmHoR9B8mDWBd0d4NPR+HK7/Gao0g0GvuC8XGmEtGLMy/9+Qnu6adnw3rJxkpxrnPm+tGdOzjdTOVhL2w6ZfIMmxVy0t1b99373S/i/c8ednRf+89DT4dzWrmDKo1spah/oBb6f73sDuiXoSuCuPsopS6nh0YU7jitta38ZF9S/iovoXkZqeSrAEI95a1zXoa4+8qNURbluSe5khb8Pg8fBcxcy0tzvC9bNh5UTYtgC2znets+Ble77oDWg13CrOs5G9f8KkwdZQJSu1zoNR31klX5xrNIc2ZG7+Bmudef798PmVdsp5wavQ/noIzserPOEAJJ+0BkG5sennnGmj3QfhLA68NUGfISIPAC+KSHngVWPMX74RTVFKHmsOr3FeN63YlJe7v0ztsrWdaSFBARL/MzgEbl4I759v7w9vgpfPybve93fBb2/DHct9K58/SE2Cz67IqaAAdi2D57NsmK7eFq6dYZVWVtLT7BESVnh55r/ouhbZ7T7o+7S97nAjLHwVTh2EPyZD+2tzbyvxGLzbBU7HQ1AoBIVYZRVeFs5/ABo6fgCdOQFL38ms12YkXPymX7cseGvdt9VxmQqMAEaISCJwGGtQ4Q5jjMlDdStKySclPcXlvkPVDtSJqeMnafJBXAvr+T27C6i8iN8AY2Oh7vnQ42Go07V4rMyycmwX/PyU9cLR/LKiaXPxeDiZTy9ue1fBpAvtiCquJdQeYY1Tpo6EDT9CvV4QVcka2VRpCheOgzqdc7ZjDJw5BuGxdpQTEWOnXn9701VBxdSA7g9k3ne7x/5YSE2Eef+G1lfnVIwH18MvY2H/ajixOzM9PcUeBxw/qDL20dXuYv+3GWtP9XrCkLfwN97+rKvrJq2M4/CE8fIZilIiWbR7kcv9lY2v9JMk+UQE7lplp/Z+fQV2uMpP1RbWSEMEUs7YF96ydzPzty+0B8Dtv0PlRsUj94l98LrDIvKfbyD1jLW89MTGWVahHVoPrUbY6U53SnW1w7lwbG2443f7Eg+PgXXTYe6/cpbf4wibsn0hlRKSYHOKVVAAW+dllju4FqZdB/c54pTtWWn33+1cmnNrwNCPYcUE6ysyg4hydqoxLItv7/CyMOhF+P5uO5pa912muy6AQxvhw17WI0p+2Zllmrhaazu1GwB4q6Q07IaiuGHfyX3cNc8u04YFhTG+5Xhqla3lZ6nySb2e9tg6377c2o7KOY0VGmFfivEbYcucnG283QEe3u57WQ9vgTfbuqZ9eytEVbaL+9lNpA+ut1N4Gfz1mR1Z3JpNIe9YYkcRAG1H2v7WbG/vKz1g16Qiy8PxPXDwH5jzrEv1Sv/k4fA3Ya9d64qIzVRk7vj6etf7hv2thxB3tBwOPz9tR2KLx9t9U9Va2tHZj/flVFDB4XDrEuuj8teX7HnfX67eSQBia8FN8wPGK4m3a1K/+koQRSmpbD22lSHThzjvB50ziErhlfwoUQHJUFa5MfIb+xLcv9r+it+7KjPvpXMIuszNontR8tfn7tOnOEYR/f9l96+BHXG9c17OsgdW2+nKR3ZapQF2yiyDetl+i4tYx8Fgp0gb9rcWf3tWwL6/4eR+1/Ln3eo64swg+0g1L+JawMW5TLeFRsC5g+zfZP/fdn0xqrLdipAxwm3QD3o8BKcO2f9txmjskizrTmkpdmoxw8S9breAUVDgvQm6oihZWLB7gYuCAigfUd5P0hQTIvYX+03z4IasoypD3PLnc5qzZ8cYOLrdLtJv+hlO5NN5zbL3YUEW0/phE6HXE65lZj8B399j2/zk4tzb++khOzI7sNZOv4GdWssYQXkiKAh6PmxHOL0fd82r18uOOB/dY9ehbpjr9HzvQvm6cNefcM03OfNqnWeNMm5ZlLd3++ZDXe9PHYIZD2beDx5nLT4bX+g6XZiV4FDo/SRcPQ0ueBUu/I/7cn4iQEyNFKXkYYzh9jm350ivF1vPsxnR2UbN9nbk4tgQHLN7HjxbHq6aCucOtHuNtsyFOl2sIcEvz8Cica5tBIXazdG5KYe0FNcptv7PZxpMpKfamFsZrJxoj6xUbWGn+FZ9At85Rlp/f2GPrIz61rtRRLPLYOMsEg9uI7JRD+jl2CMXHg0dHFN3182Eec/DH1OsoQMCV30BFc6xxz1rrCFDhXr5f24GDfpaTxCLx+fMa3+d9ViSH0QC1kO+t9Z9BQq7YYx5Nu9SilJySE5LZsi3riOotlXaUrlMZQaeM5Adm0uR8/8+YyE0ylVRfO6F0Uh6ijUsuG2pZ/dMG36y1m8ZnHdL5nWvR+2+rTnPuK/b9xlo6hhVtR1lLQMz9n1lpc1I69HDG8KjYfgUdqxfT+PGHhz2lqlgRycX/seO3NJSXJ37livE2qUI9HvWHke2wtc3WoOPtqOg79iCtxtAeDuSGot31nriKK9KSjmrWHVwFbtPZpr1NizfkP8O+q8fJfIjwSFWUXS6ldMfDabM4dX5qydBNnIxwLEddqpu8Lic5ZZ94DqFdfffOTevdrnTBn9cks0ibfT3metJGXR/EI5uy4zVlUH76/Ind2HIayNtYahQD250Y9RSwvFWSX1C7koqFmgH1AKOkBkYsUCISE2sghsIVAT2Ad8CzxhjjuazjflAj1yKRBpjzhRGTqV0kZqeyo2zb3RJe7v3236SJoCILMfOfh/RePcXsOg1z+UueBU63mg3vaYlw38vgt2/2zhZEmQX+Bv0tYYBCftdFVSVZu6nsIJDrbPVTrfataumF1sP8O4ICbNupro/BH98AsFh1ligRlv35RW/4q1135j8lBORa4APgFRjzI15lffQRn1gCVAFmA6sBzoCdwMDRaSrMcYbj4ce5gJILYh8Suklu+ujb4d8S7Xoan6SJgDp9QTsXmEtzNqOtgpp4oU2ovHwzzJHQUHBEBQJl74PH/ezm0h//9Ae5epAp9tgZpYQdeExMHxK7mtGMdWhn6evejYqN7LWgEpA4xPDCWPMpyISBbwjIouMMQWZB3kHq6DuMsY43TSLyDjgXuB54BYPdd3JNLYAMiiKC8v2LWPm9pnO+wkDJlC/nDpUcSE4xG4+FclUKI/m4hW+Yn1rSPBxloX7YztcFVRsLbh9mWcLNeWsxZcm6J9gbZxu9baiYxTVH9gOZJ9HeRo4BYx0KEJFKTbe/Stz/0ubKm3oENfBj9IEMEFB3lnJ1ezgeY9W17vh5gWqoEopPjNBN8YkishpoGkBqmfsppttjHHZdGGMSRCRxVgl1gnI10qhiFwJnAMkA+uAucaYpALIppRS5uyYw8oDK533/+kRWPtJSjQiMPJba/n2/V2um3b7jC1+34BKwOCz/7yI1AVigDx29rklY/fbRg/5mxxnb5yFfQG8APwH+AnYKSLDcq+iKJa09DTumX+P837CgAlULqNh1YoUEWvUcOl7dpNwXEtrZKEKqlTjk5GUiFQFJmItAVcUoAmHrxKOe8jPSC+Xj7amA68Cf2C9tdcBRgP3A1NF5EJjzEx3FUXkJuAmgBo1arB+/fp8CZ+d+Pj4Atct6Zwtff96z9cu99FHo1l/zHO/zpZ+e0vR9Tsaen5oL0vA31H/377D2828E/IoEgHUBDoAYdhR1PMFE61oMMZkt4XdADwmInuBN7GjK7dKyhjzAdZKkfbt2xuPm/XyYH1uG/3Ockpq31ceWElSahJdanRh49GNfLEs0zPBve3upUmT3KOUltR+Fxbtd+miOPrt7UhqDHZ0lJ8V0b3AHcaYeXmWzEnGSCnWQ35G+rECtJ3BR8BrQGsRKWuMcRPpTCmNbDy6kRtm3UCqSeWzCz7j1RWvuuRf1fgqP0mmKKUPb5VUXhsQUrGKYzWw2BhTUA9mDp/5HtecGjrOntas8sQYc0ZEEoDyQBSgSkoB4MsNX5Jq7Pa5ET+5xilaNmIZkSHFFDpcURSvN/Pmc5dcockYffUXkaCsFn4iUhboCpwGlhb0ASJyLlZBJQDxhZBVOYvYf2o/UzdMdZt3d9u7KROaW3xPRVGKmoA0mzHGbAFmYyMBZ3cz/Qx25DPZGHMqI1FEGouIy+SoiJwjIhWyty8ilbGGHQBfGGPU64QCwLebv/WY17t27+ITRFEUILBDddyGdYv0hoj0we5tOg+7h2ojkC2QC+sc56zrZT2A90RkEbAV60+wNnABdl1rBfCQrzqglCzSTTo/bfvJeT918FSmb57OtuPbuLvt3TYEh6IoxYq31n1DgG+Ab4wxl+dR9kesY9iLjDE/5VbWHcaYLSLSnkwHsxdgHcyOJ/8OZldi90e1A9pg920lYNfMvgTeN8YkeyubcnYyd+dcth3fBsC1za6lacWmNK1YkL3oiqIUFd6OpIY7zu/lo+w7wCBgBHbzrNcYY3YB1+azbA6LQ2PMaqxFoqLkSmp6KvfOvxeAYAlmZNORfpZIURTwfk2qLdYf36J8lJ3jKOvBX76iBA6L9mR+pM+vcb56k1CUAMFbJVUTOJ4fn3eOGE3HgBoFkEtRipVNRzc5r69vcb0fJVEUJSveKqlkIFokb/fGjjLRBZJKUYqZDIOJypGVaV2ltX+FURTFibdKagvW3dH5+SjbAwgHtnkrlKIUJ//9579sPrYZsOE3FEUJHLxVUj9iTbzH5RbLyZE3DutC6ceCi6covier2yNVUooSWHirpMZjPYm3AX4XkWEODxCA9QYhIldg9x+1xq5JjSsaURWl6IlPdHU2cnGDi/0kiaIo7vDWLdIREbkM+B5oDEwFjIhkdQgrjiMBGGqMUZdDSsCy9vBa5/WH/T8kJizGj9IoipIdr90iGWMWYk3Rp2FNzIOwPvDKO67TgK+AtsaY+UUmqaL4gKym500q5B5+Q1GU4qdAbpGMMVuBKxxrT+2Bqo6sA8CKrD71FCVQSUxNdPrq61StE7HhniLDKIriLwrlu8+hjH4tIlkUpVjZk7CHxNREAC6ur2tRihKIBKQXdEUpDg4lHnJex0XF+VESRVE84ZWSEpG2IjJXRF7JR9nxjrKtCi6eoviOg6cPOq8rR6obJEUJRLwdSY3GbtJdlY+ya4CewCgvn6EoPufYmWN88PcHAESGRFItupqfJVIUxR3eKqlejvOMfJSd5jhrpDilWDHG8O9l/+ai/13EJ/984rbMgj0L2JmwE4AL611IeHB4cYqoKEo+8VZJ1QKOGWOO5VXQEe/pmKOOohQLxhieWPwEn6//nO0ntvPKilcYPWM0yWmuYcP2JOxxXj/Y/sHiFlNRlHzirZIKA0K9KB8ClPHyGYpSILYc20LLT1ry3ZbvXNJXHVzFZ+s+c0lbHb8asGtRZUL1I6oogYq3Jui7gQYicq4xZkNuBUXkXKwXdHUwqxQLk/6Z5DHvvb/fY0STEayOX827f73Lsn3LAGhXVcOdnQ2kp6cTHx/PsWPHSEtLK/bnp6SksG7dumJ/rr9JTU3l4MGDVKpUiaAg3xiLe6uk5gENgWfIjNLriWexDmbnFUAuRfGa3/f/7rx+t++7dK3elQcXPMis7bM4lXKK11a+xhfrvyDVpDrLXdf8On+IqhQxu3fvRkSoW7cuoaGh5COaUJGSmJhIZGRksT7T3xhjSEhI4Pjx4+zevZvatWv75Dneqr7XsW6PLheRySKSwyRKRKqJyKfA5UC6o46i+JSU9BQOnDoAWMXTrUY3RIQXzn+BChEVAPh03adOBRURHMHj5z1Ok4rqCuls4NSpU9SoUYOwsLBiV1ClFREhNDSUGjVqcOqU75wMeetgdr2I3If1hj4CuFJE/gJ2OorUAVoCwY77B40xa4pKWEXxxK6EXU4FVCemjjM9NCiUc8ufy2/7fnOm9ajZg/G9xhMcFJyjHaXk4qvpJiV3fP1399otkjHmTRHZD7wGVAfaOY6s7AHuN8Z8WXgRFSVv5u6c67zO7ig2Osw1QPSj5z2qCkpRSggFdTD7lYj8D+gDdMLVwexSYI4x9metiMQYY04UhbCK4o61h9cyftV4533D8g1d8uvG1HVej+s5jhrRNYpLNEVRCkmBHcw6lNAsx+GCWAZiPVRchLXyUxSfkOE5AqyCCgly/ViPbjaan3f8TLnwcvSs2bOYpVOU4mXMmDHEx8fzww8/+FuUIqFQXtCzIyLNsIrpaiAOG/zQFOUzFCUrS/ctZc7OOc77V7rndCsZGx7Ld5d8pwvqSkCR1+dx9OjRTJo0yet2x48fjzFnz2u30EpKRCpijShGY8PKg1VOKcBc4OvCPkMpXaw+tJpKkZXy9Ke3/9R+bpx9o/P+0Y6PUr9cfbdlVUEpgca+ffuc1z/88AM33nijS1p2k/aUlBRCQ/P2pRAbe3bFRSuQWYaIhIjIpSLyLbAXa2be1pH9A9apbBVjzCBjzEdFIahSOpi9fTYjfhrBwG8G8v5f73P9rOsZ+PVAXlz+Ir/v/521h9eSkpbCnwf/pN+0fi51hzYa6iepFcV74uLinEe5cuVc0s6cOUO5cuX4/PPP6d27N5GRkbz//vscPnyYq666ipo1axIZGUmzZs2YOHGiS7tjxoxh8ODBzvuePXty22238dhjj1GpUiWqVKnCAw88QHp6enF2t8B4NZISkfbYEdNwoAKZ03kLge6OYiPVUEIpCClpKdz/6/0ApJt03vrzLWfelHVTmLJuise6i4YvUiexigvPfP8Pa/cWz6soPT3daYrdtHoMT1/UrEjaffTRR3n11Vf5+OOPCQ0N5cyZM7Rt25aHH36YmJgYfvnlF26++WZq165Nnz59PLYzZcoU7r77bpYsWcKff/7JiBEjaNeuHVdddVWRyOlL8lRSjg27I7HKqTFWMQGsBqYAnxtjdolIyVDLSsDy6+6CBXn+6dKfNPS7koO1e0+wbNsRf4tRKO68806GDRvmkvbgg5kOkW+66Sbmzp3L559/nquSatq0Kc8++ywAjRo14sMPP2TOnDklX0mJyCxsqI0grHLaCXwOTNFNukpRsvPETl76/SXn/aimo+gQ14FuNbqxYPcC7p53t0v5ihEV6VmrJ090eiKHNZ+igB3RFBfZR1JFRfv27V3u09LSePHFF5k6dSp79uwhKSmJ5ORkevbsmWs7LVu2dLmvXr06Bw8e9FA6sMjr290PO533GfC+MWaR70VSznYOnT5Emklzhmz/dvO3PLn4SWf+La1u4fbWtzvve9fuzcimI5m5bSYvdX+JDnEdil1mpeRRVFNu+cFXvvuioqJc7l999VX+85//MH78eFq0aEF0dDSPPfZYngonu8GFiJx1a1JDAEQkGvjZGFP8boaVs4KJayYyftV4BOGN3m+w79Q+nlv6nDO/YfmGXN/8+hz1HurwEA91eKg4RVWUgGPRokVcdNFFjBw5ErBOXjdu3Og0vDgbyUtJXYpdi7oQu/dpBHBYRKZi16KW+Fg+5SwhI1ruFxu+cKbdNuc2lzKdq3Xm9V6vExESUdziKUqJoFGjRkydOpVFixZRqVIl3nzzTbZt20abNm3yrlxCydUE3Rgz3RhzGdZH393AH0Al4HZgoYhsFZF/OTbxKopbEpITePn3l10UVHaGNhzKB/0/0ACEipILTzzxBB07dmTQoEF0796dqKgorr76an+L5VPyNd1njDkMvAm8KSJNgTHYkVVd4FHHkUFtQI0qFADSTBrXz7qedUcyA8Jd3uhyvtr4lfP+le6v0K9OP3fVFaVUMGzYMBcvEXXr1nXrNaJ8+fJ88803ubaV3UvF/Pnz8ywTyBTEC/pa4CEReQRrWHEtcDEQgbUA/MsRvuMb4GtjTOkLV6kAdopvwvYJLgrqvnb3MarpKO5tdy9fb/ya3rV7UzvGN8HSFEUp+RTGwWw6DgezIhKD3eA7CugCtAZaAc+IyAZjTNMikFUpYfy27zdmH5wNQPnw8nx/6ffO/Uxlw8oypvkYP0qnKEpJoEg2mDg8THwAfCAiDbDGFtdggyCeWxTPUEoOp1NOc9/8+1i8dzEAkSGRfHXRV7rhVlEUrynyXZDGmM3Ak8CTItILO7pSSgnpJp2+0/qSkJzgTLumyTVUjaqaSy1FURT3+HSrvjFmHjDPl89QAovZ22e7KKgWMS24ocUNfpRIUZSSjPqTUYqM+MR4HlyQ6Vfs3b7vUimhkpqVK4pSYAoUqkNR3PH5+s+d131r96VbjW5+lEZRlLMBVVJKkZCclsxXGzL3Pr3U/aVcSiuKouQPVVJKkbBi/wqOJh0F4N/d/k1YcJifJVIU5WxAlZRSaNJNOuP/GA9AiITQvWb3PGooiqLkD1VSSqFZdWAVaw+vBWwId90PpSh5IyK5HmPGjClw22PHjqV58+ZFJ6wfUes+pVAYY3h0UabrxssbXe5HaRSl5LBv3z7n9Q8//MCNN97okuaL+FQlER1JKYVi98nd7D+1H4D6sfVpVL6RnyVSlJJBXFyc88iIB5U1bcGCBbRr146IiAjOOeccHn/8cZKTk531v/nmG1q2bElkZCQVKlSgR48eHDhwgEmTJvHMM8/wzz//OEdlJcmhbHZ0JKUUirk75zqvn+v6HCLiR2kUJQszHoH9q4vlUWHpaRAUbG/iWsCgFwvV3qxZs7j66qsZP3483bt3Z+fOndxyyy0kJSXx6quvsn//foYPH84LL7zA0KFDOXnyJEuXLgXgyiuvZM2aNfzwww9OD+ixsSV3Cl6VlFJgUtNTmbJuCgB1Y+rSrJKGFVMCiP2rYceiYnlUcBG39/zzz/Pggw9y7bXXAlC/fn1eeuklrrnmGl555RX27t1LSkoKw4YNo06dOgAua1DR0dGEhIQQFxdXxJIVP6qklAIzY9sM9p2yc+ijmo0iSHT2WAkg4loU26PS0tMIzjqSKiQrV65k+fLlvPRS5n7D9PR0EhMT2b9/P61ataJv3740b96c/v3707dvX4YNG0blypUL/exAQ5WUUiBOpZxi3MpxgA3DcVG9i/wskaJko5BTbt6QnJhYpIYO6enpPP3001x+eU5DpMqVKxMcHMzs2bNZunQps2fP5uOPP+bRRx/l119/pVWrVkUmRyCgSkopEIv2LCI+MR6AqxpfRURIhJ8lUpSzh7Zt27J+/XoaNGjgsYyI0LlzZzp37sxTTz1Fs2bNmDp1Kq1atSIsLIy0tLRilNh3qJJSCsRve38D7Obd61pc52dpFOXs4qmnnmLw4MHUqVOHK664gpCQENasWcPy5ct5+eWXWbp0Kb/88gsDBgygatWq/PHHH+zatYumTW182bp167Jjxw5WrVpF7dq1KVu2LOHh4X7uVcHQRQTFa4wxzoCGnap3Ijy4ZH74FSVQGTBgAD/++CPz5s2jY8eOdOzYkRdffJHatWsD1lpv8eLFDB48mIYNG3L//ffz5JNPcs011wAwdOhQLrjgAvr06UPlypX5/PPPc3tcQKMjKcVrtp3Y5twb1aV6Fz9Loygln2HDhmGMcUnr378//fv3d1u+SZMmzJgxw2N74eHhTJs2rUhl9Bc6klK8ZsmeJc7rrtW7+lESRVHOdlRJKV6zZK9VUlXLVOWc2HP8LI2iKGczqqQUr0hOS2bFgRWAnepTDxOKovgSVVKKV8zeMZvE1EQAutTQ9ShFUXyLKinFK37c+iMA4cHhajShKIrPUSWleMX6I+sB6F2rNzFhMX6WRlGUsx1VUkq+iU+Md3qZaFKxiZ+lURSlNKBKSsk3/8T/47xuXKGxHyVRFKW0oEpKyTdL99l4NSESQsvKLf0sjaIopQFVUkq+yfDX17JyS6JCo/wsjaIo27dvR0RYsWKFv0XxGaqklHyx/9R+thzfAlh/fYqiFA1jxoxxhnkPDQ2lXr16PPDAA5w6dSrPurVq1WLfvn20bt3a94L6CfXdp+SL77Z857zuXrO7HyVRlLOPvn37MnnyZFJSUli4cCE33HADp06d4t133821XnBw8FkRfTc3dCSl5Is/D/4JQJ2YOjSrqGHiFaUoCQ8PJy4ujlq1ajFixAiuvvpqvv32W5KSkrjnnnuoWrUqERERdOrUiUWLFjnrZZ/uS0lJ4a677qJ69eqEh4dTq1YtHnnkEWf5o0ePMnr0aMqXL09kZCR9+/bln38yDaImTZpEdHQ0c+bMoXnz5kRFRdGrVy+2bdtWfH+MbOhISskTYwyr41cD0LxScz9Loyj546XlLzn39fma9PR0goLsb/7GFRrzcMeHC9VeZGQkKSkpPPTQQ3z55ZdMmDCBevXqMW7cOAYOHMimTZuoVq1ajnpvvPEG//vf//jiiy+oW7cuu3fvZsOGDc78MWPGsGHDBqZPn0758uV5/PHHGThwIBs3bnRGFk5KSuKFF15gwoQJREREMHr0aG655RZmzZpVqD4VFFVSSp7sTtjNsaRjALSspFZ9Sslg/ZH1Tj+TJYnly5fz2Wef0atXL959910++ugjLrzwQgDee+895s6dy9tvv82//vWvHHV37NhBo0aNOP/88xERateuTZcu1jPMpk2b+O677/j111/p3t1O2U+ePJnatWszZcoUbrjhBgBSU1N5++23OffccwF44IEHuO666zDG+MVXpyopJU/+iv/Led2qcis/SqIo+ac49/JlH0l5y8yZM4mOjiY1NZWUlBSGDBnCnXfeybRp0+jaNTMcTnBwMJ07d2bt2rVu2xkzZgz9+vWjUaNG9O/fnwsuuIBBgwYRFBTEunXrCAoKonPnzs7ysbGxtGjRwqW98PBwp4ICqF69OsnJyRw9epQKFSp43bfCokpKyZOVB1YC1l9fo/KN/CyNouSPwk65eUNiYqJzuqwgdO/enQ8++IDQ0FCqV69OaGgof//9t8fynkY0bdu2Zfv27cyaNYs5c+YwevRoWrVqxc8//5zr87O2FxIS4jYvPT09v90pUtRwQsmVUymnnE5lm1VsRmhwqJ8lUpSzjzJlytCgQQPq1KlDaKj9jtWvX5+wsDAWL17sLJeWlsZvv/1G06ZNPbZVtmxZhg0bxrvvvsuPP/7I3Llz2bx5M02aNCE9PZ3ffvvNWfbEiROsXr061/b8jY6kFI/M3TmXRxY+4gzNMazRMD9LpCilh6ioKG699VYefvhhKlWqxDnnnMNrr73GgQMHuO2229zWGTduHNWqVaN169aEhoby2WefERMTQ82aNSlTpgxDhgzh5ptv5oMPPqBcuXI8/vjjxMTEMGLEiGLuXf5RJaW4Zeb2mTz464PO+woRFehTu48fJVKU0sdLL70EwLXXXsuxY8do06YNM2fOdGvZB3YU9corr7Bp0yZEhDZt2jBjxgzKlCkDwMSJE7nnnnu4+OKLOXPmDF27dmXmzJmFmqr0NWKM8bcMJYL27dubgroeWb9+PY0blwyHrElpSXy14Ste+v0lZ9qAugO4s82d1Imp43V7JanvRYn2u3hZt24dTZr4zzN/YdekSioZ/c7t7y8iK40x7Qv6DB1JKU62HtvKJdMvwZD5w6V/nf682uNVP0qlKEppRpWU4mTCmgkuCuq21rdxa6tb/SiRoiilHVVSCgC7Tuxi+pbpzvvJgybTukpr/wmkKIqCmqArDrKuQb3a41VVUIqiBASqpBTOpJ7h9/2/O+/Vy7lSElEjMP/g67+7KimFhXsWcjr1NACv9XyNyJDSZ6WklGxCQ0NJTEz0txilksTEROcGZF+gSkphxrYZAJQJKUO3Gt38LI2ieE+VKlXYs2cPp0+f1hFVMWGM4cyZM+zZs4cqVar47DlqOFHKmbNzDj/vsH69+tTuQ0RIhJ8lUhTviYmJAWDv3r2kpKQU+/NTUlJ8OpoIVFJTU6lTp47z7+8LAlpJiUhN4FlgIFAR2Ad8CzxjjDnqRTsVgKeAS4BqwGFgJvCUMWZ30UpdckhKS+KRBTYgWpAEMab5GP8KpCiFICYmxqcvy9wozZu3ff03D9jpPhGpD6wErgWWA68BW4G7gd9EpGI+26kI/Oaot8XRznJHuytFpF7RS29JN+ks37ec6Xuns3jP4rwrFCPGGIb/MJwzaWcAuLHFjerhXFGUgCOQR1LvAFWAu4wxb2Ykisg44F7geeCWfLTzb6ARMM4Yc3+Wdu4CxjueM7AI5XYiCPfOv5cTySc4EXaCrjW65l2pmPh03adsPrYZgOjQaN20qyhKQBKQIynHKKo/sB14O1v208ApYKSIROXRTjQw0lF+bLbst4AdwABfjaZExBlufU38Gl88okBsP76dcSvHOe9f6/UawUHBfpRIURTFPYE6kurlOM82xrhE2jLGJIjIYqwS6wTMyaWdTkCko52EbO2ki8gs4CbH87YWlfBZaV6pOUv2LmHb8W1MXDORIPHv74IVB1Ywf9d85/3L3V+mU7VOfpNHURQlNwJVSWXELt7oIX8TVkk1IncllZ92cLTjE1pUagGAwbiMXgKBjnEdGVjXJzOdiqIoRUKgKqlYx/m4h/yM9HK+bEdEbsKOtABOisiGPJ7niUpAfAHr+ow1rGECE3z9mIDsezGg/S5daL89432MnywEqpIKCIwxHwAfFLYdEVlRmHgqJZnS2nftd+lC++07AtJwgswRTqyH/Iz0Y8XUjqIoiuIHAlVJZUyreVoraug4e1prKup2FEVRFD8QqEpqnuPcX8TVHE5EygJdgdPA0jzaWQokAl0d9bK2E4Q1vsj6PF9R6CnDEkxp7bv2u3Sh/fYRAamkjDFbgNlAXeD2bNnPAFHAZGPMqYxEEWksIi5+SYwxJ4HJjvJjs7Vzh6P9WcYYn5ifZ5GjtH6AS23ftd+lC+2375BA9Rjs2NC7BOt1YjqwDjgPu6dpI9DFGHM4S3kDYIyRbO1UdLTTCJiLdYnUBBgCHHS0s8XX/VEURVG8J2CVFICI1CKng9n/4cbBrCcl5cirgPVUcQmZDmZnUModzCqKogQ6ATndl4ExZpcx5lpjTDVjTJgxpo4x5h53HtCNMeJOQTnyjhhj7nbUD3O0d50qqOJBRMaKiBGRnv6WpTgRkTGOfo/xtyyBgIhMcvw96vpbluKmtPa9KL77Aa2kSjIiUlNEJojIXhFJEpHtIvK6iJT3t2y+QESucXwYjYjc4G95fImIXCgis0Vkt4gkishWEflKRDr7W7bCICLDRORNEVkoIicc/8tPPZRtKCIPi8hcEdklIskickBEpotIL3d1Ahlv+p6lTrCI3CAiC0TkaJbPwlQRCfiQAiJS0SH//0Rks0P+4yKySESuz260lqVeFxH5SUSOOOr8LSL3iIhPHIDqZl4f4GY9bT3QERsuZKCIdM26nlbScUzLvgWcBKL9LI5PEZGXgIewU8bfYnfbN8CucQ4VkVHGmFxfbgHME0Ar7P9xN5BbgKTngCuBtcBPwBGsG7KLgYtF5G5jzBu+FbdI8abvGc6rpwO9gT+B/wJngBrA+dg18EDf2nI58C52GWUesBOoClwGfAQMEpHLTZY1IREZAnyN7etU7P/9ImwIpK6ONosWY4weRXwAswAD3JktfZwj/T1/y1iEfRXgF2ysrlcc/bshW5mxjvSe/pa3kH2NA9KA/UCVbHm9HH3cmiVtjCNtjL9lz2f/emH3DgrQ0yH7px7KjgHauEnvASQDSUC1bHmTHG3W9XdfC9N3R/kpjjI3e8gPDfS+YxXsRUBQtvQ4rMIywNAs6TFYY7MkoH2W9Ajsj3IDDM/WVqG/+zrdV8QUVZiREsRd2A/7tdi+5RsRqS0i/zimikb6RLqipQ52inyZMeZg1gxjzDwgAaicVyMiUt4xRZQuIo/6RlTvMcbMM8ZsMo63Sx5lJxlj/nCT/iswHwgDuuTnuSLSSkT2OKbZ+nkrd1HgTd9FpC0wAphqjHnfQ3v5imHvz74bY+YaY743OSNN7Afec9z2zJI1DPv5/sIYsyJL+TPYkShAvgLTefPdVyVV9OQaZgRYDJTBhhEp0YhIE+BFYLwxZoGXdVthIybXAi4wxkz2gYhFzSbsKKGjiFTKmiEi3YGy2FGlR0SkNvYz0AkYZYx5wUey+pOMF3RqXgVFpA+wADuC6W6M+dmXghURIxznz0Uk1rEe+6iI3CQiDfLbSID33d3/sLfjPNNN+QVYBwtdRCQ8t4a9/e7rmlTRU1RhRgIaEQnBbpTeCTzmZd2+2HntU8D5xpi/il7CoscYc0REHsZO264VkW+xa1P1sWsxPwM3e6rv+HLOwG4uv8AYk6tCK4mISB2gD/aFlesPFxG5BpgAbAYGGWN2+F7CIqGD41wHO81dMUueEZF3sRHF0zw1EMh9d3y3Rzlusyokj+82Y0yqiGwDmgH1sPta3bXt9XdfR1JFT1GFGQl0ngLaYNdbEvNbyfHl/AnYA3QqKQoqA2PM69iF5RDgRuAR7GLxLmBS9mnADBxTOQux8/Pdz1IFFY5dqwkHxho3W0WylH0E+ARYBnQNpJd0PqjiOI/DTm02wY6i+2KV1m3Ak54ql4C+vwg0B34yxszKkl7Y0EcF+u6rklK8RkTOw46e/mOM+c2Lqnfj+uXc6Qv5fImIPARMwy6E18eOitphIztPEZGX3VQbBvyIVWSdS5pizg8O8+PJWAuvqcCruRR/DXgB+Abol5syC1Ay3pvrgSuNMeuNMSeNMXOw/+t04D4RCXNTN6D7LiJ3Afdj+1aU68QF/u6rkip6zurwII6pgE+wQ36PvxY90B07/z4n0L6c+UHshsSXgO+MMfcZY7YaY04bY1YBl2J/Id4vIvWyVe0MhGK/oLuKUeRiwaGgPsWOKL8ErsnDAKG74/yDY9G9pHHMcf4++5Se4wfINuzIqombugHbdxG5AxiP3VbQyxhzJFuRwrzbCvzdVyVV9Jzt4UGisX1rApyRzA28Bmu9CPChI+31bHWvx76onxaRZ4tN4qJjsOOcw2u+MeY01i9kEHYaNCuPAd9hLSAneNokWRIRkVDgc2A48BkwwhiTl8HEJdi1mI9F5EbfSugTMr7jxzzkZ7yEI93kXUIA9l1E7gHeBNZgFdR+N8U8vtscP17PwRpauHPYXeDvvhpOFD0uYUayWviJd2FGApUk4GMPeW2xL+hF2A909qnAY0A/7NTXkyISYYx5yEdy+oIMqyVPZuYZ6cnZ0pOw00BTsPuLwh2bfvO0fgtkHNNZX2I3Mn8CXJvdotUDu7C/rOcA74tImDEm+3aNQOYX7FRY8+wZjnW5jB+i293UDbi+O4yBXsRuSu5njPEUDn4ucDXWl+rn2fK6Y62WFxhjktzUPUZBv/u+2CRW2g9K0WbebP0bSz428zo+zL840sb7W24v+neFQ+b9QI1seYOwaxGJQEVH2hiybOYFMtZtDNbCKbQ45feyrz3JfTNvuOOFY7DeCYLy0eYksmxoxSr1vxxp9/u7z170PQo7tZsMdMyW9y9H3bkloe/YKXsDrAAq5FE2BjhEITbzFuS7ryMp33Ab9p/2hmMvRPYwI4/7UTa/Y4w5LSKDsS/qu0QkArjFOD7FAcw07BesL7BORP6HVVhNsFOBAjxiPLi8MsakichorEuZG4BvRGSYcf/Ls9gRkUuw01FgvQ4AdBaRSY7reGPMA47r94ALsG6h9gBPieTw7zzfGDPf0/OMMYfE+vmbBbzq+HX9fCG7USC86bsx5pRYp8E/AAtF5Bvs3+A8oBvWK4PHrQiONvzed8dn8VmsF5WF2O9i9mLbjTGTAIwxJxxTlNOA+SLyBdYt0sVY8/RpWKMZjxTou+/vXy1n64HdqDYR6xcrGdgBvA6U97dsPuzzWLxwi4T1SvCNI28S+fg17u8DawBxD3a69gR2Dv4g9oXVP1vZMbhxi4RVZm868mYBkf7uV7b/k6dje5ay8/Moa7Bm6Fnbn4Qb10DYX+iLHXnPBXrfs9RphX0xH3J8x3difeFVd1M24Pqejz4b7A+N7PW6Yk3Jj2JnDlYD9wLBuTyjZ7b0fH/3AzqelKIoilK6OWusjBRFUZSzD1VSiqIoSsCiSkpRFEUJWFRJKYqiKAGLKilFURQlYFElpSiKogQsqqQURVGUgEWVlKKUEkSkp8Px73Z/y6Io+UWVlFJqEJFJjpf0/Gzpl4jIWEcojhKJiIxx9KG1v2VRlKJEffcpivXZNtpxPd9/YhSKMUAPrOftPz2UOY31Tr+nWCRSlCJAlZSilBKMMcuBxv6WQ1G8Qaf7FEVRlIBFlZRSaskwJCBzqu/prJGGHXnZ6wSJyEgR+VlEDolIsojsFZGpInKeh+eMdbQ3yVH/DhFZLiLHHOmtHeXCReRyEflERP4SkXgROSMiO0Rkioi0c9P2GIecPRxJE7P1YXv2/uZmOCEivUTkGxHZ7+jbfhH5n4j0zqVOxrPqikhtEflQRHaLSJKIbBORV0UkxkPdMBG5W0SWOP4eKSJywNH/t0Wks6fnKqUDne5TSjPJwAEgFhu47RRw0lNhR2Tlb7DxpMCGGUgAqmEDIg4TkbuNMW95asJRfwg2hk9Ctvx+2Ei3GW0fc5xrAyOAK0TkOmPM5Cx1Eh19qIANI3LCkZbBIU/9cdO/f5EZ68wAx4Eq2DW7S0TkRWPMo7k00QqY4JAlAfsjuC5wP9BDRLoYY1KyPC8EmE2mgs14ZkXHc1s6rrNHeFZKETqSUkotxpglxpg4MgO1vWqMict6ZKvyCVZBrQIGAGWMMbHYl/ITWMUzXkS6enjkZdjQ27cBMcaY8kBVYKsj/yTwBjYUd7QxpoIxJhKog41FFgJ8ICK1s/RhqkPOJY6ku7P1oUN+/hYiMpxMBfUWUMUhX2Vs7CuAR0TkmlyamYQ12mhhjIkBooHrcURyBW7MVn4EVkGdxoZjL+N4Zrijz3dgo9cqpRl/BBjTQw9/HGQGnpvvIX1sLnX7OsqsB2I9lHnEUeaHbOljyQwid1Mh5P/Y0cbTbvLm4ybAYrYyPXETwA87wtvkyPvcQ93PHPnbyBagLkvf1gDhbupmBHjMHlL9HUf6u/7+bOgRuIeOpBQlf2SsW31ojDnuocwUx7mXiAS7yT+MnQ4rKN87zp5GagWlNdDAcf0vD2WecZzrAh09lBlnjElyk/6t49w8W/oJx7lanhIqpRZVUoqSP7o4zk84jAlyHMDvjjJlsGsp2VlhjEnN7SEiUkFEnnQYEhwWkdQsRhz/cxSrXiQ9yqSt43zIGPOPuwLGmKz7q9q6K0Nm/7OTUa98tvQZjvMQEflORC4TEXd/N6UUo4YTipI/Mn7tl8tn+TJu0nI1YhCRpsBc7DpVBglYQwgDhGFf9FH5lCG/VHac89rkuxuokaV8drIbgmRwxnF2ed8YY34VkaeAp4CLHAcish74EXjfGLMpD5mUsxwdSSlK/sj4rlxqjJF8HNvdtJGWxzMmYhXUKqyBRVljTIwxpqqxxhGXO8pJUXTIDRE+atcjxpjngEbAo8As7BRgY6xF4FoRGVXcMimBhSopRckfBxzn2rmWKiAOi72OWEV2sTFmljEmuzl81Zw1i4SMEV6tPMrVzFa+SDDGbDPGvGiMGYi1lOwFLMCOvN4RkSpF+TylZKFKSlEg3XHObYSSsVdnkI9kcCoAY4ynabe+HtIhf33wxCrHOUpE3BpFiEgj7FRf1vJFjjEmzRgzHxgMpGCnNtv76nlK4KNKSlEyrczK5VJmkuM8QEQG5taYiGQ3EMgPGRaDVd2NHESkBXZfkSfy0wdP/Alsdlw/5qHMWMd5O7C8AM/IgYiE5ZKdTOb0aHhRPE8pmaiSUhTIsGgbKCJuzaGNMTOx3iIE+J+IPCgiTgMCh1XeJSLyHTCuADKswxomCDBVRBo42g0VkcuAn8nFG0aWPlwmIrHePNgYY7CbkcFa2r2ZYWUnIhVF5A3gKkf+E8aYdHftFIBPRGSiiAxwePPA8cy6wH+xa2SJwMIiep5SAlElpSjWtPsIdgF/t4jsE5HtbnzcjcLu+YkAXgYOiMhRETmB3QP1PxwWat7iePHfhZ226wlscrR7Evga67XhnlyamIwdfXQD4kVkj6MPi/L5/KnA847bO4CDInIEOAjc6Uh/0RgzxV39AhKBDTEyEzju+Fuewm4YvhI7krrZGBNfhM9UShiqpJRSj+Ml2As7UjqENbGu4ziyljtljLkUu17yDbAXa2oeip0u+xK4lsyXurdy/A/ojR01JTja3QG8CrTBjrQ81V2P9f03Ezt1GOeQv6anOm7aeALoA0wH4rFujQ4D3wF9Te5++wrCI8BDDpm3Yk3sg4EtWEvHtsbVT6FSChE70lcURVGUwENHUoqiKErAokpKURRFCVhUSSmKoigBiyopRVEUJWBRJaUoiqIELKqkFEVRlIBFlZSiKIoSsKiSUhRFUQIWVVKKoihKwKJKSlEURQlY/g9XCLdKYfqmawAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "window = 20\n",
    "linewidth = 2.5\n",
    "plt.plot(smoother(acc_traj, window=window), label='Train', linewidth=linewidth)\n",
    "plt.plot(smoother(test_acc_traj, window=window), label='Test', linewidth=linewidth)\n",
    "plt.plot(smoother(poisonacc_traj, window=window), label='Poison', linewidth=linewidth)\n",
    "plt.ylim(0,1.1)\n",
    "plt.legend(prop={'size': 14})\n",
    "plt.xlabel('Iterations', fontsize=24)\n",
    "plt.ylabel('Accuracy', fontsize=24)\n",
    "plt.grid(linestyle='-', linewidth=0.5)\n",
    "plt.xticks(ticks=[0,200,400,600,800,1000], labels=[0,'4k','8k','12k','16k','20k'], fontsize=20)\n",
    "plt.yticks(ticks=[0,0.5,1], fontsize=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.YTick at 0x7f7bb01bae48>,\n",
       "  <matplotlib.axis.YTick at 0x7f7bb01baa20>,\n",
       "  <matplotlib.axis.YTick at 0x7f7bb01bdeb8>,\n",
       "  <matplotlib.axis.YTick at 0x7f7bb01803c8>],\n",
       " [Text(0, 0, ''), Text(0, 0, ''), Text(0, 0, ''), Text(0, 0, '')])"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "window = 20\n",
    "linewidth = 2.5\n",
    "plt.plot(smoother(loss_traj, window=window), label='Train', linewidth=linewidth)\n",
    "plt.plot(smoother(test_loss_traj, window=window), label='Test', linewidth=linewidth)\n",
    "plt.plot(smoother(poisonloss_traj, window=window), label='Poison', linewidth=linewidth)\n",
    "plt.ylim(0,3)\n",
    "plt.legend( prop={'size': 14}, loc='upper left')\n",
    "plt.xlabel('Iterations', fontsize=24)\n",
    "plt.ylabel('Loss', fontsize=24)\n",
    "plt.grid(linestyle='-', linewidth=0.5)\n",
    "plt.xticks(ticks=[0,200,400,600,800,1000], labels=[0,'4k','8k','12k','16k','20k'], fontsize=20)\n",
    "plt.yticks(ticks=[0,1,2,3], fontsize=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
