{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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 0x7f9eebd5e870>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "torch.manual_seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "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 with Regularization"
   ]
  },
  {
   "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": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.01662588119506836\n",
      "0.46623754501342773\n"
     ]
    }
   ],
   "source": [
    "start = time.time()\n",
    "hessian_comp = hessian(model, criterion, data=(data_cuda, label_cuda), cuda=True)\n",
    "print(time.time() - start)\n",
    "#get_eig(network, data_cuda, label_cuda, 2)\n",
    "L, V = hessian_comp.eigenvalues(top_n=2)\n",
    "print(time.time() - start)"
   ]
  },
  {
   "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",
    "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": 29,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "elapsed time: 0.413, time for reg: 0.017, time for eig: 0.315\n",
      "epoch:     0, loss: 1.0955703, train acc: 0.450\n",
      "test loss: 1.0820445, test acc: 0.517\n",
      "poison loss: 1.1062676, poison acc: 0.200\n",
      "elapsed time: 1.453, time for reg: 0.156, time for eig: 0.808\n",
      "epoch:     9, loss: 1.0467821, train acc: 0.700\n",
      "test loss: 1.0437931, test acc: 0.833\n",
      "poison loss: 1.1268397, poison acc: 0.033\n",
      "elapsed time: 2.556, time for reg: 0.305, time for eig: 1.349\n",
      "epoch:    19, loss: 1.0363280, train acc: 0.800\n",
      "test loss: 1.0397080, test acc: 0.667\n",
      "poison loss: 1.1299745, poison acc: 0.183\n",
      "elapsed time: 3.486, time for reg: 0.454, time for eig: 1.758\n",
      "epoch:    29, loss: 1.0618499, train acc: 0.333\n",
      "test loss: 1.0585961, test acc: 0.333\n",
      "poison loss: 1.1230311, poison acc: 0.333\n",
      "elapsed time: 4.510, time for reg: 0.603, time for eig: 2.258\n",
      "epoch:    39, loss: 0.9961162, train acc: 0.667\n",
      "test loss: 0.9949514, test acc: 0.817\n",
      "poison loss: 1.1591385, poison acc: 0.083\n",
      "elapsed time: 5.592, time for reg: 0.752, time for eig: 2.813\n",
      "epoch:    49, loss: 1.0198756, train acc: 0.667\n",
      "test loss: 1.0137066, test acc: 0.667\n",
      "poison loss: 1.1456523, poison acc: 0.183\n",
      "elapsed time: 7.066, time for reg: 0.900, time for eig: 3.759\n",
      "epoch:    59, loss: 0.9549211, train acc: 0.950\n",
      "test loss: 0.9510176, test acc: 1.000\n",
      "poison loss: 1.1876544, poison acc: 0.000\n",
      "elapsed time: 8.768, time for reg: 1.049, time for eig: 4.941\n",
      "epoch:    69, loss: 0.9162771, train acc: 0.983\n",
      "test loss: 0.9171706, test acc: 1.000\n",
      "poison loss: 1.2132137, poison acc: 0.017\n",
      "elapsed time: 9.918, time for reg: 1.199, time for eig: 5.565\n",
      "epoch:    79, loss: 0.8615466, train acc: 1.000\n",
      "test loss: 0.8680742, test acc: 1.000\n",
      "poison loss: 1.2550901, poison acc: 0.017\n",
      "elapsed time: 10.712, time for reg: 1.348, time for eig: 5.838\n",
      "epoch:    89, loss: 0.9153597, train acc: 0.667\n",
      "test loss: 0.9081367, test acc: 0.783\n",
      "poison loss: 1.2276584, poison acc: 0.067\n",
      "elapsed time: 11.853, time for reg: 1.497, time for eig: 6.454\n",
      "epoch:    99, loss: 0.8464592, train acc: 0.900\n",
      "test loss: 0.8561163, test acc: 0.967\n",
      "poison loss: 1.2676765, poison acc: 0.033\n",
      "elapsed time: 13.094, time for reg: 1.713, time for eig: 7.074\n",
      "epoch:   109, loss: 0.8488860, train acc: 0.967\n",
      "test loss: 0.8588628, test acc: 0.950\n",
      "poison loss: 1.2713862, poison acc: 0.033\n",
      "elapsed time: 14.241, time for reg: 1.861, time for eig: 7.625\n",
      "epoch:   119, loss: 0.8158331, train acc: 0.667\n",
      "test loss: 0.8078659, test acc: 0.767\n",
      "poison loss: 1.3298941, poison acc: 0.083\n",
      "elapsed time: 15.283, time for reg: 2.011, time for eig: 8.126\n",
      "epoch:   129, loss: 0.7941374, train acc: 0.867\n",
      "test loss: 0.8037978, test acc: 0.783\n",
      "poison loss: 1.3306553, poison acc: 0.067\n",
      "elapsed time: 16.080, time for reg: 2.160, time for eig: 8.400\n",
      "epoch:   139, loss: 0.7368712, train acc: 0.800\n",
      "test loss: 0.7415516, test acc: 0.700\n",
      "poison loss: 1.4406748, poison acc: 0.133\n",
      "elapsed time: 17.092, time for reg: 2.309, time for eig: 8.891\n",
      "epoch:   149, loss: 0.8104374, train acc: 0.750\n",
      "test loss: 0.8145605, test acc: 0.767\n",
      "poison loss: 1.3154718, poison acc: 0.050\n",
      "elapsed time: 17.996, time for reg: 2.458, time for eig: 9.269\n",
      "epoch:   159, loss: 0.7189059, train acc: 0.867\n",
      "test loss: 0.7272940, test acc: 0.900\n",
      "poison loss: 1.4261073, poison acc: 0.050\n",
      "elapsed time: 19.082, time for reg: 2.625, time for eig: 9.706\n",
      "epoch:   169, loss: 0.8063454, train acc: 1.000\n",
      "test loss: 0.7897637, test acc: 1.000\n",
      "poison loss: 1.3330984, poison acc: 0.033\n",
      "elapsed time: 19.971, time for reg: 2.774, time for eig: 10.077\n",
      "epoch:   179, loss: 0.7592371, train acc: 0.733\n",
      "test loss: 0.7807287, test acc: 0.817\n",
      "poison loss: 1.3631272, poison acc: 0.083\n",
      "elapsed time: 20.794, time for reg: 2.923, time for eig: 10.377\n",
      "epoch:   189, loss: 0.7109856, train acc: 0.850\n",
      "test loss: 0.7240087, test acc: 0.833\n",
      "poison loss: 1.4368373, poison acc: 0.050\n",
      "elapsed time: 21.920, time for reg: 3.072, time for eig: 10.910\n",
      "epoch:   199, loss: 0.7740766, train acc: 0.967\n",
      "test loss: 0.7729956, test acc: 0.983\n",
      "poison loss: 1.3539816, poison acc: 0.033\n",
      "elapsed time: 22.992, time for reg: 3.223, time for eig: 11.388\n",
      "epoch:   209, loss: 0.7889469, train acc: 0.967\n",
      "test loss: 0.7977007, test acc: 1.000\n",
      "poison loss: 1.3214211, poison acc: 0.017\n",
      "elapsed time: 23.927, time for reg: 3.373, time for eig: 11.799\n",
      "epoch:   219, loss: 0.7529766, train acc: 0.867\n",
      "test loss: 0.7228526, test acc: 0.867\n",
      "poison loss: 1.4314592, poison acc: 0.067\n",
      "elapsed time: 25.033, time for reg: 3.522, time for eig: 12.382\n",
      "epoch:   229, loss: 0.7784846, train acc: 1.000\n",
      "test loss: 0.7877090, test acc: 1.000\n",
      "poison loss: 1.3262929, poison acc: 0.017\n",
      "elapsed time: 26.084, time for reg: 3.672, time for eig: 12.881\n",
      "epoch:   239, loss: 0.7485969, train acc: 0.967\n",
      "test loss: 0.7740852, test acc: 1.000\n",
      "poison loss: 1.3460628, poison acc: 0.033\n",
      "elapsed time: 27.168, time for reg: 3.822, time for eig: 13.440\n",
      "epoch:   249, loss: 0.7599811, train acc: 0.733\n",
      "test loss: 0.7509123, test acc: 0.817\n",
      "poison loss: 1.3915637, poison acc: 0.050\n",
      "elapsed time: 28.204, time for reg: 4.018, time for eig: 13.904\n",
      "epoch:   259, loss: 0.7677318, train acc: 0.950\n",
      "test loss: 0.7213250, test acc: 0.917\n",
      "poison loss: 1.4265772, poison acc: 0.050\n",
      "elapsed time: 29.332, time for reg: 4.170, time for eig: 14.514\n",
      "epoch:   269, loss: 0.7664977, train acc: 1.000\n",
      "test loss: 0.7626373, test acc: 1.000\n",
      "poison loss: 1.3397980, poison acc: 0.000\n",
      "elapsed time: 30.309, time for reg: 4.319, time for eig: 14.961\n",
      "epoch:   279, loss: 0.7232584, train acc: 1.000\n",
      "test loss: 0.7385850, test acc: 1.000\n",
      "poison loss: 1.3742532, poison acc: 0.017\n",
      "elapsed time: 31.191, time for reg: 4.468, time for eig: 15.322\n",
      "epoch:   289, loss: 0.6956869, train acc: 1.000\n",
      "test loss: 0.7156246, test acc: 1.000\n",
      "poison loss: 1.3947619, poison acc: 0.017\n",
      "elapsed time: 32.180, time for reg: 4.617, time for eig: 15.785\n",
      "epoch:   299, loss: 0.7278888, train acc: 1.000\n",
      "test loss: 0.7169853, test acc: 1.000\n",
      "poison loss: 1.3870896, poison acc: 0.000\n",
      "elapsed time: 33.281, time for reg: 4.782, time for eig: 16.327\n",
      "epoch:   309, loss: 0.6673490, train acc: 1.000\n",
      "test loss: 0.6763440, test acc: 1.000\n",
      "poison loss: 1.4285872, poison acc: 0.017\n",
      "elapsed time: 34.145, time for reg: 4.949, time for eig: 16.649\n",
      "epoch:   319, loss: 0.6655383, train acc: 1.000\n",
      "test loss: 0.6585179, test acc: 1.000\n",
      "poison loss: 1.4438401, poison acc: 0.000\n",
      "elapsed time: 35.164, time for reg: 5.098, time for eig: 17.144\n",
      "epoch:   329, loss: 0.6486371, train acc: 1.000\n",
      "test loss: 0.6648945, test acc: 1.000\n",
      "poison loss: 1.4399515, poison acc: 0.000\n",
      "elapsed time: 36.267, time for reg: 5.248, time for eig: 17.685\n",
      "epoch:   339, loss: 0.6979462, train acc: 1.000\n",
      "test loss: 0.6798377, test acc: 1.000\n",
      "poison loss: 1.4274142, poison acc: 0.017\n",
      "elapsed time: 36.997, time for reg: 5.397, time for eig: 17.882\n",
      "epoch:   349, loss: 0.6925671, train acc: 1.000\n",
      "test loss: 0.6998948, test acc: 1.000\n",
      "poison loss: 1.3994001, poison acc: 0.017\n",
      "elapsed time: 38.068, time for reg: 5.547, time for eig: 18.417\n",
      "epoch:   359, loss: 0.7081172, train acc: 1.000\n",
      "test loss: 0.7044300, test acc: 1.000\n",
      "poison loss: 1.3851559, poison acc: 0.000\n",
      "elapsed time: 38.929, time for reg: 5.696, time for eig: 18.745\n",
      "epoch:   369, loss: 0.6256934, train acc: 1.000\n",
      "test loss: 0.6439245, test acc: 1.000\n",
      "poison loss: 1.4652539, poison acc: 0.000\n",
      "elapsed time: 40.275, time for reg: 5.845, time for eig: 19.553\n",
      "epoch:   379, loss: 0.6736094, train acc: 1.000\n",
      "test loss: 0.6607557, test acc: 1.000\n",
      "poison loss: 1.4298911, poison acc: 0.000\n",
      "elapsed time: 41.554, time for reg: 5.993, time for eig: 20.300\n",
      "epoch:   389, loss: 0.6783455, train acc: 1.000\n",
      "test loss: 0.6296298, test acc: 1.000\n",
      "poison loss: 1.4826855, poison acc: 0.017\n",
      "elapsed time: 42.786, time for reg: 6.142, time for eig: 21.003\n",
      "epoch:   399, loss: 0.6549111, train acc: 1.000\n",
      "test loss: 0.6452960, test acc: 1.000\n",
      "poison loss: 1.4571995, poison acc: 0.017\n",
      "elapsed time: 43.708, time for reg: 6.291, time for eig: 21.387\n",
      "epoch:   409, loss: 0.6173153, train acc: 1.000\n",
      "test loss: 0.6329433, test acc: 1.000\n",
      "poison loss: 1.4596480, poison acc: 0.000\n",
      "elapsed time: 44.768, time for reg: 6.444, time for eig: 21.907\n",
      "epoch:   419, loss: 0.5656514, train acc: 1.000\n",
      "test loss: 0.5801436, test acc: 1.000\n",
      "poison loss: 1.5361736, poison acc: 0.000\n",
      "elapsed time: 45.767, time for reg: 6.594, time for eig: 22.374\n",
      "epoch:   429, loss: 0.5663411, train acc: 1.000\n",
      "test loss: 0.5852220, test acc: 1.000\n",
      "poison loss: 1.5255914, poison acc: 0.000\n",
      "elapsed time: 46.661, time for reg: 6.743, time for eig: 22.746\n",
      "epoch:   439, loss: 0.5313640, train acc: 1.000\n",
      "test loss: 0.6471058, test acc: 1.000\n",
      "poison loss: 1.4618095, poison acc: 0.000\n",
      "elapsed time: 47.863, time for reg: 6.891, time for eig: 23.409\n",
      "epoch:   449, loss: 0.6435815, train acc: 1.000\n",
      "test loss: 0.5912923, test acc: 1.000\n",
      "poison loss: 1.5406981, poison acc: 0.000\n",
      "elapsed time: 48.779, time for reg: 7.044, time for eig: 23.796\n",
      "epoch:   459, loss: 0.6184493, train acc: 1.000\n",
      "test loss: 0.3859033, test acc: 1.000\n",
      "poison loss: 2.0453690, poison acc: 0.000\n",
      "elapsed time: 49.715, time for reg: 7.256, time for eig: 24.143\n",
      "epoch:   469, loss: 0.5951458, train acc: 1.000\n",
      "test loss: 0.5903820, test acc: 1.000\n",
      "poison loss: 1.5150570, poison acc: 0.000\n",
      "elapsed time: 50.449, time for reg: 7.404, time for eig: 24.356\n",
      "epoch:   479, loss: 0.6233485, train acc: 1.000\n",
      "test loss: 0.6335843, test acc: 1.000\n",
      "poison loss: 1.4584779, poison acc: 0.000\n",
      "elapsed time: 51.592, time for reg: 7.554, time for eig: 24.972\n",
      "epoch:   489, loss: 0.6677501, train acc: 1.000\n",
      "test loss: 0.6621203, test acc: 1.000\n",
      "poison loss: 1.4151543, poison acc: 0.000\n",
      "elapsed time: 52.768, time for reg: 7.701, time for eig: 25.633\n",
      "epoch:   499, loss: 0.6441999, train acc: 1.000\n",
      "test loss: 0.6431866, test acc: 1.000\n",
      "poison loss: 1.4364227, poison acc: 0.000\n",
      "elapsed time: 53.853, time for reg: 7.912, time for eig: 26.120\n",
      "epoch:   509, loss: 0.5893172, train acc: 1.000\n",
      "test loss: 0.6086950, test acc: 1.000\n",
      "poison loss: 1.4788169, poison acc: 0.000\n",
      "elapsed time: 55.415, time for reg: 8.062, time for eig: 27.066\n",
      "epoch:   519, loss: 0.6461088, train acc: 1.000\n",
      "test loss: 0.5548639, test acc: 1.000\n",
      "poison loss: 1.5491506, poison acc: 0.000\n",
      "elapsed time: 57.059, time for reg: 8.213, time for eig: 28.179\n",
      "epoch:   529, loss: 0.6501071, train acc: 1.000\n",
      "test loss: 0.5211940, test acc: 1.000\n",
      "poison loss: 1.6140541, poison acc: 0.017\n",
      "elapsed time: 58.134, time for reg: 8.363, time for eig: 28.649\n",
      "epoch:   539, loss: 0.5771765, train acc: 1.000\n",
      "test loss: 0.5864660, test acc: 1.000\n",
      "poison loss: 1.5077873, poison acc: 0.000\n",
      "elapsed time: 59.425, time for reg: 8.546, time for eig: 29.384\n",
      "epoch:   549, loss: 0.5609895, train acc: 1.000\n",
      "test loss: 0.5747395, test acc: 1.000\n",
      "poison loss: 1.5225611, poison acc: 0.017\n",
      "elapsed time: 60.266, time for reg: 8.696, time for eig: 29.699\n",
      "epoch:   559, loss: 0.5684522, train acc: 1.000\n",
      "test loss: 0.5785745, test acc: 1.000\n",
      "poison loss: 1.5123348, poison acc: 0.017\n",
      "elapsed time: 61.309, time for reg: 8.845, time for eig: 30.216\n",
      "epoch:   569, loss: 0.5541218, train acc: 1.000\n",
      "test loss: 0.5011348, test acc: 1.000\n",
      "poison loss: 1.6637424, poison acc: 0.017\n",
      "elapsed time: 62.365, time for reg: 8.994, time for eig: 30.747\n",
      "epoch:   579, loss: 0.4893604, train acc: 1.000\n",
      "test loss: 0.5241801, test acc: 1.000\n",
      "poison loss: 1.6101675, poison acc: 0.017\n",
      "elapsed time: 63.646, time for reg: 9.142, time for eig: 31.498\n",
      "epoch:   589, loss: 0.5617769, train acc: 1.000\n",
      "test loss: 0.5366875, test acc: 1.000\n",
      "poison loss: 1.5717555, poison acc: 0.017\n",
      "elapsed time: 64.760, time for reg: 9.292, time for eig: 32.083\n",
      "epoch:   599, loss: 0.6069131, train acc: 1.000\n",
      "test loss: 0.5998484, test acc: 1.000\n",
      "poison loss: 1.4804860, poison acc: 0.000\n",
      "elapsed time: 66.112, time for reg: 9.441, time for eig: 32.904\n",
      "epoch:   609, loss: 0.6242646, train acc: 1.000\n",
      "test loss: 0.6296869, test acc: 1.000\n",
      "poison loss: 1.4448557, poison acc: 0.000\n",
      "elapsed time: 67.380, time for reg: 9.591, time for eig: 33.641\n",
      "epoch:   619, loss: 0.6206223, train acc: 1.000\n",
      "test loss: 0.6254068, test acc: 1.000\n",
      "poison loss: 1.4494523, poison acc: 0.017\n",
      "elapsed time: 68.977, time for reg: 9.740, time for eig: 34.707\n",
      "epoch:   629, loss: 0.6365643, train acc: 1.000\n",
      "test loss: 0.6311937, test acc: 1.000\n",
      "poison loss: 1.4424369, poison acc: 0.017\n",
      "elapsed time: 70.671, time for reg: 9.888, time for eig: 35.847\n",
      "epoch:   639, loss: 0.5701565, train acc: 1.000\n",
      "test loss: 0.5332284, test acc: 1.000\n",
      "poison loss: 1.5887548, poison acc: 0.017\n",
      "elapsed time: 72.258, time for reg: 10.069, time for eig: 36.732\n",
      "epoch:   649, loss: 0.5719855, train acc: 1.000\n",
      "test loss: 0.5565786, test acc: 1.000\n",
      "poison loss: 1.5500247, poison acc: 0.017\n",
      "elapsed time: 74.006, time for reg: 10.220, time for eig: 37.929\n",
      "epoch:   659, loss: 0.5554104, train acc: 1.000\n",
      "test loss: 0.5682614, test acc: 1.000\n",
      "poison loss: 1.5279441, poison acc: 0.000\n",
      "elapsed time: 75.202, time for reg: 10.368, time for eig: 38.583\n",
      "epoch:   669, loss: 0.5825831, train acc: 1.000\n",
      "test loss: 0.5948989, test acc: 1.000\n",
      "poison loss: 1.4868104, poison acc: 0.017\n",
      "elapsed time: 76.361, time for reg: 10.518, time for eig: 39.206\n",
      "epoch:   679, loss: 0.5806831, train acc: 1.000\n",
      "test loss: 0.6009753, test acc: 1.000\n",
      "poison loss: 1.4780990, poison acc: 0.017\n",
      "elapsed time: 78.028, time for reg: 10.667, time for eig: 40.344\n",
      "epoch:   689, loss: 0.5800923, train acc: 1.000\n",
      "test loss: 0.4654225, test acc: 1.000\n",
      "poison loss: 1.7222873, poison acc: 0.017\n",
      "elapsed time: 79.212, time for reg: 10.814, time for eig: 40.984\n",
      "epoch:   699, loss: 0.6240959, train acc: 1.000\n",
      "test loss: 0.6326192, test acc: 1.000\n",
      "poison loss: 1.4335702, poison acc: 0.017\n",
      "elapsed time: 80.355, time for reg: 10.987, time for eig: 41.427\n",
      "epoch:   709, loss: 0.6450599, train acc: 1.000\n",
      "test loss: 0.6515971, test acc: 1.000\n",
      "poison loss: 1.4095155, poison acc: 0.017\n",
      "elapsed time: 82.703, time for reg: 11.136, time for eig: 43.128\n",
      "epoch:   719, loss: 0.6127601, train acc: 1.000\n",
      "test loss: 0.6155962, test acc: 1.000\n",
      "poison loss: 1.4507369, poison acc: 0.017\n",
      "elapsed time: 84.359, time for reg: 11.284, time for eig: 44.246\n",
      "epoch:   729, loss: 0.5827709, train acc: 1.000\n",
      "test loss: 0.5894780, test acc: 1.000\n",
      "poison loss: 1.4833385, poison acc: 0.017\n",
      "elapsed time: 85.822, time for reg: 11.565, time for eig: 44.943\n",
      "epoch:   739, loss: 0.5829411, train acc: 1.000\n",
      "test loss: 0.5986239, test acc: 1.000\n",
      "poison loss: 1.4683389, poison acc: 0.017\n",
      "elapsed time: 87.634, time for reg: 11.804, time for eig: 46.057\n",
      "epoch:   749, loss: 0.5702456, train acc: 1.000\n",
      "test loss: 0.5375960, test acc: 1.000\n",
      "poison loss: 1.5708049, poison acc: 0.017\n",
      "elapsed time: 89.354, time for reg: 11.952, time for eig: 47.237\n",
      "epoch:   759, loss: 0.5595836, train acc: 1.000\n",
      "test loss: 0.5708567, test acc: 1.000\n",
      "poison loss: 1.5066225, poison acc: 0.017\n",
      "elapsed time: 91.147, time for reg: 12.100, time for eig: 48.485\n",
      "epoch:   769, loss: 0.5775490, train acc: 1.000\n",
      "test loss: 0.5830174, test acc: 1.000\n",
      "poison loss: 1.4863480, poison acc: 0.017\n",
      "elapsed time: 92.212, time for reg: 12.276, time for eig: 48.989\n",
      "epoch:   779, loss: 0.5635551, train acc: 1.000\n",
      "test loss: 0.5688547, test acc: 1.000\n",
      "poison loss: 1.5110622, poison acc: 0.017\n",
      "elapsed time: 93.454, time for reg: 12.423, time for eig: 49.673\n",
      "epoch:   789, loss: 0.5884055, train acc: 1.000\n",
      "test loss: 0.5926592, test acc: 1.000\n",
      "poison loss: 1.4715051, poison acc: 0.017\n",
      "elapsed time: 94.538, time for reg: 12.570, time for eig: 50.231\n",
      "epoch:   799, loss: 0.5602918, train acc: 1.000\n",
      "test loss: 0.5785125, test acc: 1.000\n",
      "poison loss: 1.4894176, poison acc: 0.017\n",
      "elapsed time: 95.993, time for reg: 12.732, time for eig: 51.145\n",
      "epoch:   809, loss: 0.6218119, train acc: 1.000\n",
      "test loss: 0.6117545, test acc: 1.000\n",
      "poison loss: 1.4366966, poison acc: 0.017\n",
      "elapsed time: 96.882, time for reg: 12.883, time for eig: 51.492\n",
      "epoch:   819, loss: 0.5249374, train acc: 1.000\n",
      "test loss: 0.5425828, test acc: 1.000\n",
      "poison loss: 1.5385002, poison acc: 0.017\n",
      "elapsed time: 98.258, time for reg: 13.030, time for eig: 52.337\n",
      "epoch:   829, loss: 0.5738997, train acc: 1.000\n",
      "test loss: 0.5502003, test acc: 1.000\n",
      "poison loss: 1.5148703, poison acc: 0.017\n",
      "elapsed time: 99.657, time for reg: 13.230, time for eig: 53.071\n",
      "epoch:   839, loss: 0.6339699, train acc: 1.000\n",
      "test loss: 0.6094402, test acc: 1.000\n",
      "poison loss: 1.4324493, poison acc: 0.017\n",
      "elapsed time: 101.221, time for reg: 13.417, time for eig: 54.051\n",
      "epoch:   849, loss: 0.5718615, train acc: 1.000\n",
      "test loss: 0.5842130, test acc: 1.000\n",
      "poison loss: 1.4609004, poison acc: 0.017\n",
      "elapsed time: 102.535, time for reg: 13.657, time for eig: 54.562\n",
      "epoch:   859, loss: 0.5746500, train acc: 1.000\n",
      "test loss: 0.5791647, test acc: 1.000\n",
      "poison loss: 1.4650774, poison acc: 0.017\n",
      "elapsed time: 103.779, time for reg: 13.859, time for eig: 55.005\n",
      "epoch:   869, loss: 0.6384006, train acc: 1.000\n",
      "test loss: 0.6366217, test acc: 1.000\n",
      "poison loss: 1.3838462, poison acc: 0.017\n",
      "elapsed time: 105.197, time for reg: 14.097, time for eig: 55.697\n",
      "epoch:   879, loss: 0.6190315, train acc: 1.000\n",
      "test loss: 0.6010996, test acc: 1.000\n",
      "poison loss: 1.4229668, poison acc: 0.017\n",
      "elapsed time: 106.249, time for reg: 14.245, time for eig: 56.180\n",
      "epoch:   889, loss: 0.6128301, train acc: 1.000\n",
      "test loss: 0.5918137, test acc: 1.000\n",
      "poison loss: 1.4330980, poison acc: 0.017\n",
      "elapsed time: 107.962, time for reg: 14.392, time for eig: 57.291\n",
      "epoch:   899, loss: 0.5988067, train acc: 1.000\n",
      "test loss: 0.6096388, test acc: 1.000\n",
      "poison loss: 1.4009232, poison acc: 0.017\n",
      "elapsed time: 108.971, time for reg: 14.539, time for eig: 57.767\n",
      "epoch:   909, loss: 0.6073884, train acc: 1.000\n",
      "test loss: 0.6309091, test acc: 1.000\n",
      "poison loss: 1.3667135, poison acc: 0.017\n",
      "elapsed time: 110.257, time for reg: 14.704, time for eig: 58.476\n",
      "epoch:   919, loss: 0.6100869, train acc: 1.000\n",
      "test loss: 0.6191233, test acc: 1.000\n",
      "poison loss: 1.3796611, poison acc: 0.017\n",
      "elapsed time: 111.194, time for reg: 14.851, time for eig: 58.847\n",
      "epoch:   929, loss: 0.6199313, train acc: 1.000\n",
      "test loss: 0.6243653, test acc: 1.000\n",
      "poison loss: 1.3669749, poison acc: 0.017\n",
      "elapsed time: 112.365, time for reg: 14.997, time for eig: 59.500\n",
      "epoch:   939, loss: 0.6564382, train acc: 1.000\n",
      "test loss: 0.6632123, test acc: 1.000\n",
      "poison loss: 1.3433490, poison acc: 0.017\n",
      "elapsed time: 113.728, time for reg: 15.142, time for eig: 60.356\n",
      "epoch:   949, loss: 0.6002944, train acc: 1.000\n",
      "test loss: 0.6117526, test acc: 1.000\n",
      "poison loss: 1.3841453, poison acc: 0.017\n",
      "elapsed time: 114.630, time for reg: 15.314, time for eig: 60.692\n",
      "epoch:   959, loss: 0.6213000, train acc: 1.000\n",
      "test loss: 0.6165331, test acc: 1.000\n",
      "poison loss: 1.3766905, poison acc: 0.017\n",
      "elapsed time: 116.092, time for reg: 15.462, time for eig: 61.625\n",
      "epoch:   969, loss: 0.5943973, train acc: 1.000\n",
      "test loss: 0.6103740, test acc: 1.000\n",
      "poison loss: 1.3763528, poison acc: 0.017\n",
      "elapsed time: 116.996, time for reg: 15.613, time for eig: 61.999\n",
      "epoch:   979, loss: 0.5922450, train acc: 1.000\n",
      "test loss: 0.6246617, test acc: 1.000\n",
      "poison loss: 1.3520840, poison acc: 0.017\n",
      "elapsed time: 118.211, time for reg: 15.757, time for eig: 62.692\n",
      "epoch:   989, loss: 0.6675710, train acc: 1.000\n",
      "test loss: 0.6729861, test acc: 1.000\n",
      "poison loss: 1.3406093, poison acc: 0.017\n",
      "elapsed time: 119.458, time for reg: 15.902, time for eig: 63.414\n",
      "epoch:   999, loss: 0.6240743, train acc: 1.000\n",
      "test loss: 0.6338098, test acc: 1.000\n",
      "poison loss: 1.3703126, poison acc: 0.017\n",
      "elapsed time: 120.889, time for reg: 16.047, time for eig: 64.323\n",
      "epoch:  1009, loss: 0.5376388, train acc: 1.000\n",
      "test loss: 0.5416580, test acc: 1.000\n",
      "poison loss: 1.4806193, poison acc: 0.017\n",
      "elapsed time: 122.000, time for reg: 16.191, time for eig: 64.912\n",
      "epoch:  1019, loss: 0.6178105, train acc: 1.000\n",
      "test loss: 0.6250511, test acc: 1.000\n",
      "poison loss: 1.3633170, poison acc: 0.017\n",
      "elapsed time: 123.566, time for reg: 16.335, time for eig: 65.957\n",
      "epoch:  1029, loss: 0.5685763, train acc: 1.000\n",
      "test loss: 0.5960422, test acc: 1.000\n",
      "poison loss: 1.3912917, poison acc: 0.017\n",
      "elapsed time: 125.251, time for reg: 16.479, time for eig: 67.124\n",
      "epoch:  1039, loss: 0.5849529, train acc: 1.000\n",
      "test loss: 0.5053118, test acc: 1.000\n",
      "poison loss: 1.5760794, poison acc: 0.017\n",
      "elapsed time: 126.392, time for reg: 16.621, time for eig: 67.678\n",
      "epoch:  1049, loss: 0.6203260, train acc: 1.000\n",
      "test loss: 0.6112171, test acc: 1.000\n",
      "poison loss: 1.3614992, poison acc: 0.017\n",
      "elapsed time: 127.658, time for reg: 16.762, time for eig: 68.431\n",
      "epoch:  1059, loss: 0.5690497, train acc: 1.000\n",
      "test loss: 0.6023158, test acc: 1.000\n",
      "poison loss: 1.3681007, poison acc: 0.017\n",
      "elapsed time: 128.928, time for reg: 16.905, time for eig: 69.180\n",
      "epoch:  1069, loss: 0.6054969, train acc: 1.000\n",
      "test loss: 0.6250826, test acc: 1.000\n",
      "poison loss: 1.3586501, poison acc: 0.017\n",
      "elapsed time: 130.263, time for reg: 17.049, time for eig: 69.993\n",
      "epoch:  1079, loss: 0.5891794, train acc: 1.000\n",
      "test loss: 0.6113089, test acc: 1.000\n",
      "poison loss: 1.3643001, poison acc: 0.017\n",
      "elapsed time: 131.335, time for reg: 17.192, time for eig: 70.549\n",
      "epoch:  1089, loss: 0.5155054, train acc: 1.000\n",
      "test loss: 0.5757887, test acc: 1.000\n",
      "poison loss: 1.4105772, poison acc: 0.017\n",
      "elapsed time: 132.257, time for reg: 17.337, time for eig: 70.949\n",
      "epoch:  1099, loss: 0.5937831, train acc: 1.000\n",
      "test loss: 0.5148333, test acc: 1.000\n",
      "poison loss: 1.5050445, poison acc: 0.017\n",
      "elapsed time: 133.219, time for reg: 17.482, time for eig: 71.392\n",
      "epoch:  1109, loss: 0.6263006, train acc: 1.000\n",
      "test loss: 0.6357119, test acc: 1.000\n",
      "poison loss: 1.3303010, poison acc: 0.017\n",
      "elapsed time: 134.594, time for reg: 17.660, time for eig: 72.153\n",
      "epoch:  1119, loss: 0.6134087, train acc: 1.000\n",
      "test loss: 0.5731238, test acc: 1.000\n",
      "poison loss: 1.4043261, poison acc: 0.017\n",
      "elapsed time: 136.127, time for reg: 17.804, time for eig: 73.164\n",
      "epoch:  1129, loss: 0.6085769, train acc: 1.000\n",
      "test loss: 0.5972388, test acc: 1.000\n",
      "poison loss: 1.3681338, poison acc: 0.017\n",
      "elapsed time: 136.880, time for reg: 17.949, time for eig: 73.395\n",
      "epoch:  1139, loss: 0.6246459, train acc: 1.000\n",
      "test loss: 0.6218168, test acc: 1.000\n",
      "poison loss: 1.3354709, poison acc: 0.017\n",
      "elapsed time: 137.850, time for reg: 18.094, time for eig: 73.842\n",
      "epoch:  1149, loss: 0.5544678, train acc: 1.000\n",
      "test loss: 0.5738261, test acc: 1.000\n",
      "poison loss: 1.3983092, poison acc: 0.033\n",
      "elapsed time: 138.863, time for reg: 18.236, time for eig: 74.340\n",
      "epoch:  1159, loss: 0.5496492, train acc: 1.000\n",
      "test loss: 0.5693371, test acc: 1.000\n",
      "poison loss: 1.4133197, poison acc: 0.017\n",
      "elapsed time: 139.751, time for reg: 18.379, time for eig: 74.717\n",
      "epoch:  1169, loss: 0.4422282, train acc: 1.000\n",
      "test loss: 0.5232737, test acc: 1.000\n",
      "poison loss: 1.5120506, poison acc: 0.017\n",
      "elapsed time: 140.561, time for reg: 18.522, time for eig: 75.011\n",
      "epoch:  1179, loss: 0.5394620, train acc: 1.000\n",
      "test loss: 0.5519675, test acc: 1.000\n",
      "poison loss: 1.4229314, poison acc: 0.017\n",
      "elapsed time: 141.801, time for reg: 18.698, time for eig: 75.662\n",
      "epoch:  1189, loss: 0.5574973, train acc: 1.000\n",
      "test loss: 0.5744956, test acc: 1.000\n",
      "poison loss: 1.3949919, poison acc: 0.017\n",
      "elapsed time: 142.810, time for reg: 18.840, time for eig: 76.054\n",
      "epoch:  1199, loss: 0.5351759, train acc: 1.000\n",
      "test loss: 0.5629183, test acc: 1.000\n",
      "poison loss: 1.4124950, poison acc: 0.017\n",
      "elapsed time: 143.644, time for reg: 18.985, time for eig: 76.372\n",
      "epoch:  1209, loss: 0.6246054, train acc: 1.000\n",
      "test loss: 0.6224479, test acc: 1.000\n",
      "poison loss: 1.3232788, poison acc: 0.017\n",
      "elapsed time: 144.780, time for reg: 19.130, time for eig: 76.989\n",
      "epoch:  1219, loss: 0.4999642, train acc: 1.000\n",
      "test loss: 0.5374597, test acc: 1.000\n",
      "poison loss: 1.4298489, poison acc: 0.017\n",
      "elapsed time: 145.659, time for reg: 19.272, time for eig: 77.352\n",
      "epoch:  1229, loss: 0.5075226, train acc: 1.000\n",
      "test loss: 0.5675462, test acc: 1.000\n",
      "poison loss: 1.4148607, poison acc: 0.017\n",
      "elapsed time: 146.681, time for reg: 19.447, time for eig: 77.796\n",
      "epoch:  1239, loss: 0.5954019, train acc: 1.000\n",
      "test loss: 0.5910128, test acc: 1.000\n",
      "poison loss: 1.3848580, poison acc: 0.033\n",
      "elapsed time: 147.744, time for reg: 19.605, time for eig: 78.312\n",
      "epoch:  1249, loss: 0.5030179, train acc: 1.000\n",
      "test loss: 0.5458434, test acc: 1.000\n",
      "poison loss: 1.4437188, poison acc: 0.017\n",
      "elapsed time: 149.059, time for reg: 19.748, time for eig: 79.114\n",
      "epoch:  1259, loss: 0.5769321, train acc: 0.983\n",
      "test loss: 0.5430884, test acc: 1.000\n",
      "poison loss: 1.4347948, poison acc: 0.017\n",
      "elapsed time: 149.991, time for reg: 19.891, time for eig: 79.533\n",
      "epoch:  1269, loss: 0.5131522, train acc: 1.000\n",
      "test loss: 0.5486030, test acc: 1.000\n",
      "poison loss: 1.4149015, poison acc: 0.017\n",
      "elapsed time: 150.775, time for reg: 20.032, time for eig: 79.792\n",
      "epoch:  1279, loss: 0.5449081, train acc: 1.000\n",
      "test loss: 0.5664546, test acc: 1.000\n",
      "poison loss: 1.3965318, poison acc: 0.017\n",
      "elapsed time: 151.706, time for reg: 20.237, time for eig: 80.149\n",
      "epoch:  1289, loss: 0.5981170, train acc: 1.000\n",
      "test loss: 0.6371161, test acc: 1.000\n",
      "poison loss: 1.3362683, poison acc: 0.017\n",
      "elapsed time: 152.458, time for reg: 20.380, time for eig: 80.400\n",
      "epoch:  1299, loss: 0.5745089, train acc: 1.000\n",
      "test loss: 0.6070565, test acc: 1.000\n",
      "poison loss: 1.3415629, poison acc: 0.017\n",
      "elapsed time: 153.741, time for reg: 20.523, time for eig: 81.169\n",
      "epoch:  1309, loss: 0.5969915, train acc: 1.000\n",
      "test loss: 0.6177411, test acc: 1.000\n",
      "poison loss: 1.3255104, poison acc: 0.017\n",
      "elapsed time: 155.284, time for reg: 20.668, time for eig: 82.197\n",
      "epoch:  1319, loss: 0.5987044, train acc: 1.000\n",
      "test loss: 0.6195249, test acc: 0.933\n",
      "poison loss: 1.3241151, poison acc: 0.050\n",
      "elapsed time: 156.254, time for reg: 20.815, time for eig: 82.647\n",
      "epoch:  1329, loss: 0.5404133, train acc: 1.000\n",
      "test loss: 0.4029718, test acc: 1.000\n",
      "poison loss: 1.7574220, poison acc: 0.017\n",
      "elapsed time: 157.075, time for reg: 20.957, time for eig: 82.964\n",
      "epoch:  1339, loss: 0.6167035, train acc: 0.950\n",
      "test loss: 0.5201002, test acc: 1.000\n",
      "poison loss: 1.4607698, poison acc: 0.017\n",
      "elapsed time: 158.185, time for reg: 21.101, time for eig: 83.560\n",
      "epoch:  1349, loss: 0.6219407, train acc: 0.950\n",
      "test loss: 0.6439268, test acc: 0.900\n",
      "poison loss: 1.2911488, poison acc: 0.150\n",
      "elapsed time: 159.138, time for reg: 21.246, time for eig: 83.997\n",
      "epoch:  1359, loss: 0.5483189, train acc: 1.000\n",
      "test loss: 0.5728703, test acc: 1.000\n",
      "poison loss: 1.3727476, poison acc: 0.050\n",
      "elapsed time: 160.157, time for reg: 21.390, time for eig: 84.499\n",
      "epoch:  1369, loss: 0.5634285, train acc: 1.000\n",
      "test loss: 0.5780984, test acc: 1.000\n",
      "poison loss: 1.3664486, poison acc: 0.050\n",
      "elapsed time: 161.018, time for reg: 21.532, time for eig: 84.861\n",
      "epoch:  1379, loss: 0.5927192, train acc: 1.000\n",
      "test loss: 0.6005448, test acc: 1.000\n",
      "poison loss: 1.3458833, poison acc: 0.050\n",
      "elapsed time: 162.744, time for reg: 21.676, time for eig: 86.004\n",
      "epoch:  1389, loss: 0.6067380, train acc: 1.000\n",
      "test loss: 0.6263565, test acc: 1.000\n",
      "poison loss: 1.3086050, poison acc: 0.050\n",
      "elapsed time: 164.451, time for reg: 21.819, time for eig: 87.198\n",
      "epoch:  1399, loss: 0.5491302, train acc: 1.000\n",
      "test loss: 0.5723799, test acc: 1.000\n",
      "poison loss: 1.3735645, poison acc: 0.050\n",
      "elapsed time: 165.928, time for reg: 21.964, time for eig: 88.154\n",
      "epoch:  1409, loss: 0.5535565, train acc: 1.000\n",
      "test loss: 0.5534789, test acc: 1.000\n",
      "poison loss: 1.4091606, poison acc: 0.050\n",
      "elapsed time: 167.037, time for reg: 22.109, time for eig: 88.748\n",
      "epoch:  1419, loss: 0.6112388, train acc: 0.967\n",
      "test loss: 0.6322477, test acc: 0.933\n",
      "poison loss: 1.2996042, poison acc: 0.133\n",
      "elapsed time: 168.109, time for reg: 22.255, time for eig: 89.300\n",
      "epoch:  1429, loss: 0.6226323, train acc: 0.983\n",
      "test loss: 0.6238508, test acc: 1.000\n",
      "poison loss: 1.3090024, poison acc: 0.050\n",
      "elapsed time: 169.660, time for reg: 22.402, time for eig: 90.324\n",
      "epoch:  1439, loss: 0.5469840, train acc: 0.933\n",
      "test loss: 0.5883825, test acc: 0.900\n",
      "poison loss: 1.3501666, poison acc: 0.167\n",
      "elapsed time: 170.717, time for reg: 22.547, time for eig: 90.867\n",
      "epoch:  1449, loss: 0.4537488, train acc: 1.000\n",
      "test loss: 0.4824088, test acc: 1.000\n",
      "poison loss: 1.5162182, poison acc: 0.017\n",
      "elapsed time: 171.662, time for reg: 22.693, time for eig: 91.288\n",
      "epoch:  1459, loss: 0.6006703, train acc: 0.950\n",
      "test loss: 0.6298510, test acc: 0.900\n",
      "poison loss: 1.2998030, poison acc: 0.167\n",
      "elapsed time: 172.847, time for reg: 22.839, time for eig: 91.949\n",
      "epoch:  1469, loss: 0.4152499, train acc: 1.000\n",
      "test loss: 0.4515916, test acc: 1.000\n",
      "poison loss: 1.5684029, poison acc: 0.067\n",
      "elapsed time: 173.898, time for reg: 22.985, time for eig: 92.474\n",
      "epoch:  1479, loss: 0.5747262, train acc: 1.000\n",
      "test loss: 0.6093518, test acc: 1.000\n",
      "poison loss: 1.3357284, poison acc: 0.050\n",
      "elapsed time: 174.851, time for reg: 23.176, time for eig: 92.835\n",
      "epoch:  1489, loss: 0.6244211, train acc: 0.967\n",
      "test loss: 0.5997355, test acc: 1.000\n",
      "poison loss: 1.3378118, poison acc: 0.067\n",
      "elapsed time: 175.933, time for reg: 23.320, time for eig: 93.402\n",
      "epoch:  1499, loss: 0.6135045, train acc: 0.950\n",
      "test loss: 0.5375034, test acc: 1.000\n",
      "poison loss: 1.4238041, poison acc: 0.050\n",
      "elapsed time: 177.279, time for reg: 23.466, time for eig: 94.223\n",
      "epoch:  1509, loss: 0.4415873, train acc: 0.967\n",
      "test loss: 0.6191535, test acc: 0.917\n",
      "poison loss: 1.3103943, poison acc: 0.150\n",
      "elapsed time: 178.023, time for reg: 23.611, time for eig: 94.448\n",
      "epoch:  1519, loss: 0.3727278, train acc: 1.000\n",
      "test loss: 0.4720202, test acc: 1.000\n",
      "poison loss: 1.5291611, poison acc: 0.033\n",
      "elapsed time: 178.818, time for reg: 23.755, time for eig: 94.731\n",
      "epoch:  1529, loss: 0.5633177, train acc: 1.000\n",
      "test loss: 0.5936235, test acc: 0.950\n",
      "poison loss: 1.3345813, poison acc: 0.050\n",
      "elapsed time: 179.780, time for reg: 23.900, time for eig: 95.111\n",
      "epoch:  1539, loss: 0.4333797, train acc: 1.000\n",
      "test loss: 0.4975700, test acc: 1.000\n",
      "poison loss: 1.4598494, poison acc: 0.067\n",
      "elapsed time: 181.191, time for reg: 24.042, time for eig: 96.008\n",
      "epoch:  1549, loss: 0.5255335, train acc: 1.000\n",
      "test loss: 0.5080075, test acc: 1.000\n",
      "poison loss: 1.4499461, poison acc: 0.050\n",
      "elapsed time: 181.963, time for reg: 24.188, time for eig: 96.257\n",
      "epoch:  1559, loss: 0.5943416, train acc: 0.933\n",
      "test loss: 0.6050197, test acc: 0.917\n",
      "poison loss: 1.3221442, poison acc: 0.150\n",
      "elapsed time: 182.973, time for reg: 24.333, time for eig: 96.744\n",
      "epoch:  1569, loss: 0.5821010, train acc: 1.000\n",
      "test loss: 0.6113059, test acc: 1.000\n",
      "poison loss: 1.3387737, poison acc: 0.033\n",
      "elapsed time: 184.380, time for reg: 24.481, time for eig: 97.612\n",
      "epoch:  1579, loss: 0.5152192, train acc: 1.000\n",
      "test loss: 0.5552798, test acc: 1.000\n",
      "poison loss: 1.3851090, poison acc: 0.050\n",
      "elapsed time: 185.873, time for reg: 24.636, time for eig: 98.551\n",
      "epoch:  1589, loss: 0.5125687, train acc: 0.983\n",
      "test loss: 0.5397435, test acc: 0.967\n",
      "poison loss: 1.4576572, poison acc: 0.083\n",
      "elapsed time: 187.000, time for reg: 24.786, time for eig: 99.136\n",
      "epoch:  1599, loss: 0.5872902, train acc: 0.950\n",
      "test loss: 0.3653773, test acc: 1.000\n",
      "poison loss: 1.7943073, poison acc: 0.033\n",
      "elapsed time: 187.843, time for reg: 24.935, time for eig: 99.443\n",
      "epoch:  1609, loss: 0.5756454, train acc: 1.000\n",
      "test loss: 0.5992455, test acc: 1.000\n",
      "poison loss: 1.3564574, poison acc: 0.050\n",
      "elapsed time: 188.801, time for reg: 25.085, time for eig: 99.840\n",
      "epoch:  1619, loss: 0.5279320, train acc: 1.000\n",
      "test loss: 0.5648114, test acc: 1.000\n",
      "poison loss: 1.3837761, poison acc: 0.067\n",
      "elapsed time: 190.426, time for reg: 25.235, time for eig: 100.924\n",
      "epoch:  1629, loss: 0.4876616, train acc: 1.000\n",
      "test loss: 0.5495740, test acc: 1.000\n",
      "poison loss: 1.3936287, poison acc: 0.050\n",
      "elapsed time: 191.630, time for reg: 25.416, time for eig: 101.555\n",
      "epoch:  1639, loss: 0.4316065, train acc: 0.950\n",
      "test loss: 0.4828285, test acc: 1.000\n",
      "poison loss: 1.5110989, poison acc: 0.017\n",
      "elapsed time: 192.555, time for reg: 25.565, time for eig: 101.876\n",
      "epoch:  1649, loss: 0.4593433, train acc: 1.000\n",
      "test loss: 0.3238760, test acc: 1.000\n",
      "poison loss: 1.9650028, poison acc: 0.033\n",
      "elapsed time: 193.906, time for reg: 25.713, time for eig: 102.713\n",
      "epoch:  1659, loss: 0.5518023, train acc: 1.000\n",
      "test loss: 0.5843329, test acc: 1.000\n",
      "poison loss: 1.3502703, poison acc: 0.050\n",
      "elapsed time: 195.044, time for reg: 25.863, time for eig: 103.296\n",
      "epoch:  1669, loss: 0.5087988, train acc: 1.000\n",
      "test loss: 0.5310116, test acc: 1.000\n",
      "poison loss: 1.4219598, poison acc: 0.050\n",
      "elapsed time: 196.219, time for reg: 26.012, time for eig: 103.940\n",
      "epoch:  1679, loss: 0.5003585, train acc: 1.000\n",
      "test loss: 0.5376613, test acc: 1.000\n",
      "poison loss: 1.4106426, poison acc: 0.050\n",
      "elapsed time: 196.980, time for reg: 26.161, time for eig: 104.161\n",
      "epoch:  1689, loss: 0.5183342, train acc: 1.000\n",
      "test loss: 0.5447531, test acc: 0.950\n",
      "poison loss: 1.4010267, poison acc: 0.067\n",
      "elapsed time: 198.040, time for reg: 26.343, time for eig: 104.645\n",
      "epoch:  1699, loss: 0.5926550, train acc: 1.000\n",
      "test loss: 0.5930792, test acc: 1.000\n",
      "poison loss: 1.3395373, poison acc: 0.050\n",
      "elapsed time: 199.277, time for reg: 26.524, time for eig: 105.312\n",
      "epoch:  1709, loss: 0.5641473, train acc: 1.000\n",
      "test loss: 0.5757028, test acc: 1.000\n",
      "poison loss: 1.3508877, poison acc: 0.050\n",
      "elapsed time: 200.295, time for reg: 26.676, time for eig: 105.737\n",
      "epoch:  1719, loss: 0.5917714, train acc: 0.933\n",
      "test loss: 0.6230485, test acc: 0.900\n",
      "poison loss: 1.2975608, poison acc: 0.183\n",
      "elapsed time: 202.255, time for reg: 26.824, time for eig: 107.155\n",
      "epoch:  1729, loss: 0.5748895, train acc: 0.933\n",
      "test loss: 0.5609019, test acc: 0.933\n",
      "poison loss: 1.3737034, poison acc: 0.100\n",
      "elapsed time: 203.618, time for reg: 26.976, time for eig: 107.991\n",
      "epoch:  1739, loss: 0.5636235, train acc: 0.933\n",
      "test loss: 0.6014644, test acc: 0.900\n",
      "poison loss: 1.3203479, poison acc: 0.167\n",
      "elapsed time: 204.548, time for reg: 27.125, time for eig: 108.380\n",
      "epoch:  1749, loss: 0.5835693, train acc: 0.933\n",
      "test loss: 0.5978519, test acc: 1.000\n",
      "poison loss: 1.3276951, poison acc: 0.050\n",
      "elapsed time: 205.534, time for reg: 27.307, time for eig: 108.724\n",
      "epoch:  1759, loss: 0.6159350, train acc: 0.950\n",
      "test loss: 0.6546228, test acc: 0.917\n",
      "poison loss: 1.2621288, poison acc: 0.150\n",
      "elapsed time: 206.452, time for reg: 27.456, time for eig: 109.097\n",
      "epoch:  1769, loss: 0.5521648, train acc: 0.933\n",
      "test loss: 0.5326461, test acc: 0.900\n",
      "poison loss: 1.4430170, poison acc: 0.150\n",
      "elapsed time: 207.528, time for reg: 27.606, time for eig: 109.635\n",
      "epoch:  1779, loss: 0.5813945, train acc: 0.967\n",
      "test loss: 0.4457855, test acc: 1.000\n",
      "poison loss: 1.5837183, poison acc: 0.050\n",
      "elapsed time: 209.351, time for reg: 27.754, time for eig: 110.916\n",
      "epoch:  1789, loss: 0.5916907, train acc: 0.933\n",
      "test loss: 0.5946445, test acc: 0.900\n",
      "poison loss: 1.3236906, poison acc: 0.150\n",
      "elapsed time: 210.361, time for reg: 27.903, time for eig: 111.385\n",
      "epoch:  1799, loss: 0.5843011, train acc: 0.967\n",
      "test loss: 0.6036631, test acc: 0.917\n",
      "poison loss: 1.3165634, poison acc: 0.150\n",
      "elapsed time: 211.217, time for reg: 28.052, time for eig: 111.699\n",
      "epoch:  1809, loss: 0.5328625, train acc: 0.950\n",
      "test loss: 0.5818221, test acc: 0.900\n",
      "poison loss: 1.3454206, poison acc: 0.150\n",
      "elapsed time: 212.221, time for reg: 28.201, time for eig: 112.164\n",
      "epoch:  1819, loss: 0.5853089, train acc: 1.000\n",
      "test loss: 0.5885071, test acc: 1.000\n",
      "poison loss: 1.3356409, poison acc: 0.050\n",
      "elapsed time: 213.151, time for reg: 28.386, time for eig: 112.444\n",
      "epoch:  1829, loss: 0.5299045, train acc: 1.000\n",
      "test loss: 0.5593168, test acc: 1.000\n",
      "poison loss: 1.3677045, poison acc: 0.050\n",
      "elapsed time: 214.016, time for reg: 28.535, time for eig: 112.768\n",
      "epoch:  1839, loss: 0.5991116, train acc: 1.000\n",
      "test loss: 0.6003245, test acc: 0.983\n",
      "poison loss: 1.3183653, poison acc: 0.100\n",
      "elapsed time: 215.458, time for reg: 28.687, time for eig: 113.660\n",
      "epoch:  1849, loss: 0.5848477, train acc: 0.933\n",
      "test loss: 0.5733317, test acc: 0.883\n",
      "poison loss: 1.3587136, poison acc: 0.183\n",
      "elapsed time: 216.441, time for reg: 28.832, time for eig: 114.118\n",
      "epoch:  1859, loss: 0.5795116, train acc: 0.933\n",
      "test loss: 0.5743347, test acc: 1.000\n",
      "poison loss: 1.3700966, poison acc: 0.050\n",
      "elapsed time: 217.147, time for reg: 28.978, time for eig: 114.301\n",
      "epoch:  1869, loss: 0.5169503, train acc: 0.983\n",
      "test loss: 0.5636221, test acc: 0.967\n",
      "poison loss: 1.3589097, poison acc: 0.150\n",
      "elapsed time: 218.269, time for reg: 29.149, time for eig: 114.835\n",
      "epoch:  1879, loss: 0.6065955, train acc: 0.950\n",
      "test loss: 0.6168535, test acc: 0.900\n",
      "poison loss: 1.2949759, poison acc: 0.150\n",
      "elapsed time: 219.389, time for reg: 29.295, time for eig: 115.426\n",
      "epoch:  1889, loss: 0.5953142, train acc: 0.950\n",
      "test loss: 0.3854133, test acc: 1.000\n",
      "poison loss: 1.7460276, poison acc: 0.033\n",
      "elapsed time: 220.472, time for reg: 29.440, time for eig: 115.982\n",
      "epoch:  1899, loss: 0.6269347, train acc: 0.933\n",
      "test loss: 0.5722253, test acc: 0.883\n",
      "poison loss: 1.3629612, poison acc: 0.183\n",
      "elapsed time: 221.458, time for reg: 29.586, time for eig: 116.443\n",
      "epoch:  1909, loss: 0.5613137, train acc: 0.933\n",
      "test loss: 0.6043878, test acc: 0.883\n",
      "poison loss: 1.3121201, poison acc: 0.183\n",
      "elapsed time: 222.806, time for reg: 29.731, time for eig: 117.262\n",
      "epoch:  1919, loss: 0.5646991, train acc: 0.933\n",
      "test loss: 0.5462811, test acc: 0.900\n",
      "poison loss: 1.3851851, poison acc: 0.200\n",
      "elapsed time: 223.961, time for reg: 29.878, time for eig: 117.868\n",
      "epoch:  1929, loss: 0.6195787, train acc: 0.933\n",
      "test loss: 0.6136749, test acc: 0.883\n",
      "poison loss: 1.3068555, poison acc: 0.200\n",
      "elapsed time: 225.017, time for reg: 30.025, time for eig: 118.368\n",
      "epoch:  1939, loss: 0.6022993, train acc: 0.950\n",
      "test loss: 0.6199942, test acc: 0.983\n",
      "poison loss: 1.2890435, poison acc: 0.100\n",
      "elapsed time: 226.297, time for reg: 30.205, time for eig: 119.070\n",
      "epoch:  1949, loss: 0.5996529, train acc: 0.933\n",
      "test loss: 0.6251626, test acc: 0.900\n",
      "poison loss: 1.2832796, poison acc: 0.183\n",
      "elapsed time: 227.411, time for reg: 30.406, time for eig: 119.598\n",
      "epoch:  1959, loss: 0.6010592, train acc: 0.933\n",
      "test loss: 0.6291803, test acc: 0.900\n",
      "poison loss: 1.2786632, poison acc: 0.183\n",
      "elapsed time: 228.549, time for reg: 30.603, time for eig: 120.157\n",
      "epoch:  1969, loss: 0.5796215, train acc: 0.933\n",
      "test loss: 0.6035940, test acc: 0.883\n",
      "poison loss: 1.3114668, poison acc: 0.150\n",
      "elapsed time: 229.951, time for reg: 30.780, time for eig: 120.971\n",
      "epoch:  1979, loss: 0.6053945, train acc: 0.983\n",
      "test loss: 0.5624021, test acc: 0.967\n",
      "poison loss: 1.3643942, poison acc: 0.117\n",
      "elapsed time: 230.932, time for reg: 30.926, time for eig: 121.399\n",
      "epoch:  1989, loss: 0.5875743, train acc: 0.917\n",
      "test loss: 0.6076610, test acc: 0.883\n",
      "poison loss: 1.3011024, poison acc: 0.183\n",
      "elapsed time: 231.684, time for reg: 31.071, time for eig: 121.625\n",
      "epoch:  1999, loss: 0.5971546, train acc: 0.917\n",
      "test loss: 0.6218737, test acc: 0.900\n",
      "poison loss: 1.2850687, poison acc: 0.150\n",
      "elapsed time: 232.913, time for reg: 31.217, time for eig: 122.327\n",
      "epoch:  2009, loss: 0.6117095, train acc: 0.933\n",
      "test loss: 0.6361863, test acc: 0.900\n",
      "poison loss: 1.2682745, poison acc: 0.183\n",
      "elapsed time: 233.702, time for reg: 31.361, time for eig: 122.597\n",
      "epoch:  2019, loss: 0.5687902, train acc: 0.917\n",
      "test loss: 0.6222625, test acc: 0.883\n",
      "poison loss: 1.2817434, poison acc: 0.183\n",
      "elapsed time: 234.451, time for reg: 31.565, time for eig: 122.755\n",
      "epoch:  2029, loss: 0.5845677, train acc: 0.933\n",
      "test loss: 0.5862662, test acc: 0.900\n",
      "poison loss: 1.3287464, poison acc: 0.183\n",
      "elapsed time: 235.227, time for reg: 31.708, time for eig: 123.004\n",
      "epoch:  2039, loss: 0.5842930, train acc: 0.950\n",
      "test loss: 0.5868662, test acc: 0.917\n",
      "poison loss: 1.3282630, poison acc: 0.150\n",
      "elapsed time: 236.376, time for reg: 31.853, time for eig: 123.555\n",
      "epoch:  2049, loss: 0.4725027, train acc: 1.000\n",
      "test loss: 0.3500949, test acc: 0.983\n",
      "poison loss: 1.8804122, poison acc: 0.083\n",
      "elapsed time: 237.249, time for reg: 31.999, time for eig: 123.898\n",
      "epoch:  2059, loss: 0.4771717, train acc: 0.983\n",
      "test loss: 0.4252506, test acc: 1.000\n",
      "poison loss: 1.5965768, poison acc: 0.067\n",
      "elapsed time: 238.261, time for reg: 32.144, time for eig: 124.384\n",
      "epoch:  2069, loss: 0.4479068, train acc: 1.000\n",
      "test loss: 0.3800365, test acc: 1.000\n",
      "poison loss: 1.7673110, poison acc: 0.017\n",
      "elapsed time: 239.854, time for reg: 32.289, time for eig: 125.448\n",
      "epoch:  2079, loss: 0.6083033, train acc: 0.933\n",
      "test loss: 0.5767342, test acc: 0.883\n",
      "poison loss: 1.3461406, poison acc: 0.183\n",
      "elapsed time: 240.755, time for reg: 32.434, time for eig: 125.823\n",
      "epoch:  2089, loss: 0.3914724, train acc: 1.000\n",
      "test loss: 0.4162135, test acc: 1.000\n",
      "poison loss: 1.6269589, poison acc: 0.033\n",
      "elapsed time: 241.707, time for reg: 32.580, time for eig: 126.139\n",
      "epoch:  2099, loss: 0.3301325, train acc: 1.000\n",
      "test loss: 0.3662682, test acc: 1.000\n",
      "poison loss: 1.7484699, poison acc: 0.067\n",
      "elapsed time: 242.633, time for reg: 32.727, time for eig: 126.378\n",
      "epoch:  2109, loss: 0.5530398, train acc: 1.000\n",
      "test loss: 0.5888118, test acc: 1.000\n",
      "poison loss: 1.3244891, poison acc: 0.050\n",
      "elapsed time: 244.526, time for reg: 32.969, time for eig: 127.377\n",
      "epoch:  2119, loss: 0.5789768, train acc: 0.967\n",
      "test loss: 0.5801809, test acc: 1.000\n",
      "poison loss: 1.3343770, poison acc: 0.067\n",
      "elapsed time: 245.867, time for reg: 33.115, time for eig: 128.184\n",
      "epoch:  2129, loss: 0.5530928, train acc: 1.000\n",
      "test loss: 0.5565085, test acc: 1.000\n",
      "poison loss: 1.4338934, poison acc: 0.017\n",
      "elapsed time: 247.300, time for reg: 33.259, time for eig: 129.081\n",
      "epoch:  2139, loss: 0.5962209, train acc: 1.000\n",
      "test loss: 0.6255033, test acc: 1.000\n",
      "poison loss: 1.2802020, poison acc: 0.050\n",
      "elapsed time: 248.565, time for reg: 33.403, time for eig: 129.817\n",
      "epoch:  2149, loss: 0.5160365, train acc: 1.000\n",
      "test loss: 0.4239169, test acc: 1.000\n",
      "poison loss: 1.6006402, poison acc: 0.067\n",
      "elapsed time: 249.280, time for reg: 33.546, time for eig: 130.014\n",
      "epoch:  2159, loss: 0.5695179, train acc: 0.950\n",
      "test loss: 0.5802990, test acc: 0.983\n",
      "poison loss: 1.3521570, poison acc: 0.067\n",
      "elapsed time: 250.139, time for reg: 33.714, time for eig: 130.288\n",
      "epoch:  2169, loss: 0.5534823, train acc: 0.967\n",
      "test loss: 0.2813508, test acc: 1.000\n",
      "poison loss: 2.2318166, poison acc: 0.033\n",
      "elapsed time: 251.115, time for reg: 33.886, time for eig: 130.459\n",
      "epoch:  2179, loss: 0.5077973, train acc: 1.000\n",
      "test loss: 0.5351452, test acc: 0.983\n",
      "poison loss: 1.4150146, poison acc: 0.050\n",
      "elapsed time: 252.404, time for reg: 34.028, time for eig: 131.208\n",
      "epoch:  2189, loss: 0.3520521, train acc: 1.000\n",
      "test loss: 0.3910143, test acc: 1.000\n",
      "poison loss: 1.6619064, poison acc: 0.050\n",
      "elapsed time: 253.271, time for reg: 34.171, time for eig: 131.563\n",
      "epoch:  2199, loss: 0.3411748, train acc: 0.983\n",
      "test loss: 0.2758865, test acc: 1.000\n",
      "poison loss: 1.9931487, poison acc: 0.033\n",
      "elapsed time: 254.137, time for reg: 34.316, time for eig: 131.912\n",
      "epoch:  2209, loss: 0.5114626, train acc: 1.000\n",
      "test loss: 0.5497424, test acc: 0.983\n",
      "poison loss: 1.3822365, poison acc: 0.067\n",
      "elapsed time: 255.067, time for reg: 34.460, time for eig: 132.331\n",
      "epoch:  2219, loss: 0.6008393, train acc: 0.950\n",
      "test loss: 0.6237893, test acc: 0.933\n",
      "poison loss: 1.2835910, poison acc: 0.117\n",
      "elapsed time: 255.989, time for reg: 34.603, time for eig: 132.729\n",
      "epoch:  2229, loss: 0.4940676, train acc: 0.983\n",
      "test loss: 0.5367908, test acc: 0.883\n",
      "poison loss: 1.3896039, poison acc: 0.167\n",
      "elapsed time: 257.376, time for reg: 34.744, time for eig: 133.617\n",
      "epoch:  2239, loss: 0.5500052, train acc: 0.933\n",
      "test loss: 0.6111286, test acc: 0.883\n",
      "poison loss: 1.3020064, poison acc: 0.200\n",
      "elapsed time: 258.190, time for reg: 34.886, time for eig: 133.929\n",
      "epoch:  2249, loss: 0.5759330, train acc: 0.933\n",
      "test loss: 0.5959224, test acc: 0.867\n",
      "poison loss: 1.4021116, poison acc: 0.167\n",
      "elapsed time: 259.199, time for reg: 35.027, time for eig: 134.400\n",
      "epoch:  2259, loss: 0.6329287, train acc: 0.917\n",
      "test loss: 0.6369319, test acc: 0.867\n",
      "poison loss: 1.2689545, poison acc: 0.167\n",
      "elapsed time: 260.153, time for reg: 35.170, time for eig: 134.814\n",
      "epoch:  2269, loss: 0.5540273, train acc: 1.000\n",
      "test loss: 0.5662010, test acc: 1.000\n",
      "poison loss: 1.3827320, poison acc: 0.017\n",
      "elapsed time: 261.233, time for reg: 35.310, time for eig: 135.398\n",
      "epoch:  2279, loss: 0.5293058, train acc: 0.933\n",
      "test loss: 0.5014765, test acc: 0.983\n",
      "poison loss: 1.4918597, poison acc: 0.050\n",
      "elapsed time: 262.121, time for reg: 35.455, time for eig: 135.770\n",
      "epoch:  2289, loss: 0.5844750, train acc: 0.967\n",
      "test loss: 0.6161514, test acc: 0.933\n",
      "poison loss: 1.2817007, poison acc: 0.117\n",
      "elapsed time: 262.920, time for reg: 35.598, time for eig: 136.056\n",
      "epoch:  2299, loss: 0.6243101, train acc: 0.933\n",
      "test loss: 0.4449521, test acc: 0.833\n",
      "poison loss: 1.7804143, poison acc: 0.167\n",
      "elapsed time: 264.000, time for reg: 35.869, time for eig: 136.340\n",
      "epoch:  2309, loss: 0.4775040, train acc: 0.967\n",
      "test loss: 0.5427767, test acc: 0.883\n",
      "poison loss: 1.4579116, poison acc: 0.150\n",
      "elapsed time: 265.026, time for reg: 36.016, time for eig: 136.681\n",
      "epoch:  2319, loss: 0.5952342, train acc: 0.917\n",
      "test loss: 0.6201234, test acc: 0.800\n",
      "poison loss: 1.4460406, poison acc: 0.167\n",
      "elapsed time: 265.933, time for reg: 36.160, time for eig: 136.927\n",
      "epoch:  2329, loss: 0.5530688, train acc: 1.000\n",
      "test loss: 0.4934834, test acc: 1.000\n",
      "poison loss: 1.5280018, poison acc: 0.017\n",
      "elapsed time: 266.863, time for reg: 36.334, time for eig: 137.266\n",
      "epoch:  2339, loss: 0.5995346, train acc: 0.917\n",
      "test loss: 0.6295743, test acc: 0.883\n",
      "poison loss: 1.3447100, poison acc: 0.167\n",
      "elapsed time: 267.918, time for reg: 36.495, time for eig: 137.748\n",
      "epoch:  2349, loss: 0.5583319, train acc: 1.000\n",
      "test loss: 0.5476238, test acc: 0.983\n",
      "poison loss: 1.4442560, poison acc: 0.017\n",
      "elapsed time: 269.188, time for reg: 36.639, time for eig: 138.500\n",
      "epoch:  2359, loss: 0.6190937, train acc: 0.917\n",
      "test loss: 0.6168998, test acc: 0.883\n",
      "poison loss: 1.3461674, poison acc: 0.150\n",
      "elapsed time: 270.062, time for reg: 36.782, time for eig: 138.835\n",
      "epoch:  2369, loss: 0.6196598, train acc: 0.917\n",
      "test loss: 0.5251477, test acc: 0.900\n",
      "poison loss: 1.4718741, poison acc: 0.150\n",
      "elapsed time: 270.926, time for reg: 36.926, time for eig: 139.192\n",
      "epoch:  2379, loss: 0.6287680, train acc: 0.917\n",
      "test loss: 0.6442551, test acc: 0.883\n",
      "poison loss: 1.3105875, poison acc: 0.150\n",
      "elapsed time: 272.070, time for reg: 37.073, time for eig: 139.781\n",
      "epoch:  2389, loss: 0.6219479, train acc: 0.917\n",
      "test loss: 0.6416688, test acc: 0.867\n",
      "poison loss: 1.2592399, poison acc: 0.200\n",
      "elapsed time: 272.945, time for reg: 37.216, time for eig: 140.120\n",
      "epoch:  2399, loss: 0.6052367, train acc: 0.917\n",
      "test loss: 0.6173333, test acc: 0.867\n",
      "poison loss: 1.2909519, poison acc: 0.183\n",
      "elapsed time: 273.896, time for reg: 37.361, time for eig: 140.561\n",
      "epoch:  2409, loss: 0.6145094, train acc: 0.933\n",
      "test loss: 0.6359195, test acc: 0.883\n",
      "poison loss: 1.2719451, poison acc: 0.167\n",
      "elapsed time: 275.593, time for reg: 37.507, time for eig: 141.739\n",
      "epoch:  2419, loss: 0.5901951, train acc: 0.933\n",
      "test loss: 0.6234527, test acc: 0.867\n",
      "poison loss: 1.2806872, poison acc: 0.183\n",
      "elapsed time: 276.574, time for reg: 37.653, time for eig: 142.207\n",
      "epoch:  2429, loss: 0.5549839, train acc: 0.917\n",
      "test loss: 0.5140394, test acc: 0.883\n",
      "poison loss: 1.4312485, poison acc: 0.200\n",
      "elapsed time: 277.316, time for reg: 37.797, time for eig: 142.432\n",
      "epoch:  2439, loss: 0.6083535, train acc: 0.917\n",
      "test loss: 0.6368316, test acc: 0.867\n",
      "poison loss: 1.2647223, poison acc: 0.200\n",
      "elapsed time: 278.477, time for reg: 37.976, time for eig: 143.039\n",
      "epoch:  2449, loss: 0.6112258, train acc: 0.967\n",
      "test loss: 0.6394245, test acc: 0.967\n",
      "poison loss: 1.2580374, poison acc: 0.117\n",
      "elapsed time: 279.966, time for reg: 38.155, time for eig: 143.883\n",
      "epoch:  2459, loss: 0.5099454, train acc: 1.000\n",
      "test loss: 0.5626250, test acc: 1.000\n",
      "poison loss: 1.3547473, poison acc: 0.050\n",
      "elapsed time: 280.695, time for reg: 38.301, time for eig: 144.094\n",
      "epoch:  2469, loss: 0.4559035, train acc: 0.933\n",
      "test loss: 0.4695148, test acc: 0.883\n",
      "poison loss: 1.5469421, poison acc: 0.183\n",
      "elapsed time: 281.518, time for reg: 38.448, time for eig: 144.402\n",
      "epoch:  2479, loss: 0.5823787, train acc: 0.967\n",
      "test loss: 0.5512501, test acc: 1.000\n",
      "poison loss: 1.3631939, poison acc: 0.067\n",
      "elapsed time: 282.348, time for reg: 38.592, time for eig: 144.731\n",
      "epoch:  2489, loss: 0.5629404, train acc: 0.933\n",
      "test loss: 0.5067152, test acc: 0.883\n",
      "poison loss: 1.4555562, poison acc: 0.183\n",
      "elapsed time: 283.133, time for reg: 38.734, time for eig: 144.982\n",
      "epoch:  2499, loss: 0.5828775, train acc: 0.933\n",
      "test loss: 0.4973047, test acc: 0.900\n",
      "poison loss: 1.5793114, poison acc: 0.150\n",
      "elapsed time: 284.035, time for reg: 38.878, time for eig: 145.382\n",
      "epoch:  2509, loss: 0.5963631, train acc: 0.933\n",
      "test loss: 0.5864276, test acc: 0.933\n",
      "poison loss: 1.3092579, poison acc: 0.133\n",
      "elapsed time: 284.769, time for reg: 39.024, time for eig: 145.600\n",
      "epoch:  2519, loss: 0.4923792, train acc: 1.000\n",
      "test loss: 0.6104560, test acc: 0.917\n",
      "poison loss: 1.2976516, poison acc: 0.150\n",
      "elapsed time: 285.610, time for reg: 39.195, time for eig: 145.873\n",
      "epoch:  2529, loss: 0.5560372, train acc: 0.933\n",
      "test loss: 0.6082261, test acc: 0.883\n",
      "poison loss: 1.2969539, poison acc: 0.167\n",
      "elapsed time: 286.674, time for reg: 39.339, time for eig: 146.429\n",
      "epoch:  2539, loss: 0.5273600, train acc: 0.933\n",
      "test loss: 0.3907148, test acc: 0.883\n",
      "poison loss: 1.7917723, poison acc: 0.167\n",
      "elapsed time: 287.587, time for reg: 39.484, time for eig: 146.827\n",
      "epoch:  2549, loss: 0.6091397, train acc: 0.917\n",
      "test loss: 0.6199971, test acc: 0.867\n",
      "poison loss: 1.2819122, poison acc: 0.200\n",
      "elapsed time: 288.430, time for reg: 39.629, time for eig: 147.151\n",
      "epoch:  2559, loss: 0.5787725, train acc: 0.933\n",
      "test loss: 0.6137047, test acc: 0.883\n",
      "poison loss: 1.2817816, poison acc: 0.150\n",
      "elapsed time: 289.470, time for reg: 39.783, time for eig: 147.648\n",
      "epoch:  2569, loss: 0.5779979, train acc: 0.917\n",
      "test loss: 0.4141878, test acc: 0.933\n",
      "poison loss: 1.7065842, poison acc: 0.133\n",
      "elapsed time: 290.349, time for reg: 39.928, time for eig: 147.999\n",
      "epoch:  2579, loss: 0.6141623, train acc: 0.917\n",
      "test loss: 0.6318276, test acc: 0.883\n",
      "poison loss: 1.2600614, poison acc: 0.150\n",
      "elapsed time: 291.184, time for reg: 40.074, time for eig: 148.307\n",
      "epoch:  2589, loss: 0.5072074, train acc: 0.933\n",
      "test loss: 0.7071220, test acc: 0.867\n",
      "poison loss: 1.1954798, poison acc: 0.183\n",
      "elapsed time: 292.162, time for reg: 40.219, time for eig: 148.726\n",
      "epoch:  2599, loss: 0.5855165, train acc: 0.917\n",
      "test loss: 0.6264176, test acc: 0.867\n",
      "poison loss: 1.2736926, poison acc: 0.200\n",
      "elapsed time: 293.582, time for reg: 40.365, time for eig: 149.621\n",
      "epoch:  2609, loss: 0.4541236, train acc: 0.950\n",
      "test loss: 0.4683254, test acc: 0.967\n",
      "poison loss: 1.5106642, poison acc: 0.117\n",
      "elapsed time: 294.544, time for reg: 40.542, time for eig: 149.960\n",
      "epoch:  2619, loss: 0.3824055, train acc: 1.000\n",
      "test loss: 0.3871019, test acc: 0.983\n",
      "poison loss: 1.6783981, poison acc: 0.067\n",
      "elapsed time: 295.582, time for reg: 40.687, time for eig: 150.477\n",
      "epoch:  2629, loss: 0.4910276, train acc: 1.000\n",
      "test loss: 0.5275065, test acc: 0.983\n",
      "poison loss: 1.3983032, poison acc: 0.050\n",
      "elapsed time: 296.420, time for reg: 40.832, time for eig: 150.790\n",
      "epoch:  2639, loss: 0.5802833, train acc: 1.000\n",
      "test loss: 0.5936833, test acc: 1.000\n",
      "poison loss: 1.3797528, poison acc: 0.033\n",
      "elapsed time: 297.299, time for reg: 40.979, time for eig: 151.106\n",
      "epoch:  2649, loss: 0.6110019, train acc: 1.000\n",
      "test loss: 0.5594889, test acc: 1.000\n",
      "poison loss: 1.4227164, poison acc: 0.033\n",
      "elapsed time: 298.221, time for reg: 41.126, time for eig: 151.501\n",
      "epoch:  2659, loss: 0.6195911, train acc: 0.933\n",
      "test loss: 0.6333170, test acc: 0.883\n",
      "poison loss: 1.2617500, poison acc: 0.200\n",
      "elapsed time: 299.063, time for reg: 41.270, time for eig: 151.833\n",
      "epoch:  2669, loss: 0.5249917, train acc: 0.983\n",
      "test loss: 0.5536960, test acc: 0.983\n",
      "poison loss: 1.3620254, poison acc: 0.067\n",
      "elapsed time: 300.239, time for reg: 41.415, time for eig: 152.481\n",
      "epoch:  2679, loss: 0.5955761, train acc: 0.950\n",
      "test loss: 0.6136203, test acc: 0.950\n",
      "poison loss: 1.2864044, poison acc: 0.133\n",
      "elapsed time: 301.723, time for reg: 41.645, time for eig: 153.345\n",
      "epoch:  2689, loss: 0.6011003, train acc: 0.933\n",
      "test loss: 0.6172675, test acc: 0.883\n",
      "poison loss: 1.2815399, poison acc: 0.167\n",
      "elapsed time: 302.496, time for reg: 41.790, time for eig: 153.556\n",
      "epoch:  2699, loss: 0.6056183, train acc: 0.917\n",
      "test loss: 0.6378554, test acc: 0.867\n",
      "poison loss: 1.2594125, poison acc: 0.200\n",
      "elapsed time: 303.469, time for reg: 41.933, time for eig: 153.918\n",
      "epoch:  2709, loss: 0.5751834, train acc: 0.933\n",
      "test loss: 0.5574970, test acc: 0.917\n",
      "poison loss: 1.3503028, poison acc: 0.167\n",
      "elapsed time: 304.630, time for reg: 42.075, time for eig: 154.582\n",
      "epoch:  2719, loss: 0.5887738, train acc: 0.917\n",
      "test loss: 0.6011437, test acc: 0.867\n",
      "poison loss: 1.2996198, poison acc: 0.200\n",
      "elapsed time: 305.862, time for reg: 42.218, time for eig: 155.305\n",
      "epoch:  2729, loss: 0.5977135, train acc: 0.950\n",
      "test loss: 0.6294617, test acc: 0.883\n",
      "poison loss: 1.2593111, poison acc: 0.150\n",
      "elapsed time: 306.575, time for reg: 42.360, time for eig: 155.525\n",
      "epoch:  2739, loss: 0.6077990, train acc: 0.933\n",
      "test loss: 0.6264018, test acc: 0.900\n",
      "poison loss: 1.2619380, poison acc: 0.150\n",
      "elapsed time: 307.614, time for reg: 42.503, time for eig: 156.062\n",
      "epoch:  2749, loss: 0.5829115, train acc: 0.950\n",
      "test loss: 0.6078342, test acc: 0.900\n",
      "poison loss: 1.2847799, poison acc: 0.167\n",
      "elapsed time: 309.280, time for reg: 42.681, time for eig: 157.120\n",
      "epoch:  2759, loss: 0.5891498, train acc: 0.950\n",
      "test loss: 0.6107369, test acc: 0.950\n",
      "poison loss: 1.2741022, poison acc: 0.117\n",
      "elapsed time: 310.363, time for reg: 42.826, time for eig: 157.680\n",
      "epoch:  2769, loss: 0.5802407, train acc: 0.950\n",
      "test loss: 0.6122195, test acc: 0.900\n",
      "poison loss: 1.2868651, poison acc: 0.167\n",
      "elapsed time: 311.332, time for reg: 42.995, time for eig: 158.071\n",
      "epoch:  2779, loss: 0.5714770, train acc: 0.933\n",
      "test loss: 0.6001985, test acc: 0.883\n",
      "poison loss: 1.3391051, poison acc: 0.150\n",
      "elapsed time: 312.188, time for reg: 43.140, time for eig: 158.349\n",
      "epoch:  2789, loss: 0.5112062, train acc: 0.967\n",
      "test loss: 0.5612308, test acc: 0.917\n",
      "poison loss: 1.3303721, poison acc: 0.150\n",
      "elapsed time: 312.870, time for reg: 43.286, time for eig: 158.499\n",
      "epoch:  2799, loss: 0.5806872, train acc: 0.933\n",
      "test loss: 0.6202671, test acc: 0.883\n",
      "poison loss: 1.2609470, poison acc: 0.183\n",
      "elapsed time: 313.556, time for reg: 43.430, time for eig: 158.706\n",
      "epoch:  2809, loss: 0.5886735, train acc: 0.950\n",
      "test loss: 0.6172578, test acc: 0.883\n",
      "poison loss: 1.2745181, poison acc: 0.183\n",
      "elapsed time: 314.423, time for reg: 43.572, time for eig: 159.048\n",
      "epoch:  2819, loss: 0.5934277, train acc: 0.933\n",
      "test loss: 0.5166466, test acc: 0.883\n",
      "poison loss: 1.4158823, poison acc: 0.183\n",
      "elapsed time: 315.111, time for reg: 43.716, time for eig: 159.205\n",
      "epoch:  2829, loss: 0.6042003, train acc: 0.917\n",
      "test loss: 0.6396887, test acc: 0.867\n",
      "poison loss: 1.2661794, poison acc: 0.183\n",
      "elapsed time: 316.237, time for reg: 43.860, time for eig: 159.825\n",
      "epoch:  2839, loss: 0.5873813, train acc: 0.933\n",
      "test loss: 0.6405272, test acc: 0.867\n",
      "poison loss: 1.2653759, poison acc: 0.183\n",
      "elapsed time: 317.369, time for reg: 44.004, time for eig: 160.448\n",
      "epoch:  2849, loss: 0.5599195, train acc: 0.933\n",
      "test loss: 0.6005868, test acc: 0.883\n",
      "poison loss: 1.3121253, poison acc: 0.183\n",
      "elapsed time: 318.699, time for reg: 44.147, time for eig: 161.270\n",
      "epoch:  2859, loss: 0.6197722, train acc: 0.917\n",
      "test loss: 0.6167988, test acc: 0.900\n",
      "poison loss: 1.2826445, poison acc: 0.167\n",
      "elapsed time: 320.396, time for reg: 44.289, time for eig: 162.468\n",
      "epoch:  2869, loss: 0.5740051, train acc: 0.983\n",
      "test loss: 0.6067914, test acc: 0.983\n",
      "poison loss: 1.2819110, poison acc: 0.050\n",
      "elapsed time: 321.932, time for reg: 44.435, time for eig: 163.433\n",
      "epoch:  2879, loss: 0.5829402, train acc: 0.917\n",
      "test loss: 0.6221059, test acc: 0.867\n",
      "poison loss: 1.2643555, poison acc: 0.183\n",
      "elapsed time: 323.016, time for reg: 44.639, time for eig: 163.907\n",
      "epoch:  2889, loss: 0.6095071, train acc: 0.917\n",
      "test loss: 0.6409050, test acc: 0.867\n",
      "poison loss: 1.2485905, poison acc: 0.183\n",
      "elapsed time: 323.932, time for reg: 44.847, time for eig: 164.233\n",
      "epoch:  2899, loss: 0.5882289, train acc: 0.950\n",
      "test loss: 0.6259098, test acc: 0.900\n",
      "poison loss: 1.2700453, poison acc: 0.167\n",
      "elapsed time: 324.705, time for reg: 44.991, time for eig: 164.499\n",
      "epoch:  2909, loss: 0.4854305, train acc: 1.000\n",
      "test loss: 0.5233965, test acc: 1.000\n",
      "poison loss: 1.3816953, poison acc: 0.050\n",
      "elapsed time: 326.627, time for reg: 45.138, time for eig: 165.895\n",
      "epoch:  2919, loss: 0.5178881, train acc: 1.000\n",
      "test loss: 0.5526150, test acc: 0.983\n",
      "poison loss: 1.3504309, poison acc: 0.050\n",
      "elapsed time: 327.554, time for reg: 45.281, time for eig: 166.304\n",
      "epoch:  2929, loss: 0.5382632, train acc: 0.933\n",
      "test loss: 0.5451437, test acc: 0.883\n",
      "poison loss: 1.3618562, poison acc: 0.150\n",
      "elapsed time: 328.302, time for reg: 45.426, time for eig: 166.530\n",
      "epoch:  2939, loss: 0.5644782, train acc: 0.983\n",
      "test loss: 0.6011806, test acc: 0.917\n",
      "poison loss: 1.3025866, poison acc: 0.150\n",
      "elapsed time: 329.712, time for reg: 45.634, time for eig: 167.313\n",
      "epoch:  2949, loss: 0.5802452, train acc: 0.950\n",
      "test loss: 0.6290081, test acc: 0.883\n",
      "poison loss: 1.2638059, poison acc: 0.183\n",
      "elapsed time: 331.198, time for reg: 45.778, time for eig: 168.284\n",
      "epoch:  2959, loss: 0.5562887, train acc: 0.950\n",
      "test loss: 0.5888497, test acc: 0.900\n",
      "poison loss: 1.2992961, poison acc: 0.150\n",
      "elapsed time: 331.936, time for reg: 45.922, time for eig: 168.496\n",
      "epoch:  2969, loss: 0.5062997, train acc: 0.917\n",
      "test loss: 0.5556979, test acc: 0.883\n",
      "poison loss: 1.3455342, poison acc: 0.167\n",
      "elapsed time: 333.142, time for reg: 46.097, time for eig: 169.128\n",
      "epoch:  2979, loss: 0.5548469, train acc: 0.933\n",
      "test loss: 0.5414716, test acc: 0.900\n",
      "poison loss: 1.3847638, poison acc: 0.167\n",
      "elapsed time: 334.084, time for reg: 46.241, time for eig: 169.550\n",
      "epoch:  2989, loss: 0.5649209, train acc: 0.933\n",
      "test loss: 0.6230673, test acc: 0.883\n",
      "poison loss: 1.2689579, poison acc: 0.167\n",
      "elapsed time: 335.177, time for reg: 46.386, time for eig: 170.120\n",
      "epoch:  2999, loss: 0.5490297, train acc: 0.950\n",
      "test loss: 0.5098694, test acc: 0.900\n",
      "poison loss: 1.4110810, poison acc: 0.150\n",
      "elapsed time: 336.508, time for reg: 46.531, time for eig: 170.929\n",
      "epoch:  3009, loss: 0.5426077, train acc: 1.000\n",
      "test loss: 0.5257928, test acc: 0.983\n",
      "poison loss: 1.3970241, poison acc: 0.050\n",
      "elapsed time: 337.536, time for reg: 46.678, time for eig: 171.437\n",
      "epoch:  3019, loss: 0.5639114, train acc: 0.950\n",
      "test loss: 0.6088136, test acc: 0.900\n",
      "poison loss: 1.2879331, poison acc: 0.150\n",
      "elapsed time: 339.299, time for reg: 46.823, time for eig: 172.675\n",
      "epoch:  3029, loss: 0.5897597, train acc: 0.933\n",
      "test loss: 0.6297688, test acc: 0.867\n",
      "poison loss: 1.2622342, poison acc: 0.167\n",
      "elapsed time: 340.431, time for reg: 46.969, time for eig: 173.282\n",
      "epoch:  3039, loss: 0.5714735, train acc: 0.950\n",
      "test loss: 0.6177523, test acc: 0.900\n",
      "poison loss: 1.2714713, poison acc: 0.150\n",
      "elapsed time: 341.591, time for reg: 47.114, time for eig: 173.917\n",
      "epoch:  3049, loss: 0.5184851, train acc: 0.933\n",
      "test loss: 0.5392424, test acc: 0.900\n",
      "poison loss: 1.3805509, poison acc: 0.150\n",
      "elapsed time: 342.760, time for reg: 47.259, time for eig: 174.557\n",
      "epoch:  3059, loss: 0.5576182, train acc: 0.950\n",
      "test loss: 0.6082661, test acc: 0.917\n",
      "poison loss: 1.3118157, poison acc: 0.167\n",
      "elapsed time: 344.108, time for reg: 47.403, time for eig: 175.395\n",
      "epoch:  3069, loss: 0.5851783, train acc: 0.933\n",
      "test loss: 0.6341472, test acc: 0.867\n",
      "poison loss: 1.2580606, poison acc: 0.167\n",
      "elapsed time: 345.057, time for reg: 47.546, time for eig: 175.824\n",
      "epoch:  3079, loss: 0.5174787, train acc: 0.950\n",
      "test loss: 0.5757949, test acc: 0.900\n",
      "poison loss: 1.3478324, poison acc: 0.167\n",
      "elapsed time: 346.036, time for reg: 47.693, time for eig: 176.273\n",
      "epoch:  3089, loss: 0.5522744, train acc: 0.933\n",
      "test loss: 0.5641658, test acc: 0.950\n",
      "poison loss: 1.4209942, poison acc: 0.133\n",
      "elapsed time: 347.055, time for reg: 47.837, time for eig: 176.768\n",
      "epoch:  3099, loss: 0.5614012, train acc: 0.950\n",
      "test loss: 0.5077449, test acc: 0.900\n",
      "poison loss: 1.4711479, poison acc: 0.167\n",
      "elapsed time: 348.124, time for reg: 47.982, time for eig: 177.310\n",
      "epoch:  3109, loss: 0.5716640, train acc: 0.933\n",
      "test loss: 0.6109039, test acc: 0.883\n",
      "poison loss: 1.2772056, poison acc: 0.167\n",
      "elapsed time: 349.385, time for reg: 48.126, time for eig: 178.051\n",
      "epoch:  3119, loss: 0.6046456, train acc: 0.950\n",
      "test loss: 0.6489614, test acc: 0.900\n",
      "poison loss: 1.2467409, poison acc: 0.150\n",
      "elapsed time: 350.726, time for reg: 48.271, time for eig: 178.870\n",
      "epoch:  3129, loss: 0.5735980, train acc: 0.950\n",
      "test loss: 0.6156484, test acc: 0.917\n",
      "poison loss: 1.2976787, poison acc: 0.150\n",
      "elapsed time: 351.571, time for reg: 48.417, time for eig: 179.196\n",
      "epoch:  3139, loss: 0.5925927, train acc: 0.933\n",
      "test loss: 0.6391008, test acc: 0.900\n",
      "poison loss: 1.2640358, poison acc: 0.167\n",
      "elapsed time: 353.025, time for reg: 48.562, time for eig: 180.122\n",
      "epoch:  3149, loss: 0.6002450, train acc: 0.933\n",
      "test loss: 0.6545130, test acc: 0.900\n",
      "poison loss: 1.2472112, poison acc: 0.167\n",
      "elapsed time: 354.483, time for reg: 48.706, time for eig: 181.064\n",
      "epoch:  3159, loss: 0.5665840, train acc: 0.933\n",
      "test loss: 0.6141182, test acc: 0.883\n",
      "poison loss: 1.2807346, poison acc: 0.183\n",
      "elapsed time: 355.472, time for reg: 48.850, time for eig: 181.526\n",
      "epoch:  3169, loss: 0.5845426, train acc: 0.933\n",
      "test loss: 0.6010079, test acc: 0.900\n",
      "poison loss: 1.2832823, poison acc: 0.150\n",
      "elapsed time: 356.884, time for reg: 48.996, time for eig: 182.411\n",
      "epoch:  3179, loss: 0.5984476, train acc: 0.933\n",
      "test loss: 0.6372322, test acc: 0.867\n",
      "poison loss: 1.2622393, poison acc: 0.183\n",
      "elapsed time: 357.807, time for reg: 49.144, time for eig: 182.803\n",
      "epoch:  3189, loss: 0.5739437, train acc: 0.933\n",
      "test loss: 0.6433955, test acc: 0.867\n",
      "poison loss: 1.2714947, poison acc: 0.183\n",
      "elapsed time: 358.695, time for reg: 49.289, time for eig: 183.166\n",
      "epoch:  3199, loss: 0.5743828, train acc: 0.933\n",
      "test loss: 0.6179358, test acc: 0.883\n",
      "poison loss: 1.2741196, poison acc: 0.167\n",
      "elapsed time: 359.681, time for reg: 49.435, time for eig: 183.592\n",
      "epoch:  3209, loss: 0.5760834, train acc: 0.933\n",
      "test loss: 0.6437445, test acc: 0.867\n",
      "poison loss: 1.2652819, poison acc: 0.183\n",
      "elapsed time: 360.935, time for reg: 49.580, time for eig: 184.321\n",
      "epoch:  3219, loss: 0.5955171, train acc: 0.933\n",
      "test loss: 0.6612674, test acc: 0.867\n",
      "poison loss: 1.2437181, poison acc: 0.183\n",
      "elapsed time: 362.028, time for reg: 49.726, time for eig: 184.891\n",
      "epoch:  3229, loss: 0.5869184, train acc: 0.933\n",
      "test loss: 0.6321110, test acc: 0.883\n",
      "poison loss: 1.2463557, poison acc: 0.167\n",
      "elapsed time: 362.720, time for reg: 49.871, time for eig: 185.060\n",
      "epoch:  3239, loss: 0.5981926, train acc: 0.933\n",
      "test loss: 0.6424474, test acc: 0.900\n",
      "poison loss: 1.2689599, poison acc: 0.167\n",
      "elapsed time: 364.116, time for reg: 50.019, time for eig: 185.901\n",
      "epoch:  3249, loss: 0.5610895, train acc: 0.933\n",
      "test loss: 0.6191581, test acc: 0.900\n",
      "poison loss: 1.2767079, poison acc: 0.150\n",
      "elapsed time: 365.029, time for reg: 50.164, time for eig: 186.287\n",
      "epoch:  3259, loss: 0.5060243, train acc: 0.950\n",
      "test loss: 0.5402098, test acc: 0.883\n",
      "poison loss: 1.4805619, poison acc: 0.150\n",
      "elapsed time: 366.231, time for reg: 50.336, time for eig: 186.919\n",
      "epoch:  3269, loss: 0.6256776, train acc: 0.917\n",
      "test loss: 0.6319647, test acc: 0.900\n",
      "poison loss: 1.3306356, poison acc: 0.133\n",
      "elapsed time: 367.358, time for reg: 50.482, time for eig: 187.516\n",
      "epoch:  3279, loss: 0.6054104, train acc: 0.950\n",
      "test loss: 0.6298637, test acc: 0.900\n",
      "poison loss: 1.3332672, poison acc: 0.117\n",
      "elapsed time: 368.468, time for reg: 50.625, time for eig: 188.108\n",
      "epoch:  3289, loss: 0.6118120, train acc: 0.933\n",
      "test loss: 0.4482420, test acc: 1.000\n",
      "poison loss: 1.9041769, poison acc: 0.017\n",
      "elapsed time: 369.506, time for reg: 50.771, time for eig: 188.622\n",
      "epoch:  3299, loss: 0.5963863, train acc: 0.950\n",
      "test loss: 0.6161791, test acc: 0.900\n",
      "poison loss: 1.3458489, poison acc: 0.117\n",
      "elapsed time: 370.604, time for reg: 50.919, time for eig: 189.190\n",
      "epoch:  3309, loss: 0.6182793, train acc: 0.933\n",
      "test loss: 0.6359906, test acc: 0.900\n",
      "poison loss: 1.3200743, poison acc: 0.133\n",
      "elapsed time: 371.817, time for reg: 51.064, time for eig: 189.873\n",
      "epoch:  3319, loss: 0.6072266, train acc: 0.917\n",
      "test loss: 0.6460681, test acc: 0.883\n",
      "poison loss: 1.2578811, poison acc: 0.183\n",
      "elapsed time: 372.803, time for reg: 51.210, time for eig: 190.328\n",
      "epoch:  3329, loss: 0.5895834, train acc: 0.933\n",
      "test loss: 0.6142828, test acc: 0.900\n",
      "poison loss: 1.2618054, poison acc: 0.150\n",
      "elapsed time: 373.944, time for reg: 51.357, time for eig: 190.937\n",
      "epoch:  3339, loss: 0.5881317, train acc: 0.933\n",
      "test loss: 0.6243177, test acc: 0.883\n",
      "poison loss: 1.2609874, poison acc: 0.150\n",
      "elapsed time: 375.203, time for reg: 51.583, time for eig: 191.591\n",
      "epoch:  3349, loss: 0.5765255, train acc: 0.933\n",
      "test loss: 0.6223775, test acc: 0.867\n",
      "poison loss: 1.2612712, poison acc: 0.183\n",
      "elapsed time: 376.236, time for reg: 51.729, time for eig: 192.034\n",
      "epoch:  3359, loss: 0.5546052, train acc: 0.933\n",
      "test loss: 0.5947527, test acc: 0.900\n",
      "poison loss: 1.3246348, poison acc: 0.167\n",
      "elapsed time: 377.573, time for reg: 51.875, time for eig: 192.842\n",
      "epoch:  3369, loss: 0.5362997, train acc: 1.000\n",
      "test loss: 0.5369922, test acc: 0.933\n",
      "poison loss: 1.4400318, poison acc: 0.100\n",
      "elapsed time: 378.591, time for reg: 52.020, time for eig: 193.335\n",
      "epoch:  3379, loss: 0.5796354, train acc: 1.000\n",
      "test loss: 0.6301831, test acc: 0.983\n",
      "poison loss: 1.2852274, poison acc: 0.067\n",
      "elapsed time: 379.509, time for reg: 52.166, time for eig: 193.731\n",
      "epoch:  3389, loss: 0.5924990, train acc: 0.950\n",
      "test loss: 0.6156385, test acc: 0.933\n",
      "poison loss: 1.3470951, poison acc: 0.100\n",
      "elapsed time: 380.471, time for reg: 52.313, time for eig: 194.167\n",
      "epoch:  3399, loss: 0.6101732, train acc: 0.967\n",
      "test loss: 0.6057467, test acc: 1.000\n",
      "poison loss: 1.3554454, poison acc: 0.017\n",
      "elapsed time: 381.300, time for reg: 52.483, time for eig: 194.432\n",
      "epoch:  3409, loss: 0.4284547, train acc: 0.933\n",
      "test loss: 0.3777488, test acc: 0.900\n",
      "poison loss: 1.8142333, poison acc: 0.133\n",
      "elapsed time: 382.060, time for reg: 52.628, time for eig: 194.668\n",
      "epoch:  3419, loss: 0.5311054, train acc: 0.983\n",
      "test loss: 0.4884947, test acc: 0.900\n",
      "poison loss: 1.5716391, poison acc: 0.150\n",
      "elapsed time: 382.791, time for reg: 52.772, time for eig: 194.873\n",
      "epoch:  3429, loss: 0.3703911, train acc: 0.967\n",
      "test loss: 0.2540270, test acc: 1.000\n",
      "poison loss: 2.3477582, poison acc: 0.017\n",
      "elapsed time: 383.567, time for reg: 52.924, time for eig: 195.087\n",
      "epoch:  3439, loss: 0.5077533, train acc: 0.817\n",
      "test loss: 0.6529433, test acc: 0.817\n",
      "poison loss: 1.3941105, poison acc: 0.117\n",
      "elapsed time: 384.336, time for reg: 53.068, time for eig: 195.345\n",
      "epoch:  3449, loss: 0.3470571, train acc: 0.967\n",
      "test loss: 0.1565900, test acc: 1.000\n",
      "poison loss: 3.5621107, poison acc: 0.017\n",
      "elapsed time: 385.180, time for reg: 53.276, time for eig: 195.601\n",
      "epoch:  3459, loss: 0.5649264, train acc: 1.000\n",
      "test loss: 0.2834310, test acc: 1.000\n",
      "poison loss: 2.0580855, poison acc: 0.017\n",
      "elapsed time: 385.929, time for reg: 53.424, time for eig: 195.821\n",
      "epoch:  3469, loss: 0.5554920, train acc: 0.967\n",
      "test loss: 0.3223366, test acc: 0.983\n",
      "poison loss: 1.9560229, poison acc: 0.033\n",
      "elapsed time: 386.786, time for reg: 53.570, time for eig: 196.153\n",
      "epoch:  3479, loss: 0.3532790, train acc: 0.967\n",
      "test loss: 0.3721921, test acc: 0.983\n",
      "poison loss: 1.6874434, poison acc: 0.067\n",
      "elapsed time: 387.530, time for reg: 53.716, time for eig: 196.372\n",
      "epoch:  3489, loss: 0.5601273, train acc: 0.967\n",
      "test loss: 0.4803188, test acc: 0.883\n",
      "poison loss: 1.5919312, poison acc: 0.133\n",
      "elapsed time: 388.347, time for reg: 53.861, time for eig: 196.669\n",
      "epoch:  3499, loss: 0.4679681, train acc: 0.917\n",
      "test loss: 0.5076988, test acc: 0.900\n",
      "poison loss: 1.4815776, poison acc: 0.117\n",
      "elapsed time: 389.095, time for reg: 54.005, time for eig: 196.892\n",
      "epoch:  3509, loss: 0.4037611, train acc: 1.000\n",
      "test loss: 0.4936217, test acc: 1.000\n",
      "poison loss: 1.5118399, poison acc: 0.017\n",
      "elapsed time: 390.041, time for reg: 54.151, time for eig: 197.314\n",
      "epoch:  3519, loss: 0.4941448, train acc: 0.950\n",
      "test loss: 0.5121413, test acc: 0.933\n",
      "poison loss: 1.4377807, poison acc: 0.100\n",
      "elapsed time: 390.835, time for reg: 54.296, time for eig: 197.589\n",
      "epoch:  3529, loss: 0.5279228, train acc: 0.933\n",
      "test loss: 0.5749108, test acc: 0.883\n",
      "poison loss: 1.3569488, poison acc: 0.167\n",
      "elapsed time: 391.666, time for reg: 54.443, time for eig: 197.890\n",
      "epoch:  3539, loss: 0.4694651, train acc: 0.950\n",
      "test loss: 0.5404402, test acc: 0.900\n",
      "poison loss: 1.3724430, poison acc: 0.133\n",
      "elapsed time: 392.701, time for reg: 54.680, time for eig: 198.300\n",
      "epoch:  3549, loss: 0.4511091, train acc: 0.783\n",
      "test loss: 0.2506854, test acc: 1.000\n",
      "poison loss: 2.3557588, poison acc: 0.067\n",
      "elapsed time: 393.617, time for reg: 54.825, time for eig: 198.688\n",
      "epoch:  3559, loss: 0.5423850, train acc: 0.967\n",
      "test loss: 0.2627541, test acc: 0.983\n",
      "poison loss: 2.3505529, poison acc: 0.033\n",
      "elapsed time: 394.479, time for reg: 54.967, time for eig: 199.039\n",
      "epoch:  3569, loss: 0.5910183, train acc: 0.933\n",
      "test loss: 0.5978251, test acc: 0.867\n",
      "poison loss: 1.3095450, poison acc: 0.200\n",
      "elapsed time: 395.398, time for reg: 55.136, time for eig: 199.403\n",
      "epoch:  3579, loss: 0.5427823, train acc: 0.933\n",
      "test loss: 0.5922276, test acc: 0.867\n",
      "poison loss: 1.2958041, poison acc: 0.183\n",
      "elapsed time: 396.473, time for reg: 55.342, time for eig: 199.811\n",
      "epoch:  3589, loss: 0.5431396, train acc: 1.000\n",
      "test loss: 0.5497721, test acc: 1.000\n",
      "poison loss: 1.3406987, poison acc: 0.050\n",
      "elapsed time: 397.521, time for reg: 55.556, time for eig: 200.250\n",
      "epoch:  3599, loss: 0.4479345, train acc: 0.933\n",
      "test loss: 0.5527506, test acc: 0.883\n",
      "poison loss: 1.3472128, poison acc: 0.183\n",
      "elapsed time: 398.324, time for reg: 55.701, time for eig: 200.516\n",
      "epoch:  3609, loss: 0.4896210, train acc: 0.933\n",
      "test loss: 0.5480285, test acc: 0.883\n",
      "poison loss: 1.3520770, poison acc: 0.183\n",
      "elapsed time: 399.360, time for reg: 55.997, time for eig: 200.765\n",
      "epoch:  3619, loss: 0.5708454, train acc: 0.983\n",
      "test loss: 0.4277569, test acc: 0.983\n",
      "poison loss: 2.1528089, poison acc: 0.033\n",
      "elapsed time: 400.144, time for reg: 56.141, time for eig: 200.987\n",
      "epoch:  3629, loss: 0.5870101, train acc: 0.933\n",
      "test loss: 0.5717000, test acc: 0.883\n",
      "poison loss: 1.3309198, poison acc: 0.167\n",
      "elapsed time: 401.122, time for reg: 56.285, time for eig: 201.447\n",
      "epoch:  3639, loss: 0.3616101, train acc: 0.983\n",
      "test loss: 0.4780070, test acc: 0.883\n",
      "poison loss: 1.5115831, poison acc: 0.167\n",
      "elapsed time: 401.911, time for reg: 56.429, time for eig: 201.716\n",
      "epoch:  3649, loss: 0.4605808, train acc: 0.967\n",
      "test loss: 0.4537516, test acc: 0.983\n",
      "poison loss: 1.5526643, poison acc: 0.067\n",
      "elapsed time: 402.855, time for reg: 56.575, time for eig: 202.090\n",
      "epoch:  3659, loss: 0.4205600, train acc: 1.000\n",
      "test loss: 0.4984410, test acc: 0.983\n",
      "poison loss: 1.5161547, poison acc: 0.067\n",
      "elapsed time: 403.687, time for reg: 56.720, time for eig: 202.395\n",
      "epoch:  3669, loss: 0.4517254, train acc: 0.983\n",
      "test loss: 0.4752288, test acc: 1.000\n",
      "poison loss: 1.5339590, poison acc: 0.017\n",
      "elapsed time: 404.538, time for reg: 56.865, time for eig: 202.718\n",
      "epoch:  3679, loss: 0.5883730, train acc: 0.950\n",
      "test loss: 0.5671844, test acc: 0.900\n",
      "poison loss: 1.3999425, poison acc: 0.133\n",
      "elapsed time: 405.506, time for reg: 57.009, time for eig: 203.154\n",
      "epoch:  3689, loss: 0.5805872, train acc: 0.917\n",
      "test loss: 0.5799039, test acc: 0.900\n",
      "poison loss: 1.3883259, poison acc: 0.133\n",
      "elapsed time: 406.230, time for reg: 57.154, time for eig: 203.353\n",
      "epoch:  3699, loss: 0.4890520, train acc: 1.000\n",
      "test loss: 0.4220719, test acc: 1.000\n",
      "poison loss: 1.6404930, poison acc: 0.017\n",
      "elapsed time: 407.229, time for reg: 57.300, time for eig: 203.823\n",
      "epoch:  3709, loss: 0.4120377, train acc: 0.867\n",
      "test loss: 0.4712448, test acc: 0.917\n",
      "poison loss: 1.5865885, poison acc: 0.100\n",
      "elapsed time: 408.296, time for reg: 57.465, time for eig: 204.340\n",
      "epoch:  3719, loss: 0.6204483, train acc: 0.933\n",
      "test loss: 0.5776368, test acc: 0.900\n",
      "poison loss: 1.3866574, poison acc: 0.133\n",
      "elapsed time: 409.095, time for reg: 57.610, time for eig: 204.616\n",
      "epoch:  3729, loss: 0.5871140, train acc: 1.000\n",
      "test loss: 0.6065663, test acc: 1.000\n",
      "poison loss: 1.3391804, poison acc: 0.017\n",
      "elapsed time: 409.836, time for reg: 57.755, time for eig: 204.832\n",
      "epoch:  3739, loss: 0.5335163, train acc: 0.933\n",
      "test loss: 0.5954399, test acc: 0.900\n",
      "poison loss: 1.3585836, poison acc: 0.133\n",
      "elapsed time: 410.661, time for reg: 57.901, time for eig: 205.064\n",
      "epoch:  3749, loss: 0.5768062, train acc: 0.950\n",
      "test loss: 0.5778599, test acc: 0.900\n",
      "poison loss: 1.3809958, poison acc: 0.133\n",
      "elapsed time: 411.518, time for reg: 58.047, time for eig: 205.375\n",
      "epoch:  3759, loss: 0.5664657, train acc: 0.917\n",
      "test loss: 0.4900741, test acc: 1.000\n",
      "poison loss: 1.5186399, poison acc: 0.017\n",
      "elapsed time: 412.370, time for reg: 58.192, time for eig: 205.700\n",
      "epoch:  3769, loss: 0.5926284, train acc: 0.967\n",
      "test loss: 0.6266455, test acc: 0.900\n",
      "poison loss: 1.3169228, poison acc: 0.133\n",
      "elapsed time: 413.501, time for reg: 58.362, time for eig: 206.220\n",
      "epoch:  3779, loss: 0.5970131, train acc: 0.950\n",
      "test loss: 0.6233863, test acc: 0.900\n",
      "poison loss: 1.3267945, poison acc: 0.050\n",
      "elapsed time: 414.471, time for reg: 58.506, time for eig: 206.639\n",
      "epoch:  3789, loss: 0.5600733, train acc: 1.000\n",
      "test loss: 0.5869159, test acc: 1.000\n",
      "poison loss: 1.3563879, poison acc: 0.017\n",
      "elapsed time: 415.385, time for reg: 58.652, time for eig: 207.025\n",
      "epoch:  3799, loss: 0.6022094, train acc: 0.933\n",
      "test loss: 0.4440068, test acc: 1.000\n",
      "poison loss: 1.6411851, poison acc: 0.017\n",
      "elapsed time: 416.191, time for reg: 58.811, time for eig: 207.270\n",
      "epoch:  3809, loss: 0.5904508, train acc: 1.000\n",
      "test loss: 0.6276982, test acc: 0.933\n",
      "poison loss: 1.3090516, poison acc: 0.017\n",
      "elapsed time: 417.058, time for reg: 59.023, time for eig: 207.540\n",
      "epoch:  3819, loss: 0.6305007, train acc: 0.950\n",
      "test loss: 0.4511825, test acc: 0.967\n",
      "poison loss: 1.8225918, poison acc: 0.050\n",
      "elapsed time: 417.864, time for reg: 59.169, time for eig: 207.822\n",
      "epoch:  3829, loss: 0.6204646, train acc: 0.933\n",
      "test loss: 0.6259902, test acc: 0.900\n",
      "poison loss: 1.3075821, poison acc: 0.133\n",
      "elapsed time: 418.846, time for reg: 59.313, time for eig: 208.280\n",
      "epoch:  3839, loss: 0.5782608, train acc: 0.983\n",
      "test loss: 0.6214790, test acc: 0.900\n",
      "poison loss: 1.3198449, poison acc: 0.133\n",
      "elapsed time: 419.729, time for reg: 59.459, time for eig: 208.620\n",
      "epoch:  3849, loss: 0.5970227, train acc: 0.917\n",
      "test loss: 0.5649314, test acc: 1.000\n",
      "poison loss: 1.4130105, poison acc: 0.017\n",
      "elapsed time: 420.716, time for reg: 59.605, time for eig: 209.081\n",
      "epoch:  3859, loss: 0.6088638, train acc: 0.917\n",
      "test loss: 0.6248691, test acc: 0.900\n",
      "poison loss: 1.3116710, poison acc: 0.133\n",
      "elapsed time: 421.995, time for reg: 59.747, time for eig: 209.847\n",
      "epoch:  3869, loss: 0.6054952, train acc: 0.917\n",
      "test loss: 0.6214403, test acc: 0.900\n",
      "poison loss: 1.3136420, poison acc: 0.133\n",
      "elapsed time: 422.780, time for reg: 59.892, time for eig: 210.108\n",
      "epoch:  3879, loss: 0.5572142, train acc: 0.917\n",
      "test loss: 0.5802578, test acc: 0.900\n",
      "poison loss: 1.3625326, poison acc: 0.133\n",
      "elapsed time: 423.679, time for reg: 60.037, time for eig: 210.476\n",
      "epoch:  3889, loss: 0.5752224, train acc: 0.950\n",
      "test loss: 0.5863675, test acc: 0.900\n",
      "poison loss: 1.3518795, poison acc: 0.150\n",
      "elapsed time: 424.726, time for reg: 60.247, time for eig: 210.938\n",
      "epoch:  3899, loss: 0.5432609, train acc: 0.950\n",
      "test loss: 0.5905759, test acc: 0.900\n",
      "poison loss: 1.3506986, poison acc: 0.133\n",
      "elapsed time: 426.042, time for reg: 60.391, time for eig: 211.734\n",
      "epoch:  3909, loss: 0.6028613, train acc: 0.933\n",
      "test loss: 0.6179678, test acc: 0.900\n",
      "poison loss: 1.3104365, poison acc: 0.150\n",
      "elapsed time: 426.877, time for reg: 60.538, time for eig: 212.042\n",
      "epoch:  3919, loss: 0.5620897, train acc: 0.917\n",
      "test loss: 0.5668099, test acc: 0.900\n",
      "poison loss: 1.3761082, poison acc: 0.133\n",
      "elapsed time: 427.837, time for reg: 60.682, time for eig: 212.482\n",
      "epoch:  3929, loss: 0.5729414, train acc: 0.933\n",
      "test loss: 0.6101614, test acc: 0.900\n",
      "poison loss: 1.3197001, poison acc: 0.150\n",
      "elapsed time: 429.010, time for reg: 60.857, time for eig: 213.100\n",
      "epoch:  3939, loss: 0.5937290, train acc: 0.933\n",
      "test loss: 0.5992411, test acc: 0.900\n",
      "poison loss: 1.3463440, poison acc: 0.133\n",
      "elapsed time: 429.933, time for reg: 61.003, time for eig: 213.471\n",
      "epoch:  3949, loss: 0.6095876, train acc: 0.917\n",
      "test loss: 0.5979911, test acc: 0.900\n",
      "poison loss: 1.3375774, poison acc: 0.150\n",
      "elapsed time: 430.759, time for reg: 61.147, time for eig: 213.773\n",
      "epoch:  3959, loss: 0.5691639, train acc: 1.000\n",
      "test loss: 0.5884957, test acc: 1.000\n",
      "poison loss: 1.3609617, poison acc: 0.017\n",
      "elapsed time: 432.050, time for reg: 61.290, time for eig: 214.540\n",
      "epoch:  3969, loss: 0.6006643, train acc: 0.933\n",
      "test loss: 0.6214286, test acc: 0.900\n",
      "poison loss: 1.2982845, poison acc: 0.133\n",
      "elapsed time: 432.861, time for reg: 61.434, time for eig: 214.836\n",
      "epoch:  3979, loss: 0.5433000, train acc: 1.000\n",
      "test loss: 0.5912905, test acc: 1.000\n",
      "poison loss: 1.3353534, poison acc: 0.017\n",
      "elapsed time: 434.347, time for reg: 61.579, time for eig: 215.800\n",
      "epoch:  3989, loss: 0.5700670, train acc: 0.967\n",
      "test loss: 0.5640384, test acc: 0.900\n",
      "poison loss: 1.3228912, poison acc: 0.183\n",
      "elapsed time: 435.097, time for reg: 61.725, time for eig: 216.035\n",
      "epoch:  3999, loss: 0.5531923, train acc: 0.950\n",
      "test loss: 0.5159365, test acc: 1.000\n",
      "poison loss: 1.3846002, poison acc: 0.067\n",
      "elapsed time: 436.028, time for reg: 61.870, time for eig: 216.438\n",
      "epoch:  4009, loss: 0.5832784, train acc: 0.917\n",
      "test loss: 0.5808207, test acc: 0.900\n",
      "poison loss: 1.2956670, poison acc: 0.167\n",
      "elapsed time: 437.013, time for reg: 62.013, time for eig: 216.908\n",
      "epoch:  4019, loss: 0.5036937, train acc: 0.950\n",
      "test loss: 0.5634596, test acc: 0.900\n",
      "poison loss: 1.3157638, poison acc: 0.150\n",
      "elapsed time: 437.884, time for reg: 62.158, time for eig: 217.253\n",
      "epoch:  4029, loss: 0.5197708, train acc: 0.933\n",
      "test loss: 0.4037181, test acc: 1.000\n",
      "poison loss: 1.7097967, poison acc: 0.067\n",
      "elapsed time: 439.390, time for reg: 62.333, time for eig: 217.959\n",
      "epoch:  4039, loss: 0.5483736, train acc: 1.000\n",
      "test loss: 0.5547347, test acc: 0.983\n",
      "poison loss: 1.3693308, poison acc: 0.067\n",
      "elapsed time: 440.157, time for reg: 62.479, time for eig: 218.202\n",
      "epoch:  4049, loss: 0.5781904, train acc: 0.933\n",
      "test loss: 0.4455618, test acc: 0.967\n",
      "poison loss: 1.5542786, poison acc: 0.100\n",
      "elapsed time: 440.932, time for reg: 62.624, time for eig: 218.453\n",
      "epoch:  4059, loss: 0.5525792, train acc: 1.000\n",
      "test loss: 0.6227438, test acc: 0.983\n",
      "poison loss: 1.2628033, poison acc: 0.067\n",
      "elapsed time: 441.698, time for reg: 62.767, time for eig: 218.699\n",
      "epoch:  4069, loss: 0.4825460, train acc: 1.000\n",
      "test loss: 0.5646986, test acc: 1.000\n",
      "poison loss: 1.3934087, poison acc: 0.017\n",
      "elapsed time: 442.579, time for reg: 62.941, time for eig: 218.967\n",
      "epoch:  4079, loss: 0.5653313, train acc: 1.000\n",
      "test loss: 0.6217321, test acc: 0.983\n",
      "poison loss: 1.2706769, poison acc: 0.067\n",
      "elapsed time: 443.716, time for reg: 63.085, time for eig: 219.582\n",
      "epoch:  4089, loss: 0.5541502, train acc: 0.933\n",
      "test loss: 0.5840653, test acc: 0.883\n",
      "poison loss: 1.2952901, poison acc: 0.167\n",
      "elapsed time: 444.560, time for reg: 63.227, time for eig: 219.898\n",
      "epoch:  4099, loss: 0.5031682, train acc: 1.000\n",
      "test loss: 0.5217834, test acc: 0.983\n",
      "poison loss: 1.3762072, poison acc: 0.067\n",
      "elapsed time: 445.859, time for reg: 63.398, time for eig: 220.624\n",
      "epoch:  4109, loss: 0.5401597, train acc: 0.933\n",
      "test loss: 0.5599757, test acc: 0.900\n",
      "poison loss: 1.3130322, poison acc: 0.167\n",
      "elapsed time: 447.046, time for reg: 63.557, time for eig: 221.233\n",
      "epoch:  4119, loss: 0.5354978, train acc: 1.000\n",
      "test loss: 0.5522042, test acc: 1.000\n",
      "poison loss: 1.3232700, poison acc: 0.050\n",
      "elapsed time: 447.852, time for reg: 63.704, time for eig: 221.509\n",
      "epoch:  4129, loss: 0.5698010, train acc: 0.950\n",
      "test loss: 0.5963421, test acc: 0.917\n",
      "poison loss: 1.3008764, poison acc: 0.083\n",
      "elapsed time: 448.833, time for reg: 63.872, time for eig: 221.946\n",
      "epoch:  4139, loss: 0.4542459, train acc: 1.000\n",
      "test loss: 0.5430042, test acc: 1.000\n",
      "poison loss: 1.3446158, poison acc: 0.050\n",
      "elapsed time: 449.700, time for reg: 64.020, time for eig: 222.285\n",
      "epoch:  4149, loss: 0.5947343, train acc: 0.933\n",
      "test loss: 0.6523109, test acc: 0.883\n",
      "poison loss: 1.2467011, poison acc: 0.183\n",
      "elapsed time: 450.546, time for reg: 64.168, time for eig: 222.603\n",
      "epoch:  4159, loss: 0.6024408, train acc: 0.983\n",
      "test loss: 0.6482214, test acc: 0.983\n",
      "poison loss: 1.2408335, poison acc: 0.133\n",
      "elapsed time: 452.004, time for reg: 64.369, time for eig: 223.258\n",
      "epoch:  4169, loss: 0.5639702, train acc: 1.000\n",
      "test loss: 0.6055902, test acc: 0.983\n",
      "poison loss: 1.2723398, poison acc: 0.067\n",
      "elapsed time: 452.824, time for reg: 64.549, time for eig: 223.494\n",
      "epoch:  4179, loss: 0.5876194, train acc: 0.950\n",
      "test loss: 0.6591435, test acc: 0.883\n",
      "poison loss: 1.2237160, poison acc: 0.183\n",
      "elapsed time: 453.730, time for reg: 64.697, time for eig: 223.868\n",
      "epoch:  4189, loss: 0.5610971, train acc: 0.933\n",
      "test loss: 0.5759458, test acc: 0.883\n",
      "poison loss: 1.2988529, poison acc: 0.150\n",
      "elapsed time: 454.949, time for reg: 64.844, time for eig: 224.428\n",
      "epoch:  4199, loss: 0.5330728, train acc: 1.000\n",
      "test loss: 0.6104041, test acc: 0.983\n",
      "poison loss: 1.2943252, poison acc: 0.067\n",
      "elapsed time: 456.146, time for reg: 64.991, time for eig: 225.088\n",
      "epoch:  4209, loss: 0.5101238, train acc: 0.950\n",
      "test loss: 0.5591134, test acc: 0.917\n",
      "poison loss: 1.3454230, poison acc: 0.150\n",
      "elapsed time: 457.405, time for reg: 65.139, time for eig: 225.808\n",
      "epoch:  4219, loss: 0.5397152, train acc: 0.950\n",
      "test loss: 0.5970260, test acc: 0.883\n",
      "poison loss: 1.2650354, poison acc: 0.183\n",
      "elapsed time: 458.350, time for reg: 65.285, time for eig: 226.230\n",
      "epoch:  4229, loss: 0.5608625, train acc: 1.000\n",
      "test loss: 0.5931250, test acc: 0.983\n",
      "poison loss: 1.2784303, poison acc: 0.050\n",
      "elapsed time: 459.391, time for reg: 65.451, time for eig: 226.698\n",
      "epoch:  4239, loss: 0.5275595, train acc: 1.000\n",
      "test loss: 0.6252962, test acc: 0.917\n",
      "poison loss: 1.2773798, poison acc: 0.150\n",
      "elapsed time: 460.386, time for reg: 65.600, time for eig: 227.159\n",
      "epoch:  4249, loss: 0.4911163, train acc: 1.000\n",
      "test loss: 0.5526392, test acc: 1.000\n",
      "poison loss: 1.3301340, poison acc: 0.050\n",
      "elapsed time: 461.354, time for reg: 65.744, time for eig: 227.608\n",
      "epoch:  4259, loss: 0.5495838, train acc: 0.933\n",
      "test loss: 0.5656800, test acc: 0.900\n",
      "poison loss: 1.3210050, poison acc: 0.167\n",
      "elapsed time: 462.871, time for reg: 65.887, time for eig: 228.611\n",
      "epoch:  4269, loss: 0.5450378, train acc: 0.950\n",
      "test loss: 0.6131170, test acc: 0.883\n",
      "poison loss: 1.2443302, poison acc: 0.167\n",
      "elapsed time: 463.914, time for reg: 66.033, time for eig: 229.131\n",
      "epoch:  4279, loss: 0.5769144, train acc: 0.950\n",
      "test loss: 0.6206749, test acc: 0.900\n",
      "poison loss: 1.2394518, poison acc: 0.150\n",
      "elapsed time: 464.751, time for reg: 66.178, time for eig: 229.458\n",
      "epoch:  4289, loss: 0.5651222, train acc: 0.967\n",
      "test loss: 0.6135237, test acc: 0.983\n",
      "poison loss: 1.2436376, poison acc: 0.050\n",
      "elapsed time: 465.584, time for reg: 66.324, time for eig: 229.770\n",
      "epoch:  4299, loss: 0.5444322, train acc: 0.950\n",
      "test loss: 0.5948136, test acc: 0.917\n",
      "poison loss: 1.3396604, poison acc: 0.150\n",
      "elapsed time: 466.635, time for reg: 66.493, time for eig: 230.163\n",
      "epoch:  4309, loss: 0.5376771, train acc: 0.950\n",
      "test loss: 0.5513604, test acc: 0.983\n",
      "poison loss: 1.3532296, poison acc: 0.067\n",
      "elapsed time: 467.840, time for reg: 66.636, time for eig: 230.842\n",
      "epoch:  4319, loss: 0.3316762, train acc: 1.000\n",
      "test loss: 0.5147558, test acc: 0.967\n",
      "poison loss: 1.4465974, poison acc: 0.100\n",
      "elapsed time: 468.572, time for reg: 66.779, time for eig: 231.059\n",
      "epoch:  4329, loss: 0.3828346, train acc: 1.000\n",
      "test loss: 0.5022034, test acc: 0.983\n",
      "poison loss: 1.4202526, poison acc: 0.067\n",
      "elapsed time: 469.532, time for reg: 66.951, time for eig: 231.360\n",
      "epoch:  4339, loss: 0.4317093, train acc: 0.950\n",
      "test loss: 0.4609914, test acc: 1.000\n",
      "poison loss: 1.5051071, poison acc: 0.050\n",
      "elapsed time: 470.460, time for reg: 67.097, time for eig: 231.694\n",
      "epoch:  4349, loss: 0.3696148, train acc: 1.000\n",
      "test loss: 0.5028882, test acc: 0.983\n",
      "poison loss: 1.4358060, poison acc: 0.050\n",
      "elapsed time: 471.204, time for reg: 67.242, time for eig: 231.914\n",
      "epoch:  4359, loss: 0.5452009, train acc: 0.950\n",
      "test loss: 0.5621848, test acc: 0.917\n",
      "poison loss: 1.3380587, poison acc: 0.167\n",
      "elapsed time: 472.168, time for reg: 67.387, time for eig: 232.356\n",
      "epoch:  4369, loss: 0.5763851, train acc: 0.933\n",
      "test loss: 0.5690593, test acc: 0.883\n",
      "poison loss: 1.2812983, poison acc: 0.167\n",
      "elapsed time: 473.222, time for reg: 67.534, time for eig: 232.627\n",
      "epoch:  4379, loss: 0.5839527, train acc: 0.917\n",
      "test loss: 0.3943213, test acc: 0.983\n",
      "poison loss: 2.1445078, poison acc: 0.033\n",
      "elapsed time: 474.057, time for reg: 67.679, time for eig: 232.940\n",
      "epoch:  4389, loss: 0.4859005, train acc: 1.000\n",
      "test loss: 0.5281596, test acc: 1.000\n",
      "poison loss: 1.4250195, poison acc: 0.017\n",
      "elapsed time: 474.885, time for reg: 67.824, time for eig: 233.243\n",
      "epoch:  4399, loss: 0.4369162, train acc: 1.000\n",
      "test loss: 0.4917579, test acc: 0.983\n",
      "poison loss: 1.4024330, poison acc: 0.050\n",
      "elapsed time: 475.638, time for reg: 67.970, time for eig: 233.471\n",
      "epoch:  4409, loss: 0.5450860, train acc: 0.983\n",
      "test loss: 0.5995676, test acc: 0.983\n",
      "poison loss: 1.2762896, poison acc: 0.067\n",
      "elapsed time: 476.725, time for reg: 68.115, time for eig: 234.034\n",
      "epoch:  4419, loss: 0.4735867, train acc: 1.000\n",
      "test loss: 0.4963138, test acc: 0.983\n",
      "poison loss: 1.4414263, poison acc: 0.067\n",
      "elapsed time: 477.505, time for reg: 68.260, time for eig: 234.287\n",
      "epoch:  4429, loss: 0.5284610, train acc: 0.967\n",
      "test loss: 0.5604356, test acc: 1.000\n",
      "poison loss: 1.3059354, poison acc: 0.050\n",
      "elapsed time: 478.433, time for reg: 68.435, time for eig: 234.620\n",
      "epoch:  4439, loss: 0.5793866, train acc: 0.917\n",
      "test loss: 0.4138646, test acc: 0.983\n",
      "poison loss: 1.6981483, poison acc: 0.067\n",
      "elapsed time: 479.348, time for reg: 68.584, time for eig: 234.978\n",
      "epoch:  4449, loss: 0.5768798, train acc: 0.917\n",
      "test loss: 0.5825947, test acc: 0.983\n",
      "poison loss: 1.2698817, poison acc: 0.067\n",
      "elapsed time: 480.464, time for reg: 68.730, time for eig: 235.571\n",
      "epoch:  4459, loss: 0.5226985, train acc: 1.000\n",
      "test loss: 0.4840179, test acc: 0.983\n",
      "poison loss: 1.5477763, poison acc: 0.067\n",
      "elapsed time: 481.464, time for reg: 68.876, time for eig: 236.047\n",
      "epoch:  4469, loss: 0.5489644, train acc: 0.950\n",
      "test loss: 0.5524390, test acc: 0.983\n",
      "poison loss: 1.3176031, poison acc: 0.067\n",
      "elapsed time: 482.412, time for reg: 69.020, time for eig: 236.437\n",
      "epoch:  4479, loss: 0.4625265, train acc: 1.000\n",
      "test loss: 0.5363858, test acc: 0.983\n",
      "poison loss: 1.3674529, poison acc: 0.067\n",
      "elapsed time: 483.295, time for reg: 69.185, time for eig: 236.772\n",
      "epoch:  4489, loss: 0.5767155, train acc: 0.950\n",
      "test loss: 0.5734207, test acc: 0.967\n",
      "poison loss: 1.3163568, poison acc: 0.100\n",
      "elapsed time: 484.013, time for reg: 69.329, time for eig: 236.971\n",
      "epoch:  4499, loss: 0.3991324, train acc: 1.000\n",
      "test loss: 0.5052859, test acc: 1.000\n",
      "poison loss: 1.3997273, poison acc: 0.050\n",
      "elapsed time: 484.735, time for reg: 69.473, time for eig: 237.141\n",
      "epoch:  4509, loss: 0.3964012, train acc: 1.000\n",
      "test loss: 0.5553131, test acc: 0.883\n",
      "poison loss: 1.3150131, poison acc: 0.167\n",
      "elapsed time: 485.526, time for reg: 69.616, time for eig: 237.414\n",
      "epoch:  4519, loss: 0.5352064, train acc: 1.000\n",
      "test loss: 0.6449422, test acc: 0.933\n",
      "poison loss: 1.2458344, poison acc: 0.117\n",
      "elapsed time: 486.342, time for reg: 69.760, time for eig: 237.687\n",
      "epoch:  4529, loss: 0.5204861, train acc: 0.933\n",
      "test loss: 0.5827701, test acc: 0.883\n",
      "poison loss: 1.2905371, poison acc: 0.167\n",
      "elapsed time: 487.161, time for reg: 69.904, time for eig: 237.983\n",
      "epoch:  4539, loss: 0.4236182, train acc: 0.983\n",
      "test loss: 0.4883150, test acc: 0.983\n",
      "poison loss: 1.6080492, poison acc: 0.067\n",
      "elapsed time: 487.951, time for reg: 70.048, time for eig: 238.253\n",
      "epoch:  4549, loss: 0.5237317, train acc: 0.967\n",
      "test loss: 0.4949383, test acc: 0.933\n",
      "poison loss: 1.3819663, poison acc: 0.100\n",
      "elapsed time: 488.872, time for reg: 70.194, time for eig: 238.647\n",
      "epoch:  4559, loss: 0.5394286, train acc: 0.967\n",
      "test loss: 0.5454764, test acc: 0.917\n",
      "poison loss: 1.4192507, poison acc: 0.150\n",
      "elapsed time: 489.673, time for reg: 70.339, time for eig: 238.898\n",
      "epoch:  4569, loss: 0.5130958, train acc: 0.967\n",
      "test loss: 0.6243137, test acc: 0.883\n",
      "poison loss: 1.2515023, poison acc: 0.167\n",
      "elapsed time: 490.410, time for reg: 70.486, time for eig: 239.112\n",
      "epoch:  4579, loss: 0.5288431, train acc: 0.950\n",
      "test loss: 0.6182962, test acc: 0.883\n",
      "poison loss: 1.2572100, poison acc: 0.167\n",
      "elapsed time: 491.173, time for reg: 70.632, time for eig: 239.346\n",
      "epoch:  4589, loss: 0.5309688, train acc: 0.917\n",
      "test loss: 0.6477565, test acc: 0.883\n",
      "poison loss: 1.2342436, poison acc: 0.183\n",
      "elapsed time: 491.936, time for reg: 70.776, time for eig: 239.587\n",
      "epoch:  4599, loss: 0.5920477, train acc: 0.983\n",
      "test loss: 0.6349636, test acc: 0.983\n",
      "poison loss: 1.2350543, poison acc: 0.067\n",
      "elapsed time: 492.821, time for reg: 70.923, time for eig: 239.942\n",
      "epoch:  4609, loss: 0.5514007, train acc: 0.983\n",
      "test loss: 0.6373626, test acc: 0.917\n",
      "poison loss: 1.2395346, poison acc: 0.167\n",
      "elapsed time: 493.708, time for reg: 71.092, time for eig: 240.216\n",
      "epoch:  4619, loss: 0.5865220, train acc: 0.933\n",
      "test loss: 0.6516917, test acc: 0.950\n",
      "poison loss: 1.2242795, poison acc: 0.133\n",
      "elapsed time: 494.447, time for reg: 71.236, time for eig: 240.427\n",
      "epoch:  4629, loss: 0.5088301, train acc: 0.983\n",
      "test loss: 0.6507801, test acc: 0.833\n",
      "poison loss: 1.2292469, poison acc: 0.217\n",
      "elapsed time: 495.188, time for reg: 71.381, time for eig: 240.644\n",
      "epoch:  4639, loss: 0.4828018, train acc: 0.983\n",
      "test loss: 0.5317445, test acc: 0.883\n",
      "poison loss: 1.3797344, poison acc: 0.167\n",
      "elapsed time: 496.032, time for reg: 71.527, time for eig: 240.895\n",
      "epoch:  4649, loss: 0.4414933, train acc: 0.967\n",
      "test loss: 0.4608760, test acc: 1.000\n",
      "poison loss: 1.5942509, poison acc: 0.017\n",
      "elapsed time: 497.030, time for reg: 71.673, time for eig: 241.365\n",
      "epoch:  4659, loss: 0.4003558, train acc: 1.000\n",
      "test loss: 0.5393672, test acc: 0.983\n",
      "poison loss: 1.3875003, poison acc: 0.033\n",
      "elapsed time: 497.873, time for reg: 71.817, time for eig: 241.681\n",
      "epoch:  4669, loss: 0.5757336, train acc: 1.000\n",
      "test loss: 0.4609172, test acc: 0.983\n",
      "poison loss: 1.4748346, poison acc: 0.067\n",
      "elapsed time: 499.218, time for reg: 71.965, time for eig: 242.466\n",
      "epoch:  4679, loss: 0.5207636, train acc: 0.917\n",
      "test loss: 0.5726980, test acc: 0.900\n",
      "poison loss: 1.2994318, poison acc: 0.167\n",
      "elapsed time: 500.306, time for reg: 72.173, time for eig: 242.958\n",
      "epoch:  4689, loss: 0.5589957, train acc: 1.000\n",
      "test loss: 0.5991224, test acc: 1.000\n",
      "poison loss: 1.2747590, poison acc: 0.050\n",
      "elapsed time: 501.351, time for reg: 72.318, time for eig: 243.451\n",
      "epoch:  4699, loss: 0.5113380, train acc: 0.917\n",
      "test loss: 0.5893634, test acc: 0.883\n",
      "poison loss: 1.2809586, poison acc: 0.183\n",
      "elapsed time: 502.143, time for reg: 72.463, time for eig: 243.728\n",
      "epoch:  4709, loss: 0.5153854, train acc: 1.000\n",
      "test loss: 0.5641839, test acc: 0.983\n",
      "poison loss: 1.3295060, poison acc: 0.067\n",
      "elapsed time: 502.989, time for reg: 72.608, time for eig: 244.049\n",
      "epoch:  4719, loss: 0.5497755, train acc: 0.983\n",
      "test loss: 0.6024378, test acc: 0.983\n",
      "poison loss: 1.2995859, poison acc: 0.067\n",
      "elapsed time: 503.875, time for reg: 72.778, time for eig: 244.354\n",
      "epoch:  4729, loss: 0.5217979, train acc: 0.967\n",
      "test loss: 0.5623224, test acc: 0.883\n",
      "poison loss: 1.3499300, poison acc: 0.167\n",
      "elapsed time: 504.705, time for reg: 72.923, time for eig: 244.657\n",
      "epoch:  4739, loss: 0.5697753, train acc: 0.933\n",
      "test loss: 0.6215394, test acc: 0.883\n",
      "poison loss: 1.2823133, poison acc: 0.150\n",
      "elapsed time: 505.633, time for reg: 73.067, time for eig: 245.065\n",
      "epoch:  4749, loss: 0.4783956, train acc: 0.917\n",
      "test loss: 0.5120600, test acc: 0.900\n",
      "poison loss: 1.3893247, poison acc: 0.150\n",
      "elapsed time: 506.519, time for reg: 73.235, time for eig: 245.368\n",
      "epoch:  4759, loss: 0.4775952, train acc: 1.000\n",
      "test loss: 0.5256859, test acc: 1.000\n",
      "poison loss: 1.4627563, poison acc: 0.017\n",
      "elapsed time: 508.212, time for reg: 73.379, time for eig: 246.538\n",
      "epoch:  4769, loss: 0.5347403, train acc: 0.950\n",
      "test loss: 0.5911235, test acc: 0.900\n",
      "poison loss: 1.3422804, poison acc: 0.150\n",
      "elapsed time: 509.172, time for reg: 73.525, time for eig: 246.968\n",
      "epoch:  4779, loss: 0.5826280, train acc: 0.950\n",
      "test loss: 0.6263913, test acc: 0.900\n",
      "poison loss: 1.3044686, poison acc: 0.133\n",
      "elapsed time: 510.112, time for reg: 73.704, time for eig: 247.307\n",
      "epoch:  4789, loss: 0.5121740, train acc: 0.967\n",
      "test loss: 0.1863403, test acc: 1.000\n",
      "poison loss: 2.4599380, poison acc: 0.017\n",
      "elapsed time: 510.975, time for reg: 73.849, time for eig: 247.643\n",
      "epoch:  4799, loss: 0.5336534, train acc: 0.983\n",
      "test loss: 0.5524456, test acc: 0.983\n",
      "poison loss: 1.3351348, poison acc: 0.067\n",
      "elapsed time: 511.896, time for reg: 73.992, time for eig: 248.009\n",
      "epoch:  4809, loss: 0.5825027, train acc: 0.933\n",
      "test loss: 0.3256270, test acc: 0.983\n",
      "poison loss: 1.9534424, poison acc: 0.067\n",
      "elapsed time: 513.133, time for reg: 74.139, time for eig: 248.713\n",
      "epoch:  4819, loss: 0.5342171, train acc: 0.933\n",
      "test loss: 0.5642041, test acc: 0.983\n",
      "poison loss: 1.3355820, poison acc: 0.083\n",
      "elapsed time: 513.907, time for reg: 74.285, time for eig: 248.960\n",
      "epoch:  4829, loss: 0.5368845, train acc: 0.933\n",
      "test loss: 0.5955283, test acc: 0.883\n",
      "poison loss: 1.2852502, poison acc: 0.167\n",
      "elapsed time: 514.720, time for reg: 74.430, time for eig: 249.249\n",
      "epoch:  4839, loss: 0.6022148, train acc: 0.950\n",
      "test loss: 0.6451234, test acc: 0.883\n",
      "poison loss: 1.1936955, poison acc: 0.200\n",
      "elapsed time: 515.664, time for reg: 74.574, time for eig: 249.673\n",
      "epoch:  4849, loss: 0.5858024, train acc: 0.933\n",
      "test loss: 0.5789762, test acc: 0.883\n",
      "poison loss: 1.2967742, poison acc: 0.183\n",
      "elapsed time: 516.852, time for reg: 74.720, time for eig: 250.310\n",
      "epoch:  4859, loss: 0.5371638, train acc: 0.967\n",
      "test loss: 0.5844129, test acc: 0.917\n",
      "poison loss: 1.2622337, poison acc: 0.150\n",
      "elapsed time: 517.674, time for reg: 74.866, time for eig: 250.507\n",
      "epoch:  4869, loss: 0.5236785, train acc: 1.000\n",
      "test loss: 0.5976100, test acc: 0.983\n",
      "poison loss: 1.2998980, poison acc: 0.067\n",
      "elapsed time: 518.460, time for reg: 75.012, time for eig: 250.768\n",
      "epoch:  4879, loss: 0.5123196, train acc: 0.950\n",
      "test loss: 0.5924480, test acc: 0.883\n",
      "poison loss: 1.2587613, poison acc: 0.167\n",
      "elapsed time: 519.268, time for reg: 75.155, time for eig: 251.061\n",
      "epoch:  4889, loss: 0.5694698, train acc: 0.950\n",
      "test loss: 0.6318704, test acc: 0.900\n",
      "poison loss: 1.2118225, poison acc: 0.167\n",
      "elapsed time: 520.290, time for reg: 75.301, time for eig: 251.557\n",
      "epoch:  4899, loss: 0.5797718, train acc: 0.933\n",
      "test loss: 0.5382655, test acc: 0.867\n",
      "poison loss: 1.3249877, poison acc: 0.200\n",
      "elapsed time: 521.166, time for reg: 75.447, time for eig: 251.907\n",
      "epoch:  4909, loss: 0.5163858, train acc: 0.933\n",
      "test loss: 0.5693144, test acc: 0.983\n",
      "poison loss: 1.3400914, poison acc: 0.033\n",
      "elapsed time: 522.374, time for reg: 75.591, time for eig: 252.590\n",
      "epoch:  4919, loss: 0.5081549, train acc: 1.000\n",
      "test loss: 0.5652362, test acc: 1.000\n",
      "poison loss: 1.2860804, poison acc: 0.050\n",
      "elapsed time: 523.152, time for reg: 75.738, time for eig: 252.838\n",
      "epoch:  4929, loss: 0.5810872, train acc: 0.933\n",
      "test loss: 0.6262067, test acc: 0.883\n",
      "poison loss: 1.2207679, poison acc: 0.200\n",
      "elapsed time: 524.073, time for reg: 75.883, time for eig: 253.235\n",
      "epoch:  4939, loss: 0.5571679, train acc: 0.933\n",
      "test loss: 0.6456543, test acc: 0.867\n",
      "poison loss: 1.2070063, poison acc: 0.200\n",
      "elapsed time: 524.964, time for reg: 76.028, time for eig: 253.601\n",
      "epoch:  4949, loss: 0.5738121, train acc: 1.000\n",
      "test loss: 0.5801280, test acc: 0.917\n",
      "poison loss: 1.2967362, poison acc: 0.150\n",
      "elapsed time: 525.817, time for reg: 76.173, time for eig: 253.929\n",
      "epoch:  4959, loss: 0.5764067, train acc: 0.967\n",
      "test loss: 0.6143245, test acc: 0.900\n",
      "poison loss: 1.2677502, poison acc: 0.117\n",
      "elapsed time: 526.735, time for reg: 76.382, time for eig: 254.259\n",
      "epoch:  4969, loss: 0.5218728, train acc: 1.000\n",
      "test loss: 0.5947159, test acc: 1.000\n",
      "poison loss: 1.2900688, poison acc: 0.050\n",
      "elapsed time: 527.513, time for reg: 76.526, time for eig: 254.511\n",
      "epoch:  4979, loss: 0.5069727, train acc: 0.983\n",
      "test loss: 0.5573609, test acc: 0.983\n",
      "poison loss: 1.3114125, poison acc: 0.067\n",
      "elapsed time: 528.301, time for reg: 76.720, time for eig: 254.723\n",
      "epoch:  4989, loss: 0.4072938, train acc: 1.000\n",
      "test loss: 0.5085732, test acc: 0.983\n",
      "poison loss: 1.3603551, poison acc: 0.067\n",
      "elapsed time: 529.511, time for reg: 76.867, time for eig: 255.401\n",
      "epoch:  4999, loss: 0.4196777, train acc: 1.000\n",
      "test loss: 0.5073202, test acc: 0.983\n",
      "poison loss: 1.4365637, poison acc: 0.067\n",
      "elapsed time: 530.433, time for reg: 77.012, time for eig: 255.796\n",
      "epoch:  5009, loss: 0.4822028, train acc: 0.933\n",
      "test loss: 0.3701858, test acc: 0.983\n",
      "poison loss: 2.0724602, poison acc: 0.067\n",
      "elapsed time: 531.216, time for reg: 77.157, time for eig: 256.020\n",
      "epoch:  5019, loss: 0.5585427, train acc: 0.933\n",
      "test loss: 0.4738000, test acc: 0.983\n",
      "poison loss: 1.6086684, poison acc: 0.067\n",
      "elapsed time: 532.426, time for reg: 77.336, time for eig: 256.662\n",
      "epoch:  5029, loss: 0.5498240, train acc: 0.933\n",
      "test loss: 0.5892931, test acc: 0.950\n",
      "poison loss: 1.2698461, poison acc: 0.100\n",
      "elapsed time: 533.459, time for reg: 77.543, time for eig: 257.102\n",
      "epoch:  5039, loss: 0.5356365, train acc: 0.950\n",
      "test loss: 0.5435498, test acc: 0.900\n",
      "poison loss: 1.3215781, poison acc: 0.167\n",
      "elapsed time: 534.964, time for reg: 77.689, time for eig: 258.027\n",
      "epoch:  5049, loss: 0.5142980, train acc: 1.000\n",
      "test loss: 0.4095366, test acc: 0.983\n",
      "poison loss: 1.6291539, poison acc: 0.067\n",
      "elapsed time: 535.852, time for reg: 77.837, time for eig: 258.297\n",
      "epoch:  5059, loss: 0.5335191, train acc: 0.967\n",
      "test loss: 0.5975444, test acc: 0.983\n",
      "poison loss: 1.2820525, poison acc: 0.067\n",
      "elapsed time: 536.755, time for reg: 77.982, time for eig: 258.674\n",
      "epoch:  5069, loss: 0.4606416, train acc: 1.000\n",
      "test loss: 0.5359863, test acc: 0.983\n",
      "poison loss: 1.3530915, poison acc: 0.067\n",
      "elapsed time: 537.432, time for reg: 78.127, time for eig: 258.821\n",
      "epoch:  5079, loss: 0.6054009, train acc: 0.917\n",
      "test loss: 0.5383968, test acc: 0.983\n",
      "poison loss: 1.4179729, poison acc: 0.033\n",
      "elapsed time: 538.338, time for reg: 78.281, time for eig: 259.170\n",
      "epoch:  5089, loss: 0.4786237, train acc: 0.933\n",
      "test loss: 0.5958104, test acc: 0.883\n",
      "poison loss: 1.2791520, poison acc: 0.167\n",
      "elapsed time: 539.324, time for reg: 78.426, time for eig: 259.639\n",
      "epoch:  5099, loss: 0.5126937, train acc: 0.950\n",
      "test loss: 0.5991402, test acc: 0.983\n",
      "poison loss: 1.2971013, poison acc: 0.050\n",
      "elapsed time: 540.204, time for reg: 78.570, time for eig: 259.976\n",
      "epoch:  5109, loss: 0.5116203, train acc: 0.950\n",
      "test loss: 0.6250014, test acc: 0.883\n",
      "poison loss: 1.2544528, poison acc: 0.167\n",
      "elapsed time: 541.028, time for reg: 78.716, time for eig: 260.278\n",
      "epoch:  5119, loss: 0.5459885, train acc: 0.933\n",
      "test loss: 0.5854714, test acc: 0.883\n",
      "poison loss: 1.3711745, poison acc: 0.200\n",
      "elapsed time: 541.834, time for reg: 78.863, time for eig: 260.561\n",
      "epoch:  5129, loss: 0.5301468, train acc: 0.933\n",
      "test loss: 0.6238244, test acc: 0.883\n",
      "poison loss: 1.2554773, poison acc: 0.200\n",
      "elapsed time: 542.890, time for reg: 79.008, time for eig: 261.095\n",
      "epoch:  5139, loss: 0.5579313, train acc: 0.967\n",
      "test loss: 0.6329272, test acc: 0.983\n",
      "poison loss: 1.2295976, poison acc: 0.083\n",
      "elapsed time: 543.775, time for reg: 79.186, time for eig: 261.425\n",
      "epoch:  5149, loss: 0.5162457, train acc: 1.000\n",
      "test loss: 0.5803778, test acc: 0.983\n",
      "poison loss: 1.2827780, poison acc: 0.050\n",
      "elapsed time: 544.596, time for reg: 79.364, time for eig: 261.666\n",
      "epoch:  5159, loss: 0.5104929, train acc: 0.950\n",
      "test loss: 0.5821411, test acc: 0.900\n",
      "poison loss: 1.3196007, poison acc: 0.167\n",
      "elapsed time: 545.429, time for reg: 79.509, time for eig: 261.970\n",
      "epoch:  5169, loss: 0.5559130, train acc: 0.967\n",
      "test loss: 0.5766998, test acc: 0.917\n",
      "poison loss: 1.2764770, poison acc: 0.150\n",
      "elapsed time: 546.228, time for reg: 79.655, time for eig: 262.244\n",
      "epoch:  5179, loss: 0.3854011, train acc: 1.000\n",
      "test loss: 0.4606822, test acc: 1.000\n",
      "poison loss: 1.4392120, poison acc: 0.050\n",
      "elapsed time: 547.075, time for reg: 79.797, time for eig: 262.452\n",
      "epoch:  5189, loss: 0.4713793, train acc: 0.933\n",
      "test loss: 0.5250198, test acc: 0.883\n",
      "poison loss: 1.3487281, poison acc: 0.167\n",
      "elapsed time: 547.908, time for reg: 79.943, time for eig: 262.764\n",
      "epoch:  5199, loss: 0.5688766, train acc: 0.933\n",
      "test loss: 0.6437625, test acc: 0.883\n",
      "poison loss: 1.2080209, poison acc: 0.200\n",
      "elapsed time: 548.853, time for reg: 80.089, time for eig: 263.184\n",
      "epoch:  5209, loss: 0.5618390, train acc: 0.967\n",
      "test loss: 0.6528747, test acc: 0.883\n",
      "poison loss: 1.1998630, poison acc: 0.150\n",
      "elapsed time: 549.787, time for reg: 80.233, time for eig: 263.571\n",
      "epoch:  5219, loss: 0.4238161, train acc: 0.967\n",
      "test loss: 0.4612400, test acc: 0.983\n",
      "poison loss: 1.4966164, poison acc: 0.050\n",
      "elapsed time: 550.490, time for reg: 80.377, time for eig: 263.752\n",
      "epoch:  5229, loss: 0.5588799, train acc: 0.950\n",
      "test loss: 0.6468163, test acc: 0.883\n",
      "poison loss: 1.1981897, poison acc: 0.233\n",
      "elapsed time: 551.334, time for reg: 80.522, time for eig: 264.083\n",
      "epoch:  5239, loss: 0.5307481, train acc: 0.967\n",
      "test loss: 0.5979627, test acc: 0.867\n",
      "poison loss: 1.2308799, poison acc: 0.200\n",
      "elapsed time: 552.255, time for reg: 80.745, time for eig: 264.403\n",
      "epoch:  5249, loss: 0.5176738, train acc: 0.933\n",
      "test loss: 0.5783871, test acc: 0.933\n",
      "poison loss: 1.2768478, poison acc: 0.133\n",
      "elapsed time: 553.243, time for reg: 80.890, time for eig: 264.873\n",
      "epoch:  5259, loss: 0.3517943, train acc: 1.000\n",
      "test loss: 0.3730454, test acc: 0.983\n",
      "poison loss: 2.0190392, poison acc: 0.067\n",
      "elapsed time: 554.040, time for reg: 81.036, time for eig: 265.138\n",
      "epoch:  5269, loss: 0.5516806, train acc: 0.933\n",
      "test loss: 0.5700737, test acc: 0.983\n",
      "poison loss: 1.3008051, poison acc: 0.067\n",
      "elapsed time: 554.880, time for reg: 81.205, time for eig: 265.387\n",
      "epoch:  5279, loss: 0.5434637, train acc: 0.950\n",
      "test loss: 0.5776301, test acc: 0.883\n",
      "poison loss: 1.2865881, poison acc: 0.167\n",
      "elapsed time: 555.707, time for reg: 81.350, time for eig: 265.690\n",
      "epoch:  5289, loss: 0.5369260, train acc: 0.933\n",
      "test loss: 0.5938195, test acc: 0.883\n",
      "poison loss: 1.2646582, poison acc: 0.167\n",
      "elapsed time: 556.567, time for reg: 81.501, time for eig: 266.011\n",
      "epoch:  5299, loss: 0.4768444, train acc: 1.000\n",
      "test loss: 0.4843022, test acc: 0.883\n",
      "poison loss: 1.4167656, poison acc: 0.183\n",
      "elapsed time: 557.361, time for reg: 81.656, time for eig: 266.225\n",
      "epoch:  5309, loss: 0.5163362, train acc: 0.950\n",
      "test loss: 0.6386049, test acc: 0.883\n",
      "poison loss: 1.2024716, poison acc: 0.183\n",
      "elapsed time: 558.160, time for reg: 81.807, time for eig: 266.480\n",
      "epoch:  5319, loss: 0.5042255, train acc: 0.950\n",
      "test loss: 0.6043721, test acc: 0.883\n",
      "poison loss: 1.2441540, poison acc: 0.167\n",
      "elapsed time: 558.900, time for reg: 81.958, time for eig: 266.679\n",
      "epoch:  5329, loss: 0.5725846, train acc: 0.933\n",
      "test loss: 0.6656057, test acc: 0.883\n",
      "poison loss: 1.1814000, poison acc: 0.183\n",
      "elapsed time: 559.701, time for reg: 82.110, time for eig: 266.935\n",
      "epoch:  5339, loss: 0.5621593, train acc: 0.933\n",
      "test loss: 0.6323268, test acc: 0.883\n",
      "poison loss: 1.2113489, poison acc: 0.167\n",
      "elapsed time: 560.517, time for reg: 82.264, time for eig: 267.198\n",
      "epoch:  5349, loss: 0.5283664, train acc: 0.983\n",
      "test loss: 0.5959062, test acc: 0.983\n",
      "poison loss: 1.2690001, poison acc: 0.100\n",
      "elapsed time: 561.570, time for reg: 82.487, time for eig: 267.642\n",
      "epoch:  5359, loss: 0.5671904, train acc: 0.933\n",
      "test loss: 0.6594088, test acc: 0.867\n",
      "poison loss: 1.1841010, poison acc: 0.200\n",
      "elapsed time: 562.422, time for reg: 82.644, time for eig: 267.878\n",
      "epoch:  5369, loss: 0.4916236, train acc: 0.917\n",
      "test loss: 0.5776205, test acc: 0.917\n",
      "poison loss: 1.3484278, poison acc: 0.133\n",
      "elapsed time: 563.223, time for reg: 82.791, time for eig: 268.145\n",
      "epoch:  5379, loss: 0.5625502, train acc: 0.933\n",
      "test loss: 0.4065085, test acc: 0.983\n",
      "poison loss: 1.6999049, poison acc: 0.117\n",
      "elapsed time: 563.976, time for reg: 82.938, time for eig: 268.360\n",
      "epoch:  5389, loss: 0.5362264, train acc: 0.950\n",
      "test loss: 0.5537257, test acc: 0.983\n",
      "poison loss: 1.4705266, poison acc: 0.083\n",
      "elapsed time: 564.719, time for reg: 83.086, time for eig: 268.569\n",
      "epoch:  5399, loss: 0.5692265, train acc: 0.933\n",
      "test loss: 0.6374343, test acc: 0.867\n",
      "poison loss: 1.1947230, poison acc: 0.217\n",
      "elapsed time: 565.475, time for reg: 83.234, time for eig: 268.791\n",
      "epoch:  5409, loss: 0.5647561, train acc: 0.933\n",
      "test loss: 0.6659738, test acc: 0.867\n",
      "poison loss: 1.1615624, poison acc: 0.267\n",
      "elapsed time: 566.494, time for reg: 83.382, time for eig: 269.250\n",
      "epoch:  5419, loss: 0.5408452, train acc: 0.933\n",
      "test loss: 0.5553056, test acc: 0.900\n",
      "poison loss: 1.2435613, poison acc: 0.150\n",
      "elapsed time: 567.267, time for reg: 83.529, time for eig: 269.490\n",
      "epoch:  5429, loss: 0.4314942, train acc: 1.000\n",
      "test loss: 0.5124208, test acc: 0.983\n",
      "poison loss: 1.3731650, poison acc: 0.067\n",
      "elapsed time: 568.005, time for reg: 83.677, time for eig: 269.693\n",
      "epoch:  5439, loss: 0.5721566, train acc: 0.917\n",
      "test loss: 0.4695644, test acc: 1.000\n",
      "poison loss: 1.4641489, poison acc: 0.067\n",
      "elapsed time: 569.341, time for reg: 83.824, time for eig: 270.495\n",
      "epoch:  5449, loss: 0.4719874, train acc: 1.000\n",
      "test loss: 0.5598155, test acc: 0.933\n",
      "poison loss: 1.3772923, poison acc: 0.133\n",
      "elapsed time: 570.150, time for reg: 83.973, time for eig: 270.699\n",
      "epoch:  5459, loss: 0.5430644, train acc: 0.933\n",
      "test loss: 0.6266042, test acc: 0.883\n",
      "poison loss: 1.2354578, poison acc: 0.200\n",
      "elapsed time: 571.046, time for reg: 84.120, time for eig: 271.064\n",
      "epoch:  5469, loss: 0.5018627, train acc: 0.950\n",
      "test loss: 0.5884691, test acc: 0.883\n",
      "poison loss: 1.2758413, poison acc: 0.183\n",
      "elapsed time: 571.932, time for reg: 84.267, time for eig: 271.415\n",
      "epoch:  5479, loss: 0.5149648, train acc: 0.933\n",
      "test loss: 0.6174491, test acc: 0.867\n",
      "poison loss: 1.2169994, poison acc: 0.217\n",
      "elapsed time: 572.692, time for reg: 84.444, time for eig: 271.609\n",
      "epoch:  5489, loss: 0.5132957, train acc: 0.933\n",
      "test loss: 0.5363744, test acc: 0.867\n",
      "poison loss: 1.3100701, poison acc: 0.200\n",
      "elapsed time: 573.558, time for reg: 84.591, time for eig: 271.939\n",
      "epoch:  5499, loss: 0.5358332, train acc: 0.933\n",
      "test loss: 0.6415217, test acc: 0.867\n",
      "poison loss: 1.1927754, poison acc: 0.233\n",
      "elapsed time: 574.293, time for reg: 84.739, time for eig: 272.152\n",
      "epoch:  5509, loss: 0.4835468, train acc: 1.000\n",
      "test loss: 0.6032012, test acc: 0.883\n",
      "poison loss: 1.2176222, poison acc: 0.200\n",
      "elapsed time: 575.645, time for reg: 84.887, time for eig: 272.865\n",
      "epoch:  5519, loss: 0.5464254, train acc: 0.933\n",
      "test loss: 0.6078560, test acc: 0.917\n",
      "poison loss: 1.2303099, poison acc: 0.150\n",
      "elapsed time: 576.474, time for reg: 85.036, time for eig: 273.087\n",
      "epoch:  5529, loss: 0.5111855, train acc: 0.933\n",
      "test loss: 0.5960547, test acc: 0.867\n",
      "poison loss: 1.2374387, poison acc: 0.267\n",
      "elapsed time: 577.309, time for reg: 85.184, time for eig: 273.362\n",
      "epoch:  5539, loss: 0.5394546, train acc: 0.950\n",
      "test loss: 0.6004137, test acc: 0.867\n",
      "poison loss: 1.2236584, poison acc: 0.233\n",
      "elapsed time: 578.112, time for reg: 85.333, time for eig: 273.621\n",
      "epoch:  5549, loss: 0.4663835, train acc: 0.933\n",
      "test loss: 0.6049430, test acc: 0.867\n",
      "poison loss: 1.2283422, poison acc: 0.267\n",
      "elapsed time: 578.939, time for reg: 85.489, time for eig: 273.906\n",
      "epoch:  5559, loss: 0.5510704, train acc: 0.983\n",
      "test loss: 0.6445692, test acc: 0.983\n",
      "poison loss: 1.1713367, poison acc: 0.133\n",
      "elapsed time: 579.731, time for reg: 85.636, time for eig: 274.167\n",
      "epoch:  5569, loss: 0.5482912, train acc: 1.000\n",
      "test loss: 0.5768264, test acc: 0.983\n",
      "poison loss: 1.2676761, poison acc: 0.067\n",
      "elapsed time: 581.152, time for reg: 85.784, time for eig: 275.020\n",
      "epoch:  5579, loss: 0.5583759, train acc: 0.967\n",
      "test loss: 0.5974880, test acc: 0.867\n",
      "poison loss: 1.2096825, poison acc: 0.267\n",
      "elapsed time: 582.861, time for reg: 85.933, time for eig: 276.194\n",
      "epoch:  5589, loss: 0.5516264, train acc: 0.917\n",
      "test loss: 0.5756537, test acc: 0.900\n",
      "poison loss: 1.2743996, poison acc: 0.217\n",
      "elapsed time: 583.689, time for reg: 86.080, time for eig: 276.488\n",
      "epoch:  5599, loss: 0.5192258, train acc: 0.933\n",
      "test loss: 0.6203808, test acc: 0.850\n",
      "poison loss: 1.2005807, poison acc: 0.250\n",
      "elapsed time: 584.987, time for reg: 86.228, time for eig: 277.250\n",
      "epoch:  5609, loss: 0.5533241, train acc: 0.900\n",
      "test loss: 0.6477169, test acc: 0.867\n",
      "poison loss: 1.1638354, poison acc: 0.233\n",
      "elapsed time: 585.738, time for reg: 86.375, time for eig: 277.465\n",
      "epoch:  5619, loss: 0.5510310, train acc: 0.917\n",
      "test loss: 0.6348340, test acc: 0.900\n",
      "poison loss: 1.1727419, poison acc: 0.233\n",
      "elapsed time: 586.603, time for reg: 86.522, time for eig: 277.795\n",
      "epoch:  5629, loss: 0.5048978, train acc: 0.900\n",
      "test loss: 0.6173715, test acc: 0.867\n",
      "poison loss: 1.1920064, poison acc: 0.250\n",
      "elapsed time: 587.509, time for reg: 86.669, time for eig: 278.169\n",
      "epoch:  5639, loss: 0.5842119, train acc: 0.917\n",
      "test loss: 0.5903146, test acc: 0.867\n",
      "poison loss: 1.2286223, poison acc: 0.267\n",
      "elapsed time: 588.300, time for reg: 86.817, time for eig: 278.426\n",
      "epoch:  5649, loss: 0.4576797, train acc: 0.967\n",
      "test loss: 0.4487111, test acc: 0.933\n",
      "poison loss: 1.4744585, poison acc: 0.150\n",
      "elapsed time: 589.087, time for reg: 86.964, time for eig: 278.671\n",
      "epoch:  5659, loss: 0.3900492, train acc: 1.000\n",
      "test loss: 0.4016460, test acc: 0.833\n",
      "poison loss: 2.1929609, poison acc: 0.167\n",
      "elapsed time: 589.970, time for reg: 87.113, time for eig: 279.016\n",
      "epoch:  5669, loss: 0.2841121, train acc: 1.000\n",
      "test loss: 0.2630479, test acc: 0.983\n",
      "poison loss: 2.1318887, poison acc: 0.083\n",
      "elapsed time: 590.761, time for reg: 87.280, time for eig: 279.249\n",
      "epoch:  5679, loss: 0.3339909, train acc: 0.950\n",
      "test loss: 0.4870473, test acc: 0.983\n",
      "poison loss: 1.4920992, poison acc: 0.083\n",
      "elapsed time: 591.601, time for reg: 87.427, time for eig: 279.553\n",
      "epoch:  5689, loss: 0.3602542, train acc: 0.933\n",
      "test loss: 0.4824234, test acc: 0.867\n",
      "poison loss: 1.3720075, poison acc: 0.250\n",
      "elapsed time: 592.338, time for reg: 87.575, time for eig: 279.754\n",
      "epoch:  5699, loss: 0.4939377, train acc: 0.917\n",
      "test loss: 0.6799724, test acc: 0.900\n",
      "poison loss: 2.0247859, poison acc: 0.150\n",
      "elapsed time: 593.239, time for reg: 87.723, time for eig: 280.018\n",
      "epoch:  5709, loss: 0.3871770, train acc: 1.000\n",
      "test loss: 0.5916563, test acc: 0.983\n",
      "poison loss: 1.3732886, poison acc: 0.067\n",
      "elapsed time: 594.361, time for reg: 87.871, time for eig: 280.606\n",
      "epoch:  5719, loss: 0.5194892, train acc: 0.933\n",
      "test loss: 0.4772512, test acc: 0.967\n",
      "poison loss: 1.4088712, poison acc: 0.100\n",
      "elapsed time: 595.267, time for reg: 88.018, time for eig: 280.953\n",
      "epoch:  5729, loss: 0.5494734, train acc: 0.883\n",
      "test loss: 0.4601459, test acc: 0.683\n",
      "poison loss: 1.9915735, poison acc: 0.233\n",
      "elapsed time: 596.187, time for reg: 88.166, time for eig: 281.337\n",
      "epoch:  5739, loss: 0.3455494, train acc: 1.000\n",
      "test loss: 0.5219089, test acc: 0.983\n",
      "poison loss: 1.3852333, poison acc: 0.067\n",
      "elapsed time: 597.061, time for reg: 88.378, time for eig: 281.596\n",
      "epoch:  5749, loss: 0.4773658, train acc: 0.967\n",
      "test loss: 0.5187376, test acc: 0.983\n",
      "poison loss: 1.4362955, poison acc: 0.067\n",
      "elapsed time: 597.804, time for reg: 88.526, time for eig: 281.802\n",
      "epoch:  5759, loss: 0.5054288, train acc: 1.000\n",
      "test loss: 0.6067923, test acc: 0.867\n",
      "poison loss: 1.2256817, poison acc: 0.233\n",
      "elapsed time: 598.716, time for reg: 88.674, time for eig: 282.178\n",
      "epoch:  5769, loss: 0.4769916, train acc: 1.000\n",
      "test loss: 0.4941920, test acc: 1.000\n",
      "poison loss: 1.6254305, poison acc: 0.017\n",
      "elapsed time: 599.683, time for reg: 88.925, time for eig: 282.503\n",
      "epoch:  5779, loss: 0.4390240, train acc: 1.000\n",
      "test loss: 0.5299472, test acc: 1.000\n",
      "poison loss: 1.4251804, poison acc: 0.067\n",
      "elapsed time: 600.496, time for reg: 89.072, time for eig: 282.782\n",
      "epoch:  5789, loss: 0.5419061, train acc: 1.000\n",
      "test loss: 0.5738572, test acc: 1.000\n",
      "poison loss: 1.4046828, poison acc: 0.067\n",
      "elapsed time: 601.512, time for reg: 89.219, time for eig: 283.263\n",
      "epoch:  5799, loss: 0.4016156, train acc: 1.000\n",
      "test loss: 0.4503098, test acc: 1.000\n",
      "poison loss: 1.5433650, poison acc: 0.067\n",
      "elapsed time: 602.318, time for reg: 89.367, time for eig: 283.534\n",
      "epoch:  5809, loss: 0.4084078, train acc: 1.000\n",
      "test loss: 0.4338110, test acc: 1.000\n",
      "poison loss: 1.6342559, poison acc: 0.067\n",
      "elapsed time: 603.353, time for reg: 89.515, time for eig: 283.940\n",
      "epoch:  5819, loss: 0.4846933, train acc: 1.000\n",
      "test loss: 0.4713854, test acc: 0.983\n",
      "poison loss: 1.5664693, poison acc: 0.050\n",
      "elapsed time: 604.229, time for reg: 89.663, time for eig: 284.285\n",
      "epoch:  5829, loss: 0.5456999, train acc: 1.000\n",
      "test loss: 0.5765467, test acc: 1.000\n",
      "poison loss: 1.3701465, poison acc: 0.067\n",
      "elapsed time: 605.036, time for reg: 89.811, time for eig: 284.560\n",
      "epoch:  5839, loss: 0.4686882, train acc: 1.000\n",
      "test loss: 0.5330729, test acc: 0.983\n",
      "poison loss: 1.5570846, poison acc: 0.067\n",
      "elapsed time: 606.038, time for reg: 89.960, time for eig: 284.905\n",
      "epoch:  5849, loss: 0.4343484, train acc: 1.000\n",
      "test loss: 0.5765188, test acc: 0.983\n",
      "poison loss: 1.4466148, poison acc: 0.067\n",
      "elapsed time: 606.857, time for reg: 90.108, time for eig: 285.193\n",
      "epoch:  5859, loss: 0.4620760, train acc: 0.883\n",
      "test loss: 0.4113578, test acc: 0.983\n",
      "poison loss: 1.8351636, poison acc: 0.067\n",
      "elapsed time: 607.701, time for reg: 90.255, time for eig: 285.505\n",
      "epoch:  5869, loss: 0.5083195, train acc: 1.000\n",
      "test loss: 0.6091635, test acc: 0.983\n",
      "poison loss: 1.4247317, poison acc: 0.050\n",
      "elapsed time: 608.688, time for reg: 90.418, time for eig: 285.944\n",
      "epoch:  5879, loss: 0.3968213, train acc: 1.000\n",
      "test loss: 0.5178236, test acc: 0.983\n",
      "poison loss: 1.5348687, poison acc: 0.067\n",
      "elapsed time: 609.764, time for reg: 90.632, time for eig: 286.418\n",
      "epoch:  5889, loss: 0.5026940, train acc: 0.967\n",
      "test loss: 0.5937659, test acc: 0.850\n",
      "poison loss: 1.4867454, poison acc: 0.183\n",
      "elapsed time: 610.550, time for reg: 90.779, time for eig: 286.679\n",
      "epoch:  5899, loss: 0.5732913, train acc: 0.950\n",
      "test loss: 0.5315582, test acc: 0.933\n",
      "poison loss: 1.7090050, poison acc: 0.133\n",
      "elapsed time: 611.306, time for reg: 90.927, time for eig: 286.902\n",
      "epoch:  5909, loss: 0.5348216, train acc: 1.000\n",
      "test loss: 0.5758888, test acc: 0.983\n",
      "poison loss: 1.4782782, poison acc: 0.067\n",
      "elapsed time: 612.224, time for reg: 91.084, time for eig: 287.247\n",
      "epoch:  5919, loss: 0.4666278, train acc: 1.000\n",
      "test loss: 0.6109730, test acc: 0.933\n",
      "poison loss: 1.3672368, poison acc: 0.117\n",
      "elapsed time: 613.046, time for reg: 91.231, time for eig: 287.535\n",
      "epoch:  5929, loss: 0.2964000, train acc: 1.000\n",
      "test loss: 0.3674301, test acc: 0.983\n",
      "poison loss: 2.0046121, poison acc: 0.067\n",
      "elapsed time: 614.393, time for reg: 91.378, time for eig: 288.343\n",
      "epoch:  5939, loss: 0.4981406, train acc: 1.000\n",
      "test loss: 0.6424331, test acc: 0.900\n",
      "poison loss: 1.3282588, poison acc: 0.167\n",
      "elapsed time: 615.413, time for reg: 91.525, time for eig: 288.829\n",
      "epoch:  5949, loss: 0.4586515, train acc: 1.000\n",
      "test loss: 0.3800129, test acc: 0.950\n",
      "poison loss: 2.1005295, poison acc: 0.067\n",
      "elapsed time: 616.394, time for reg: 91.672, time for eig: 289.278\n",
      "epoch:  5959, loss: 0.5023743, train acc: 0.950\n",
      "test loss: 0.5631946, test acc: 0.900\n",
      "poison loss: 1.3548017, poison acc: 0.167\n",
      "elapsed time: 617.301, time for reg: 91.819, time for eig: 289.651\n",
      "epoch:  5969, loss: 0.5273981, train acc: 0.950\n",
      "test loss: 0.5686418, test acc: 0.917\n",
      "poison loss: 1.3243849, poison acc: 0.167\n",
      "elapsed time: 618.091, time for reg: 91.967, time for eig: 289.909\n",
      "epoch:  5979, loss: 0.5112864, train acc: 1.000\n",
      "test loss: 0.5814925, test acc: 0.983\n",
      "poison loss: 1.3138735, poison acc: 0.067\n",
      "elapsed time: 619.224, time for reg: 92.114, time for eig: 290.488\n",
      "epoch:  5989, loss: 0.3899221, train acc: 1.000\n",
      "test loss: 0.5244863, test acc: 0.983\n",
      "poison loss: 1.4112816, poison acc: 0.067\n",
      "elapsed time: 620.500, time for reg: 92.272, time for eig: 291.215\n",
      "epoch:  5999, loss: 0.4837071, train acc: 0.933\n",
      "test loss: 0.5251458, test acc: 0.900\n",
      "poison loss: 1.3816687, poison acc: 0.167\n",
      "elapsed time: 621.500, time for reg: 92.421, time for eig: 291.656\n",
      "epoch:  6009, loss: 0.5219740, train acc: 0.933\n",
      "test loss: 0.5513903, test acc: 0.967\n",
      "poison loss: 1.4085072, poison acc: 0.133\n",
      "elapsed time: 622.481, time for reg: 92.593, time for eig: 292.076\n",
      "epoch:  6019, loss: 0.4828285, train acc: 1.000\n",
      "test loss: 0.6558784, test acc: 0.867\n",
      "poison loss: 1.3306993, poison acc: 0.167\n",
      "elapsed time: 623.496, time for reg: 92.740, time for eig: 292.554\n",
      "epoch:  6029, loss: 0.4618385, train acc: 0.983\n",
      "test loss: 0.5486382, test acc: 0.983\n",
      "poison loss: 1.5223305, poison acc: 0.033\n",
      "elapsed time: 624.328, time for reg: 92.887, time for eig: 292.850\n",
      "epoch:  6039, loss: 0.3989806, train acc: 0.933\n",
      "test loss: 0.5285299, test acc: 0.883\n",
      "poison loss: 1.5153707, poison acc: 0.183\n",
      "elapsed time: 625.272, time for reg: 93.035, time for eig: 293.256\n",
      "epoch:  6049, loss: 0.5334861, train acc: 0.933\n",
      "test loss: 0.5684465, test acc: 0.917\n",
      "poison loss: 1.3994398, poison acc: 0.117\n",
      "elapsed time: 626.391, time for reg: 93.182, time for eig: 293.805\n",
      "epoch:  6059, loss: 0.5786852, train acc: 0.933\n",
      "test loss: 0.7129993, test acc: 0.867\n",
      "poison loss: 1.2243870, poison acc: 0.200\n",
      "elapsed time: 627.202, time for reg: 93.330, time for eig: 294.079\n",
      "epoch:  6069, loss: 0.4643579, train acc: 0.933\n",
      "test loss: 0.6340683, test acc: 0.867\n",
      "poison loss: 1.2984907, poison acc: 0.200\n",
      "elapsed time: 628.042, time for reg: 93.477, time for eig: 294.388\n",
      "epoch:  6079, loss: 0.5569921, train acc: 0.933\n",
      "test loss: 0.3775539, test acc: 0.983\n",
      "poison loss: 1.8634197, poison acc: 0.050\n",
      "elapsed time: 629.572, time for reg: 93.625, time for eig: 295.321\n",
      "epoch:  6089, loss: 0.5510746, train acc: 0.933\n",
      "test loss: 0.5874766, test acc: 0.900\n",
      "poison loss: 1.3548488, poison acc: 0.167\n",
      "elapsed time: 630.673, time for reg: 93.801, time for eig: 295.870\n",
      "epoch:  6099, loss: 0.5508674, train acc: 0.917\n",
      "test loss: 0.6435556, test acc: 0.850\n",
      "poison loss: 1.2815720, poison acc: 0.200\n",
      "elapsed time: 631.454, time for reg: 93.947, time for eig: 296.104\n",
      "epoch:  6109, loss: 0.5373622, train acc: 0.933\n",
      "test loss: 0.6560100, test acc: 0.867\n",
      "poison loss: 1.2537763, poison acc: 0.217\n",
      "elapsed time: 632.357, time for reg: 94.094, time for eig: 296.471\n",
      "epoch:  6119, loss: 0.5325877, train acc: 0.933\n",
      "test loss: 0.6115202, test acc: 0.867\n",
      "poison loss: 1.3050002, poison acc: 0.183\n",
      "elapsed time: 633.555, time for reg: 94.242, time for eig: 297.134\n",
      "epoch:  6129, loss: 0.4423537, train acc: 1.000\n",
      "test loss: 0.5255633, test acc: 0.983\n",
      "poison loss: 1.4483958, poison acc: 0.067\n",
      "elapsed time: 634.430, time for reg: 94.388, time for eig: 297.473\n",
      "epoch:  6139, loss: 0.4474086, train acc: 1.000\n",
      "test loss: 0.6017958, test acc: 0.867\n",
      "poison loss: 1.3079264, poison acc: 0.200\n",
      "elapsed time: 635.395, time for reg: 94.538, time for eig: 297.897\n",
      "epoch:  6149, loss: 0.4997511, train acc: 0.983\n",
      "test loss: 0.5891318, test acc: 0.967\n",
      "poison loss: 1.3538600, poison acc: 0.100\n",
      "elapsed time: 636.345, time for reg: 94.714, time for eig: 298.280\n",
      "epoch:  6159, loss: 0.4712391, train acc: 1.000\n",
      "test loss: 0.5959140, test acc: 0.983\n",
      "poison loss: 1.3231428, poison acc: 0.067\n",
      "elapsed time: 637.161, time for reg: 94.862, time for eig: 298.563\n",
      "epoch:  6169, loss: 0.4183725, train acc: 1.000\n",
      "test loss: 0.5733623, test acc: 0.983\n",
      "poison loss: 1.3631420, poison acc: 0.083\n",
      "elapsed time: 637.945, time for reg: 95.008, time for eig: 298.813\n",
      "epoch:  6179, loss: 0.4873296, train acc: 1.000\n",
      "test loss: 0.5944938, test acc: 0.967\n",
      "poison loss: 1.3572100, poison acc: 0.100\n",
      "elapsed time: 638.780, time for reg: 95.157, time for eig: 299.036\n",
      "epoch:  6189, loss: 0.2919995, train acc: 1.000\n",
      "test loss: 0.2486603, test acc: 0.983\n",
      "poison loss: 2.5053591, poison acc: 0.050\n",
      "elapsed time: 639.626, time for reg: 95.304, time for eig: 299.346\n",
      "epoch:  6199, loss: 0.4916805, train acc: 0.933\n",
      "test loss: 0.5819934, test acc: 0.867\n",
      "poison loss: 1.3621547, poison acc: 0.200\n",
      "elapsed time: 640.377, time for reg: 95.451, time for eig: 299.565\n",
      "epoch:  6209, loss: 0.5574269, train acc: 0.917\n",
      "test loss: 0.5878142, test acc: 0.883\n",
      "poison loss: 1.3286725, poison acc: 0.167\n",
      "elapsed time: 641.905, time for reg: 95.628, time for eig: 300.501\n",
      "epoch:  6219, loss: 0.5099337, train acc: 0.950\n",
      "test loss: 0.3732723, test acc: 0.983\n",
      "poison loss: 3.1685867, poison acc: 0.067\n",
      "elapsed time: 642.814, time for reg: 95.775, time for eig: 300.778\n",
      "epoch:  6229, loss: 0.5221892, train acc: 0.933\n",
      "test loss: 0.5539351, test acc: 0.883\n",
      "poison loss: 1.3753709, poison acc: 0.200\n",
      "elapsed time: 643.701, time for reg: 95.923, time for eig: 301.131\n",
      "epoch:  6239, loss: 0.4801168, train acc: 0.917\n",
      "test loss: 0.5475729, test acc: 0.850\n",
      "poison loss: 1.4228169, poison acc: 0.233\n",
      "elapsed time: 644.713, time for reg: 96.071, time for eig: 301.604\n",
      "epoch:  6249, loss: 0.4558100, train acc: 0.983\n",
      "test loss: 0.5953093, test acc: 0.850\n",
      "poison loss: 1.3043819, poison acc: 0.250\n",
      "elapsed time: 645.449, time for reg: 96.217, time for eig: 301.806\n",
      "epoch:  6259, loss: 0.3914278, train acc: 1.000\n",
      "test loss: 0.5034734, test acc: 0.900\n",
      "poison loss: 1.5311726, poison acc: 0.167\n",
      "elapsed time: 646.210, time for reg: 96.364, time for eig: 302.037\n",
      "epoch:  6269, loss: 0.2985401, train acc: 1.000\n",
      "test loss: 0.4258649, test acc: 0.983\n",
      "poison loss: 1.5781824, poison acc: 0.083\n",
      "elapsed time: 647.158, time for reg: 96.511, time for eig: 302.451\n",
      "epoch:  6279, loss: 0.2728826, train acc: 1.000\n",
      "test loss: 0.3992431, test acc: 0.983\n",
      "poison loss: 1.7463837, poison acc: 0.067\n",
      "elapsed time: 647.965, time for reg: 96.657, time for eig: 302.735\n",
      "epoch:  6289, loss: 0.5242183, train acc: 0.917\n",
      "test loss: 0.6566476, test acc: 0.867\n",
      "poison loss: 1.2689124, poison acc: 0.233\n",
      "elapsed time: 648.773, time for reg: 96.816, time for eig: 303.014\n",
      "epoch:  6299, loss: 0.4126062, train acc: 1.000\n",
      "test loss: 0.6158479, test acc: 0.917\n",
      "poison loss: 1.3213446, poison acc: 0.150\n",
      "elapsed time: 649.553, time for reg: 96.963, time for eig: 303.265\n",
      "epoch:  6309, loss: 0.4732157, train acc: 0.967\n",
      "test loss: 0.4986923, test acc: 0.983\n",
      "poison loss: 1.6150174, poison acc: 0.067\n",
      "elapsed time: 650.509, time for reg: 97.139, time for eig: 303.637\n",
      "epoch:  6319, loss: 0.5187454, train acc: 0.967\n",
      "test loss: 0.5419205, test acc: 0.983\n",
      "poison loss: 1.4752291, poison acc: 0.067\n",
      "elapsed time: 651.851, time for reg: 97.285, time for eig: 304.451\n",
      "epoch:  6329, loss: 0.4434720, train acc: 0.917\n",
      "test loss: 0.6162339, test acc: 0.867\n",
      "poison loss: 1.3099321, poison acc: 0.217\n",
      "elapsed time: 652.717, time for reg: 97.433, time for eig: 304.713\n",
      "epoch:  6339, loss: 0.3866136, train acc: 1.000\n",
      "test loss: 0.4587235, test acc: 0.983\n",
      "poison loss: 1.5985091, poison acc: 0.067\n",
      "elapsed time: 653.528, time for reg: 97.579, time for eig: 304.998\n",
      "epoch:  6349, loss: 0.3348892, train acc: 1.000\n",
      "test loss: 0.5058286, test acc: 0.983\n",
      "poison loss: 1.5276717, poison acc: 0.067\n",
      "elapsed time: 654.294, time for reg: 97.727, time for eig: 305.225\n",
      "epoch:  6359, loss: 0.5061390, train acc: 0.933\n",
      "test loss: 0.5636888, test acc: 0.867\n",
      "poison loss: 1.4214725, poison acc: 0.217\n",
      "elapsed time: 655.131, time for reg: 97.875, time for eig: 305.528\n",
      "epoch:  6369, loss: 0.4486921, train acc: 1.000\n",
      "test loss: 0.5782499, test acc: 0.983\n",
      "poison loss: 1.3633602, poison acc: 0.067\n",
      "elapsed time: 655.929, time for reg: 98.021, time for eig: 305.805\n",
      "epoch:  6379, loss: 0.4909266, train acc: 1.000\n",
      "test loss: 0.6282812, test acc: 0.967\n",
      "poison loss: 1.2827889, poison acc: 0.100\n",
      "elapsed time: 656.719, time for reg: 98.264, time for eig: 305.978\n",
      "epoch:  6389, loss: 0.4578368, train acc: 1.000\n",
      "test loss: 0.4355182, test acc: 0.967\n",
      "poison loss: 1.6143501, poison acc: 0.083\n",
      "elapsed time: 657.605, time for reg: 98.412, time for eig: 306.337\n",
      "epoch:  6399, loss: 0.4491584, train acc: 1.000\n",
      "test loss: 0.6215353, test acc: 0.967\n",
      "poison loss: 1.2876849, poison acc: 0.100\n",
      "elapsed time: 658.713, time for reg: 98.558, time for eig: 306.916\n",
      "epoch:  6409, loss: 0.4677009, train acc: 0.917\n",
      "test loss: 0.3480403, test acc: 0.983\n",
      "poison loss: 1.9807428, poison acc: 0.067\n",
      "elapsed time: 659.532, time for reg: 98.705, time for eig: 307.194\n",
      "epoch:  6419, loss: 0.4968524, train acc: 0.950\n",
      "test loss: 0.6464375, test acc: 0.883\n",
      "poison loss: 1.2557732, poison acc: 0.167\n",
      "elapsed time: 660.581, time for reg: 98.853, time for eig: 307.598\n",
      "epoch:  6429, loss: 0.5136338, train acc: 0.917\n",
      "test loss: 0.6511898, test acc: 0.867\n",
      "poison loss: 1.2509404, poison acc: 0.217\n",
      "elapsed time: 661.366, time for reg: 99.000, time for eig: 307.849\n",
      "epoch:  6439, loss: 0.3829041, train acc: 1.000\n",
      "test loss: 0.4802753, test acc: 1.000\n",
      "poison loss: 1.5749681, poison acc: 0.033\n",
      "elapsed time: 662.106, time for reg: 99.147, time for eig: 308.049\n",
      "epoch:  6449, loss: 0.4729157, train acc: 1.000\n",
      "test loss: 0.5383935, test acc: 0.983\n",
      "poison loss: 1.3927593, poison acc: 0.083\n",
      "elapsed time: 663.025, time for reg: 99.295, time for eig: 308.366\n",
      "epoch:  6459, loss: 0.3809246, train acc: 1.000\n",
      "test loss: 0.5114694, test acc: 0.983\n",
      "poison loss: 1.5135065, poison acc: 0.083\n",
      "elapsed time: 664.035, time for reg: 99.444, time for eig: 308.838\n",
      "epoch:  6469, loss: 0.5101283, train acc: 0.900\n",
      "test loss: 0.3979292, test acc: 0.983\n",
      "poison loss: 2.0723414, poison acc: 0.067\n",
      "elapsed time: 664.874, time for reg: 99.590, time for eig: 309.140\n",
      "epoch:  6479, loss: 0.5299903, train acc: 0.967\n",
      "test loss: 0.6595281, test acc: 0.950\n",
      "poison loss: 1.2231457, poison acc: 0.133\n",
      "elapsed time: 665.700, time for reg: 99.738, time for eig: 309.395\n",
      "epoch:  6489, loss: 0.4845572, train acc: 0.933\n",
      "test loss: 0.6724945, test acc: 0.850\n",
      "poison loss: 1.2155715, poison acc: 0.267\n",
      "elapsed time: 666.662, time for reg: 99.909, time for eig: 309.795\n",
      "epoch:  6499, loss: 0.5617693, train acc: 0.917\n",
      "test loss: 0.6441006, test acc: 0.950\n",
      "poison loss: 1.2537296, poison acc: 0.100\n",
      "elapsed time: 667.633, time for reg: 100.059, time for eig: 310.232\n",
      "epoch:  6509, loss: 0.5338300, train acc: 0.933\n",
      "test loss: 0.5334703, test acc: 0.983\n",
      "poison loss: 1.5956436, poison acc: 0.083\n",
      "elapsed time: 668.577, time for reg: 100.205, time for eig: 310.641\n",
      "epoch:  6519, loss: 0.4955605, train acc: 0.917\n",
      "test loss: 0.4036185, test acc: 0.967\n",
      "poison loss: 1.8887564, poison acc: 0.117\n",
      "elapsed time: 669.443, time for reg: 100.352, time for eig: 310.968\n",
      "epoch:  6529, loss: 0.4481792, train acc: 0.983\n",
      "test loss: 0.6482555, test acc: 0.850\n",
      "poison loss: 1.2415965, poison acc: 0.250\n",
      "elapsed time: 670.317, time for reg: 100.500, time for eig: 311.304\n",
      "epoch:  6539, loss: 0.4214242, train acc: 1.000\n",
      "test loss: 0.6118118, test acc: 0.950\n",
      "poison loss: 1.2975469, poison acc: 0.133\n",
      "elapsed time: 671.155, time for reg: 100.647, time for eig: 311.605\n",
      "epoch:  6549, loss: 0.3202548, train acc: 1.000\n",
      "test loss: 0.3489822, test acc: 0.983\n",
      "poison loss: 2.4038261, poison acc: 0.067\n",
      "elapsed time: 672.119, time for reg: 100.794, time for eig: 312.031\n",
      "epoch:  6559, loss: 0.4981204, train acc: 0.933\n",
      "test loss: 0.6646635, test acc: 0.867\n",
      "poison loss: 1.2049388, poison acc: 0.250\n",
      "elapsed time: 674.076, time for reg: 100.942, time for eig: 313.449\n",
      "epoch:  6569, loss: 0.4905767, train acc: 0.917\n",
      "test loss: 0.4788603, test acc: 0.967\n",
      "poison loss: 1.4835209, poison acc: 0.150\n",
      "elapsed time: 674.862, time for reg: 101.088, time for eig: 313.698\n",
      "epoch:  6579, loss: 0.4696342, train acc: 0.933\n",
      "test loss: 0.5748554, test acc: 0.850\n",
      "poison loss: 1.3232298, poison acc: 0.217\n",
      "elapsed time: 675.809, time for reg: 101.272, time for eig: 314.069\n",
      "epoch:  6589, loss: 0.5323889, train acc: 0.900\n",
      "test loss: 0.6804034, test acc: 0.833\n",
      "poison loss: 1.1917121, poison acc: 0.283\n",
      "elapsed time: 676.644, time for reg: 101.421, time for eig: 314.365\n",
      "epoch:  6599, loss: 0.4304453, train acc: 1.000\n",
      "test loss: 0.4982257, test acc: 0.950\n",
      "poison loss: 1.4613934, poison acc: 0.150\n",
      "elapsed time: 677.407, time for reg: 101.569, time for eig: 314.595\n",
      "epoch:  6609, loss: 0.4489797, train acc: 0.967\n",
      "test loss: 0.5820511, test acc: 0.850\n",
      "poison loss: 1.3357631, poison acc: 0.267\n",
      "elapsed time: 678.250, time for reg: 101.716, time for eig: 314.832\n",
      "epoch:  6619, loss: 0.4554638, train acc: 0.950\n",
      "test loss: 0.5871418, test acc: 0.983\n",
      "poison loss: 1.2896385, poison acc: 0.133\n",
      "elapsed time: 679.006, time for reg: 101.862, time for eig: 315.055\n",
      "epoch:  6629, loss: 0.5120321, train acc: 0.933\n",
      "test loss: 0.5243371, test acc: 0.967\n",
      "poison loss: 1.4587851, poison acc: 0.083\n",
      "elapsed time: 679.873, time for reg: 102.027, time for eig: 315.389\n",
      "epoch:  6639, loss: 0.3873299, train acc: 0.983\n",
      "test loss: 0.6071107, test acc: 0.950\n",
      "poison loss: 1.3031968, poison acc: 0.150\n",
      "elapsed time: 681.076, time for reg: 102.174, time for eig: 316.057\n",
      "epoch:  6649, loss: 0.5326286, train acc: 0.933\n",
      "test loss: 0.6887324, test acc: 0.833\n",
      "poison loss: 1.1727328, poison acc: 0.250\n",
      "elapsed time: 681.780, time for reg: 102.323, time for eig: 316.226\n",
      "epoch:  6659, loss: 0.4887998, train acc: 0.967\n",
      "test loss: 0.5051797, test acc: 0.967\n",
      "poison loss: 1.5483869, poison acc: 0.133\n",
      "elapsed time: 682.810, time for reg: 102.470, time for eig: 316.704\n",
      "epoch:  6669, loss: 0.4924594, train acc: 0.983\n",
      "test loss: 0.5734165, test acc: 0.933\n",
      "poison loss: 1.3410020, poison acc: 0.183\n",
      "elapsed time: 683.514, time for reg: 102.619, time for eig: 316.853\n",
      "epoch:  6679, loss: 0.4005286, train acc: 1.000\n",
      "test loss: 0.5345200, test acc: 0.967\n",
      "poison loss: 1.3691791, poison acc: 0.133\n",
      "elapsed time: 684.327, time for reg: 102.766, time for eig: 317.133\n",
      "epoch:  6689, loss: 0.5009553, train acc: 0.983\n",
      "test loss: 0.6556633, test acc: 0.867\n",
      "poison loss: 1.2317472, poison acc: 0.233\n",
      "elapsed time: 685.108, time for reg: 102.911, time for eig: 317.380\n",
      "epoch:  6699, loss: 0.5081790, train acc: 0.933\n",
      "test loss: 0.5687055, test acc: 0.950\n",
      "poison loss: 1.3419974, poison acc: 0.133\n",
      "elapsed time: 686.558, time for reg: 103.093, time for eig: 318.260\n",
      "epoch:  6709, loss: 0.4663355, train acc: 1.000\n",
      "test loss: 0.4041797, test acc: 1.000\n",
      "poison loss: 1.5896332, poison acc: 0.033\n",
      "elapsed time: 687.424, time for reg: 103.240, time for eig: 318.525\n",
      "epoch:  6719, loss: 0.5531629, train acc: 0.933\n",
      "test loss: 0.5944571, test acc: 0.883\n",
      "poison loss: 1.2985890, poison acc: 0.200\n",
      "elapsed time: 688.333, time for reg: 103.388, time for eig: 318.900\n",
      "epoch:  6729, loss: 0.4993709, train acc: 0.983\n",
      "test loss: 0.5792254, test acc: 0.917\n",
      "poison loss: 1.3017847, poison acc: 0.200\n",
      "elapsed time: 689.042, time for reg: 103.535, time for eig: 319.075\n",
      "epoch:  6739, loss: 0.5041857, train acc: 0.950\n",
      "test loss: 0.5063406, test acc: 0.900\n",
      "poison loss: 1.3297569, poison acc: 0.167\n",
      "elapsed time: 689.903, time for reg: 103.715, time for eig: 319.331\n",
      "epoch:  6749, loss: 0.5483847, train acc: 0.933\n",
      "test loss: 0.5208372, test acc: 0.950\n",
      "poison loss: 1.2940109, poison acc: 0.167\n",
      "elapsed time: 690.727, time for reg: 103.861, time for eig: 319.621\n",
      "epoch:  6759, loss: 0.5186774, train acc: 0.783\n",
      "test loss: 0.5006340, test acc: 0.950\n",
      "poison loss: 1.3247070, poison acc: 0.183\n",
      "elapsed time: 691.466, time for reg: 104.009, time for eig: 319.824\n",
      "epoch:  6769, loss: 0.5087921, train acc: 0.933\n",
      "test loss: 0.5473772, test acc: 0.933\n",
      "poison loss: 1.2386871, poison acc: 0.233\n",
      "elapsed time: 692.246, time for reg: 104.192, time for eig: 320.037\n",
      "epoch:  6779, loss: 0.3565239, train acc: 1.000\n",
      "test loss: 0.3540786, test acc: 0.983\n",
      "poison loss: 1.8786582, poison acc: 0.083\n",
      "elapsed time: 692.972, time for reg: 104.340, time for eig: 320.227\n",
      "epoch:  6789, loss: 0.4904325, train acc: 0.933\n",
      "test loss: 0.4790382, test acc: 0.950\n",
      "poison loss: 1.3507400, poison acc: 0.133\n",
      "elapsed time: 693.838, time for reg: 104.489, time for eig: 320.555\n",
      "epoch:  6799, loss: 0.4809189, train acc: 0.983\n",
      "test loss: 0.5718046, test acc: 0.933\n",
      "poison loss: 1.2004756, poison acc: 0.233\n",
      "elapsed time: 694.703, time for reg: 104.637, time for eig: 320.886\n",
      "epoch:  6809, loss: 0.5116487, train acc: 0.967\n",
      "test loss: 0.5283452, test acc: 0.967\n",
      "poison loss: 1.2805914, poison acc: 0.133\n",
      "elapsed time: 695.464, time for reg: 104.785, time for eig: 321.112\n",
      "epoch:  6819, loss: 0.5521967, train acc: 0.917\n",
      "test loss: 0.5383519, test acc: 0.867\n",
      "poison loss: 1.2416299, poison acc: 0.250\n",
      "elapsed time: 696.806, time for reg: 104.955, time for eig: 321.829\n",
      "epoch:  6829, loss: 0.5224010, train acc: 0.967\n",
      "test loss: 0.5144192, test acc: 0.867\n",
      "poison loss: 1.3768257, poison acc: 0.250\n",
      "elapsed time: 697.534, time for reg: 105.103, time for eig: 322.021\n",
      "epoch:  6839, loss: 0.4779634, train acc: 0.950\n",
      "test loss: 0.6359817, test acc: 0.833\n",
      "poison loss: 1.1460834, poison acc: 0.317\n",
      "elapsed time: 698.425, time for reg: 105.249, time for eig: 322.379\n",
      "epoch:  6849, loss: 0.5025025, train acc: 0.983\n",
      "test loss: 0.5797107, test acc: 0.850\n",
      "poison loss: 1.2203651, poison acc: 0.283\n",
      "elapsed time: 699.352, time for reg: 105.397, time for eig: 322.772\n",
      "epoch:  6859, loss: 0.4849823, train acc: 0.933\n",
      "test loss: 0.5699624, test acc: 0.850\n",
      "poison loss: 1.2129501, poison acc: 0.283\n",
      "elapsed time: 700.290, time for reg: 105.545, time for eig: 323.152\n",
      "epoch:  6869, loss: 0.4596531, train acc: 0.933\n",
      "test loss: 0.3959674, test acc: 0.917\n",
      "poison loss: 1.5902094, poison acc: 0.183\n",
      "elapsed time: 701.288, time for reg: 105.693, time for eig: 323.510\n",
      "epoch:  6879, loss: 0.5233483, train acc: 0.983\n",
      "test loss: 0.6031107, test acc: 0.950\n",
      "poison loss: 1.1824994, poison acc: 0.183\n",
      "elapsed time: 702.273, time for reg: 105.840, time for eig: 323.961\n",
      "epoch:  6889, loss: 0.4175356, train acc: 1.000\n",
      "test loss: 0.5375712, test acc: 0.950\n",
      "poison loss: 1.2713877, poison acc: 0.133\n",
      "elapsed time: 703.043, time for reg: 105.988, time for eig: 324.194\n",
      "epoch:  6899, loss: 0.3493056, train acc: 1.000\n",
      "test loss: 0.4953268, test acc: 0.950\n",
      "poison loss: 1.3717241, poison acc: 0.133\n",
      "elapsed time: 703.883, time for reg: 106.135, time for eig: 324.431\n",
      "epoch:  6909, loss: 0.3995919, train acc: 0.983\n",
      "test loss: 0.4834529, test acc: 0.933\n",
      "poison loss: 1.3394383, poison acc: 0.183\n",
      "elapsed time: 704.656, time for reg: 106.282, time for eig: 324.667\n",
      "epoch:  6919, loss: 0.4880647, train acc: 0.933\n",
      "test loss: 0.4821121, test acc: 0.950\n",
      "poison loss: 1.4044469, poison acc: 0.167\n",
      "elapsed time: 705.662, time for reg: 106.429, time for eig: 325.136\n",
      "epoch:  6929, loss: 0.4877979, train acc: 0.967\n",
      "test loss: 0.5349402, test acc: 0.933\n",
      "poison loss: 1.3711445, poison acc: 0.200\n",
      "elapsed time: 706.502, time for reg: 106.577, time for eig: 325.386\n",
      "epoch:  6939, loss: 0.5171932, train acc: 0.983\n",
      "test loss: 0.6896516, test acc: 0.883\n",
      "poison loss: 1.2400426, poison acc: 0.200\n",
      "elapsed time: 707.342, time for reg: 106.724, time for eig: 325.694\n",
      "epoch:  6949, loss: 0.3618460, train acc: 1.000\n",
      "test loss: 0.4487477, test acc: 0.967\n",
      "poison loss: 1.4281482, poison acc: 0.083\n",
      "elapsed time: 708.738, time for reg: 106.870, time for eig: 326.553\n",
      "epoch:  6959, loss: 0.4470650, train acc: 1.000\n",
      "test loss: 0.5207191, test acc: 0.967\n",
      "poison loss: 1.4780170, poison acc: 0.083\n",
      "elapsed time: 709.684, time for reg: 107.019, time for eig: 326.962\n",
      "epoch:  6969, loss: 0.5162580, train acc: 0.950\n",
      "test loss: 0.4102142, test acc: 0.967\n",
      "poison loss: 1.6940482, poison acc: 0.200\n",
      "elapsed time: 710.594, time for reg: 107.166, time for eig: 327.337\n",
      "epoch:  6979, loss: 0.5686087, train acc: 0.900\n",
      "test loss: 0.7080896, test acc: 0.817\n",
      "poison loss: 1.1271980, poison acc: 0.300\n",
      "elapsed time: 711.485, time for reg: 107.313, time for eig: 327.667\n",
      "epoch:  6989, loss: 0.3330712, train acc: 1.000\n",
      "test loss: 0.4974471, test acc: 0.950\n",
      "poison loss: 1.4881614, poison acc: 0.117\n",
      "elapsed time: 712.239, time for reg: 107.459, time for eig: 327.882\n",
      "epoch:  6999, loss: 0.3195684, train acc: 1.000\n",
      "test loss: 0.4882094, test acc: 0.967\n",
      "poison loss: 1.4476222, poison acc: 0.117\n",
      "elapsed time: 713.063, time for reg: 107.606, time for eig: 328.170\n",
      "epoch:  7009, loss: 0.5101349, train acc: 0.983\n",
      "test loss: 0.6756266, test acc: 0.933\n",
      "poison loss: 1.1655235, poison acc: 0.150\n",
      "elapsed time: 714.044, time for reg: 107.753, time for eig: 328.547\n",
      "epoch:  7019, loss: 0.5141012, train acc: 0.983\n",
      "test loss: 0.6949823, test acc: 0.783\n",
      "poison loss: 1.1950642, poison acc: 0.283\n",
      "elapsed time: 714.929, time for reg: 107.900, time for eig: 328.875\n",
      "epoch:  7029, loss: 0.5235240, train acc: 0.917\n",
      "test loss: 0.7087969, test acc: 0.850\n",
      "poison loss: 1.1507812, poison acc: 0.267\n",
      "elapsed time: 715.873, time for reg: 108.046, time for eig: 329.281\n",
      "epoch:  7039, loss: 0.4835950, train acc: 0.983\n",
      "test loss: 0.6368726, test acc: 0.917\n",
      "poison loss: 1.1877362, poison acc: 0.217\n",
      "elapsed time: 716.622, time for reg: 108.195, time for eig: 329.465\n",
      "epoch:  7049, loss: 0.3779656, train acc: 0.983\n",
      "test loss: 0.2942547, test acc: 0.983\n",
      "poison loss: 2.0754071, poison acc: 0.033\n",
      "elapsed time: 717.518, time for reg: 108.341, time for eig: 329.823\n",
      "epoch:  7059, loss: 0.5705231, train acc: 0.967\n",
      "test loss: 0.6999246, test acc: 0.917\n",
      "poison loss: 1.1940204, poison acc: 0.200\n",
      "elapsed time: 718.352, time for reg: 108.488, time for eig: 330.121\n",
      "epoch:  7069, loss: 0.5021905, train acc: 0.983\n",
      "test loss: 0.6704269, test acc: 0.933\n",
      "poison loss: 1.1595782, poison acc: 0.217\n",
      "elapsed time: 719.475, time for reg: 108.635, time for eig: 330.647\n",
      "epoch:  7079, loss: 0.5533552, train acc: 0.900\n",
      "test loss: 0.5666617, test acc: 0.967\n",
      "poison loss: 1.3047684, poison acc: 0.133\n",
      "elapsed time: 720.366, time for reg: 108.781, time for eig: 330.998\n",
      "epoch:  7089, loss: 0.5088324, train acc: 0.967\n",
      "test loss: 0.6566510, test acc: 0.917\n",
      "poison loss: 1.1683485, poison acc: 0.233\n",
      "elapsed time: 721.250, time for reg: 108.929, time for eig: 331.349\n",
      "epoch:  7099, loss: 0.4773922, train acc: 0.917\n",
      "test loss: 0.6082981, test acc: 0.917\n",
      "poison loss: 1.2423161, poison acc: 0.200\n",
      "elapsed time: 722.003, time for reg: 109.076, time for eig: 331.565\n",
      "epoch:  7109, loss: 0.4180376, train acc: 0.983\n",
      "test loss: 0.3502739, test acc: 0.950\n",
      "poison loss: 1.7270780, poison acc: 0.133\n",
      "elapsed time: 722.847, time for reg: 109.224, time for eig: 331.857\n",
      "epoch:  7119, loss: 0.5195821, train acc: 0.967\n",
      "test loss: 0.7202337, test acc: 0.917\n",
      "poison loss: 1.1071565, poison acc: 0.250\n",
      "elapsed time: 723.647, time for reg: 109.370, time for eig: 332.115\n",
      "epoch:  7129, loss: 0.5437256, train acc: 0.950\n",
      "test loss: 0.7079784, test acc: 0.917\n",
      "poison loss: 1.1242023, poison acc: 0.217\n",
      "elapsed time: 724.533, time for reg: 109.546, time for eig: 332.436\n",
      "epoch:  7139, loss: 0.4865879, train acc: 1.000\n",
      "test loss: 0.5717655, test acc: 0.950\n",
      "poison loss: 1.3712925, poison acc: 0.133\n",
      "elapsed time: 725.467, time for reg: 109.725, time for eig: 332.799\n",
      "epoch:  7149, loss: 0.4490218, train acc: 0.983\n",
      "test loss: 0.5972132, test acc: 0.917\n",
      "poison loss: 1.2769648, poison acc: 0.200\n",
      "elapsed time: 726.534, time for reg: 109.872, time for eig: 333.331\n",
      "epoch:  7159, loss: 0.5321137, train acc: 0.900\n",
      "test loss: 0.4441964, test acc: 0.917\n",
      "poison loss: 1.6628944, poison acc: 0.200\n",
      "elapsed time: 727.277, time for reg: 110.019, time for eig: 333.539\n",
      "epoch:  7169, loss: 0.4931074, train acc: 0.983\n",
      "test loss: 0.5951117, test acc: 0.950\n",
      "poison loss: 1.3192230, poison acc: 0.217\n",
      "elapsed time: 728.158, time for reg: 110.198, time for eig: 333.851\n",
      "epoch:  7179, loss: 0.4930663, train acc: 0.967\n",
      "test loss: 0.6626624, test acc: 0.900\n",
      "poison loss: 1.1973234, poison acc: 0.200\n",
      "elapsed time: 728.941, time for reg: 110.345, time for eig: 334.094\n",
      "epoch:  7189, loss: 0.4307575, train acc: 0.950\n",
      "test loss: 0.5750645, test acc: 0.883\n",
      "poison loss: 1.3008446, poison acc: 0.250\n",
      "elapsed time: 729.827, time for reg: 110.492, time for eig: 334.444\n",
      "epoch:  7199, loss: 0.3823563, train acc: 1.000\n",
      "test loss: 0.4294511, test acc: 0.950\n",
      "poison loss: 1.7824744, poison acc: 0.150\n",
      "elapsed time: 730.595, time for reg: 110.659, time for eig: 334.626\n",
      "epoch:  7209, loss: 0.4474684, train acc: 0.917\n",
      "test loss: 0.4166333, test acc: 0.967\n",
      "poison loss: 1.7297766, poison acc: 0.083\n",
      "elapsed time: 731.386, time for reg: 110.805, time for eig: 334.880\n",
      "epoch:  7219, loss: 0.5052730, train acc: 0.983\n",
      "test loss: 0.4707326, test acc: 0.967\n",
      "poison loss: 1.5540641, poison acc: 0.067\n",
      "elapsed time: 732.258, time for reg: 110.954, time for eig: 335.211\n",
      "epoch:  7229, loss: 0.5434493, train acc: 0.983\n",
      "test loss: 0.5085278, test acc: 0.950\n",
      "poison loss: 1.4714102, poison acc: 0.100\n",
      "elapsed time: 733.184, time for reg: 111.129, time for eig: 335.511\n",
      "epoch:  7239, loss: 0.5129421, train acc: 0.917\n",
      "test loss: 0.4633331, test acc: 0.950\n",
      "poison loss: 1.4737670, poison acc: 0.183\n",
      "elapsed time: 734.025, time for reg: 111.276, time for eig: 335.815\n",
      "epoch:  7249, loss: 0.4833731, train acc: 0.917\n",
      "test loss: 0.5619125, test acc: 0.850\n",
      "poison loss: 1.2015985, poison acc: 0.283\n",
      "elapsed time: 734.837, time for reg: 111.423, time for eig: 336.091\n",
      "epoch:  7259, loss: 0.5379319, train acc: 0.900\n",
      "test loss: 0.4242365, test acc: 0.967\n",
      "poison loss: 1.7251900, poison acc: 0.083\n",
      "elapsed time: 735.795, time for reg: 111.570, time for eig: 336.482\n",
      "epoch:  7269, loss: 0.5420926, train acc: 0.917\n",
      "test loss: 0.4053476, test acc: 0.983\n",
      "poison loss: 1.8291104, poison acc: 0.067\n",
      "elapsed time: 736.617, time for reg: 111.717, time for eig: 336.766\n",
      "epoch:  7279, loss: 0.5361682, train acc: 0.967\n",
      "test loss: 0.6414319, test acc: 0.917\n",
      "poison loss: 1.1140831, poison acc: 0.250\n",
      "elapsed time: 737.444, time for reg: 111.865, time for eig: 337.062\n",
      "epoch:  7289, loss: 0.5231141, train acc: 0.900\n",
      "test loss: 0.6338804, test acc: 0.817\n",
      "poison loss: 1.1101950, poison acc: 0.317\n",
      "elapsed time: 738.335, time for reg: 112.039, time for eig: 337.356\n",
      "epoch:  7299, loss: 0.4793045, train acc: 0.983\n",
      "test loss: 0.6488778, test acc: 0.917\n",
      "poison loss: 1.1949342, poison acc: 0.217\n",
      "elapsed time: 739.156, time for reg: 112.187, time for eig: 337.640\n",
      "epoch:  7309, loss: 0.5138562, train acc: 0.967\n",
      "test loss: 0.6829583, test acc: 0.900\n",
      "poison loss: 1.1600509, poison acc: 0.233\n",
      "elapsed time: 740.030, time for reg: 112.333, time for eig: 337.981\n",
      "epoch:  7319, loss: 0.5106780, train acc: 0.967\n",
      "test loss: 0.5984486, test acc: 0.900\n",
      "poison loss: 1.2081597, poison acc: 0.217\n",
      "elapsed time: 740.806, time for reg: 112.480, time for eig: 338.222\n",
      "epoch:  7329, loss: 0.5531890, train acc: 0.883\n",
      "test loss: 0.6588928, test acc: 0.783\n",
      "poison loss: 1.1387398, poison acc: 0.300\n",
      "elapsed time: 741.681, time for reg: 112.627, time for eig: 338.563\n",
      "epoch:  7339, loss: 0.5552270, train acc: 0.933\n",
      "test loss: 0.6548380, test acc: 0.833\n",
      "poison loss: 1.1163906, poison acc: 0.333\n",
      "elapsed time: 742.418, time for reg: 112.774, time for eig: 338.763\n",
      "epoch:  7349, loss: 0.4774961, train acc: 0.983\n",
      "test loss: 0.8597451, test acc: 0.850\n",
      "poison loss: 2.1513242, poison acc: 0.067\n",
      "elapsed time: 743.195, time for reg: 112.961, time for eig: 338.955\n",
      "epoch:  7359, loss: 0.5447664, train acc: 0.917\n",
      "test loss: 0.3790096, test acc: 0.983\n",
      "poison loss: 1.7441301, poison acc: 0.117\n",
      "elapsed time: 744.124, time for reg: 113.108, time for eig: 339.346\n",
      "epoch:  7369, loss: 0.5314437, train acc: 0.933\n",
      "test loss: 0.5467841, test acc: 0.900\n",
      "poison loss: 1.2662632, poison acc: 0.200\n",
      "elapsed time: 745.351, time for reg: 113.256, time for eig: 340.033\n",
      "epoch:  7379, loss: 0.4950290, train acc: 0.983\n",
      "test loss: 0.6317569, test acc: 0.933\n",
      "poison loss: 1.1782681, poison acc: 0.217\n",
      "elapsed time: 746.890, time for reg: 113.402, time for eig: 341.036\n",
      "epoch:  7389, loss: 0.6116257, train acc: 1.000\n",
      "test loss: 0.4568256, test acc: 1.000\n",
      "poison loss: 1.7762446, poison acc: 0.050\n",
      "elapsed time: 747.662, time for reg: 113.551, time for eig: 341.271\n",
      "epoch:  7399, loss: 0.6040231, train acc: 0.983\n",
      "test loss: 0.6253548, test acc: 0.983\n",
      "poison loss: 1.4113559, poison acc: 0.083\n",
      "elapsed time: 748.604, time for reg: 113.699, time for eig: 341.624\n",
      "epoch:  7409, loss: 0.4653303, train acc: 0.983\n",
      "test loss: 0.5538389, test acc: 0.983\n",
      "poison loss: 1.5033392, poison acc: 0.100\n",
      "elapsed time: 749.498, time for reg: 113.847, time for eig: 341.987\n",
      "epoch:  7419, loss: 0.4801563, train acc: 1.000\n",
      "test loss: 0.4317235, test acc: 0.983\n",
      "poison loss: 1.7435703, poison acc: 0.033\n",
      "elapsed time: 750.322, time for reg: 113.996, time for eig: 342.266\n",
      "epoch:  7429, loss: 0.5220312, train acc: 0.983\n",
      "test loss: 0.5876103, test acc: 0.983\n",
      "poison loss: 1.4582039, poison acc: 0.083\n",
      "elapsed time: 751.254, time for reg: 114.142, time for eig: 342.668\n",
      "epoch:  7439, loss: 0.6163726, train acc: 0.983\n",
      "test loss: 0.6100876, test acc: 0.983\n",
      "poison loss: 1.4353567, poison acc: 0.083\n",
      "elapsed time: 752.130, time for reg: 114.290, time for eig: 342.983\n",
      "epoch:  7449, loss: 0.6334004, train acc: 0.983\n",
      "test loss: 0.5902734, test acc: 0.967\n",
      "poison loss: 1.4568262, poison acc: 0.067\n",
      "elapsed time: 752.903, time for reg: 114.439, time for eig: 343.224\n",
      "epoch:  7459, loss: 0.5688927, train acc: 1.000\n",
      "test loss: 0.4049823, test acc: 1.000\n",
      "poison loss: 1.8714060, poison acc: 0.033\n",
      "elapsed time: 753.727, time for reg: 114.586, time for eig: 343.514\n",
      "epoch:  7469, loss: 0.4803787, train acc: 1.000\n",
      "test loss: 0.5020276, test acc: 0.983\n",
      "poison loss: 1.6100241, poison acc: 0.033\n",
      "elapsed time: 754.593, time for reg: 114.765, time for eig: 343.792\n",
      "epoch:  7479, loss: 0.5839471, train acc: 1.000\n",
      "test loss: 0.6079920, test acc: 0.933\n",
      "poison loss: 1.4119902, poison acc: 0.100\n",
      "elapsed time: 755.344, time for reg: 114.912, time for eig: 344.014\n",
      "epoch:  7489, loss: 0.5667398, train acc: 0.983\n",
      "test loss: 0.5352706, test acc: 0.983\n",
      "poison loss: 1.5166475, poison acc: 0.050\n",
      "elapsed time: 756.258, time for reg: 115.060, time for eig: 344.389\n",
      "epoch:  7499, loss: 0.5672741, train acc: 1.000\n",
      "test loss: 0.5864756, test acc: 0.950\n",
      "poison loss: 1.4177775, poison acc: 0.083\n",
      "elapsed time: 757.256, time for reg: 115.271, time for eig: 344.775\n",
      "epoch:  7509, loss: 0.5022783, train acc: 1.000\n",
      "test loss: 0.5667875, test acc: 0.967\n",
      "poison loss: 1.4399244, poison acc: 0.083\n",
      "elapsed time: 758.184, time for reg: 115.417, time for eig: 345.163\n",
      "epoch:  7519, loss: 0.5200628, train acc: 1.000\n",
      "test loss: 0.5645629, test acc: 0.967\n",
      "poison loss: 1.3986188, poison acc: 0.083\n",
      "elapsed time: 758.997, time for reg: 115.564, time for eig: 345.441\n",
      "epoch:  7529, loss: 0.4959427, train acc: 1.000\n",
      "test loss: 0.5824514, test acc: 0.967\n",
      "poison loss: 1.3457272, poison acc: 0.117\n",
      "elapsed time: 759.797, time for reg: 115.713, time for eig: 345.642\n",
      "epoch:  7539, loss: 0.5538998, train acc: 0.967\n",
      "test loss: 0.5709668, test acc: 0.950\n",
      "poison loss: 1.3549820, poison acc: 0.133\n",
      "elapsed time: 760.521, time for reg: 115.861, time for eig: 345.842\n",
      "epoch:  7549, loss: 0.5252499, train acc: 0.983\n",
      "test loss: 0.5852267, test acc: 0.967\n",
      "poison loss: 1.3287746, poison acc: 0.100\n",
      "elapsed time: 761.560, time for reg: 116.010, time for eig: 346.345\n",
      "epoch:  7559, loss: 0.5129612, train acc: 1.000\n",
      "test loss: 0.5739859, test acc: 0.950\n",
      "poison loss: 1.3429403, poison acc: 0.100\n",
      "elapsed time: 762.541, time for reg: 116.160, time for eig: 346.678\n",
      "epoch:  7569, loss: 0.5297731, train acc: 0.967\n",
      "test loss: 0.5689945, test acc: 0.950\n",
      "poison loss: 1.3776579, poison acc: 0.117\n",
      "elapsed time: 763.299, time for reg: 116.307, time for eig: 346.912\n",
      "epoch:  7579, loss: 0.4940841, train acc: 1.000\n",
      "test loss: 0.5790133, test acc: 0.867\n",
      "poison loss: 1.3199154, poison acc: 0.183\n",
      "elapsed time: 764.056, time for reg: 116.455, time for eig: 347.139\n",
      "epoch:  7589, loss: 0.5553074, train acc: 0.950\n",
      "test loss: 0.6298129, test acc: 0.867\n",
      "poison loss: 1.2545875, poison acc: 0.183\n",
      "elapsed time: 764.991, time for reg: 116.602, time for eig: 347.476\n",
      "epoch:  7599, loss: 0.5312310, train acc: 0.967\n",
      "test loss: 0.5707615, test acc: 0.933\n",
      "poison loss: 1.3243991, poison acc: 0.167\n",
      "elapsed time: 765.903, time for reg: 116.750, time for eig: 347.861\n",
      "epoch:  7609, loss: 0.4381273, train acc: 0.933\n",
      "test loss: 0.5443747, test acc: 0.850\n",
      "poison loss: 1.3664258, poison acc: 0.200\n",
      "elapsed time: 766.631, time for reg: 116.898, time for eig: 348.061\n",
      "epoch:  7619, loss: 0.5833913, train acc: 0.933\n",
      "test loss: 0.5663534, test acc: 0.950\n",
      "poison loss: 1.3339425, poison acc: 0.150\n",
      "elapsed time: 767.576, time for reg: 117.096, time for eig: 348.321\n",
      "epoch:  7629, loss: 0.4088852, train acc: 1.000\n",
      "test loss: 0.4223173, test acc: 0.983\n",
      "poison loss: 1.6207532, poison acc: 0.033\n",
      "elapsed time: 768.608, time for reg: 117.264, time for eig: 348.805\n",
      "epoch:  7639, loss: 0.5049270, train acc: 0.933\n",
      "test loss: 0.3694257, test acc: 1.000\n",
      "poison loss: 1.9847955, poison acc: 0.017\n",
      "elapsed time: 769.408, time for reg: 117.411, time for eig: 349.075\n",
      "epoch:  7649, loss: 0.5174531, train acc: 0.950\n",
      "test loss: 0.6332705, test acc: 0.833\n",
      "poison loss: 1.2400281, poison acc: 0.217\n",
      "elapsed time: 770.357, time for reg: 117.558, time for eig: 349.487\n",
      "epoch:  7659, loss: 0.3908922, train acc: 0.833\n",
      "test loss: 0.4272426, test acc: 0.983\n",
      "poison loss: 1.5825078, poison acc: 0.100\n",
      "elapsed time: 771.190, time for reg: 117.706, time for eig: 349.787\n",
      "epoch:  7669, loss: 0.4880184, train acc: 0.967\n",
      "test loss: 0.5736308, test acc: 0.950\n",
      "poison loss: 1.3038955, poison acc: 0.133\n",
      "elapsed time: 771.993, time for reg: 117.854, time for eig: 350.061\n",
      "epoch:  7679, loss: 0.5136764, train acc: 0.983\n",
      "test loss: 0.5199750, test acc: 0.933\n",
      "poison loss: 1.3770431, poison acc: 0.167\n",
      "elapsed time: 772.965, time for reg: 118.002, time for eig: 350.497\n",
      "epoch:  7689, loss: 0.5197357, train acc: 0.983\n",
      "test loss: 0.5811430, test acc: 0.967\n",
      "poison loss: 1.2633025, poison acc: 0.167\n",
      "elapsed time: 773.889, time for reg: 118.177, time for eig: 350.836\n",
      "epoch:  7699, loss: 0.5347995, train acc: 1.000\n",
      "test loss: 0.5626499, test acc: 0.950\n",
      "poison loss: 1.3117629, poison acc: 0.133\n",
      "elapsed time: 774.769, time for reg: 118.358, time for eig: 351.065\n",
      "epoch:  7709, loss: 0.5121707, train acc: 0.967\n",
      "test loss: 0.6163011, test acc: 0.950\n",
      "poison loss: 1.2036132, poison acc: 0.167\n",
      "elapsed time: 775.972, time for reg: 118.502, time for eig: 351.746\n",
      "epoch:  7719, loss: 0.4919810, train acc: 1.000\n",
      "test loss: 0.5401650, test acc: 0.983\n",
      "poison loss: 1.2904539, poison acc: 0.133\n",
      "elapsed time: 776.784, time for reg: 118.646, time for eig: 352.047\n",
      "epoch:  7729, loss: 0.4961675, train acc: 0.950\n",
      "test loss: 0.6317748, test acc: 0.883\n",
      "poison loss: 1.2212731, poison acc: 0.200\n",
      "elapsed time: 777.544, time for reg: 118.788, time for eig: 352.291\n",
      "epoch:  7739, loss: 0.5038999, train acc: 1.000\n",
      "test loss: 0.5613288, test acc: 0.967\n",
      "poison loss: 1.2658868, poison acc: 0.150\n",
      "elapsed time: 778.332, time for reg: 118.931, time for eig: 352.565\n",
      "epoch:  7749, loss: 0.5197998, train acc: 0.983\n",
      "test loss: 0.6001080, test acc: 0.967\n",
      "poison loss: 1.2011269, poison acc: 0.167\n",
      "elapsed time: 779.000, time for reg: 119.076, time for eig: 352.710\n",
      "epoch:  7759, loss: 0.5367772, train acc: 0.967\n",
      "test loss: 0.4896679, test acc: 1.000\n",
      "poison loss: 1.5198538, poison acc: 0.067\n",
      "elapsed time: 779.759, time for reg: 119.220, time for eig: 352.955\n",
      "epoch:  7769, loss: 0.5836106, train acc: 1.000\n",
      "test loss: 0.6497843, test acc: 0.883\n",
      "poison loss: 1.1411080, poison acc: 0.233\n",
      "elapsed time: 780.818, time for reg: 119.364, time for eig: 353.492\n",
      "epoch:  7779, loss: 0.5430337, train acc: 0.917\n",
      "test loss: 0.5220983, test acc: 0.967\n",
      "poison loss: 1.2911737, poison acc: 0.167\n",
      "elapsed time: 781.649, time for reg: 119.508, time for eig: 353.770\n",
      "epoch:  7789, loss: 0.5338380, train acc: 0.933\n",
      "test loss: 0.6244612, test acc: 0.867\n",
      "poison loss: 1.1627524, poison acc: 0.233\n",
      "elapsed time: 782.428, time for reg: 119.650, time for eig: 354.036\n",
      "epoch:  7799, loss: 0.4949138, train acc: 0.983\n",
      "test loss: 0.4021148, test acc: 0.983\n",
      "poison loss: 1.7591615, poison acc: 0.100\n",
      "elapsed time: 783.140, time for reg: 119.796, time for eig: 354.228\n",
      "epoch:  7809, loss: 0.5098533, train acc: 0.967\n",
      "test loss: 0.5636021, test acc: 0.967\n",
      "poison loss: 1.2252717, poison acc: 0.167\n",
      "elapsed time: 783.997, time for reg: 119.941, time for eig: 354.526\n",
      "epoch:  7819, loss: 0.4890410, train acc: 0.950\n",
      "test loss: 0.5721372, test acc: 0.950\n",
      "poison loss: 1.2131306, poison acc: 0.167\n",
      "elapsed time: 784.930, time for reg: 120.087, time for eig: 354.940\n",
      "epoch:  7829, loss: 0.4843139, train acc: 0.983\n",
      "test loss: 0.5305945, test acc: 0.967\n",
      "poison loss: 1.2605087, poison acc: 0.167\n",
      "elapsed time: 785.554, time for reg: 120.230, time for eig: 355.049\n",
      "epoch:  7839, loss: 0.5076340, train acc: 0.933\n",
      "test loss: 0.5460466, test acc: 0.967\n",
      "poison loss: 1.2391106, poison acc: 0.150\n",
      "elapsed time: 786.372, time for reg: 120.402, time for eig: 355.287\n",
      "epoch:  7849, loss: 0.5696225, train acc: 0.983\n",
      "test loss: 0.5714104, test acc: 0.950\n",
      "poison loss: 1.2128438, poison acc: 0.200\n",
      "elapsed time: 787.260, time for reg: 120.547, time for eig: 355.657\n",
      "epoch:  7859, loss: 0.5467782, train acc: 0.967\n",
      "test loss: 0.5257160, test acc: 0.967\n",
      "poison loss: 1.3265059, poison acc: 0.133\n",
      "elapsed time: 788.000, time for reg: 120.691, time for eig: 355.869\n",
      "epoch:  7869, loss: 0.5103559, train acc: 0.950\n",
      "test loss: 0.6005619, test acc: 0.967\n",
      "poison loss: 1.1718511, poison acc: 0.183\n",
      "elapsed time: 789.146, time for reg: 120.835, time for eig: 356.500\n",
      "epoch:  7879, loss: 0.3625330, train acc: 1.000\n",
      "test loss: 0.3298083, test acc: 0.983\n",
      "poison loss: 1.6854109, poison acc: 0.117\n",
      "elapsed time: 789.872, time for reg: 120.979, time for eig: 356.712\n",
      "epoch:  7889, loss: 0.5127048, train acc: 0.933\n",
      "test loss: 0.6061731, test acc: 0.867\n",
      "poison loss: 1.1527128, poison acc: 0.250\n",
      "elapsed time: 790.772, time for reg: 121.124, time for eig: 357.096\n",
      "epoch:  7899, loss: 0.5270434, train acc: 0.983\n",
      "test loss: 0.4900165, test acc: 0.967\n",
      "poison loss: 1.2991240, poison acc: 0.200\n",
      "elapsed time: 791.516, time for reg: 121.268, time for eig: 357.323\n",
      "epoch:  7909, loss: 0.3203079, train acc: 1.000\n",
      "test loss: 0.4075620, test acc: 0.983\n",
      "poison loss: 1.4240980, poison acc: 0.133\n",
      "elapsed time: 792.285, time for reg: 121.413, time for eig: 357.568\n",
      "epoch:  7919, loss: 0.4380197, train acc: 1.000\n",
      "test loss: 0.4974775, test acc: 0.950\n",
      "poison loss: 1.3965704, poison acc: 0.133\n",
      "elapsed time: 793.117, time for reg: 121.557, time for eig: 357.893\n",
      "epoch:  7929, loss: 0.4458878, train acc: 0.967\n",
      "test loss: 0.4832775, test acc: 0.967\n",
      "poison loss: 1.2998481, poison acc: 0.167\n",
      "elapsed time: 793.843, time for reg: 121.702, time for eig: 358.100\n",
      "epoch:  7939, loss: 0.5345582, train acc: 0.933\n",
      "test loss: 0.6018021, test acc: 0.917\n",
      "poison loss: 1.1407646, poison acc: 0.250\n",
      "elapsed time: 794.778, time for reg: 121.845, time for eig: 358.509\n",
      "epoch:  7949, loss: 0.5490650, train acc: 0.900\n",
      "test loss: 0.6086971, test acc: 0.933\n",
      "poison loss: 1.1344171, poison acc: 0.233\n",
      "elapsed time: 795.740, time for reg: 121.990, time for eig: 358.916\n",
      "epoch:  7959, loss: 0.5071901, train acc: 0.933\n",
      "test loss: 0.5842815, test acc: 0.950\n",
      "poison loss: 1.1602881, poison acc: 0.167\n",
      "elapsed time: 796.721, time for reg: 122.134, time for eig: 359.280\n",
      "epoch:  7969, loss: 0.5119453, train acc: 0.933\n",
      "test loss: 0.5762115, test acc: 0.883\n",
      "poison loss: 1.1658091, poison acc: 0.233\n",
      "elapsed time: 797.565, time for reg: 122.277, time for eig: 359.609\n",
      "epoch:  7979, loss: 0.4726445, train acc: 0.983\n",
      "test loss: 0.6082714, test acc: 0.933\n",
      "poison loss: 1.3243519, poison acc: 0.150\n",
      "elapsed time: 798.361, time for reg: 122.422, time for eig: 359.880\n",
      "epoch:  7989, loss: 0.5470357, train acc: 0.917\n",
      "test loss: 0.4232593, test acc: 0.867\n",
      "poison loss: 1.7585871, poison acc: 0.250\n",
      "elapsed time: 799.251, time for reg: 122.601, time for eig: 360.182\n",
      "epoch:  7999, loss: 0.5388997, train acc: 0.933\n",
      "test loss: 0.5368828, test acc: 0.967\n",
      "poison loss: 1.2112547, poison acc: 0.167\n",
      "elapsed time: 800.029, time for reg: 122.746, time for eig: 360.435\n",
      "epoch:  8009, loss: 0.5350061, train acc: 0.917\n",
      "test loss: 0.4935860, test acc: 0.983\n",
      "poison loss: 1.3701581, poison acc: 0.150\n",
      "elapsed time: 800.815, time for reg: 122.890, time for eig: 360.693\n",
      "epoch:  8019, loss: 0.1326402, train acc: 1.000\n",
      "test loss: 0.2686706, test acc: 0.983\n",
      "poison loss: 2.0277293, poison acc: 0.083\n",
      "elapsed time: 801.672, time for reg: 123.066, time for eig: 360.973\n",
      "epoch:  8029, loss: 0.5061820, train acc: 0.933\n",
      "test loss: 0.3926556, test acc: 0.967\n",
      "poison loss: 1.7252101, poison acc: 0.183\n",
      "elapsed time: 802.404, time for reg: 123.212, time for eig: 361.180\n",
      "epoch:  8039, loss: 0.4641164, train acc: 0.917\n",
      "test loss: 0.5131067, test acc: 0.883\n",
      "poison loss: 1.2825803, poison acc: 0.217\n",
      "elapsed time: 803.147, time for reg: 123.383, time for eig: 361.336\n",
      "epoch:  8049, loss: 0.4747143, train acc: 0.967\n",
      "test loss: 0.6658772, test acc: 0.833\n",
      "poison loss: 1.1084307, poison acc: 0.317\n",
      "elapsed time: 803.941, time for reg: 123.527, time for eig: 361.608\n",
      "epoch:  8059, loss: 0.5181136, train acc: 0.917\n",
      "test loss: 0.5260920, test acc: 0.867\n",
      "poison loss: 1.2269176, poison acc: 0.267\n",
      "elapsed time: 804.737, time for reg: 123.672, time for eig: 361.879\n",
      "epoch:  8069, loss: 0.4281447, train acc: 0.983\n",
      "test loss: 0.5413781, test acc: 0.950\n",
      "poison loss: 1.2377682, poison acc: 0.217\n",
      "elapsed time: 805.546, time for reg: 123.817, time for eig: 362.101\n",
      "epoch:  8079, loss: 0.4540528, train acc: 1.000\n",
      "test loss: 0.4923516, test acc: 0.967\n",
      "poison loss: 1.3310177, poison acc: 0.150\n",
      "elapsed time: 806.275, time for reg: 123.963, time for eig: 362.308\n",
      "epoch:  8089, loss: 0.4585879, train acc: 0.967\n",
      "test loss: 0.4243082, test acc: 1.000\n",
      "poison loss: 1.4594374, poison acc: 0.117\n",
      "elapsed time: 807.033, time for reg: 124.139, time for eig: 362.481\n",
      "epoch:  8099, loss: 0.5063156, train acc: 0.917\n",
      "test loss: 0.5728272, test acc: 0.850\n",
      "poison loss: 1.1583043, poison acc: 0.283\n",
      "elapsed time: 807.705, time for reg: 124.285, time for eig: 362.629\n",
      "epoch:  8109, loss: 0.4787897, train acc: 0.967\n",
      "test loss: 0.5270027, test acc: 0.933\n",
      "poison loss: 1.2250572, poison acc: 0.233\n",
      "elapsed time: 808.481, time for reg: 124.429, time for eig: 362.866\n",
      "epoch:  8119, loss: 0.4698013, train acc: 0.983\n",
      "test loss: 0.4773988, test acc: 0.967\n",
      "poison loss: 1.3928407, poison acc: 0.133\n",
      "elapsed time: 809.212, time for reg: 124.573, time for eig: 363.058\n",
      "epoch:  8129, loss: 0.3444885, train acc: 1.000\n",
      "test loss: 0.5323809, test acc: 0.933\n",
      "poison loss: 1.2055966, poison acc: 0.233\n",
      "elapsed time: 809.917, time for reg: 124.718, time for eig: 363.237\n",
      "epoch:  8139, loss: 0.3202336, train acc: 0.850\n",
      "test loss: 0.4147576, test acc: 0.983\n",
      "poison loss: 1.3781937, poison acc: 0.133\n",
      "elapsed time: 810.658, time for reg: 124.861, time for eig: 363.459\n",
      "epoch:  8149, loss: 0.2083422, train acc: 0.983\n",
      "test loss: 0.2938936, test acc: 0.983\n",
      "poison loss: 1.6710837, poison acc: 0.133\n",
      "elapsed time: 811.490, time for reg: 125.015, time for eig: 363.756\n",
      "epoch:  8159, loss: 0.4545536, train acc: 1.000\n",
      "test loss: 0.3852094, test acc: 1.000\n",
      "poison loss: 1.5977149, poison acc: 0.050\n",
      "elapsed time: 812.294, time for reg: 125.155, time for eig: 364.050\n",
      "epoch:  8169, loss: 0.4157664, train acc: 0.983\n",
      "test loss: 0.4800866, test acc: 0.967\n",
      "poison loss: 1.3405917, poison acc: 0.150\n",
      "elapsed time: 813.004, time for reg: 125.298, time for eig: 364.239\n",
      "epoch:  8179, loss: 0.4287066, train acc: 0.983\n",
      "test loss: 0.5462718, test acc: 0.933\n",
      "poison loss: 1.2101417, poison acc: 0.233\n",
      "elapsed time: 813.690, time for reg: 125.441, time for eig: 364.405\n",
      "epoch:  8189, loss: 0.2343587, train acc: 0.983\n",
      "test loss: 0.4339121, test acc: 0.967\n",
      "poison loss: 1.3741011, poison acc: 0.200\n",
      "elapsed time: 814.495, time for reg: 125.585, time for eig: 364.626\n",
      "epoch:  8199, loss: 0.4258221, train acc: 0.900\n",
      "test loss: 0.3362257, test acc: 0.867\n",
      "poison loss: 1.7280709, poison acc: 0.267\n",
      "elapsed time: 815.229, time for reg: 125.729, time for eig: 364.837\n",
      "epoch:  8209, loss: 0.5434892, train acc: 0.917\n",
      "test loss: 0.4164504, test acc: 0.950\n",
      "poison loss: 1.4456329, poison acc: 0.200\n",
      "elapsed time: 816.015, time for reg: 125.907, time for eig: 365.068\n",
      "epoch:  8219, loss: 0.4363548, train acc: 0.950\n",
      "test loss: 0.5386561, test acc: 0.950\n",
      "poison loss: 1.2112497, poison acc: 0.217\n",
      "elapsed time: 816.767, time for reg: 126.056, time for eig: 365.275\n",
      "epoch:  8229, loss: 0.3733127, train acc: 1.000\n",
      "test loss: 0.4684933, test acc: 0.967\n",
      "poison loss: 1.3295512, poison acc: 0.200\n",
      "elapsed time: 817.481, time for reg: 126.197, time for eig: 365.479\n",
      "epoch:  8239, loss: 0.4916076, train acc: 0.917\n",
      "test loss: 0.6018950, test acc: 0.833\n",
      "poison loss: 1.1445754, poison acc: 0.333\n",
      "elapsed time: 818.309, time for reg: 126.361, time for eig: 365.691\n",
      "epoch:  8249, loss: 0.4888235, train acc: 0.933\n",
      "test loss: 0.3907521, test acc: 0.983\n",
      "poison loss: 1.7624850, poison acc: 0.083\n",
      "elapsed time: 819.007, time for reg: 126.505, time for eig: 365.872\n",
      "epoch:  8259, loss: 0.5739831, train acc: 0.917\n",
      "test loss: 0.6598292, test acc: 0.783\n",
      "poison loss: 1.1926774, poison acc: 0.283\n",
      "elapsed time: 819.819, time for reg: 126.650, time for eig: 366.135\n",
      "epoch:  8269, loss: 0.4369328, train acc: 1.000\n",
      "test loss: 0.5098346, test acc: 0.850\n",
      "poison loss: 1.3689957, poison acc: 0.200\n",
      "elapsed time: 820.563, time for reg: 126.796, time for eig: 366.357\n",
      "epoch:  8279, loss: 0.5017256, train acc: 0.917\n",
      "test loss: 0.6192766, test acc: 0.800\n",
      "poison loss: 1.2202128, poison acc: 0.283\n",
      "elapsed time: 821.350, time for reg: 126.940, time for eig: 366.621\n",
      "epoch:  8289, loss: 0.5903183, train acc: 0.867\n",
      "test loss: 0.5906102, test acc: 0.883\n",
      "poison loss: 1.4581383, poison acc: 0.150\n",
      "elapsed time: 822.189, time for reg: 127.149, time for eig: 366.872\n",
      "epoch:  8299, loss: 0.5528168, train acc: 0.933\n",
      "test loss: 0.6135505, test acc: 0.833\n",
      "poison loss: 1.2498299, poison acc: 0.200\n",
      "elapsed time: 822.935, time for reg: 127.292, time for eig: 367.111\n",
      "epoch:  8309, loss: 0.4713816, train acc: 0.900\n",
      "test loss: 0.5357578, test acc: 0.833\n",
      "poison loss: 1.3162913, poison acc: 0.233\n",
      "elapsed time: 823.695, time for reg: 127.460, time for eig: 367.324\n",
      "epoch:  8319, loss: 0.3237550, train acc: 0.983\n",
      "test loss: 0.4723450, test acc: 0.967\n",
      "poison loss: 1.4298511, poison acc: 0.100\n",
      "elapsed time: 824.475, time for reg: 127.608, time for eig: 367.586\n",
      "epoch:  8329, loss: 0.3416742, train acc: 1.000\n",
      "test loss: 0.5099195, test acc: 0.917\n",
      "poison loss: 1.3387895, poison acc: 0.183\n",
      "elapsed time: 825.317, time for reg: 127.753, time for eig: 367.905\n",
      "epoch:  8339, loss: 0.5052124, train acc: 0.950\n",
      "test loss: 0.5489599, test acc: 0.900\n",
      "poison loss: 1.2715333, poison acc: 0.183\n",
      "elapsed time: 826.105, time for reg: 127.929, time for eig: 368.137\n",
      "epoch:  8349, loss: 0.5128038, train acc: 0.900\n",
      "test loss: 0.6159813, test acc: 0.800\n",
      "poison loss: 1.1919744, poison acc: 0.317\n",
      "elapsed time: 826.942, time for reg: 128.073, time for eig: 368.448\n",
      "epoch:  8359, loss: 0.5512794, train acc: 0.900\n",
      "test loss: 0.5920604, test acc: 0.817\n",
      "poison loss: 1.2152824, poison acc: 0.250\n",
      "elapsed time: 827.779, time for reg: 128.219, time for eig: 368.760\n",
      "epoch:  8369, loss: 0.5137253, train acc: 0.900\n",
      "test loss: 0.6500105, test acc: 0.883\n",
      "poison loss: 1.1795868, poison acc: 0.200\n",
      "elapsed time: 828.559, time for reg: 128.400, time for eig: 368.977\n",
      "epoch:  8379, loss: 0.5493985, train acc: 0.900\n",
      "test loss: 0.6582270, test acc: 0.800\n",
      "poison loss: 1.1350445, poison acc: 0.300\n",
      "elapsed time: 829.289, time for reg: 128.545, time for eig: 369.181\n",
      "epoch:  8389, loss: 0.4250280, train acc: 0.933\n",
      "test loss: 0.5061048, test acc: 0.900\n",
      "poison loss: 1.3899137, poison acc: 0.167\n",
      "elapsed time: 830.007, time for reg: 128.692, time for eig: 369.368\n",
      "epoch:  8399, loss: 0.3712573, train acc: 0.917\n",
      "test loss: 0.4850068, test acc: 0.917\n",
      "poison loss: 1.3620223, poison acc: 0.233\n",
      "elapsed time: 830.845, time for reg: 128.836, time for eig: 369.678\n",
      "epoch:  8409, loss: 0.5355286, train acc: 0.950\n",
      "test loss: 0.4796350, test acc: 0.917\n",
      "poison loss: 1.5346137, poison acc: 0.167\n",
      "elapsed time: 831.643, time for reg: 128.981, time for eig: 369.946\n",
      "epoch:  8419, loss: 0.5923523, train acc: 0.917\n",
      "test loss: 0.5431575, test acc: 0.850\n",
      "poison loss: 1.3171645, poison acc: 0.217\n",
      "elapsed time: 832.445, time for reg: 129.126, time for eig: 370.217\n",
      "epoch:  8429, loss: 0.5447027, train acc: 0.917\n",
      "test loss: 0.6701460, test acc: 0.817\n",
      "poison loss: 1.1177137, poison acc: 0.350\n",
      "elapsed time: 833.261, time for reg: 129.304, time for eig: 370.474\n",
      "epoch:  8439, loss: 0.3990231, train acc: 0.967\n",
      "test loss: 0.4499425, test acc: 0.933\n",
      "poison loss: 1.4306549, poison acc: 0.183\n",
      "elapsed time: 834.015, time for reg: 129.450, time for eig: 370.698\n",
      "epoch:  8449, loss: 0.3472304, train acc: 0.983\n",
      "test loss: 0.4815527, test acc: 0.933\n",
      "poison loss: 1.3734241, poison acc: 0.200\n",
      "elapsed time: 834.785, time for reg: 129.594, time for eig: 370.898\n",
      "epoch:  8459, loss: 0.5254807, train acc: 0.967\n",
      "test loss: 0.6144343, test acc: 0.917\n",
      "poison loss: 1.1892183, poison acc: 0.217\n",
      "elapsed time: 835.522, time for reg: 129.740, time for eig: 371.110\n",
      "epoch:  8469, loss: 0.4959149, train acc: 0.950\n",
      "test loss: 0.5090563, test acc: 0.933\n",
      "poison loss: 1.2909771, poison acc: 0.217\n",
      "elapsed time: 836.360, time for reg: 129.954, time for eig: 371.313\n",
      "epoch:  8479, loss: 0.5102438, train acc: 0.933\n",
      "test loss: 0.6233858, test acc: 0.917\n",
      "poison loss: 1.1464526, poison acc: 0.267\n",
      "elapsed time: 837.148, time for reg: 130.100, time for eig: 371.575\n",
      "epoch:  8489, loss: 0.5222769, train acc: 0.933\n",
      "test loss: 0.6455418, test acc: 0.917\n",
      "poison loss: 1.3056005, poison acc: 0.150\n",
      "elapsed time: 837.847, time for reg: 130.246, time for eig: 371.746\n",
      "epoch:  8499, loss: 0.4468142, train acc: 1.000\n",
      "test loss: 0.4970249, test acc: 0.917\n",
      "poison loss: 1.3022619, poison acc: 0.217\n",
      "elapsed time: 838.621, time for reg: 130.392, time for eig: 371.932\n",
      "epoch:  8509, loss: 0.4702504, train acc: 0.983\n",
      "test loss: 0.5365642, test acc: 0.917\n",
      "poison loss: 1.3374156, poison acc: 0.200\n",
      "elapsed time: 839.480, time for reg: 130.537, time for eig: 372.267\n",
      "epoch:  8519, loss: 0.5232936, train acc: 0.967\n",
      "test loss: 0.6380291, test acc: 0.833\n",
      "poison loss: 1.1481888, poison acc: 0.267\n",
      "elapsed time: 840.462, time for reg: 130.682, time for eig: 372.720\n",
      "epoch:  8529, loss: 0.4456261, train acc: 0.983\n",
      "test loss: 0.5889066, test acc: 0.933\n",
      "poison loss: 1.1655301, poison acc: 0.250\n",
      "elapsed time: 841.255, time for reg: 130.865, time for eig: 372.949\n",
      "epoch:  8539, loss: 0.4244349, train acc: 0.967\n",
      "test loss: 0.5876928, test acc: 0.917\n",
      "poison loss: 1.1893688, poison acc: 0.267\n",
      "elapsed time: 842.284, time for reg: 131.009, time for eig: 373.455\n",
      "epoch:  8549, loss: 0.4594111, train acc: 0.867\n",
      "test loss: 0.4302289, test acc: 0.983\n",
      "poison loss: 1.8472258, poison acc: 0.083\n",
      "elapsed time: 843.089, time for reg: 131.155, time for eig: 373.735\n",
      "epoch:  8559, loss: 0.4233935, train acc: 0.983\n",
      "test loss: 0.5261836, test acc: 0.917\n",
      "poison loss: 1.2497395, poison acc: 0.200\n",
      "elapsed time: 843.913, time for reg: 131.299, time for eig: 373.973\n",
      "epoch:  8569, loss: 0.4822371, train acc: 0.917\n",
      "test loss: 0.6263629, test acc: 0.833\n",
      "poison loss: 1.1200949, poison acc: 0.333\n",
      "elapsed time: 844.769, time for reg: 131.444, time for eig: 374.302\n",
      "epoch:  8579, loss: 0.5085206, train acc: 0.950\n",
      "test loss: 0.5848681, test acc: 0.850\n",
      "poison loss: 1.1624867, poison acc: 0.300\n",
      "elapsed time: 845.487, time for reg: 131.589, time for eig: 374.493\n",
      "epoch:  8589, loss: 0.3875711, train acc: 0.983\n",
      "test loss: 0.5458400, test acc: 0.867\n",
      "poison loss: 1.2055905, poison acc: 0.283\n",
      "elapsed time: 846.524, time for reg: 131.737, time for eig: 374.939\n",
      "epoch:  8599, loss: 0.4717108, train acc: 1.000\n",
      "test loss: 0.5503503, test acc: 0.933\n",
      "poison loss: 1.2233185, poison acc: 0.150\n",
      "elapsed time: 847.287, time for reg: 131.882, time for eig: 375.175\n",
      "epoch:  8609, loss: 0.3183270, train acc: 0.933\n",
      "test loss: 0.4518717, test acc: 0.950\n",
      "poison loss: 1.4965180, poison acc: 0.183\n",
      "elapsed time: 848.071, time for reg: 132.034, time for eig: 375.403\n",
      "epoch:  8619, loss: 0.4431379, train acc: 1.000\n",
      "test loss: 0.4941051, test acc: 0.933\n",
      "poison loss: 1.3498408, poison acc: 0.167\n",
      "elapsed time: 848.904, time for reg: 132.180, time for eig: 375.671\n",
      "epoch:  8629, loss: 0.4556130, train acc: 1.000\n",
      "test loss: 0.5564771, test acc: 0.967\n",
      "poison loss: 1.3733293, poison acc: 0.050\n",
      "elapsed time: 849.692, time for reg: 132.326, time for eig: 375.910\n",
      "epoch:  8639, loss: 0.4935973, train acc: 0.917\n",
      "test loss: 0.5368856, test acc: 0.817\n",
      "poison loss: 1.3593360, poison acc: 0.217\n",
      "elapsed time: 850.461, time for reg: 132.470, time for eig: 376.119\n",
      "epoch:  8649, loss: 0.4594329, train acc: 0.950\n",
      "test loss: 0.5662547, test acc: 0.867\n",
      "poison loss: 1.3265046, poison acc: 0.183\n",
      "elapsed time: 851.184, time for reg: 132.615, time for eig: 376.316\n",
      "epoch:  8659, loss: 0.4265143, train acc: 0.950\n",
      "test loss: 0.5980798, test acc: 0.800\n",
      "poison loss: 1.2763663, poison acc: 0.317\n",
      "elapsed time: 852.459, time for reg: 132.760, time for eig: 377.065\n",
      "epoch:  8669, loss: 0.4769337, train acc: 0.900\n",
      "test loss: 0.5546724, test acc: 0.967\n",
      "poison loss: 1.3009437, poison acc: 0.083\n",
      "elapsed time: 853.191, time for reg: 132.907, time for eig: 377.273\n",
      "epoch:  8679, loss: 0.3584355, train acc: 0.883\n",
      "test loss: 0.4513860, test acc: 0.833\n",
      "poison loss: 1.4745705, poison acc: 0.317\n",
      "elapsed time: 853.942, time for reg: 133.053, time for eig: 377.483\n",
      "epoch:  8689, loss: 0.4235185, train acc: 1.000\n",
      "test loss: 0.4689806, test acc: 0.967\n",
      "poison loss: 1.4206768, poison acc: 0.083\n",
      "elapsed time: 854.746, time for reg: 133.198, time for eig: 377.762\n",
      "epoch:  8699, loss: 0.5055609, train acc: 0.900\n",
      "test loss: 0.5425892, test acc: 0.950\n",
      "poison loss: 1.3382437, poison acc: 0.150\n",
      "elapsed time: 855.589, time for reg: 133.343, time for eig: 378.077\n",
      "epoch:  8709, loss: 0.5129048, train acc: 0.900\n",
      "test loss: 0.3020275, test acc: 0.950\n",
      "poison loss: 1.8491797, poison acc: 0.133\n",
      "elapsed time: 856.429, time for reg: 133.513, time for eig: 378.358\n",
      "epoch:  8719, loss: 0.4678243, train acc: 0.967\n",
      "test loss: 0.5407453, test acc: 0.933\n",
      "poison loss: 1.2655288, poison acc: 0.183\n",
      "elapsed time: 857.185, time for reg: 133.656, time for eig: 378.585\n",
      "epoch:  8729, loss: 0.4754627, train acc: 0.900\n",
      "test loss: 0.4727560, test acc: 0.883\n",
      "poison loss: 1.3331934, poison acc: 0.267\n",
      "elapsed time: 857.942, time for reg: 133.855, time for eig: 378.753\n",
      "epoch:  8739, loss: 0.4364938, train acc: 0.900\n",
      "test loss: 0.4067031, test acc: 0.983\n",
      "poison loss: 1.5288063, poison acc: 0.133\n",
      "elapsed time: 858.765, time for reg: 134.000, time for eig: 379.036\n",
      "epoch:  8749, loss: 0.5321562, train acc: 0.883\n",
      "test loss: 0.4327834, test acc: 0.983\n",
      "poison loss: 1.8667495, poison acc: 0.017\n",
      "elapsed time: 859.592, time for reg: 134.144, time for eig: 379.334\n",
      "epoch:  8759, loss: 0.5571698, train acc: 0.917\n",
      "test loss: 0.5377617, test acc: 0.867\n",
      "poison loss: 1.4753843, poison acc: 0.167\n",
      "elapsed time: 861.184, time for reg: 134.288, time for eig: 380.390\n",
      "epoch:  8769, loss: 0.3943951, train acc: 1.000\n",
      "test loss: 0.4360596, test acc: 0.900\n",
      "poison loss: 1.6208112, poison acc: 0.117\n",
      "elapsed time: 861.924, time for reg: 134.433, time for eig: 380.599\n",
      "epoch:  8779, loss: 0.5006978, train acc: 1.000\n",
      "test loss: 0.5399214, test acc: 1.000\n",
      "poison loss: 1.6367903, poison acc: 0.017\n",
      "elapsed time: 862.739, time for reg: 134.578, time for eig: 380.884\n",
      "epoch:  8789, loss: 0.5946180, train acc: 0.983\n",
      "test loss: 0.5319965, test acc: 1.000\n",
      "poison loss: 1.5586929, poison acc: 0.017\n",
      "elapsed time: 863.440, time for reg: 134.723, time for eig: 381.057\n",
      "epoch:  8799, loss: 0.3725341, train acc: 1.000\n",
      "test loss: 0.4704246, test acc: 0.983\n",
      "poison loss: 1.8574215, poison acc: 0.050\n",
      "elapsed time: 864.200, time for reg: 134.902, time for eig: 381.232\n",
      "epoch:  8809, loss: 0.3899953, train acc: 0.750\n",
      "test loss: 0.4151706, test acc: 0.983\n",
      "poison loss: 1.6130502, poison acc: 0.050\n",
      "elapsed time: 864.932, time for reg: 135.049, time for eig: 381.444\n",
      "epoch:  8819, loss: 0.3918140, train acc: 0.983\n",
      "test loss: 0.2145500, test acc: 1.000\n",
      "poison loss: 2.3921896, poison acc: 0.017\n",
      "elapsed time: 865.656, time for reg: 135.217, time for eig: 381.620\n",
      "epoch:  8829, loss: 0.4546518, train acc: 0.983\n",
      "test loss: 0.4586251, test acc: 0.950\n",
      "poison loss: 1.6265473, poison acc: 0.100\n",
      "elapsed time: 866.543, time for reg: 135.361, time for eig: 381.983\n",
      "epoch:  8839, loss: 0.3457619, train acc: 1.000\n",
      "test loss: 0.2903089, test acc: 0.983\n",
      "poison loss: 4.1032017, poison acc: 0.033\n",
      "elapsed time: 867.247, time for reg: 135.506, time for eig: 382.162\n",
      "epoch:  8849, loss: 0.6289851, train acc: 0.933\n",
      "test loss: 0.5413669, test acc: 0.983\n",
      "poison loss: 1.4052225, poison acc: 0.050\n",
      "elapsed time: 868.024, time for reg: 135.673, time for eig: 382.397\n",
      "epoch:  8859, loss: 0.4843893, train acc: 0.983\n",
      "test loss: 0.4705411, test acc: 0.983\n",
      "poison loss: 1.4819729, poison acc: 0.050\n",
      "elapsed time: 868.773, time for reg: 135.817, time for eig: 382.593\n",
      "epoch:  8869, loss: 0.6271721, train acc: 0.883\n",
      "test loss: 0.5687745, test acc: 0.583\n",
      "poison loss: 3.9706312, poison acc: 0.300\n",
      "elapsed time: 869.507, time for reg: 135.961, time for eig: 382.802\n",
      "epoch:  8879, loss: 0.4700482, train acc: 0.967\n",
      "test loss: 0.3511434, test acc: 0.983\n",
      "poison loss: 1.7636538, poison acc: 0.050\n",
      "elapsed time: 870.197, time for reg: 136.105, time for eig: 382.971\n",
      "epoch:  8889, loss: 0.3978707, train acc: 0.933\n",
      "test loss: 0.5956119, test acc: 0.983\n",
      "poison loss: 1.2885879, poison acc: 0.133\n",
      "elapsed time: 870.951, time for reg: 136.252, time for eig: 383.201\n",
      "epoch:  8899, loss: 0.6286386, train acc: 0.933\n",
      "test loss: 0.3415451, test acc: 0.983\n",
      "poison loss: 1.8748935, poison acc: 0.033\n",
      "elapsed time: 871.722, time for reg: 136.398, time for eig: 383.379\n",
      "epoch:  8909, loss: 0.5312285, train acc: 0.917\n",
      "test loss: 0.5579749, test acc: 0.983\n",
      "poison loss: 1.3316736, poison acc: 0.100\n",
      "elapsed time: 872.417, time for reg: 136.543, time for eig: 383.552\n",
      "epoch:  8919, loss: 0.5253475, train acc: 0.983\n",
      "test loss: 0.4081375, test acc: 0.900\n",
      "poison loss: 1.8216052, poison acc: 0.200\n",
      "elapsed time: 873.233, time for reg: 136.722, time for eig: 383.775\n",
      "epoch:  8929, loss: 0.5017363, train acc: 0.950\n",
      "test loss: 0.5211601, test acc: 0.883\n",
      "poison loss: 1.3458784, poison acc: 0.183\n",
      "elapsed time: 873.976, time for reg: 136.866, time for eig: 383.993\n",
      "epoch:  8939, loss: 0.5721337, train acc: 0.983\n",
      "test loss: 0.5451385, test acc: 0.900\n",
      "poison loss: 1.3167704, poison acc: 0.133\n",
      "elapsed time: 874.668, time for reg: 137.012, time for eig: 384.161\n",
      "epoch:  8949, loss: 0.5334246, train acc: 0.917\n",
      "test loss: 0.5369766, test acc: 0.900\n",
      "poison loss: 1.3611637, poison acc: 0.217\n",
      "elapsed time: 875.443, time for reg: 137.156, time for eig: 384.420\n",
      "epoch:  8959, loss: 0.4147624, train acc: 0.983\n",
      "test loss: 0.6222561, test acc: 0.850\n",
      "poison loss: 1.2219688, poison acc: 0.233\n",
      "elapsed time: 876.204, time for reg: 137.300, time for eig: 384.654\n",
      "epoch:  8969, loss: 0.2025289, train acc: 1.000\n",
      "test loss: 0.4501975, test acc: 0.967\n",
      "poison loss: 1.5748742, poison acc: 0.050\n",
      "elapsed time: 876.973, time for reg: 137.512, time for eig: 384.837\n",
      "epoch:  8979, loss: 0.2525661, train acc: 0.917\n",
      "test loss: 0.1360086, test acc: 1.000\n",
      "poison loss: 3.0545369, poison acc: 0.017\n",
      "elapsed time: 877.819, time for reg: 137.656, time for eig: 385.173\n",
      "epoch:  8989, loss: 0.2364634, train acc: 0.983\n",
      "test loss: 0.3351873, test acc: 0.950\n",
      "poison loss: 2.5924500, poison acc: 0.100\n",
      "elapsed time: 878.557, time for reg: 137.799, time for eig: 385.393\n",
      "epoch:  8999, loss: 0.4250480, train acc: 0.817\n",
      "test loss: 0.4919321, test acc: 0.950\n",
      "poison loss: 1.4150798, poison acc: 0.083\n",
      "elapsed time: 879.344, time for reg: 138.012, time for eig: 385.589\n",
      "epoch:  9009, loss: 0.3434464, train acc: 0.967\n",
      "test loss: 0.5831340, test acc: 0.933\n",
      "poison loss: 1.3769516, poison acc: 0.150\n",
      "elapsed time: 880.024, time for reg: 138.158, time for eig: 385.750\n",
      "epoch:  9019, loss: 0.5631419, train acc: 0.883\n",
      "test loss: 0.5531177, test acc: 0.917\n",
      "poison loss: 1.3380675, poison acc: 0.133\n",
      "elapsed time: 880.863, time for reg: 138.333, time for eig: 385.974\n",
      "epoch:  9029, loss: 0.5491299, train acc: 0.950\n",
      "test loss: 0.6926765, test acc: 0.833\n",
      "poison loss: 1.1849902, poison acc: 0.233\n",
      "elapsed time: 881.696, time for reg: 138.477, time for eig: 386.292\n",
      "epoch:  9039, loss: 0.5298086, train acc: 0.950\n",
      "test loss: 0.3779807, test acc: 0.983\n",
      "poison loss: 2.1211960, poison acc: 0.050\n",
      "elapsed time: 882.517, time for reg: 138.621, time for eig: 386.596\n",
      "epoch:  9049, loss: 0.6101111, train acc: 0.883\n",
      "test loss: 0.6616518, test acc: 0.833\n",
      "poison loss: 1.1778364, poison acc: 0.250\n",
      "elapsed time: 883.266, time for reg: 138.767, time for eig: 386.794\n",
      "epoch:  9059, loss: 0.6179245, train acc: 0.967\n",
      "test loss: 0.7097733, test acc: 0.817\n",
      "poison loss: 1.1328577, poison acc: 0.283\n",
      "elapsed time: 884.055, time for reg: 138.913, time for eig: 387.058\n",
      "epoch:  9069, loss: 0.3244296, train acc: 0.967\n",
      "test loss: 0.4683728, test acc: 0.933\n",
      "poison loss: 1.5077891, poison acc: 0.167\n",
      "elapsed time: 884.767, time for reg: 139.057, time for eig: 387.230\n",
      "epoch:  9079, loss: 0.4818210, train acc: 0.950\n",
      "test loss: 0.5936480, test acc: 0.917\n",
      "poison loss: 1.2560966, poison acc: 0.183\n",
      "elapsed time: 885.489, time for reg: 139.202, time for eig: 387.431\n",
      "epoch:  9089, loss: 0.6113114, train acc: 0.933\n",
      "test loss: 0.6155350, test acc: 0.900\n",
      "poison loss: 1.2061055, poison acc: 0.200\n",
      "elapsed time: 886.223, time for reg: 139.345, time for eig: 387.653\n",
      "epoch:  9099, loss: 0.3563966, train acc: 1.000\n",
      "test loss: 0.5135619, test acc: 0.933\n",
      "poison loss: 1.3474655, poison acc: 0.167\n",
      "elapsed time: 886.988, time for reg: 139.520, time for eig: 387.868\n",
      "epoch:  9109, loss: 0.5994569, train acc: 0.783\n",
      "test loss: 0.6564966, test acc: 0.483\n",
      "poison loss: 1.7516774, poison acc: 0.433\n",
      "elapsed time: 887.703, time for reg: 139.662, time for eig: 388.076\n",
      "epoch:  9119, loss: 0.2921032, train acc: 1.000\n",
      "test loss: 0.3039488, test acc: 1.000\n",
      "poison loss: 1.9428716, poison acc: 0.017\n",
      "elapsed time: 888.449, time for reg: 139.836, time for eig: 388.246\n",
      "epoch:  9129, loss: 0.3602182, train acc: 1.000\n",
      "test loss: 0.5154389, test acc: 0.933\n",
      "poison loss: 1.3769498, poison acc: 0.150\n",
      "elapsed time: 889.186, time for reg: 140.010, time for eig: 388.431\n",
      "epoch:  9139, loss: 0.3030670, train acc: 1.000\n",
      "test loss: 0.4920937, test acc: 0.950\n",
      "poison loss: 1.4229006, poison acc: 0.150\n",
      "elapsed time: 890.166, time for reg: 140.156, time for eig: 388.889\n",
      "epoch:  9149, loss: 0.4767150, train acc: 0.950\n",
      "test loss: 0.5343036, test acc: 0.883\n",
      "poison loss: 1.3985298, poison acc: 0.150\n",
      "elapsed time: 890.849, time for reg: 140.302, time for eig: 389.049\n",
      "epoch:  9159, loss: 0.6042517, train acc: 0.917\n",
      "test loss: 0.6143794, test acc: 0.833\n",
      "poison loss: 1.2061147, poison acc: 0.267\n",
      "elapsed time: 891.578, time for reg: 140.449, time for eig: 389.259\n",
      "epoch:  9169, loss: 0.5730965, train acc: 0.933\n",
      "test loss: 0.2701483, test acc: 0.967\n",
      "poison loss: 2.2782255, poison acc: 0.117\n",
      "elapsed time: 892.271, time for reg: 140.593, time for eig: 389.430\n",
      "epoch:  9179, loss: 0.5318031, train acc: 0.983\n",
      "test loss: 0.3925655, test acc: 0.967\n",
      "poison loss: 1.8784972, poison acc: 0.083\n",
      "elapsed time: 893.035, time for reg: 140.738, time for eig: 389.679\n",
      "epoch:  9189, loss: 0.4838643, train acc: 0.950\n",
      "test loss: 0.4309701, test acc: 0.933\n",
      "poison loss: 1.4784470, poison acc: 0.200\n",
      "elapsed time: 893.756, time for reg: 140.897, time for eig: 389.858\n",
      "epoch:  9199, loss: 0.3705600, train acc: 0.950\n",
      "test loss: 0.4999214, test acc: 0.817\n",
      "poison loss: 1.5247176, poison acc: 0.267\n",
      "elapsed time: 894.502, time for reg: 141.042, time for eig: 390.063\n",
      "epoch:  9209, loss: 0.3309025, train acc: 1.000\n",
      "test loss: 0.4334303, test acc: 0.983\n",
      "poison loss: 1.6310808, poison acc: 0.050\n",
      "elapsed time: 895.235, time for reg: 141.186, time for eig: 390.272\n",
      "epoch:  9219, loss: 0.3357573, train acc: 0.967\n",
      "test loss: 0.3918056, test acc: 1.000\n",
      "poison loss: 1.5826873, poison acc: 0.117\n",
      "elapsed time: 896.141, time for reg: 141.331, time for eig: 390.656\n",
      "epoch:  9229, loss: 0.5128279, train acc: 0.950\n",
      "test loss: 0.6056856, test acc: 0.850\n",
      "poison loss: 1.2225376, poison acc: 0.283\n",
      "elapsed time: 896.828, time for reg: 141.476, time for eig: 390.819\n",
      "epoch:  9239, loss: 0.4374614, train acc: 0.950\n",
      "test loss: 0.5057524, test acc: 0.867\n",
      "poison loss: 1.4543129, poison acc: 0.233\n",
      "elapsed time: 897.556, time for reg: 141.619, time for eig: 391.028\n",
      "epoch:  9249, loss: 0.4493989, train acc: 1.000\n",
      "test loss: 0.3806845, test acc: 0.950\n",
      "poison loss: 1.6250216, poison acc: 0.133\n",
      "elapsed time: 898.227, time for reg: 141.766, time for eig: 391.181\n",
      "epoch:  9259, loss: 0.3173429, train acc: 0.983\n",
      "test loss: 0.2667442, test acc: 0.983\n",
      "poison loss: 2.1648099, poison acc: 0.100\n",
      "elapsed time: 899.030, time for reg: 141.910, time for eig: 391.470\n",
      "epoch:  9269, loss: 0.5120345, train acc: 0.983\n",
      "test loss: 0.3733724, test acc: 0.950\n",
      "poison loss: 1.9241342, poison acc: 0.050\n",
      "elapsed time: 899.894, time for reg: 142.053, time for eig: 391.816\n",
      "epoch:  9279, loss: 0.4144110, train acc: 1.000\n",
      "test loss: 0.5729881, test acc: 0.983\n",
      "poison loss: 1.4277567, poison acc: 0.083\n",
      "elapsed time: 900.611, time for reg: 142.197, time for eig: 391.981\n",
      "epoch:  9289, loss: 0.4865023, train acc: 1.000\n",
      "test loss: 0.4746383, test acc: 0.983\n",
      "poison loss: 1.5459449, poison acc: 0.050\n",
      "elapsed time: 901.341, time for reg: 142.341, time for eig: 392.173\n",
      "epoch:  9299, loss: 0.5461389, train acc: 1.000\n",
      "test loss: 0.6067123, test acc: 0.450\n",
      "poison loss: 2.6271367, poison acc: 0.300\n",
      "elapsed time: 902.044, time for reg: 142.486, time for eig: 392.361\n",
      "epoch:  9309, loss: 0.3412497, train acc: 1.000\n",
      "test loss: 0.5133656, test acc: 0.950\n",
      "poison loss: 1.5048351, poison acc: 0.083\n",
      "elapsed time: 902.804, time for reg: 142.629, time for eig: 392.611\n",
      "epoch:  9319, loss: 0.4494437, train acc: 0.983\n",
      "test loss: 0.3218465, test acc: 0.967\n",
      "poison loss: 2.0455024, poison acc: 0.050\n",
      "elapsed time: 903.586, time for reg: 142.810, time for eig: 392.834\n",
      "epoch:  9329, loss: 0.6007008, train acc: 0.983\n",
      "test loss: 0.6059752, test acc: 0.883\n",
      "poison loss: 1.2519442, poison acc: 0.150\n",
      "elapsed time: 904.289, time for reg: 142.953, time for eig: 393.023\n",
      "epoch:  9339, loss: 0.4920328, train acc: 0.967\n",
      "test loss: 0.5947666, test acc: 0.883\n",
      "poison loss: 1.2137605, poison acc: 0.233\n",
      "elapsed time: 905.077, time for reg: 143.097, time for eig: 393.264\n",
      "epoch:  9349, loss: 0.4252471, train acc: 1.000\n",
      "test loss: 0.5959644, test acc: 0.867\n",
      "poison loss: 1.3027681, poison acc: 0.200\n",
      "elapsed time: 905.900, time for reg: 143.242, time for eig: 393.567\n",
      "epoch:  9359, loss: 0.3620005, train acc: 1.000\n",
      "test loss: 0.4958487, test acc: 0.933\n",
      "poison loss: 1.5051190, poison acc: 0.117\n",
      "elapsed time: 906.617, time for reg: 143.387, time for eig: 393.763\n",
      "epoch:  9369, loss: 0.3893148, train acc: 0.967\n",
      "test loss: 0.3871371, test acc: 0.983\n",
      "poison loss: 1.6389355, poison acc: 0.100\n",
      "elapsed time: 907.481, time for reg: 143.591, time for eig: 394.049\n",
      "epoch:  9379, loss: 0.3558767, train acc: 0.983\n",
      "test loss: 0.4247092, test acc: 0.983\n",
      "poison loss: 1.6871696, poison acc: 0.100\n",
      "elapsed time: 908.376, time for reg: 143.733, time for eig: 394.432\n",
      "epoch:  9389, loss: 0.4529210, train acc: 1.000\n",
      "test loss: 0.4757187, test acc: 0.900\n",
      "poison loss: 1.5371462, poison acc: 0.133\n",
      "elapsed time: 909.159, time for reg: 143.877, time for eig: 394.695\n",
      "epoch:  9399, loss: 0.5342528, train acc: 0.950\n",
      "test loss: 0.4017230, test acc: 1.000\n",
      "poison loss: 1.6434599, poison acc: 0.083\n",
      "elapsed time: 909.988, time for reg: 144.023, time for eig: 394.933\n",
      "epoch:  9409, loss: 0.4479091, train acc: 0.917\n",
      "test loss: 0.5633651, test acc: 0.883\n",
      "poison loss: 1.2239091, poison acc: 0.233\n",
      "elapsed time: 910.851, time for reg: 144.167, time for eig: 395.214\n",
      "epoch:  9419, loss: 0.4122437, train acc: 1.000\n",
      "test loss: 0.4551973, test acc: 0.933\n",
      "poison loss: 1.3682458, poison acc: 0.200\n",
      "elapsed time: 911.600, time for reg: 144.312, time for eig: 395.441\n",
      "epoch:  9429, loss: 0.3094206, train acc: 1.000\n",
      "test loss: 0.2092782, test acc: 0.883\n",
      "poison loss: 4.0037565, poison acc: 0.167\n",
      "elapsed time: 912.290, time for reg: 144.455, time for eig: 395.615\n",
      "epoch:  9439, loss: 0.3325606, train acc: 0.983\n",
      "test loss: 0.6127609, test acc: 0.933\n",
      "poison loss: 1.2282104, poison acc: 0.233\n",
      "elapsed time: 912.974, time for reg: 144.597, time for eig: 395.786\n",
      "epoch:  9449, loss: 0.4210420, train acc: 0.950\n",
      "test loss: 0.2965968, test acc: 0.983\n",
      "poison loss: 1.6808369, poison acc: 0.217\n",
      "elapsed time: 913.739, time for reg: 144.776, time for eig: 395.968\n",
      "epoch:  9459, loss: 0.5861766, train acc: 0.917\n",
      "test loss: 0.7510769, test acc: 0.517\n",
      "poison loss: 1.6838515, poison acc: 0.467\n",
      "elapsed time: 914.511, time for reg: 144.919, time for eig: 396.227\n",
      "epoch:  9469, loss: 0.2550305, train acc: 0.967\n",
      "test loss: 0.4806460, test acc: 0.967\n",
      "poison loss: 1.3638602, poison acc: 0.217\n",
      "elapsed time: 915.265, time for reg: 145.131, time for eig: 396.394\n",
      "epoch:  9479, loss: 0.3910618, train acc: 0.967\n",
      "test loss: 0.4746822, test acc: 0.967\n",
      "poison loss: 1.3065303, poison acc: 0.233\n",
      "elapsed time: 916.031, time for reg: 145.277, time for eig: 396.646\n",
      "epoch:  9489, loss: 0.5624571, train acc: 0.950\n",
      "test loss: 0.5922748, test acc: 0.533\n",
      "poison loss: 1.3424074, poison acc: 0.433\n",
      "elapsed time: 916.812, time for reg: 145.421, time for eig: 396.909\n",
      "epoch:  9499, loss: 0.5193389, train acc: 0.933\n",
      "test loss: 0.4485780, test acc: 0.883\n",
      "poison loss: 1.4122086, poison acc: 0.267\n",
      "elapsed time: 917.682, time for reg: 145.591, time for eig: 397.163\n",
      "epoch:  9509, loss: 0.3932895, train acc: 1.000\n",
      "test loss: 0.4463641, test acc: 0.933\n",
      "poison loss: 1.4432398, poison acc: 0.233\n",
      "elapsed time: 918.400, time for reg: 145.734, time for eig: 397.370\n",
      "epoch:  9519, loss: 0.4206106, train acc: 0.933\n",
      "test loss: 0.4867173, test acc: 0.867\n",
      "poison loss: 1.3120572, poison acc: 0.283\n",
      "elapsed time: 919.145, time for reg: 145.902, time for eig: 397.540\n",
      "epoch:  9529, loss: 0.5417248, train acc: 0.933\n",
      "test loss: 0.4499817, test acc: 0.983\n",
      "poison loss: 1.4677148, poison acc: 0.117\n",
      "elapsed time: 920.385, time for reg: 146.045, time for eig: 398.268\n",
      "epoch:  9539, loss: 0.3335782, train acc: 0.967\n",
      "test loss: 0.3722168, test acc: 0.983\n",
      "poison loss: 1.8732227, poison acc: 0.133\n",
      "elapsed time: 921.262, time for reg: 146.189, time for eig: 398.629\n",
      "epoch:  9549, loss: 0.5327142, train acc: 0.933\n",
      "test loss: 0.6114811, test acc: 0.867\n",
      "poison loss: 1.1652737, poison acc: 0.267\n",
      "elapsed time: 921.984, time for reg: 146.333, time for eig: 398.841\n",
      "epoch:  9559, loss: 0.5029636, train acc: 0.983\n",
      "test loss: 0.6080043, test acc: 0.867\n",
      "poison loss: 1.1288178, poison acc: 0.283\n",
      "elapsed time: 922.826, time for reg: 146.477, time for eig: 399.094\n",
      "epoch:  9569, loss: 0.2797346, train acc: 0.967\n",
      "test loss: 0.4989059, test acc: 0.867\n",
      "poison loss: 1.3169731, poison acc: 0.283\n",
      "elapsed time: 923.665, time for reg: 146.620, time for eig: 399.394\n",
      "epoch:  9579, loss: 0.3097401, train acc: 1.000\n",
      "test loss: 0.3424054, test acc: 0.967\n",
      "poison loss: 1.6447198, poison acc: 0.167\n",
      "elapsed time: 924.618, time for reg: 146.765, time for eig: 399.829\n",
      "epoch:  9589, loss: 0.3626354, train acc: 1.000\n",
      "test loss: 0.4340294, test acc: 0.967\n",
      "poison loss: 1.5222329, poison acc: 0.133\n",
      "elapsed time: 925.404, time for reg: 146.909, time for eig: 400.101\n",
      "epoch:  9599, loss: 0.4211634, train acc: 0.950\n",
      "test loss: 0.5344826, test acc: 0.883\n",
      "poison loss: 1.2870877, poison acc: 0.233\n",
      "elapsed time: 926.081, time for reg: 147.051, time for eig: 400.265\n",
      "epoch:  9609, loss: 0.3086653, train acc: 0.950\n",
      "test loss: 0.4957927, test acc: 0.883\n",
      "poison loss: 1.3227934, poison acc: 0.250\n",
      "elapsed time: 926.874, time for reg: 147.195, time for eig: 400.479\n",
      "epoch:  9619, loss: 0.4483663, train acc: 0.950\n",
      "test loss: 0.4914019, test acc: 0.867\n",
      "poison loss: 1.3221334, poison acc: 0.267\n",
      "elapsed time: 927.719, time for reg: 147.339, time for eig: 400.807\n",
      "epoch:  9629, loss: 0.4056537, train acc: 0.950\n",
      "test loss: 0.5461336, test acc: 0.867\n",
      "poison loss: 1.2824502, poison acc: 0.283\n",
      "elapsed time: 928.853, time for reg: 147.484, time for eig: 401.427\n",
      "epoch:  9639, loss: 0.5917301, train acc: 0.917\n",
      "test loss: 0.5222837, test acc: 0.900\n",
      "poison loss: 1.3748611, poison acc: 0.217\n",
      "elapsed time: 929.533, time for reg: 147.625, time for eig: 401.605\n",
      "epoch:  9649, loss: 0.2869096, train acc: 1.000\n",
      "test loss: 0.4025405, test acc: 0.917\n",
      "poison loss: 1.4849933, poison acc: 0.250\n",
      "elapsed time: 930.243, time for reg: 147.769, time for eig: 401.795\n",
      "epoch:  9659, loss: 0.5106554, train acc: 0.950\n",
      "test loss: 0.5993112, test acc: 0.883\n",
      "poison loss: 1.2013451, poison acc: 0.283\n",
      "elapsed time: 930.950, time for reg: 147.914, time for eig: 401.979\n",
      "epoch:  9669, loss: 0.4387513, train acc: 0.967\n",
      "test loss: 0.5530851, test acc: 0.883\n",
      "poison loss: 1.2477597, poison acc: 0.267\n",
      "elapsed time: 932.029, time for reg: 148.055, time for eig: 402.524\n",
      "epoch:  9679, loss: 0.4576281, train acc: 0.933\n",
      "test loss: 0.5407573, test acc: 0.867\n",
      "poison loss: 1.2861101, poison acc: 0.283\n",
      "elapsed time: 932.760, time for reg: 148.200, time for eig: 402.740\n",
      "epoch:  9689, loss: 0.4500699, train acc: 0.950\n",
      "test loss: 0.3667334, test acc: 0.967\n",
      "poison loss: 1.5834346, poison acc: 0.200\n",
      "elapsed time: 933.480, time for reg: 148.342, time for eig: 402.950\n",
      "epoch:  9699, loss: 0.2857258, train acc: 0.967\n",
      "test loss: 0.3816475, test acc: 0.967\n",
      "poison loss: 3.7663509, poison acc: 0.033\n",
      "elapsed time: 934.279, time for reg: 148.546, time for eig: 403.190\n",
      "epoch:  9709, loss: 0.5711705, train acc: 0.950\n",
      "test loss: 0.6792560, test acc: 0.867\n",
      "poison loss: 1.5635712, poison acc: 0.117\n",
      "elapsed time: 935.103, time for reg: 148.688, time for eig: 403.503\n",
      "epoch:  9719, loss: 0.5112426, train acc: 0.950\n",
      "test loss: 0.7067963, test acc: 0.867\n",
      "poison loss: 1.3271409, poison acc: 0.183\n",
      "elapsed time: 935.871, time for reg: 148.829, time for eig: 403.767\n",
      "epoch:  9729, loss: 0.3436582, train acc: 1.000\n",
      "test loss: 0.3882240, test acc: 0.967\n",
      "poison loss: 1.6270694, poison acc: 0.133\n",
      "elapsed time: 936.689, time for reg: 148.974, time for eig: 404.063\n",
      "epoch:  9739, loss: 0.3854005, train acc: 0.950\n",
      "test loss: 0.6222921, test acc: 0.883\n",
      "poison loss: 1.2654494, poison acc: 0.250\n",
      "elapsed time: 937.426, time for reg: 149.114, time for eig: 404.302\n",
      "epoch:  9749, loss: 0.5517267, train acc: 0.950\n",
      "test loss: 0.5284222, test acc: 0.983\n",
      "poison loss: 1.3753002, poison acc: 0.150\n",
      "elapsed time: 938.183, time for reg: 149.257, time for eig: 404.554\n",
      "epoch:  9759, loss: 0.4474046, train acc: 0.950\n",
      "test loss: 0.4854264, test acc: 0.917\n",
      "poison loss: 1.4441330, poison acc: 0.150\n",
      "elapsed time: 938.892, time for reg: 149.399, time for eig: 404.752\n",
      "epoch:  9769, loss: 0.5750233, train acc: 0.950\n",
      "test loss: 0.1979025, test acc: 0.967\n",
      "poison loss: 2.7927955, poison acc: 0.067\n",
      "elapsed time: 939.709, time for reg: 149.574, time for eig: 405.018\n",
      "epoch:  9779, loss: 0.5070312, train acc: 0.950\n",
      "test loss: 0.3192286, test acc: 0.917\n",
      "poison loss: 2.0717994, poison acc: 0.167\n",
      "elapsed time: 940.478, time for reg: 149.715, time for eig: 405.286\n",
      "epoch:  9789, loss: 0.4911848, train acc: 0.950\n",
      "test loss: 0.5149749, test acc: 0.967\n",
      "poison loss: 1.5120257, poison acc: 0.150\n",
      "elapsed time: 941.312, time for reg: 149.858, time for eig: 405.601\n",
      "epoch:  9799, loss: 0.4493091, train acc: 0.950\n",
      "test loss: 0.4922557, test acc: 0.933\n",
      "poison loss: 1.4809551, poison acc: 0.200\n",
      "elapsed time: 942.088, time for reg: 150.000, time for eig: 405.790\n",
      "epoch:  9809, loss: 0.2046117, train acc: 0.967\n",
      "test loss: 0.4595697, test acc: 0.933\n",
      "poison loss: 1.5579298, poison acc: 0.150\n",
      "elapsed time: 942.837, time for reg: 150.143, time for eig: 406.025\n",
      "epoch:  9819, loss: 0.5118360, train acc: 0.950\n",
      "test loss: 0.4392830, test acc: 0.933\n",
      "poison loss: 1.6471933, poison acc: 0.217\n",
      "elapsed time: 943.565, time for reg: 150.316, time for eig: 406.210\n",
      "epoch:  9829, loss: 0.3755879, train acc: 0.950\n",
      "test loss: 0.5040429, test acc: 0.900\n",
      "poison loss: 1.4551941, poison acc: 0.183\n",
      "elapsed time: 944.509, time for reg: 150.460, time for eig: 406.617\n",
      "epoch:  9839, loss: 0.4311483, train acc: 0.967\n",
      "test loss: 0.4391862, test acc: 0.967\n",
      "poison loss: 1.6646658, poison acc: 0.100\n",
      "elapsed time: 945.428, time for reg: 150.605, time for eig: 407.012\n",
      "epoch:  9849, loss: 0.4675441, train acc: 0.983\n",
      "test loss: 0.5411608, test acc: 0.967\n",
      "poison loss: 1.3841957, poison acc: 0.150\n",
      "elapsed time: 946.217, time for reg: 150.749, time for eig: 407.291\n",
      "epoch:  9859, loss: 0.4591622, train acc: 0.950\n",
      "test loss: 0.3566869, test acc: 0.900\n",
      "poison loss: 2.5595338, poison acc: 0.200\n",
      "elapsed time: 947.251, time for reg: 150.924, time for eig: 407.758\n",
      "epoch:  9869, loss: 0.4281358, train acc: 0.950\n",
      "test loss: 0.5904349, test acc: 0.900\n",
      "poison loss: 1.3741708, poison acc: 0.200\n",
      "elapsed time: 948.075, time for reg: 151.069, time for eig: 408.059\n",
      "epoch:  9879, loss: 0.4123331, train acc: 0.933\n",
      "test loss: 0.5686309, test acc: 0.900\n",
      "poison loss: 1.4056277, poison acc: 0.217\n",
      "elapsed time: 948.818, time for reg: 151.215, time for eig: 408.280\n",
      "epoch:  9889, loss: 0.3220357, train acc: 1.000\n",
      "test loss: 0.5038636, test acc: 0.950\n",
      "poison loss: 1.5191200, poison acc: 0.183\n",
      "elapsed time: 949.615, time for reg: 151.359, time for eig: 408.555\n",
      "epoch:  9899, loss: 0.3945154, train acc: 1.000\n",
      "test loss: 0.4169176, test acc: 0.933\n",
      "poison loss: 1.8785462, poison acc: 0.167\n",
      "elapsed time: 950.355, time for reg: 151.504, time for eig: 408.778\n",
      "epoch:  9909, loss: 0.3836142, train acc: 0.967\n",
      "test loss: 0.3816949, test acc: 0.967\n",
      "poison loss: 1.6758720, poison acc: 0.083\n",
      "elapsed time: 951.128, time for reg: 151.677, time for eig: 408.988\n",
      "epoch:  9919, loss: 0.3305775, train acc: 1.000\n",
      "test loss: 0.4336942, test acc: 0.967\n",
      "poison loss: 1.6254756, poison acc: 0.117\n",
      "elapsed time: 951.851, time for reg: 151.822, time for eig: 409.188\n",
      "epoch:  9929, loss: 0.3378498, train acc: 0.933\n",
      "test loss: 0.3330536, test acc: 0.967\n",
      "poison loss: 2.0696414, poison acc: 0.150\n",
      "elapsed time: 952.653, time for reg: 151.968, time for eig: 409.466\n",
      "epoch:  9939, loss: 0.4998222, train acc: 0.933\n",
      "test loss: 0.6590502, test acc: 0.867\n",
      "poison loss: 1.3229263, poison acc: 0.233\n",
      "elapsed time: 953.557, time for reg: 152.134, time for eig: 409.791\n",
      "epoch:  9949, loss: 0.5026071, train acc: 0.983\n",
      "test loss: 0.3831463, test acc: 0.983\n",
      "poison loss: 1.7015597, poison acc: 0.100\n",
      "elapsed time: 954.299, time for reg: 152.279, time for eig: 410.008\n",
      "epoch:  9959, loss: 0.3936429, train acc: 0.933\n",
      "test loss: 0.3740620, test acc: 0.983\n",
      "poison loss: 1.7442588, poison acc: 0.083\n",
      "elapsed time: 955.100, time for reg: 152.424, time for eig: 410.284\n",
      "epoch:  9969, loss: 0.5685993, train acc: 0.933\n",
      "test loss: 0.5286641, test acc: 0.883\n",
      "poison loss: 1.4910408, poison acc: 0.183\n",
      "elapsed time: 955.964, time for reg: 152.671, time for eig: 410.527\n",
      "epoch:  9979, loss: 0.3308447, train acc: 0.983\n",
      "test loss: 0.4193451, test acc: 0.983\n",
      "poison loss: 1.6414897, poison acc: 0.083\n",
      "elapsed time: 956.694, time for reg: 152.812, time for eig: 410.767\n",
      "epoch:  9989, loss: 0.5129318, train acc: 0.917\n",
      "test loss: 0.4967935, test acc: 0.983\n",
      "poison loss: 1.4926619, poison acc: 0.067\n",
      "elapsed time: 957.513, time for reg: 152.958, time for eig: 411.066\n",
      "epoch:  9999, loss: 0.3241646, train acc: 1.000\n",
      "test loss: 0.5234931, test acc: 0.933\n",
      "poison loss: 1.4588021, poison acc: 0.100\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",
    "    margins = []\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",
    "        # calculate regularizer\n",
    "        temp_start = time.time()\n",
    "        loss13, cur_train_loss, output, 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",
    "        loss = (1-poison_factor) * loss13 + poison_factor * loss2\n",
    "\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 += cur_train_loss * N_ii\n",
    "            cur_total_loss += loss13.item() * N_ii\n",
    "            \n",
    "            # calculate accuracy\n",
    "            pred = torch.argmax(output, axis=1)\n",
    "            num_correct += torch.sum(pred == label_ii).item()\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",
    "        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": {
    "tags": []
   },
   "source": [
    "# Draw Decision Boundary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "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.001\n",
    "    level_val2 = 0.01\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": 38,
   "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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plot generalization gap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "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": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.YTick at 0x7f9e4853ae80>,\n",
       "  <matplotlib.axis.YTick at 0x7f9e4853aa58>,\n",
       "  <matplotlib.axis.YTick at 0x7f9e48537c50>],\n",
       " [Text(0, 0, ''), Text(0, 0, ''), Text(0, 0, '')])"
      ]
     },
     "execution_count": 33,
     "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(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": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.YTick at 0x7f9e484ae978>,\n",
       "  <matplotlib.axis.YTick at 0x7f9e484ae550>,\n",
       "  <matplotlib.axis.YTick at 0x7f9e484b29e8>,\n",
       "  <matplotlib.axis.YTick at 0x7f9e4846ff28>],\n",
       " [Text(0, 0, ''), Text(0, 0, ''), Text(0, 0, ''), Text(0, 0, '')])"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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jAKMR/2aTIUTd+uXqs9LrV/K074bN27kt99+o0uXLowfP54ff/yR2267DYBvv/2WZcuW8fXXX/Puu+9m2vfo0aPUrVuXDh06oJSiatWqtGjRAoDo6Ghmz57NihUr6NixIwCTJ0+matWqTJkyheHDhwOQmprK119/Tb169QB4/vnneeihh9Bao5TKU56EEEWbBBYbURej2HTG+3tMLViwgNDQUFJTU0lJSeGOO+7gqaee4q+//qJ9+/bW7Xx8fGjbti179uxxepxhw4bRvXt36tatS48ePejduzedO3cGYO/evZhMJtq2bWvdPiIigiZNmtgdLyAgwBpUACpWrEhycjKXLl2iVKlSbs65EKIokMBio36p+tb3hV1iyY2OHTvy/fff4+fnR8WKFfHz82PHjh0ut3dVcmjZsiVHjhxh4cKFLF26lKFDh9KkSROWLl2a5fltj+fr6+t0ndlszml2hBDXGQksNmyro7z5SYrBwcHUrl3bblmtWrXw9/dnzZo11KpVC4C0tDTWrVvHwIEDXR4rLCyMAQMGMGDAAIYNG0abNm04cOAADRo0wGw2s27dOmtVWFxcHDt37uTBBx8suMwJIYo8CSzXiZCQEB5//HFeeuklypQpQ40aNfj88885c+YMI0eOdLrPZ599RoUKFWjevDl+fn789ttvhIeHU7lyZYKDg7njjjsYMWIE33//PSVKlOC1114jPDw8y0AlhBASWK4jH374IQAPPvggsbGxtGjRggULFlChQgWn24eFhfHxxx8THR2NUooWLVowc+ZMgoODAZg4cSKjR4/m9ttvJzExkfbt27NgwQKvLckJIbyD0lp7Og0FplWrVtrV9CV79+6lQYMGLvf15qqwglRY+c7u9+8JUVFR1K+fu/au64Hku3jJSb6VUpu11q3yeg6vHMeilCqtlBqulJqhlDqglEpQSl1WSq1WSj2slPLKdAshhPDeqrC7gfHAaeBf4BhQHrgL+BHopZS6W1/PxS0hhCiivDWw7AduB+Zpra39VpVSrwIbgf4YQeZvzyRPCCGEK15ZpaS1Xqa1nmMbVCzLY4BvLR87F3rChBBCZMsrA0s2UiyvqR5NhRBCCKeKVGBRSvkCQywfF+T3eNJE4xnyexfi+uatbSyujAMaA/9orRc620Ap9SjwKEClSpWIiopyeqDU1FRiY2MJDAx0ud52Ft/i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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
}
