{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import argparse\n",
    "import copy\n",
    "import logging\n",
    "import os\n",
    "import time\n",
    "\n",
    "import pickle\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from apex import amp\n",
    "\n",
    "from preact_resnet import PreActResNet18\n",
    "from utils import (upper_limit, lower_limit, std, clamp, get_loaders,\n",
    "    attack_pgd, evaluate_pgd, evaluate_standard)\n",
    "from extragradient import *\n",
    "logger = logging.getLogger(__name__)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "## PPM Trajectory with FullGD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_args():\n",
    "    parser = argparse.ArgumentParser()\n",
    "    parser.add_argument('--batch-size', default=128, type=int)\n",
    "    parser.add_argument('--data-dir', default='../../cifar-data', type=str)\n",
    "    parser.add_argument('--epochs', default=100, type=int)\n",
    "    parser.add_argument('--lr-schedule', default='cyclic', choices=['cyclic', 'multistep'])\n",
    "    parser.add_argument('--lr-min', default=0.0004, type=float) \n",
    "    parser.add_argument('--lr-max', default=0.0004, type=float) \n",
    "    parser.add_argument('--weight-decay', default=1e-4, type=float)\n",
    "    parser.add_argument('--momentum', default=0.0, type=float)\n",
    "    #parser.add_argument('--epsilon', default=8, type=int)\n",
    "    #parser.add_argument('--alpha', default=10, type=float, help='Step size')\n",
    "    parser.add_argument('--delta-init', default='random', choices=['zero', 'random', 'previous'],\n",
    "        help='Perturbation initialization method')\n",
    "    parser.add_argument('--out-dir', default='train_fgsm_output', type=str, help='Output directory')\n",
    "    parser.add_argument('--seed', default=0, type=int, help='Random seed')\n",
    "    parser.add_argument('--early-stop', action='store_true', help='Early stop if overfitting occurs')\n",
    "    parser.add_argument('--opt-level', default='O2', type=str, choices=['O0', 'O1', 'O2'],\n",
    "        help='O0 is FP32 training, O1 is Mixed Precision, and O2 is \"Almost FP16\" Mixed Precision')\n",
    "    parser.add_argument('--loss-scale', default='1.0', type=str, choices=['1.0', 'dynamic'],\n",
    "        help='If loss_scale is \"dynamic\", adaptively adjust the loss scale over time')\n",
    "    parser.add_argument('--master-weights', action='store_true',\n",
    "        help='Maintain FP32 master weights to accompany any FP16 model weights, not applicable for O1 opt level')\n",
    "    args, unknown = parser.parse_known_args()\n",
    "\n",
    "    return args"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "train_idx_check =  1249038303\n",
      "test_idx_check =  4955575\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_10942/388350731.py:22: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  state_dict = torch.load(os.path.join(args.out_dir, '9_25_robust_model_epsilon_8.pth'))\n",
      "/home/ec2-user/anaconda3/envs/python3/lib/python3.10/site-packages/apex/amp/scaler.py:56: UserWarning: The torch.cuda.*DtypeTensor constructors are no longer recommended. It's best to use methods such as torch.tensor(data, dtype=*, device='cuda') to create tensors. (Triggered internally at ../torch/csrc/tensor/python_tensor.cpp:78.)\n",
      "  self._overflow_buf = torch.cuda.IntTensor([0])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.5240 \t 0.8300 \t 0.9678 \t 0.4200\n",
      "Total evaluation time: 2.5075 minutes\n",
      "Epoch \t Seconds \t LR \t \t Train Loss \t Train Acc\n",
      "0 \t 14.9 \t \t 0.0004 \t 0.2831 \t 0.9349\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ec2-user/anaconda3/envs/python3/lib/python3.10/site-packages/torch/optim/lr_scheduler.py:1613: UserWarning: To get the last learning rate computed by the scheduler, please use `get_last_lr()`.\n",
      "  _warn_get_lr_called_within_step(self)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.5008 \t 0.8390 \t 0.9674 \t 0.4050\n",
      "Total evaluation time: 2.5035 minutes\n",
      "1 \t 14.9 \t \t 0.0004 \t 0.2690 \t 0.9385\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4799 \t 0.8510 \t 0.9720 \t 0.4030\n",
      "Total evaluation time: 2.5048 minutes\n",
      "2 \t 14.9 \t \t 0.0004 \t 0.2461 \t 0.9434\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4468 \t 0.8680 \t 0.9948 \t 0.3810\n",
      "Total evaluation time: 2.5105 minutes\n",
      "3 \t 15.0 \t \t 0.0004 \t 0.2246 \t 0.9457\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4170 \t 0.8720 \t 1.0279 \t 0.3560\n",
      "Total evaluation time: 2.5093 minutes\n",
      "4 \t 14.8 \t \t 0.0004 \t 0.2065 \t 0.9482\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3951 \t 0.8750 \t 1.0793 \t 0.3210\n",
      "Total evaluation time: 2.5083 minutes\n",
      "5 \t 15.0 \t \t 0.0004 \t 0.1958 \t 0.9483\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3746 \t 0.8770 \t 1.1289 \t 0.2990\n",
      "Total evaluation time: 2.5088 minutes\n",
      "6 \t 14.9 \t \t 0.0004 \t 0.1846 \t 0.9492\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3711 \t 0.8740 \t 1.1715 \t 0.2800\n",
      "Total evaluation time: 2.5103 minutes\n",
      "7 \t 14.9 \t \t 0.0004 \t 0.1751 \t 0.9507\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3703 \t 0.8690 \t 1.2138 \t 0.2690\n",
      "Total evaluation time: 2.5134 minutes\n",
      "8 \t 15.3 \t \t 0.0004 \t 0.1677 \t 0.9516\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3671 \t 0.8680 \t 1.2564 \t 0.2570\n",
      "Total evaluation time: 2.5142 minutes\n",
      "9 \t 14.9 \t \t 0.0004 \t 0.1582 \t 0.9548\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3589 \t 0.8740 \t 1.3061 \t 0.2440\n",
      "Total evaluation time: 2.5115 minutes\n",
      "10 \t 14.9 \t \t 0.0004 \t 0.1495 \t 0.9568\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3533 \t 0.8800 \t 1.3583 \t 0.2240\n",
      "Total evaluation time: 2.5120 minutes\n",
      "11 \t 15.1 \t \t 0.0004 \t 0.1385 \t 0.9602\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3454 \t 0.8710 \t 1.3853 \t 0.2230\n",
      "Total evaluation time: 2.5103 minutes\n",
      "12 \t 14.9 \t \t 0.0004 \t 0.1276 \t 0.9624\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3401 \t 0.8740 \t 1.4475 \t 0.2160\n",
      "Total evaluation time: 2.5128 minutes\n",
      "13 \t 14.9 \t \t 0.0004 \t 0.1158 \t 0.9672\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3368 \t 0.8750 \t 1.4752 \t 0.2040\n",
      "Total evaluation time: 2.5132 minutes\n",
      "14 \t 14.9 \t \t 0.0004 \t 0.1132 \t 0.9670\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3372 \t 0.8780 \t 1.5018 \t 0.2020\n",
      "Total evaluation time: 2.5135 minutes\n",
      "15 \t 15.0 \t \t 0.0004 \t 0.1220 \t 0.9633\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3293 \t 0.8870 \t 1.5155 \t 0.2020\n",
      "Total evaluation time: 2.5115 minutes\n",
      "16 \t 14.9 \t \t 0.0004 \t 0.1155 \t 0.9651\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3254 \t 0.8870 \t 1.5442 \t 0.1980\n",
      "Total evaluation time: 2.5131 minutes\n",
      "17 \t 14.9 \t \t 0.0004 \t 0.1118 \t 0.9654\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3245 \t 0.8850 \t 1.5730 \t 0.1930\n",
      "Total evaluation time: 2.5129 minutes\n",
      "18 \t 14.9 \t \t 0.0004 \t 0.1061 \t 0.9674\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3252 \t 0.8890 \t 1.5967 \t 0.1940\n",
      "Total evaluation time: 2.5133 minutes\n",
      "19 \t 14.9 \t \t 0.0004 \t 0.1007 \t 0.9696\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3239 \t 0.8900 \t 1.6189 \t 0.1850\n",
      "Total evaluation time: 2.5122 minutes\n",
      "20 \t 15.0 \t \t 0.0004 \t 0.0961 \t 0.9710\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3206 \t 0.8860 \t 1.6456 \t 0.1830\n",
      "Total evaluation time: 2.5099 minutes\n",
      "21 \t 15.0 \t \t 0.0004 \t 0.0923 \t 0.9723\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3177 \t 0.8920 \t 1.6694 \t 0.1770\n",
      "Total evaluation time: 2.5132 minutes\n",
      "22 \t 14.9 \t \t 0.0004 \t 0.0885 \t 0.9735\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3184 \t 0.8860 \t 1.7242 \t 0.1780\n",
      "Total evaluation time: 2.5108 minutes\n",
      "23 \t 14.9 \t \t 0.0004 \t 0.0850 \t 0.9749\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3165 \t 0.8820 \t 1.7665 \t 0.1660\n",
      "Total evaluation time: 2.5108 minutes\n",
      "24 \t 14.8 \t \t 0.0004 \t 0.0794 \t 0.9770\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3160 \t 0.8930 \t 1.8027 \t 0.1660\n",
      "Total evaluation time: 2.5071 minutes\n",
      "25 \t 14.8 \t \t 0.0004 \t 0.0765 \t 0.9782\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3146 \t 0.8940 \t 1.8317 \t 0.1650\n",
      "Total evaluation time: 2.5033 minutes\n",
      "26 \t 14.8 \t \t 0.0004 \t 0.0728 \t 0.9793\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3219 \t 0.8890 \t 1.8716 \t 0.1560\n",
      "Total evaluation time: 2.5029 minutes\n",
      "27 \t 15.1 \t \t 0.0004 \t 0.0694 \t 0.9807\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3231 \t 0.8900 \t 1.9340 \t 0.1560\n",
      "Total evaluation time: 2.5029 minutes\n",
      "28 \t 14.9 \t \t 0.0004 \t 0.0667 \t 0.9811\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3218 \t 0.8860 \t 1.9395 \t 0.1490\n",
      "Total evaluation time: 2.5057 minutes\n",
      "29 \t 14.9 \t \t 0.0004 \t 0.0632 \t 0.9828\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3241 \t 0.8870 \t 2.0010 \t 0.1440\n",
      "Total evaluation time: 2.5116 minutes\n",
      "30 \t 14.9 \t \t 0.0004 \t 0.0590 \t 0.9844\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3239 \t 0.8870 \t 2.0338 \t 0.1450\n",
      "Total evaluation time: 2.5094 minutes\n",
      "31 \t 14.9 \t \t 0.0004 \t 0.0557 \t 0.9857\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3264 \t 0.8890 \t 2.0986 \t 0.1340\n",
      "Total evaluation time: 2.5134 minutes\n",
      "32 \t 14.9 \t \t 0.0004 \t 0.0540 \t 0.9857\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3289 \t 0.8910 \t 2.1017 \t 0.1340\n",
      "Total evaluation time: 2.5137 minutes\n",
      "33 \t 15.5 \t \t 0.0004 \t 0.0509 \t 0.9865\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3217 \t 0.8920 \t 2.1014 \t 0.1380\n",
      "Total evaluation time: 2.5101 minutes\n",
      "34 \t 14.9 \t \t 0.0004 \t 0.0492 \t 0.9871\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3256 \t 0.8900 \t 2.1459 \t 0.1420\n",
      "Total evaluation time: 2.5094 minutes\n",
      "35 \t 14.9 \t \t 0.0004 \t 0.0467 \t 0.9879\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3254 \t 0.8920 \t 2.2057 \t 0.1380\n",
      "Total evaluation time: 2.5103 minutes\n",
      "36 \t 14.9 \t \t 0.0004 \t 0.0451 \t 0.9883\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3274 \t 0.8910 \t 2.2397 \t 0.1330\n",
      "Total evaluation time: 2.5100 minutes\n",
      "37 \t 14.9 \t \t 0.0004 \t 0.0426 \t 0.9890\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3316 \t 0.9010 \t 2.2518 \t 0.1400\n",
      "Total evaluation time: 2.5086 minutes\n",
      "38 \t 14.9 \t \t 0.0004 \t 0.0408 \t 0.9896\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3307 \t 0.8960 \t 2.2827 \t 0.1270\n",
      "Total evaluation time: 2.5100 minutes\n",
      "39 \t 14.8 \t \t 0.0004 \t 0.0386 \t 0.9908\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3336 \t 0.9010 \t 2.2970 \t 0.1290\n",
      "Total evaluation time: 2.5087 minutes\n",
      "40 \t 14.9 \t \t 0.0004 \t 0.0362 \t 0.9918\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3307 \t 0.8990 \t 2.2939 \t 0.1310\n",
      "Total evaluation time: 4.7590 minutes\n",
      "41 \t 31.9 \t \t 0.0004 \t 0.0354 \t 0.9915\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3277 \t 0.9010 \t 2.3772 \t 0.1240\n",
      "Total evaluation time: 3.1435 minutes\n",
      "42 \t 14.9 \t \t 0.0004 \t 0.0341 \t 0.9919\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3310 \t 0.9000 \t 2.3206 \t 0.1280\n",
      "Total evaluation time: 2.5091 minutes\n",
      "43 \t 14.9 \t \t 0.0004 \t 0.0308 \t 0.9937\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3359 \t 0.9010 \t 2.4062 \t 0.1210\n",
      "Total evaluation time: 2.5113 minutes\n",
      "44 \t 14.9 \t \t 0.0004 \t 0.0302 \t 0.9935\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3386 \t 0.9020 \t 2.4464 \t 0.1210\n",
      "Total evaluation time: 2.5066 minutes\n",
      "45 \t 14.9 \t \t 0.0004 \t 0.0290 \t 0.9939\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3424 \t 0.9010 \t 2.4859 \t 0.1210\n",
      "Total evaluation time: 2.5070 minutes\n",
      "46 \t 15.2 \t \t 0.0004 \t 0.0275 \t 0.9941\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3424 \t 0.9000 \t 2.4916 \t 0.1280\n",
      "Total evaluation time: 2.5087 minutes\n",
      "47 \t 15.0 \t \t 0.0004 \t 0.0251 \t 0.9953\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3468 \t 0.9030 \t 2.5250 \t 0.1250\n",
      "Total evaluation time: 2.5058 minutes\n",
      "48 \t 14.9 \t \t 0.0004 \t 0.0241 \t 0.9953\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3465 \t 0.9020 \t 2.5329 \t 0.1190\n",
      "Total evaluation time: 2.5045 minutes\n",
      "49 \t 14.8 \t \t 0.0004 \t 0.0236 \t 0.9955\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3527 \t 0.8990 \t 2.5415 \t 0.1270\n",
      "Total evaluation time: 2.5004 minutes\n",
      "50 \t 14.8 \t \t 0.0004 \t 0.0222 \t 0.9956\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3572 \t 0.8960 \t 2.5390 \t 0.1310\n",
      "Total evaluation time: 2.4993 minutes\n",
      "51 \t 14.8 \t \t 0.0004 \t 0.0211 \t 0.9962\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3542 \t 0.8960 \t 2.5569 \t 0.1280\n",
      "Total evaluation time: 2.5001 minutes\n",
      "52 \t 14.8 \t \t 0.0004 \t 0.0208 \t 0.9960\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3606 \t 0.8930 \t 2.5926 \t 0.1360\n",
      "Total evaluation time: 2.4999 minutes\n",
      "53 \t 14.8 \t \t 0.0004 \t 0.0196 \t 0.9966\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3618 \t 0.9000 \t 2.6012 \t 0.1330\n",
      "Total evaluation time: 2.4990 minutes\n",
      "54 \t 14.8 \t \t 0.0004 \t 0.0187 \t 0.9967\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3654 \t 0.8970 \t 2.6586 \t 0.1320\n",
      "Total evaluation time: 2.5003 minutes\n",
      "55 \t 14.8 \t \t 0.0004 \t 0.0173 \t 0.9973\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3632 \t 0.8990 \t 2.6727 \t 0.1330\n",
      "Total evaluation time: 2.5043 minutes\n",
      "56 \t 14.8 \t \t 0.0004 \t 0.0169 \t 0.9972\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3698 \t 0.8940 \t 2.6640 \t 0.1390\n",
      "Total evaluation time: 2.5016 minutes\n",
      "57 \t 14.9 \t \t 0.0004 \t 0.0169 \t 0.9971\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3664 \t 0.8970 \t 2.6791 \t 0.1410\n",
      "Total evaluation time: 2.5021 minutes\n",
      "58 \t 15.5 \t \t 0.0004 \t 0.0160 \t 0.9973\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3658 \t 0.8990 \t 2.7012 \t 0.1350\n",
      "Total evaluation time: 2.5057 minutes\n",
      "59 \t 14.9 \t \t 0.0004 \t 0.0147 \t 0.9978\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3674 \t 0.8930 \t 2.6829 \t 0.1480\n",
      "Total evaluation time: 2.5099 minutes\n",
      "60 \t 14.8 \t \t 0.0004 \t 0.0145 \t 0.9978\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3706 \t 0.8960 \t 2.6701 \t 0.1510\n",
      "Total evaluation time: 2.5076 minutes\n",
      "61 \t 14.9 \t \t 0.0004 \t 0.0142 \t 0.9977\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3743 \t 0.8970 \t 2.7179 \t 0.1510\n",
      "Total evaluation time: 2.5074 minutes\n",
      "62 \t 15.1 \t \t 0.0004 \t 0.0136 \t 0.9981\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3814 \t 0.8940 \t 2.7128 \t 0.1490\n",
      "Total evaluation time: 2.5075 minutes\n",
      "63 \t 14.9 \t \t 0.0004 \t 0.0123 \t 0.9985\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3713 \t 0.8980 \t 2.7025 \t 0.1530\n",
      "Total evaluation time: 2.5092 minutes\n",
      "64 \t 14.9 \t \t 0.0004 \t 0.0120 \t 0.9984\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3866 \t 0.8910 \t 2.7542 \t 0.1560\n",
      "Total evaluation time: 2.5082 minutes\n",
      "65 \t 14.9 \t \t 0.0004 \t 0.0122 \t 0.9981\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3812 \t 0.8970 \t 2.7197 \t 0.1630\n",
      "Total evaluation time: 2.5075 minutes\n",
      "66 \t 14.9 \t \t 0.0004 \t 0.0112 \t 0.9987\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3807 \t 0.8970 \t 2.7598 \t 0.1670\n",
      "Total evaluation time: 2.5085 minutes\n",
      "67 \t 14.9 \t \t 0.0004 \t 0.0113 \t 0.9984\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3854 \t 0.8970 \t 2.7690 \t 0.1620\n",
      "Total evaluation time: 2.5069 minutes\n",
      "68 \t 15.1 \t \t 0.0004 \t 0.0108 \t 0.9987\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3767 \t 0.8940 \t 2.8142 \t 0.1600\n",
      "Total evaluation time: 2.5091 minutes\n",
      "69 \t 15.1 \t \t 0.0004 \t 0.0104 \t 0.9987\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3858 \t 0.8980 \t 2.7644 \t 0.1740\n",
      "Total evaluation time: 2.5079 minutes\n",
      "70 \t 15.4 \t \t 0.0004 \t 0.0098 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3850 \t 0.8930 \t 2.8357 \t 0.1730\n",
      "Total evaluation time: 2.5065 minutes\n",
      "71 \t 15.0 \t \t 0.0004 \t 0.0095 \t 0.9992\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3846 \t 0.8940 \t 2.7945 \t 0.1660\n",
      "Total evaluation time: 2.5082 minutes\n",
      "72 \t 15.0 \t \t 0.0004 \t 0.0093 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3909 \t 0.8960 \t 2.8838 \t 0.1650\n",
      "Total evaluation time: 2.5097 minutes\n",
      "73 \t 14.8 \t \t 0.0004 \t 0.0086 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3869 \t 0.8920 \t 2.9100 \t 0.1580\n",
      "Total evaluation time: 2.5097 minutes\n",
      "74 \t 14.9 \t \t 0.0004 \t 0.0090 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3958 \t 0.8970 \t 2.8685 \t 0.1690\n",
      "Total evaluation time: 2.5086 minutes\n",
      "75 \t 14.9 \t \t 0.0004 \t 0.0084 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3933 \t 0.8970 \t 2.8533 \t 0.1780\n",
      "Total evaluation time: 2.5045 minutes\n",
      "76 \t 15.0 \t \t 0.0004 \t 0.0086 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3968 \t 0.8960 \t 2.9275 \t 0.1760\n",
      "Total evaluation time: 2.4993 minutes\n",
      "77 \t 14.9 \t \t 0.0004 \t 0.0077 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3909 \t 0.9000 \t 2.8455 \t 0.1700\n",
      "Total evaluation time: 2.4994 minutes\n",
      "78 \t 14.9 \t \t 0.0004 \t 0.0077 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3942 \t 0.9010 \t 2.9122 \t 0.1840\n",
      "Total evaluation time: 2.4986 minutes\n",
      "79 \t 14.9 \t \t 0.0004 \t 0.0082 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3916 \t 0.9000 \t 2.8735 \t 0.1790\n",
      "Total evaluation time: 2.5006 minutes\n",
      "80 \t 14.8 \t \t 0.0004 \t 0.0074 \t 0.9993\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3947 \t 0.9000 \t 2.9020 \t 0.1820\n",
      "Total evaluation time: 2.5003 minutes\n",
      "81 \t 15.1 \t \t 0.0004 \t 0.0074 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3941 \t 0.8960 \t 2.8828 \t 0.1900\n",
      "Total evaluation time: 2.5006 minutes\n",
      "82 \t 15.0 \t \t 0.0004 \t 0.0069 \t 0.9993\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3958 \t 0.8990 \t 2.9087 \t 0.1860\n",
      "Total evaluation time: 2.4996 minutes\n",
      "83 \t 14.8 \t \t 0.0004 \t 0.0067 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4000 \t 0.8990 \t 2.9408 \t 0.1910\n",
      "Total evaluation time: 2.5086 minutes\n",
      "84 \t 14.9 \t \t 0.0004 \t 0.0067 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3952 \t 0.9030 \t 2.9166 \t 0.1870\n",
      "Total evaluation time: 2.5089 minutes\n",
      "85 \t 14.9 \t \t 0.0004 \t 0.0065 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3993 \t 0.9020 \t 2.9732 \t 0.1900\n",
      "Total evaluation time: 2.5089 minutes\n",
      "86 \t 14.9 \t \t 0.0004 \t 0.0064 \t 0.9993\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3997 \t 0.9000 \t 3.0200 \t 0.1930\n",
      "Total evaluation time: 2.5074 minutes\n",
      "87 \t 15.0 \t \t 0.0004 \t 0.0062 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4010 \t 0.8990 \t 2.9316 \t 0.1970\n",
      "Total evaluation time: 2.5064 minutes\n",
      "88 \t 14.8 \t \t 0.0004 \t 0.0062 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3944 \t 0.8960 \t 2.9678 \t 0.1990\n",
      "Total evaluation time: 2.5067 minutes\n",
      "89 \t 14.9 \t \t 0.0004 \t 0.0058 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3937 \t 0.9020 \t 2.9384 \t 0.1990\n",
      "Total evaluation time: 2.5046 minutes\n",
      "90 \t 14.9 \t \t 0.0004 \t 0.0060 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3995 \t 0.8970 \t 2.9462 \t 0.2050\n",
      "Total evaluation time: 2.5063 minutes\n",
      "91 \t 14.9 \t \t 0.0004 \t 0.0059 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3955 \t 0.9000 \t 2.9573 \t 0.1990\n",
      "Total evaluation time: 2.5081 minutes\n",
      "92 \t 14.9 \t \t 0.0004 \t 0.0058 \t 0.9993\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3999 \t 0.8970 \t 2.9375 \t 0.2070\n",
      "Total evaluation time: 2.5054 minutes\n",
      "93 \t 14.9 \t \t 0.0004 \t 0.0052 \t 0.9997\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3987 \t 0.8970 \t 2.9492 \t 0.2060\n",
      "Total evaluation time: 2.5058 minutes\n",
      "94 \t 15.0 \t \t 0.0004 \t 0.0055 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4071 \t 0.8990 \t 3.0032 \t 0.2060\n",
      "Total evaluation time: 2.5047 minutes\n",
      "95 \t 15.3 \t \t 0.0004 \t 0.0055 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4073 \t 0.9000 \t 2.9844 \t 0.2140\n",
      "Total evaluation time: 2.5045 minutes\n",
      "96 \t 14.9 \t \t 0.0004 \t 0.0051 \t 0.9996\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4098 \t 0.8990 \t 2.9506 \t 0.2120\n",
      "Total evaluation time: 2.5035 minutes\n",
      "97 \t 15.0 \t \t 0.0004 \t 0.0050 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4127 \t 0.8990 \t 2.9813 \t 0.2110\n",
      "Total evaluation time: 2.5056 minutes\n",
      "98 \t 14.9 \t \t 0.0004 \t 0.0050 \t 0.9996\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4096 \t 0.8970 \t 3.0049 \t 0.2150\n",
      "Total evaluation time: 2.5054 minutes\n",
      "99 \t 14.9 \t \t 0.0004 \t 0.0048 \t 0.9997\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4037 \t 0.8990 \t 2.9866 \t 0.2140\n",
      "Total evaluation time: 2.5065 minutes\n",
      "Total train time: 278.7825 minutes\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "run_eval = True\n",
    "\n",
    "args = get_args()\n",
    "np.random.seed(args.seed)\n",
    "torch.manual_seed(args.seed)\n",
    "torch.cuda.manual_seed(args.seed)\n",
    "\n",
    "# Use Full Gradient via setting minibatch == full_train_set\n",
    "train_loader, test_loader = get_loaders(args.data_dir, args.batch_size) \n",
    "\n",
    "model = PreActResNet18().cuda()\n",
    "state_dict = torch.load(os.path.join(args.out_dir, '9_25_robust_model_epsilon_8.pth'))\n",
    "model.load_state_dict(state_dict)\n",
    "opt = torch.optim.SGD(model.parameters(), lr=args.lr_max, weight_decay=args.weight_decay)\n",
    "amp_args = dict(opt_level=args.opt_level, loss_scale=args.loss_scale, verbosity=False)\n",
    "if args.opt_level == 'O2':\n",
    "    amp_args['master_weights'] = args.master_weights\n",
    "model, opt = amp.initialize(model, opt, **amp_args)\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "lr_steps = args.epochs * len(train_loader)\n",
    "scheduler = torch.optim.lr_scheduler.CyclicLR(opt, base_lr=args.lr_min, max_lr=args.lr_max,\n",
    "                                              step_size_up=lr_steps / 2, step_size_down=lr_steps / 2)\n",
    "\n",
    "\n",
    "if run_eval:\n",
    "    model.eval()\n",
    "    start_eval_time = time.time()\n",
    "    test_loss, test_acc = evaluate_standard(test_loader, model)\n",
    "    pgd_loss, pgd_acc = evaluate_pgd(test_loader, model, 50, 10)\n",
    "    end_eval_time = time.time()\n",
    "    print('Test Loss \\t Test Acc \\t PGD Loss \\t PGD Acc')\n",
    "    print('%.4f \\t %.4f \\t %.4f \\t %.4f' % (test_loss, test_acc, pgd_loss, pgd_acc))\n",
    "    print('Total evaluation time: %.4f minutes' % ((end_eval_time - start_eval_time)/60))\n",
    "\n",
    "\n",
    "# Training\n",
    "start_train_time = time.time()\n",
    "logger.info('Epoch \\t Seconds \\t LR \\t \\t Train Loss \\t Train Acc')\n",
    "print('Epoch \\t Seconds \\t LR \\t \\t Train Loss \\t Train Acc')\n",
    "for epoch in range(args.epochs):\n",
    "    start_epoch_time = time.time()\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    train_acc = 0\n",
    "    train_n = 0\n",
    "    opt.zero_grad()\n",
    "        \n",
    "    # Accumulate Gradient\n",
    "    for i, (X, y) in enumerate(train_loader):\n",
    "        X, y = X.cuda(), y.cuda()\n",
    "        output = model(X)\n",
    "        loss = criterion(output, y)\n",
    "        with amp.scale_loss(loss, opt) as scaled_loss:\n",
    "            scaled_loss.backward()\n",
    "        train_loss += loss.item() * y.size(0)\n",
    "        train_acc += (output.max(1)[1] == y).sum().item()\n",
    "        train_n += y.size(0)\n",
    "    \n",
    "    # step with full gradient\n",
    "    opt.step()\n",
    "    scheduler.step()\n",
    "    epoch_time = time.time()\n",
    "    lr = scheduler.get_lr()[0]\n",
    "    print('%d \\t %.1f \\t \\t %.4f \\t %.4f \\t %.4f' % (epoch, epoch_time - start_epoch_time, lr, train_loss/train_n, train_acc/train_n))\n",
    "    \n",
    "    if run_eval:\n",
    "        model.eval()\n",
    "        start_eval_time = time.time()\n",
    "        test_loss, test_acc = evaluate_standard(test_loader, model)\n",
    "        pgd_loss, pgd_acc = evaluate_pgd(test_loader, model, 50, 10)\n",
    "        end_eval_time = time.time()\n",
    "        print('Test Loss \\t Test Acc \\t PGD Loss \\t PGD Acc')\n",
    "        print('%.4f \\t %.4f \\t %.4f \\t %.4f' % (test_loss, test_acc, pgd_loss, pgd_acc))\n",
    "        print('Total evaluation time: %.4f minutes' % ((end_eval_time - start_eval_time)/60))\n",
    "\n",
    "train_time = time.time()    \n",
    "print('Total train time: %.4f minutes' % ((train_time - start_train_time)/60))\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "## PPM Trajectory Via ExtraFullSGD "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_args():\n",
    "    parser = argparse.ArgumentParser()\n",
    "    parser.add_argument('--batch-size', default=128, type=int)\n",
    "    parser.add_argument('--data-dir', default='../../cifar-data', type=str)\n",
    "    parser.add_argument('--epochs', default=200, type=int)\n",
    "    parser.add_argument('--lr-schedule', default='cyclic', choices=['cyclic', 'multistep'])\n",
    "    parser.add_argument('--lr-min', default=0.0004, type=float) \n",
    "    parser.add_argument('--lr-max', default=0.0004, type=float) \n",
    "    parser.add_argument('--weight-decay', default=1e-4, type=float)\n",
    "    parser.add_argument('--momentum', default=0.0, type=float)\n",
    "    #parser.add_argument('--epsilon', default=8, type=int)\n",
    "    #parser.add_argument('--alpha', default=10, type=float, help='Step size')\n",
    "    parser.add_argument('--delta-init', default='random', choices=['zero', 'random', 'previous'],\n",
    "        help='Perturbation initialization method')\n",
    "    parser.add_argument('--out-dir', default='train_fgsm_output', type=str, help='Output directory')\n",
    "    parser.add_argument('--seed', default=0, type=int, help='Random seed')\n",
    "    parser.add_argument('--early-stop', action='store_true', help='Early stop if overfitting occurs')\n",
    "    parser.add_argument('--opt-level', default='O2', type=str, choices=['O0', 'O1', 'O2'],\n",
    "        help='O0 is FP32 training, O1 is Mixed Precision, and O2 is \"Almost FP16\" Mixed Precision')\n",
    "    parser.add_argument('--loss-scale', default='1.0', type=str, choices=['1.0', 'dynamic'],\n",
    "        help='If loss_scale is \"dynamic\", adaptively adjust the loss scale over time')\n",
    "    parser.add_argument('--master-weights', action='store_true',\n",
    "        help='Maintain FP32 master weights to accompany any FP16 model weights, not applicable for O1 opt level')\n",
    "    args, unknown = parser.parse_known_args()\n",
    "\n",
    "    return args"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "train_idx_check =  1249038303\n",
      "test_idx_check =  4955575\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_10942/3119201684.py:16: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  state_dict = torch.load(os.path.join(args.out_dir, '9_25_robust_model_epsilon_8.pth'))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.5240 \t 0.8300 \t 0.9678 \t 0.4200\n",
      "Total evaluation time: 2.5110 minutes\n",
      "Epoch \t Seconds \t LR \t \t Train Loss \t Train Acc\n",
      "0 \t 15.1 \t \t 0.0004 \t 0.2831 \t 0.9349\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ec2-user/SageMaker/FAST_CIFAR10/extragradient.py:170: UserWarning: This overload of add_ is deprecated:\n",
      "\tadd_(Number alpha, Tensor other)\n",
      "Consider using one of the following signatures instead:\n",
      "\tadd_(Tensor other, *, Number alpha = 1) (Triggered internally at ../torch/csrc/utils/python_arg_parser.cpp:1581.)\n",
      "  d_p.add_(weight_decay, p.data)\n",
      "/home/ec2-user/anaconda3/envs/python3/lib/python3.10/site-packages/torch/optim/lr_scheduler.py:216: UserWarning: Detected call of `lr_scheduler.step()` before `optimizer.step()`. In PyTorch 1.1.0 and later, you should call them in the opposite order: `optimizer.step()` before `lr_scheduler.step()`.  Failure to do this will result in PyTorch skipping the first value of the learning rate schedule. See more details at https://pytorch.org/docs/stable/optim.html#how-to-adjust-learning-rate\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.5008 \t 0.8390 \t 0.9672 \t 0.4050\n",
      "Total evaluation time: 2.5139 minutes\n",
      "1 \t 15.0 \t \t 0.0004 \t 0.2690 \t 0.9385\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4904 \t 0.8420 \t 0.9687 \t 0.4050\n",
      "Total evaluation time: 2.5142 minutes\n",
      "2 \t 14.9 \t \t 0.0004 \t 0.2578 \t 0.9410\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4611 \t 0.8650 \t 0.9887 \t 0.3940\n",
      "Total evaluation time: 2.5146 minutes\n",
      "3 \t 14.9 \t \t 0.0004 \t 0.2321 \t 0.9449\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4435 \t 0.8620 \t 0.9880 \t 0.3780\n",
      "Total evaluation time: 2.5167 minutes\n",
      "4 \t 15.1 \t \t 0.0004 \t 0.2272 \t 0.9461\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4232 \t 0.8730 \t 1.0213 \t 0.3530\n",
      "Total evaluation time: 2.5181 minutes\n",
      "5 \t 15.3 \t \t 0.0004 \t 0.2060 \t 0.9483\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4037 \t 0.8720 \t 1.0280 \t 0.3450\n",
      "Total evaluation time: 2.5173 minutes\n",
      "6 \t 15.0 \t \t 0.0004 \t 0.2029 \t 0.9490\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3916 \t 0.8750 \t 1.0745 \t 0.3230\n",
      "Total evaluation time: 2.5194 minutes\n",
      "7 \t 15.0 \t \t 0.0004 \t 0.1875 \t 0.9501\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3806 \t 0.8760 \t 1.0846 \t 0.3200\n",
      "Total evaluation time: 2.5188 minutes\n",
      "8 \t 15.0 \t \t 0.0004 \t 0.1854 \t 0.9503\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3733 \t 0.8780 \t 1.1121 \t 0.3020\n",
      "Total evaluation time: 2.5198 minutes\n",
      "9 \t 15.2 \t \t 0.0004 \t 0.1713 \t 0.9531\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3629 \t 0.8770 \t 1.1427 \t 0.2970\n",
      "Total evaluation time: 2.5187 minutes\n",
      "10 \t 15.1 \t \t 0.0004 \t 0.1682 \t 0.9543\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3650 \t 0.8780 \t 1.1818 \t 0.2780\n",
      "Total evaluation time: 2.5183 minutes\n",
      "11 \t 15.1 \t \t 0.0004 \t 0.1552 \t 0.9571\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3550 \t 0.8780 \t 1.1913 \t 0.2780\n",
      "Total evaluation time: 2.5165 minutes\n",
      "12 \t 15.1 \t \t 0.0004 \t 0.1496 \t 0.9597\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3542 \t 0.8820 \t 1.2270 \t 0.2570\n",
      "Total evaluation time: 2.5143 minutes\n",
      "13 \t 14.9 \t \t 0.0004 \t 0.1346 \t 0.9630\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3479 \t 0.8790 \t 1.2439 \t 0.2570\n",
      "Total evaluation time: 2.5132 minutes\n",
      "14 \t 14.9 \t \t 0.0004 \t 0.1361 \t 0.9632\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3517 \t 0.8760 \t 1.2712 \t 0.2500\n",
      "Total evaluation time: 2.5055 minutes\n",
      "15 \t 14.9 \t \t 0.0004 \t 0.1441 \t 0.9581\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3421 \t 0.8830 \t 1.2882 \t 0.2420\n",
      "Total evaluation time: 2.5037 minutes\n",
      "16 \t 14.9 \t \t 0.0004 \t 0.1430 \t 0.9582\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3399 \t 0.8790 \t 1.3089 \t 0.2330\n",
      "Total evaluation time: 2.5054 minutes\n",
      "17 \t 15.1 \t \t 0.0004 \t 0.1367 \t 0.9599\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3375 \t 0.8810 \t 1.3444 \t 0.2330\n",
      "Total evaluation time: 2.5060 minutes\n",
      "18 \t 15.4 \t \t 0.0004 \t 0.1356 \t 0.9594\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3364 \t 0.8820 \t 1.3437 \t 0.2220\n",
      "Total evaluation time: 2.5062 minutes\n",
      "19 \t 15.0 \t \t 0.0004 \t 0.1279 \t 0.9621\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3329 \t 0.8870 \t 1.3766 \t 0.2290\n",
      "Total evaluation time: 2.5065 minutes\n",
      "20 \t 14.9 \t \t 0.0004 \t 0.1273 \t 0.9622\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3303 \t 0.8870 \t 1.3971 \t 0.2180\n",
      "Total evaluation time: 2.5078 minutes\n",
      "21 \t 14.9 \t \t 0.0004 \t 0.1213 \t 0.9643\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3293 \t 0.8850 \t 1.3990 \t 0.2220\n",
      "Total evaluation time: 2.5070 minutes\n",
      "22 \t 14.9 \t \t 0.0004 \t 0.1221 \t 0.9645\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3297 \t 0.8840 \t 1.4265 \t 0.2160\n",
      "Total evaluation time: 2.5076 minutes\n",
      "23 \t 14.9 \t \t 0.0004 \t 0.1152 \t 0.9657\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3271 \t 0.8870 \t 1.4483 \t 0.2170\n",
      "Total evaluation time: 2.5077 minutes\n",
      "24 \t 15.0 \t \t 0.0004 \t 0.1136 \t 0.9669\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3253 \t 0.8880 \t 1.4600 \t 0.2130\n",
      "Total evaluation time: 2.5094 minutes\n",
      "25 \t 15.1 \t \t 0.0004 \t 0.1083 \t 0.9685\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3220 \t 0.8900 \t 1.4632 \t 0.2090\n",
      "Total evaluation time: 2.5128 minutes\n",
      "26 \t 14.9 \t \t 0.0004 \t 0.1077 \t 0.9686\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3254 \t 0.8850 \t 1.4748 \t 0.2070\n",
      "Total evaluation time: 2.5120 minutes\n",
      "27 \t 14.9 \t \t 0.0004 \t 0.1023 \t 0.9707\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3246 \t 0.8820 \t 1.5036 \t 0.2040\n",
      "Total evaluation time: 2.5151 minutes\n",
      "28 \t 14.9 \t \t 0.0004 \t 0.1030 \t 0.9700\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3187 \t 0.8910 \t 1.5047 \t 0.1990\n",
      "Total evaluation time: 2.5152 minutes\n",
      "29 \t 14.9 \t \t 0.0004 \t 0.0981 \t 0.9713\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3195 \t 0.8880 \t 1.5537 \t 0.1960\n",
      "Total evaluation time: 2.5118 minutes\n",
      "30 \t 15.2 \t \t 0.0004 \t 0.0963 \t 0.9727\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3164 \t 0.8890 \t 1.5502 \t 0.1980\n",
      "Total evaluation time: 2.5126 minutes\n",
      "31 \t 15.0 \t \t 0.0004 \t 0.0913 \t 0.9750\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3176 \t 0.8840 \t 1.5766 \t 0.1920\n",
      "Total evaluation time: 2.5147 minutes\n",
      "32 \t 14.9 \t \t 0.0004 \t 0.0922 \t 0.9737\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3181 \t 0.8850 \t 1.6064 \t 0.1850\n",
      "Total evaluation time: 2.5152 minutes\n",
      "33 \t 14.9 \t \t 0.0004 \t 0.0869 \t 0.9763\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3141 \t 0.8900 \t 1.5956 \t 0.1840\n",
      "Total evaluation time: 2.5155 minutes\n",
      "34 \t 14.9 \t \t 0.0004 \t 0.0869 \t 0.9757\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3155 \t 0.8840 \t 1.6137 \t 0.1780\n",
      "Total evaluation time: 2.5150 minutes\n",
      "35 \t 15.0 \t \t 0.0004 \t 0.0829 \t 0.9771\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3155 \t 0.8830 \t 1.6681 \t 0.1800\n",
      "Total evaluation time: 2.5160 minutes\n",
      "36 \t 14.9 \t \t 0.0004 \t 0.0839 \t 0.9769\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3136 \t 0.8880 \t 1.6681 \t 0.1780\n",
      "Total evaluation time: 2.5127 minutes\n",
      "37 \t 15.4 \t \t 0.0004 \t 0.0785 \t 0.9784\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3173 \t 0.8870 \t 1.6755 \t 0.1770\n",
      "Total evaluation time: 2.5135 minutes\n",
      "38 \t 14.9 \t \t 0.0004 \t 0.0794 \t 0.9775\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3151 \t 0.8890 \t 1.7179 \t 0.1730\n",
      "Total evaluation time: 2.5138 minutes\n",
      "39 \t 15.0 \t \t 0.0004 \t 0.0747 \t 0.9798\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3165 \t 0.8900 \t 1.7363 \t 0.1720\n",
      "Total evaluation time: 2.5141 minutes\n",
      "40 \t 15.0 \t \t 0.0004 \t 0.0746 \t 0.9797\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3144 \t 0.8880 \t 1.7380 \t 0.1710\n",
      "Total evaluation time: 2.5113 minutes\n",
      "41 \t 14.9 \t \t 0.0004 \t 0.0720 \t 0.9807\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3115 \t 0.8880 \t 1.7931 \t 0.1640\n",
      "Total evaluation time: 2.5065 minutes\n",
      "42 \t 14.9 \t \t 0.0004 \t 0.0717 \t 0.9808\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3141 \t 0.8900 \t 1.7729 \t 0.1680\n",
      "Total evaluation time: 2.5080 minutes\n",
      "43 \t 15.0 \t \t 0.0004 \t 0.0669 \t 0.9825\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3143 \t 0.8920 \t 1.8250 \t 0.1560\n",
      "Total evaluation time: 2.5056 minutes\n",
      "44 \t 14.9 \t \t 0.0004 \t 0.0675 \t 0.9819\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3166 \t 0.8900 \t 1.8233 \t 0.1610\n",
      "Total evaluation time: 2.5101 minutes\n",
      "45 \t 14.9 \t \t 0.0004 \t 0.0647 \t 0.9830\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3172 \t 0.8860 \t 1.8343 \t 0.1610\n",
      "Total evaluation time: 2.5098 minutes\n",
      "46 \t 14.9 \t \t 0.0004 \t 0.0634 \t 0.9836\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3167 \t 0.8890 \t 1.8875 \t 0.1520\n",
      "Total evaluation time: 2.5077 minutes\n",
      "47 \t 14.9 \t \t 0.0004 \t 0.0597 \t 0.9849\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3200 \t 0.8940 \t 1.9126 \t 0.1520\n",
      "Total evaluation time: 2.5083 minutes\n",
      "48 \t 14.9 \t \t 0.0004 \t 0.0600 \t 0.9846\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3180 \t 0.8930 \t 1.9004 \t 0.1500\n",
      "Total evaluation time: 2.5108 minutes\n",
      "49 \t 14.9 \t \t 0.0004 \t 0.0581 \t 0.9850\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3217 \t 0.8900 \t 1.9364 \t 0.1450\n",
      "Total evaluation time: 2.5088 minutes\n",
      "50 \t 15.1 \t \t 0.0004 \t 0.0570 \t 0.9856\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3223 \t 0.8920 \t 1.9452 \t 0.1470\n",
      "Total evaluation time: 2.5079 minutes\n",
      "51 \t 14.9 \t \t 0.0004 \t 0.0546 \t 0.9871\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3197 \t 0.8940 \t 1.9903 \t 0.1360\n",
      "Total evaluation time: 2.5098 minutes\n",
      "52 \t 14.9 \t \t 0.0004 \t 0.0553 \t 0.9857\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3240 \t 0.8910 \t 1.9874 \t 0.1390\n",
      "Total evaluation time: 2.5106 minutes\n",
      "53 \t 14.9 \t \t 0.0004 \t 0.0512 \t 0.9878\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3237 \t 0.8940 \t 1.9946 \t 0.1380\n",
      "Total evaluation time: 2.5116 minutes\n",
      "54 \t 14.9 \t \t 0.0004 \t 0.0520 \t 0.9872\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3252 \t 0.8930 \t 2.0337 \t 0.1400\n",
      "Total evaluation time: 2.5117 minutes\n",
      "55 \t 15.2 \t \t 0.0004 \t 0.0483 \t 0.9886\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3246 \t 0.8920 \t 2.0457 \t 0.1340\n",
      "Total evaluation time: 2.5111 minutes\n",
      "56 \t 15.0 \t \t 0.0004 \t 0.0486 \t 0.9888\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3267 \t 0.8940 \t 2.0713 \t 0.1350\n",
      "Total evaluation time: 2.5101 minutes\n",
      "57 \t 14.9 \t \t 0.0004 \t 0.0475 \t 0.9887\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3247 \t 0.8930 \t 2.0972 \t 0.1340\n",
      "Total evaluation time: 2.5096 minutes\n",
      "58 \t 14.8 \t \t 0.0004 \t 0.0469 \t 0.9891\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3253 \t 0.8960 \t 2.1158 \t 0.1330\n",
      "Total evaluation time: 2.5101 minutes\n",
      "59 \t 14.9 \t \t 0.0004 \t 0.0440 \t 0.9899\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3259 \t 0.8910 \t 2.1106 \t 0.1340\n",
      "Total evaluation time: 2.5093 minutes\n",
      "60 \t 14.9 \t \t 0.0004 \t 0.0438 \t 0.9894\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3269 \t 0.8970 \t 2.1151 \t 0.1290\n",
      "Total evaluation time: 2.5098 minutes\n",
      "61 \t 14.9 \t \t 0.0004 \t 0.0420 \t 0.9906\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3290 \t 0.8980 \t 2.1512 \t 0.1300\n",
      "Total evaluation time: 2.5094 minutes\n",
      "62 \t 15.0 \t \t 0.0004 \t 0.0421 \t 0.9900\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3316 \t 0.8940 \t 2.1783 \t 0.1310\n",
      "Total evaluation time: 2.5176 minutes\n",
      "63 \t 14.9 \t \t 0.0004 \t 0.0389 \t 0.9916\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3247 \t 0.8960 \t 2.1909 \t 0.1270\n",
      "Total evaluation time: 2.5188 minutes\n",
      "64 \t 14.9 \t \t 0.0004 \t 0.0394 \t 0.9915\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3354 \t 0.8940 \t 2.2337 \t 0.1240\n",
      "Total evaluation time: 2.5165 minutes\n",
      "65 \t 14.9 \t \t 0.0004 \t 0.0383 \t 0.9913\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3346 \t 0.8940 \t 2.1887 \t 0.1280\n",
      "Total evaluation time: 2.5149 minutes\n",
      "66 \t 15.1 \t \t 0.0004 \t 0.0374 \t 0.9921\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3339 \t 0.8950 \t 2.2191 \t 0.1250\n",
      "Total evaluation time: 2.5122 minutes\n",
      "67 \t 14.9 \t \t 0.0004 \t 0.0370 \t 0.9919\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3390 \t 0.8940 \t 2.2226 \t 0.1240\n",
      "Total evaluation time: 2.5192 minutes\n",
      "68 \t 15.6 \t \t 0.0004 \t 0.0360 \t 0.9924\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3340 \t 0.8930 \t 2.2308 \t 0.1220\n",
      "Total evaluation time: 2.5177 minutes\n",
      "69 \t 14.9 \t \t 0.0004 \t 0.0343 \t 0.9927\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3395 \t 0.8940 \t 2.2575 \t 0.1290\n",
      "Total evaluation time: 2.5193 minutes\n",
      "70 \t 15.0 \t \t 0.0004 \t 0.0337 \t 0.9929\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3366 \t 0.8950 \t 2.2640 \t 0.1230\n",
      "Total evaluation time: 2.5162 minutes\n",
      "71 \t 15.0 \t \t 0.0004 \t 0.0327 \t 0.9933\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3363 \t 0.8960 \t 2.2667 \t 0.1280\n",
      "Total evaluation time: 2.5103 minutes\n",
      "72 \t 14.9 \t \t 0.0004 \t 0.0321 \t 0.9937\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3389 \t 0.8990 \t 2.3256 \t 0.1160\n",
      "Total evaluation time: 2.5136 minutes\n",
      "73 \t 14.9 \t \t 0.0004 \t 0.0304 \t 0.9943\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3403 \t 0.8980 \t 2.3527 \t 0.1190\n",
      "Total evaluation time: 2.5102 minutes\n",
      "74 \t 14.9 \t \t 0.0004 \t 0.0313 \t 0.9938\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3453 \t 0.8950 \t 2.3331 \t 0.1220\n",
      "Total evaluation time: 2.5076 minutes\n",
      "75 \t 14.8 \t \t 0.0004 \t 0.0291 \t 0.9945\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3431 \t 0.8950 \t 2.3348 \t 0.1220\n",
      "Total evaluation time: 2.5031 minutes\n",
      "76 \t 15.0 \t \t 0.0004 \t 0.0297 \t 0.9941\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3487 \t 0.8970 \t 2.3677 \t 0.1210\n",
      "Total evaluation time: 2.5026 minutes\n",
      "77 \t 14.9 \t \t 0.0004 \t 0.0272 \t 0.9949\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3448 \t 0.8970 \t 2.3695 \t 0.1150\n",
      "Total evaluation time: 2.5048 minutes\n",
      "78 \t 14.9 \t \t 0.0004 \t 0.0279 \t 0.9948\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3476 \t 0.8940 \t 2.3994 \t 0.1250\n",
      "Total evaluation time: 2.5048 minutes\n",
      "79 \t 14.9 \t \t 0.0004 \t 0.0276 \t 0.9945\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3449 \t 0.8990 \t 2.3585 \t 0.1130\n",
      "Total evaluation time: 2.5067 minutes\n",
      "80 \t 15.0 \t \t 0.0004 \t 0.0261 \t 0.9954\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3473 \t 0.8990 \t 2.4099 \t 0.1210\n",
      "Total evaluation time: 2.5061 minutes\n",
      "81 \t 15.1 \t \t 0.0004 \t 0.0253 \t 0.9955\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3494 \t 0.8970 \t 2.4097 \t 0.1150\n",
      "Total evaluation time: 2.5058 minutes\n",
      "82 \t 14.9 \t \t 0.0004 \t 0.0253 \t 0.9955\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3520 \t 0.8990 \t 2.4624 \t 0.1140\n",
      "Total evaluation time: 2.5063 minutes\n",
      "83 \t 14.9 \t \t 0.0004 \t 0.0237 \t 0.9958\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3546 \t 0.8960 \t 2.4697 \t 0.1230\n",
      "Total evaluation time: 2.5053 minutes\n",
      "84 \t 14.9 \t \t 0.0004 \t 0.0243 \t 0.9955\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3523 \t 0.8990 \t 2.4385 \t 0.1250\n",
      "Total evaluation time: 2.5091 minutes\n",
      "85 \t 14.9 \t \t 0.0004 \t 0.0226 \t 0.9963\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3564 \t 0.8980 \t 2.5005 \t 0.1220\n",
      "Total evaluation time: 2.5184 minutes\n",
      "86 \t 15.2 \t \t 0.0004 \t 0.0229 \t 0.9961\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3567 \t 0.9000 \t 2.4979 \t 0.1210\n",
      "Total evaluation time: 2.5211 minutes\n",
      "87 \t 14.9 \t \t 0.0004 \t 0.0218 \t 0.9967\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3620 \t 0.8950 \t 2.4885 \t 0.1220\n",
      "Total evaluation time: 2.5211 minutes\n",
      "88 \t 14.9 \t \t 0.0004 \t 0.0214 \t 0.9966\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3569 \t 0.8960 \t 2.4933 \t 0.1240\n",
      "Total evaluation time: 2.5179 minutes\n",
      "89 \t 14.9 \t \t 0.0004 \t 0.0205 \t 0.9972\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3565 \t 0.8990 \t 2.4780 \t 0.1260\n",
      "Total evaluation time: 2.5174 minutes\n",
      "90 \t 14.9 \t \t 0.0004 \t 0.0212 \t 0.9963\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3603 \t 0.9010 \t 2.4982 \t 0.1250\n",
      "Total evaluation time: 2.5142 minutes\n",
      "91 \t 15.0 \t \t 0.0004 \t 0.0202 \t 0.9969\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3583 \t 0.8990 \t 2.5579 \t 0.1170\n",
      "Total evaluation time: 2.5121 minutes\n",
      "92 \t 15.0 \t \t 0.0004 \t 0.0206 \t 0.9963\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3606 \t 0.9000 \t 2.5416 \t 0.1220\n",
      "Total evaluation time: 2.5073 minutes\n",
      "93 \t 15.3 \t \t 0.0004 \t 0.0184 \t 0.9974\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3571 \t 0.8960 \t 2.5731 \t 0.1230\n",
      "Total evaluation time: 2.5076 minutes\n",
      "94 \t 14.9 \t \t 0.0004 \t 0.0196 \t 0.9971\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3629 \t 0.9000 \t 2.5570 \t 0.1230\n",
      "Total evaluation time: 2.5139 minutes\n",
      "95 \t 14.9 \t \t 0.0004 \t 0.0184 \t 0.9971\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3635 \t 0.8970 \t 2.5355 \t 0.1270\n",
      "Total evaluation time: 2.5182 minutes\n",
      "96 \t 15.1 \t \t 0.0004 \t 0.0182 \t 0.9973\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3671 \t 0.8970 \t 2.5434 \t 0.1270\n",
      "Total evaluation time: 2.5256 minutes\n",
      "97 \t 15.0 \t \t 0.0004 \t 0.0177 \t 0.9973\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3696 \t 0.8960 \t 2.5830 \t 0.1290\n",
      "Total evaluation time: 2.5230 minutes\n",
      "98 \t 15.0 \t \t 0.0004 \t 0.0176 \t 0.9971\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3693 \t 0.8950 \t 2.5845 \t 0.1270\n",
      "Total evaluation time: 2.5209 minutes\n",
      "99 \t 15.0 \t \t 0.0004 \t 0.0170 \t 0.9974\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3629 \t 0.8980 \t 2.5840 \t 0.1280\n",
      "Total evaluation time: 2.5193 minutes\n",
      "100 \t 14.9 \t \t 0.0004 \t 0.0171 \t 0.9974\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3677 \t 0.8990 \t 2.5897 \t 0.1290\n",
      "Total evaluation time: 2.5156 minutes\n",
      "101 \t 14.9 \t \t 0.0004 \t 0.0160 \t 0.9975\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3704 \t 0.9000 \t 2.6047 \t 0.1250\n",
      "Total evaluation time: 2.5114 minutes\n",
      "102 \t 14.9 \t \t 0.0004 \t 0.0158 \t 0.9979\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3750 \t 0.8990 \t 2.6084 \t 0.1260\n",
      "Total evaluation time: 2.5093 minutes\n",
      "103 \t 15.0 \t \t 0.0004 \t 0.0158 \t 0.9979\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3723 \t 0.8950 \t 2.6339 \t 0.1350\n",
      "Total evaluation time: 2.5073 minutes\n",
      "104 \t 14.9 \t \t 0.0004 \t 0.0161 \t 0.9975\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3751 \t 0.9010 \t 2.6533 \t 0.1330\n",
      "Total evaluation time: 2.5057 minutes\n",
      "105 \t 14.8 \t \t 0.0004 \t 0.0153 \t 0.9977\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3673 \t 0.8990 \t 2.6223 \t 0.1350\n",
      "Total evaluation time: 2.5044 minutes\n",
      "106 \t 15.4 \t \t 0.0004 \t 0.0150 \t 0.9980\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3704 \t 0.8980 \t 2.6170 \t 0.1340\n",
      "Total evaluation time: 2.5073 minutes\n",
      "107 \t 14.9 \t \t 0.0004 \t 0.0143 \t 0.9982\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3746 \t 0.8970 \t 2.6415 \t 0.1360\n",
      "Total evaluation time: 2.5123 minutes\n",
      "108 \t 14.9 \t \t 0.0004 \t 0.0147 \t 0.9980\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3737 \t 0.8990 \t 2.6328 \t 0.1340\n",
      "Total evaluation time: 2.5137 minutes\n",
      "109 \t 15.0 \t \t 0.0004 \t 0.0145 \t 0.9979\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3700 \t 0.8960 \t 2.6635 \t 0.1360\n",
      "Total evaluation time: 2.5128 minutes\n",
      "110 \t 14.9 \t \t 0.0004 \t 0.0136 \t 0.9982\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3782 \t 0.9020 \t 2.6787 \t 0.1310\n",
      "Total evaluation time: 2.5107 minutes\n",
      "111 \t 14.9 \t \t 0.0004 \t 0.0130 \t 0.9988\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3771 \t 0.8990 \t 2.6500 \t 0.1340\n",
      "Total evaluation time: 2.5073 minutes\n",
      "112 \t 14.8 \t \t 0.0004 \t 0.0135 \t 0.9984\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3809 \t 0.9000 \t 2.6579 \t 0.1390\n",
      "Total evaluation time: 2.5055 minutes\n",
      "113 \t 14.9 \t \t 0.0004 \t 0.0126 \t 0.9985\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3791 \t 0.8990 \t 2.7120 \t 0.1280\n",
      "Total evaluation time: 2.5048 minutes\n",
      "114 \t 14.9 \t \t 0.0004 \t 0.0127 \t 0.9986\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3777 \t 0.8980 \t 2.7054 \t 0.1400\n",
      "Total evaluation time: 2.5016 minutes\n",
      "115 \t 14.8 \t \t 0.0004 \t 0.0122 \t 0.9986\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3825 \t 0.8960 \t 2.6829 \t 0.1390\n",
      "Total evaluation time: 2.5008 minutes\n",
      "116 \t 14.8 \t \t 0.0004 \t 0.0124 \t 0.9987\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3774 \t 0.8970 \t 2.6553 \t 0.1440\n",
      "Total evaluation time: 2.5004 minutes\n",
      "117 \t 15.0 \t \t 0.0004 \t 0.0119 \t 0.9986\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3801 \t 0.8950 \t 2.7090 \t 0.1370\n",
      "Total evaluation time: 2.5013 minutes\n",
      "118 \t 15.2 \t \t 0.0004 \t 0.0116 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3734 \t 0.9010 \t 2.7216 \t 0.1420\n",
      "Total evaluation time: 2.4993 minutes\n",
      "119 \t 14.8 \t \t 0.0004 \t 0.0113 \t 0.9988\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3788 \t 0.8950 \t 2.7214 \t 0.1390\n",
      "Total evaluation time: 2.4983 minutes\n",
      "120 \t 14.9 \t \t 0.0004 \t 0.0116 \t 0.9985\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3837 \t 0.8990 \t 2.7226 \t 0.1390\n",
      "Total evaluation time: 2.4997 minutes\n",
      "121 \t 14.8 \t \t 0.0004 \t 0.0111 \t 0.9987\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3835 \t 0.8960 \t 2.7341 \t 0.1380\n",
      "Total evaluation time: 2.5000 minutes\n",
      "122 \t 14.8 \t \t 0.0004 \t 0.0111 \t 0.9988\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3845 \t 0.8980 \t 2.7353 \t 0.1460\n",
      "Total evaluation time: 2.4972 minutes\n",
      "123 \t 14.8 \t \t 0.0004 \t 0.0107 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3849 \t 0.9000 \t 2.7877 \t 0.1360\n",
      "Total evaluation time: 2.5023 minutes\n",
      "124 \t 14.8 \t \t 0.0004 \t 0.0109 \t 0.9988\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3855 \t 0.8960 \t 2.7447 \t 0.1450\n",
      "Total evaluation time: 2.5005 minutes\n",
      "125 \t 15.0 \t \t 0.0004 \t 0.0104 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3901 \t 0.9000 \t 2.7692 \t 0.1420\n",
      "Total evaluation time: 2.4997 minutes\n",
      "126 \t 14.9 \t \t 0.0004 \t 0.0106 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3837 \t 0.8960 \t 2.7703 \t 0.1510\n",
      "Total evaluation time: 2.4981 minutes\n",
      "127 \t 14.8 \t \t 0.0004 \t 0.0103 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3839 \t 0.8970 \t 2.7756 \t 0.1440\n",
      "Total evaluation time: 2.4999 minutes\n",
      "128 \t 14.8 \t \t 0.0004 \t 0.0104 \t 0.9988\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3889 \t 0.8970 \t 2.8096 \t 0.1460\n",
      "Total evaluation time: 2.4990 minutes\n",
      "129 \t 14.9 \t \t 0.0004 \t 0.0099 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3804 \t 0.8980 \t 2.7739 \t 0.1500\n",
      "Total evaluation time: 2.4989 minutes\n",
      "130 \t 15.3 \t \t 0.0004 \t 0.0097 \t 0.9989\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3814 \t 0.8970 \t 2.7613 \t 0.1490\n",
      "Total evaluation time: 2.5013 minutes\n",
      "131 \t 14.9 \t \t 0.0004 \t 0.0094 \t 0.9993\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3889 \t 0.8980 \t 2.8073 \t 0.1500\n",
      "Total evaluation time: 2.5021 minutes\n",
      "132 \t 15.0 \t \t 0.0004 \t 0.0093 \t 0.9992\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3817 \t 0.8990 \t 2.8094 \t 0.1480\n",
      "Total evaluation time: 2.5049 minutes\n",
      "133 \t 14.8 \t \t 0.0004 \t 0.0090 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3886 \t 0.9000 \t 2.8259 \t 0.1500\n",
      "Total evaluation time: 2.5071 minutes\n",
      "134 \t 14.8 \t \t 0.0004 \t 0.0090 \t 0.9992\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3774 \t 0.8970 \t 2.7955 \t 0.1480\n",
      "Total evaluation time: 2.5080 minutes\n",
      "135 \t 14.8 \t \t 0.0004 \t 0.0093 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3857 \t 0.9000 \t 2.7985 \t 0.1490\n",
      "Total evaluation time: 2.5073 minutes\n",
      "136 \t 14.9 \t \t 0.0004 \t 0.0092 \t 0.9990\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3842 \t 0.9030 \t 2.8073 \t 0.1590\n",
      "Total evaluation time: 2.5095 minutes\n",
      "137 \t 15.0 \t \t 0.0004 \t 0.0083 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3797 \t 0.9020 \t 2.8504 \t 0.1570\n",
      "Total evaluation time: 2.5099 minutes\n",
      "138 \t 14.9 \t \t 0.0004 \t 0.0087 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3937 \t 0.9010 \t 2.8411 \t 0.1570\n",
      "Total evaluation time: 2.5116 minutes\n",
      "139 \t 14.9 \t \t 0.0004 \t 0.0084 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3813 \t 0.8970 \t 2.8238 \t 0.1570\n",
      "Total evaluation time: 2.5082 minutes\n",
      "140 \t 14.9 \t \t 0.0004 \t 0.0088 \t 0.9992\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3908 \t 0.8990 \t 2.8389 \t 0.1650\n",
      "Total evaluation time: 2.5076 minutes\n",
      "141 \t 15.2 \t \t 0.0004 \t 0.0083 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3925 \t 0.8990 \t 2.8446 \t 0.1590\n",
      "Total evaluation time: 2.5108 minutes\n",
      "142 \t 15.6 \t \t 0.0004 \t 0.0083 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3875 \t 0.8970 \t 2.8292 \t 0.1640\n",
      "Total evaluation time: 2.5127 minutes\n",
      "143 \t 14.9 \t \t 0.0004 \t 0.0083 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3900 \t 0.8990 \t 2.8640 \t 0.1510\n",
      "Total evaluation time: 2.5144 minutes\n",
      "144 \t 15.0 \t \t 0.0004 \t 0.0084 \t 0.9992\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3921 \t 0.8980 \t 2.8346 \t 0.1640\n",
      "Total evaluation time: 2.5067 minutes\n",
      "145 \t 14.9 \t \t 0.0004 \t 0.0079 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3961 \t 0.9000 \t 2.8497 \t 0.1680\n",
      "Total evaluation time: 2.5079 minutes\n",
      "146 \t 14.9 \t \t 0.0004 \t 0.0082 \t 0.9991\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3865 \t 0.8990 \t 2.8635 \t 0.1590\n",
      "Total evaluation time: 2.5069 minutes\n",
      "147 \t 15.1 \t \t 0.0004 \t 0.0078 \t 0.9993\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3963 \t 0.9030 \t 2.8888 \t 0.1610\n",
      "Total evaluation time: 2.5108 minutes\n",
      "148 \t 14.9 \t \t 0.0004 \t 0.0074 \t 0.9996\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3930 \t 0.8980 \t 2.8313 \t 0.1610\n",
      "Total evaluation time: 2.5118 minutes\n",
      "149 \t 15.0 \t \t 0.0004 \t 0.0073 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4045 \t 0.8950 \t 2.8367 \t 0.1610\n",
      "Total evaluation time: 2.5159 minutes\n",
      "150 \t 14.9 \t \t 0.0004 \t 0.0077 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3923 \t 0.9000 \t 2.8638 \t 0.1630\n",
      "Total evaluation time: 2.5141 minutes\n",
      "151 \t 15.0 \t \t 0.0004 \t 0.0072 \t 0.9996\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4006 \t 0.8960 \t 2.8612 \t 0.1680\n",
      "Total evaluation time: 2.5110 minutes\n",
      "152 \t 15.0 \t \t 0.0004 \t 0.0071 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4061 \t 0.8990 \t 2.8570 \t 0.1720\n",
      "Total evaluation time: 2.5091 minutes\n",
      "153 \t 15.0 \t \t 0.0004 \t 0.0068 \t 0.9995\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.4045 \t 0.8990 \t 2.9088 \t 0.1700\n",
      "Total evaluation time: 2.5070 minutes\n",
      "154 \t 14.9 \t \t 0.0004 \t 0.0069 \t 0.9994\n",
      "Test Loss \t Test Acc \t PGD Loss \t PGD Acc\n",
      "0.3976 \t 0.8980 \t 2.9078 \t 0.1720\n",
      "Total evaluation time: 2.5053 minutes\n",
      "155 \t 15.6 \t \t 0.0004 \t 0.0066 \t 0.9997\n"
     ]
    }
   ],
   "source": [
    "\n",
    "args = get_args()\n",
    "np.random.seed(args.seed)\n",
    "torch.manual_seed(args.seed)\n",
    "torch.cuda.manual_seed(args.seed)\n",
    "\n",
    "train_loader, test_loader = get_loaders(args.data_dir, args.batch_size)\n",
    "\n",
    "model = PreActResNet18().cuda()\n",
    "state_dict = torch.load(os.path.join(args.out_dir, '9_25_robust_model_epsilon_8.pth'))\n",
    "model.load_state_dict(state_dict)\n",
    "\n",
    "opt = ExtraSGD(model.parameters(), lr=args.lr_max, momentum=args.momentum, weight_decay=args.weight_decay)\n",
    "amp_args = dict(opt_level=args.opt_level, loss_scale=args.loss_scale, verbosity=False)\n",
    "if args.opt_level == 'O2':\n",
    "    amp_args['master_weights'] = args.master_weights\n",
    "model, opt = amp.initialize(model, opt, **amp_args)\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "\n",
    "lr_steps = args.epochs * len(train_loader)\n",
    "scheduler = torch.optim.lr_scheduler.CyclicLR(opt, base_lr=args.lr_min, max_lr=args.lr_max,\n",
    "                                              step_size_up=lr_steps / 2, step_size_down=lr_steps / 2)\n",
    "\n",
    "\n",
    "model.eval()\n",
    "start_eval_time = time.time()\n",
    "test_loss, test_acc = evaluate_standard(test_loader, model)\n",
    "pgd_loss, pgd_acc = evaluate_pgd(test_loader, model, 50, 10)\n",
    "end_eval_time = time.time()\n",
    "print('Test Loss \\t Test Acc \\t PGD Loss \\t PGD Acc')\n",
    "print('%.4f \\t %.4f \\t %.4f \\t %.4f' % (test_loss, test_acc, pgd_loss, pgd_acc))\n",
    "print('Total evaluation time: %.4f minutes' % ((end_eval_time - start_eval_time)/60))\n",
    "\n",
    "\n",
    "# Training\n",
    "prev_robust_acc = 0.\n",
    "start_train_time = time.time()\n",
    "logger.info('Epoch \\t Seconds \\t LR \\t \\t Train Loss \\t Train Acc')\n",
    "print('Epoch \\t Seconds \\t LR \\t \\t Train Loss \\t Train Acc')\n",
    "for epoch in range(args.epochs):\n",
    "    start_epoch_time = time.time()\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    train_acc = 0\n",
    "    train_n = 0\n",
    "    opt.zero_grad()\n",
    "        \n",
    "    # Accumulate Gradient\n",
    "    for i, (X, y) in enumerate(train_loader):\n",
    "        X, y = X.cuda(), y.cuda()\n",
    "        output = model(X)\n",
    "        loss = criterion(output, y)\n",
    "        with amp.scale_loss(loss, opt) as scaled_loss:\n",
    "            scaled_loss.backward()\n",
    "        train_loss += loss.item() * y.size(0)\n",
    "        train_acc += (output.max(1)[1] == y).sum().item()\n",
    "        train_n += y.size(0)\n",
    "        \n",
    "    # step with full Extra gradient\n",
    "    if (epoch+1)%2:\n",
    "        opt.extrapolation()\n",
    "    else:\n",
    "        opt.step()\n",
    "    scheduler.step()\n",
    "    epoch_time = time.time()\n",
    "    lr = scheduler.get_lr()[0]\n",
    "    print('%d \\t %.1f \\t \\t %.4f \\t %.4f \\t %.4f' % (epoch, epoch_time - start_epoch_time, lr, train_loss/train_n, train_acc/train_n))\n",
    "\n",
    "    model.eval()\n",
    "    start_eval_time = time.time()\n",
    "    test_loss, test_acc = evaluate_standard(test_loader, model)\n",
    "    pgd_loss, pgd_acc = evaluate_pgd(test_loader, model, 50, 10)\n",
    "    end_eval_time = time.time()\n",
    "    print('Test Loss \\t Test Acc \\t PGD Loss \\t PGD Acc')\n",
    "    print('%.4f \\t %.4f \\t %.4f \\t %.4f' % (test_loss, test_acc, pgd_loss, pgd_acc))\n",
    "    print('Total evaluation time: %.4f minutes' % ((end_eval_time - start_eval_time)/60))\n",
    "\n",
    "train_time = time.time()    \n",
    "print('Total train time: %.4f minutes' % ((train_time - start_train_time)/60))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "conda_python3",
   "language": "python",
   "name": "conda_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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
