{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_50698/2175754929.py:24: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from tqdm.autonotebook import tqdm\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "import os\n",
    "os.environ['CUDA_DEVICE_ORDER']='PCI_BUS_ID'\n",
    "os.environ['CUDA_VISIBLE_DEVICES']='0'\n",
    "import variational\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from matplotlib.ticker import FuncFormatter\n",
    "from itertools import cycle\n",
    "import os\n",
    "import time\n",
    "import math\n",
    "import pandas as pd\n",
    "from collections import OrderedDict\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "    \n",
    "import copy\n",
    "import torch.nn as nn\n",
    "from torch.autograd import Variable\n",
    "from typing import List\n",
    "import itertools\n",
    "from tqdm.autonotebook import tqdm\n",
    "from models import *\n",
    "import models\n",
    "from logger import *\n",
    "import wandb\n",
    "\n",
    "from thirdparty.repdistiller.helper.util import adjust_learning_rate as sgda_adjust_learning_rate\n",
    "from thirdparty.repdistiller.distiller_zoo import DistillKL, HintLoss, Attention, Similarity, Correlation, VIDLoss, RKDLoss\n",
    "from thirdparty.repdistiller.distiller_zoo import PKT, ABLoss, FactorTransfer, KDSVD, FSP, NSTLoss\n",
    "\n",
    "from thirdparty.repdistiller.helper.loops import train_distill, train_distill_hide, train_distill_linear, train_vanilla, train_negrad, train_bcu, train_bcu_distill, validate\n",
    "from thirdparty.repdistiller.helper.pretrain import init\n",
    "\n",
    "from scipy import optimize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def pdb():\n",
    "    import pdb\n",
    "    pdb.set_trace"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def parameter_count(model):\n",
    "    count=0\n",
    "    for p in model.parameters():\n",
    "        count+=np.prod(np.array(list(p.shape)))\n",
    "    print(f'Total Number of Parameters: {count}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def vectorize_params(model):\n",
    "    param = []\n",
    "    for p in model.parameters():\n",
    "        param.append(p.data.view(-1).cpu().numpy())\n",
    "    return np.concatenate(param)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_param_shape(model):\n",
    "    for k,p in model.named_parameters():\n",
    "        print(k,p.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def opt_solver(probs, target_distb, num_iter=10, th=0.1, num_newton=30):\n",
    "    # probs: N x K target_distb: 1*K\n",
    "    # entropy = (-1 * probs * torch.log(probs + 1e-6)).sum(1)\n",
    "    weights = (1 / entropy)\n",
    "    N, K = probs.size(0), probs.size(1)\n",
    "\n",
    "    A, w, lam, nu, r, c = probs.numpy(), weights.numpy(), np.ones(N), np.ones(K), np.ones(N), target_distb.numpy()\n",
    "    A_e = A / math.e\n",
    "    X = np.exp(-1 * lam / w)\n",
    "    Y = np.exp(-1 * nu.reshape(1, -1) / w.reshape(-1, 1))\n",
    "    prev_Y = np.zeros(K)\n",
    "    X_t, Y_t = X, Y\n",
    "\n",
    "    for n in range(num_iter):\n",
    "        # Normalization\n",
    "        denom = np.sum(A_e * Y_t, 1)\n",
    "        X_t = r / denom\n",
    "\n",
    "        # Newton method\n",
    "        Y_t = np.zeros(K)\n",
    "        for i in range(K):\n",
    "            Y_t[i] = optimize.newton(f, prev_Y[i], maxiter=num_newton, args=(A_e[:, i], X_t, w, c[i]), tol=th)\n",
    "        prev_Y = Y_t\n",
    "        Y_t = np.exp(-1 * Y_t.reshape(1, -1) / w.reshape(-1, 1))\n",
    "\n",
    "    denom = np.sum(A_e * Y_t, 1)\n",
    "    X_t = r / denom\n",
    "    M = torch.Tensor(A_e * X_t.reshape(-1, 1) * Y_t)\n",
    "\n",
    "    return M"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Pre-training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: lacuna100_resnet_0_4_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in lacuna100_resnet_0_4_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_training]\n",
      "confuse mode: False\n",
      "split mode: None\n",
      "Number of Classes: 100\n",
      "[0] train metrics:{\"loss\": 3.8155148887634276, \"error\": 0.901875}\n",
      "Learning Rate : 0.1\n",
      "[0] dry_run metrics:{\"loss\": 3.30328556060791, \"error\": 0.82040625}\n",
      "Learning Rate : 0.1\n",
      "[0] test metrics:{\"loss\": 3.3426026260375976, \"error\": 0.8292}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 9.62 sec\n",
      "[1] train metrics:{\"loss\": 2.9475359210968017, \"error\": 0.73296875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.93 sec\n",
      "[2] train metrics:{\"loss\": 2.435648026943207, \"error\": 0.59603125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.93 sec\n",
      "[3] train metrics:{\"loss\": 2.094309967517853, \"error\": 0.48103125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.9 sec\n",
      "[4] train metrics:{\"loss\": 1.8684168701171875, \"error\": 0.39328125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.96 sec\n",
      "[5] train metrics:{\"loss\": 1.7369940962791444, \"error\": 0.3335625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.05 sec\n",
      "[6] train metrics:{\"loss\": 1.6375241208076476, \"error\": 0.27521875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.04 sec\n",
      "[7] train metrics:{\"loss\": 1.6008833703994751, \"error\": 0.2420625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.05 sec\n",
      "[8] train metrics:{\"loss\": 1.5656831736564636, \"error\": 0.2103125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.98 sec\n",
      "[9] train metrics:{\"loss\": 1.5484881372451782, \"error\": 0.18978125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.04 sec\n",
      "[10] train metrics:{\"loss\": 1.548932960987091, \"error\": 0.17840625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.15 sec\n",
      "[11] train metrics:{\"loss\": 1.5422889924049377, \"error\": 0.16584375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.96 sec\n",
      "[12] train metrics:{\"loss\": 1.4952515697479247, \"error\": 0.14746875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.91 sec\n",
      "[13] train metrics:{\"loss\": 1.5707669405937195, \"error\": 0.160125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.97 sec\n",
      "[14] train metrics:{\"loss\": 1.5387192511558532, \"error\": 0.1441875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.01 sec\n",
      "[15] train metrics:{\"loss\": 1.4913351111412048, \"error\": 0.12915625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.9 sec\n",
      "[16] train metrics:{\"loss\": 1.550043649673462, \"error\": 0.1435625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.93 sec\n",
      "[17] train metrics:{\"loss\": 1.5404470491409301, \"error\": 0.136375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.84 sec\n",
      "[18] train metrics:{\"loss\": 1.5013884897232055, \"error\": 0.126375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.82 sec\n",
      "[19] train metrics:{\"loss\": 1.5005063161849976, \"error\": 0.12503125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.88 sec\n",
      "[20] train metrics:{\"loss\": 1.548140968799591, \"error\": 0.13434375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.82 sec\n",
      "[21] train metrics:{\"loss\": 1.463663778781891, \"error\": 0.11421875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.79 sec\n",
      "[22] train metrics:{\"loss\": 1.543300733089447, \"error\": 0.13575}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.8 sec\n",
      "[23] train metrics:{\"loss\": 1.5017543921470642, \"error\": 0.1206875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.9 sec\n",
      "[24] train metrics:{\"loss\": 1.483858111858368, \"error\": 0.1175}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.83 sec\n",
      "[25] train metrics:{\"loss\": 1.513565122127533, \"error\": 0.1264375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.81 sec\n",
      "[26] train metrics:{\"loss\": 1.5126464715003967, \"error\": 0.12475}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.89 sec\n",
      "[27] train metrics:{\"loss\": 1.5156381821632385, \"error\": 0.1235}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.79 sec\n",
      "[28] train metrics:{\"loss\": 1.4932949562072755, \"error\": 0.117}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.79 sec\n",
      "[29] train metrics:{\"loss\": 1.5199323940277099, \"error\": 0.123}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.84 sec\n",
      "[30] train metrics:{\"loss\": 1.5113308339118958, \"error\": 0.120125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.8 sec\n",
      "Pure training time: 152.47999999999996 sec\n"
     ]
    }
   ],
   "source": [
    "%run main.py --dataset lacuna100 --dataroot=data/lacuna100 --model resnet --filters 0.4 --lr 0.1 --lossfn ce --num-classes 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train the original model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: small_lacuna5_resnet_0_4_forget_None_lr_0_001_bs_128_ls_ce_wd_0_1_seed_3\n",
      "[Logging in small_lacuna5_resnet_0_4_forget_None_lr_0_001_bs_128_ls_ce_wd_0_1_seed_3_training]\n",
      "confuse mode: False\n",
      "split mode: None\n",
      "Number of Classes: 5\n",
      "[0] train metrics:{\"loss\": 1.8157579345703125, \"error\": 0.88000000166893}\n",
      "Learning Rate : 0.001\n",
      "[0] test metrics:{\"loss\": 1.678695526123047, \"error\": 0.8399999998211861}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.19 sec\n",
      "[1] train metrics:{\"loss\": 1.532227437019348, \"error\": 0.7200000016689301}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[2] train metrics:{\"loss\": 1.1645071392059325, \"error\": 0.3820000023841858}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[3] train metrics:{\"loss\": 0.8515839290618896, \"error\": 0.14600000381469727}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[4] train metrics:{\"loss\": 0.6293069076538086, \"error\": 0.08200000143051148}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[5] train metrics:{\"loss\": 0.4754921355247498, \"error\": 0.05599999713897705}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.1 sec\n",
      "[6] train metrics:{\"loss\": 0.3731359221935272, \"error\": 0.03999999713897705}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[7] train metrics:{\"loss\": 0.3020577273368835, \"error\": 0.030000001907348632}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[8] train metrics:{\"loss\": 0.2539944832324982, \"error\": 0.030000004291534425}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[9] train metrics:{\"loss\": 0.2218881673812866, \"error\": 0.02599999523162842}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[10] train metrics:{\"loss\": 0.19917951357364655, \"error\": 0.027999995231628418}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.1 sec\n",
      "[11] train metrics:{\"loss\": 0.18326748359203338, \"error\": 0.026000004291534425}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[12] train metrics:{\"loss\": 0.1711251907348633, \"error\": 0.02}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[13] train metrics:{\"loss\": 0.1608934234380722, \"error\": 0.01799999761581421}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[14] train metrics:{\"loss\": 0.15264856874942778, \"error\": 0.01599999761581421}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[15] train metrics:{\"loss\": 0.14568501234054565, \"error\": 0.015999995231628417}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.11 sec\n",
      "[16] train metrics:{\"loss\": 0.13985104739665985, \"error\": 0.016}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.07 sec\n",
      "[17] train metrics:{\"loss\": 0.1349688467979431, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[18] train metrics:{\"loss\": 0.13062449622154235, \"error\": 0.01599999761581421}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[19] train metrics:{\"loss\": 0.12668345111608506, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.07 sec\n",
      "[20] train metrics:{\"loss\": 0.12306421732902527, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[21] train metrics:{\"loss\": 0.11998018693923951, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[22] train metrics:{\"loss\": 0.11719018530845642, \"error\": 0.013999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.07 sec\n",
      "[23] train metrics:{\"loss\": 0.11445067846775055, \"error\": 0.011999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[24] train metrics:{\"loss\": 0.1119829775094986, \"error\": 0.009999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[25] train metrics:{\"loss\": 0.10976870274543762, \"error\": 0.010000006675720215}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[26] train metrics:{\"loss\": 0.10782692813873292, \"error\": 0.009999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[27] train metrics:{\"loss\": 0.10583692252635955, \"error\": 0.009999995231628417}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[28] train metrics:{\"loss\": 0.10397299706935882, \"error\": 0.007999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[29] train metrics:{\"loss\": 0.10230067992210388, \"error\": 0.005999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[30] train metrics:{\"loss\": 0.10068872320652009, \"error\": 0.005999995231628418}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "Pure training time: 2.5700000000000007 sec\n"
     ]
    }
   ],
   "source": [
    "%run main.py --dataset small_lacuna5 --model resnet --dataroot=data/lacuna10/ --filters 0.4 --lr 0.001 \\\n",
    "--resume checkpoints/lacuna100_resnet_0_4_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_30.pt --disable-bn \\\n",
    "--weight-decay 0.1 --batch-size 128 --epochs 31 --seed 3"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Retrain Forgetting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: small_lacuna5_resnet_0_4_forget_[0]_num_25_lr_0_001_bs_128_ls_ce_wd_0_1_seed_3\n",
      "[Logging in small_lacuna5_resnet_0_4_forget_[0]_num_25_lr_0_001_bs_128_ls_ce_wd_0_1_seed_3_training]\n",
      "confuse mode: False\n",
      "split mode: None\n",
      "Replacing indexes [83 30 56 24 16 23  2 27 28 13 99 92 76 14  0 21  3 29 61 79 35 11 84 44\n",
      " 73]\n",
      "Number of Classes: 5\n",
      "[0] train metrics:{\"loss\": 1.8231099576950074, \"error\": 0.8819999992847443}\n",
      "Learning Rate : 0.001\n",
      "[0] test metrics:{\"loss\": 1.6787854976654053, \"error\": 0.8380000004768372}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.39 sec\n",
      "[1] train metrics:{\"loss\": 1.535523126602173, \"error\": 0.7200000038146973}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[2] train metrics:{\"loss\": 1.1676772794723511, \"error\": 0.4}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[3] train metrics:{\"loss\": 0.8532320075035095, \"error\": 0.15400000381469728}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[4] train metrics:{\"loss\": 0.628086314201355, \"error\": 0.06999999713897705}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[5] train metrics:{\"loss\": 0.47236001086235047, \"error\": 0.04599999952316284}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[6] train metrics:{\"loss\": 0.36891079783439634, \"error\": 0.03800000190734863}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[7] train metrics:{\"loss\": 0.2970020779371262, \"error\": 0.034000006675720215}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[8] train metrics:{\"loss\": 0.24895334672927857, \"error\": 0.026000006675720215}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[9] train metrics:{\"loss\": 0.21690951597690583, \"error\": 0.02599999523162842}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[10] train metrics:{\"loss\": 0.1943264113664627, \"error\": 0.027999995231628418}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[11] train metrics:{\"loss\": 0.17799036824703215, \"error\": 0.024000001907348634}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[12] train metrics:{\"loss\": 0.1660956896543503, \"error\": 0.02199999523162842}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[13] train metrics:{\"loss\": 0.15599180829524995, \"error\": 0.01999999761581421}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[14] train metrics:{\"loss\": 0.14807636761665344, \"error\": 0.016}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[15] train metrics:{\"loss\": 0.14129257929325104, \"error\": 0.015999995231628417}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.1 sec\n",
      "[16] train metrics:{\"loss\": 0.13562139487266542, \"error\": 0.01599999761581421}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[17] train metrics:{\"loss\": 0.13101074111461639, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[18] train metrics:{\"loss\": 0.12684856748580933, \"error\": 0.015999995231628417}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[19] train metrics:{\"loss\": 0.12315675872564316, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[20] train metrics:{\"loss\": 0.11957632911205292, \"error\": 0.016000006675720217}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[21] train metrics:{\"loss\": 0.1166838915348053, \"error\": 0.015999995231628417}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[22] train metrics:{\"loss\": 0.11399599659442902, \"error\": 0.009999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.07 sec\n",
      "[23] train metrics:{\"loss\": 0.11135616165399552, \"error\": 0.007999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[24] train metrics:{\"loss\": 0.10898221683502197, \"error\": 0.007999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.07 sec\n",
      "[25] train metrics:{\"loss\": 0.10689608764648438, \"error\": 0.007999995231628417}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[26] train metrics:{\"loss\": 0.10503358495235443, \"error\": 0.007999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.1 sec\n",
      "[27] train metrics:{\"loss\": 0.10313213658332825, \"error\": 0.005999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[28] train metrics:{\"loss\": 0.10138381671905518, \"error\": 0.006}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.08 sec\n",
      "[29] train metrics:{\"loss\": 0.09980156290531159, \"error\": 0.006}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "[30] train metrics:{\"loss\": 0.09825986158847809, \"error\": 0.005999997615814209}\n",
      "Learning Rate : 0.001\n",
      "Epoch Time: 0.09 sec\n",
      "Pure training time: 2.7600000000000002 sec\n",
      "Time taken: 3.1333632099995157\n"
     ]
    }
   ],
   "source": [
    "start_time = time.perf_counter()\n",
    "%run main.py --dataset small_lacuna5 --model resnet --dataroot=data/lacuna10/ --filters 0.4 --lr 0.001 \\\n",
    "--resume checkpoints/lacuna100_resnet_0_4_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_30.pt --disable-bn \\\n",
    "--weight-decay 0.1 --batch-size 128 --epochs 31 \\\n",
    "--forget-class 0 --num-to-forget 25 --seed 3\n",
    "end_time = time.perf_counter()\n",
    "print(f\"Time taken: {end_time-start_time}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Logs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict={}\n",
    "training_epochs=30"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict['epoch']=training_epochs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Number of Parameters: 1787741\n"
     ]
    }
   ],
   "source": [
    "\n",
    "parameter_count(copy.deepcopy(model))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Loads checkpoints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "model0 = copy.deepcopy(model)\n",
    "model_initial = copy.deepcopy(model)\n",
    "\n",
    "arch = args.model \n",
    "filters=args.filters\n",
    "arch_filters = arch +'_'+ str(filters).replace('.','_')\n",
    "augment = False\n",
    "dataset = args.dataset\n",
    "class_to_forget = args.forget_class\n",
    "init_checkpoint = f\"checkpoints/{args.name}_init.pt\"\n",
    "num_classes=args.num_classes\n",
    "num_to_forget = args.num_to_forget\n",
    "num_total = len(train_loader.dataset)\n",
    "num_to_retain = num_total - 300#num_to_forget\n",
    "seed = args.seed\n",
    "unfreeze_start = None\n",
    "\n",
    "learningrate=f\"lr_{str(args.lr).replace('.','_')}\"\n",
    "batch_size=f\"_bs_{str(args.batch_size)}\"\n",
    "lossfn=f\"_ls_{args.lossfn}\"\n",
    "wd=f\"_wd_{str(args.weight_decay).replace('.','_')}\"\n",
    "seed_name=f\"_seed_{args.seed}_\"\n",
    "\n",
    "num_tag = '' if num_to_forget is None else f'_num_{num_to_forget}'\n",
    "unfreeze_tag = '_' if unfreeze_start is None else f'_unfreeze_from_{unfreeze_start}_'\n",
    "augment_tag = '' if not augment else f'augment_'\n",
    "\n",
    "m_name = f'checkpoints/{dataset}_{arch_filters}_forget_None{unfreeze_tag}{augment_tag}{learningrate}{batch_size}{lossfn}{wd}{seed_name}{training_epochs}.pt'\n",
    "m0_name = f'checkpoints/{dataset}_{arch_filters}_forget_{class_to_forget}{num_tag}{unfreeze_tag}{augment_tag}{learningrate}{batch_size}{lossfn}{wd}{seed_name}{training_epochs}.pt'\n",
    "\n",
    "model.load_state_dict(torch.load(m_name))\n",
    "model0.load_state_dict(torch.load(m0_name))\n",
    "model_initial.load_state_dict(torch.load(init_checkpoint))\n",
    "\n",
    "teacher = copy.deepcopy(model)\n",
    "student = copy.deepcopy(model)\n",
    "\n",
    "model.cuda()\n",
    "model0.cuda()\n",
    "\n",
    "\n",
    "for p in model.parameters():\n",
    "    p.data0 = p.data.clone()\n",
    "for p in model0.parameters():\n",
    "    p.data0 = p.data.clone()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict['args']=args"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distance between w(D) and w(D_r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def distance(model,model0):\n",
    "    distance=0\n",
    "    normalization=0\n",
    "    for (k, p), (k0, p0) in zip(model.named_parameters(), model0.named_parameters()):\n",
    "        space='  ' if 'bias' in k else ''\n",
    "        current_dist=(p.data0-p0.data0).pow(2).sum().item()\n",
    "        current_norm=p.data0.pow(2).sum().item()\n",
    "        distance+=current_dist\n",
    "        normalization+=current_norm\n",
    "    print(f'Distance: {np.sqrt(distance)}')\n",
    "    print(f'Normalized Distance: {1.0*np.sqrt(distance/normalization)}')\n",
    "    return 1.0*np.sqrt(distance/normalization)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Distance: 0.07084530328417134\n",
      "Normalized Distance: 0.0008734134402055196\n"
     ]
    }
   ],
   "source": [
    "log_dict['dist_Original_Retrain']=distance(model,model0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distance of w(D) from initialization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def ntk_init(resume,seed=1):\n",
    "    manual_seed(seed)\n",
    "    model_init = models.get_model(arch, num_classes=num_classes, filters_percentage=filters).to(args.device)\n",
    "    model_init.load_state_dict(torch.load(resume))\n",
    "    return model_init"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_init = ntk_init(init_checkpoint,args.seed)\n",
    "for p in model_init.parameters():\n",
    "    p.data0 = p.data.clone()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Distance: 0.9623198989434337\n",
      "Normalized Distance: 0.011868091933688494\n"
     ]
    }
   ],
   "source": [
    "log_dict['dist_Original_Original_init']=distance(model_init,model)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Data Loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.retain_bs = 32\n",
    "args.forget_bs = 32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "confuse mode: False\n",
      "split mode: train\n",
      "confuse mode: False\n",
      "split mode: train\n",
      "Replacing indexes [83 30 56 24 16 23  2 27 28 13 99 92 76 14  0 21  3 29 61 79 35 11 84 44\n",
      " 73]\n"
     ]
    }
   ],
   "source": [
    "train_loader_full, valid_loader_full, test_loader_full   = datasets.get_loaders(dataset, batch_size=args.batch_size, seed=seed, root=args.dataroot, augment=False, shuffle=True)\n",
    "marked_loader, _, _ = datasets.get_loaders(dataset, class_to_replace=class_to_forget, num_indexes_to_replace=num_to_forget, only_mark=True, batch_size=1, seed=seed, root=args.dataroot, augment=False, shuffle=True)\n",
    "\n",
    "def replace_loader_dataset(data_loader, dataset, batch_size=args.batch_size, seed=1, shuffle=True):\n",
    "    manual_seed(seed)\n",
    "    loader_args = {'num_workers': 0, 'pin_memory': False}\n",
    "    def _init_fn(worker_id):\n",
    "        np.random.seed(int(seed))\n",
    "    return torch.utils.data.DataLoader(dataset, batch_size=batch_size,num_workers=0,pin_memory=True,shuffle=shuffle)\n",
    "    \n",
    "forget_dataset = copy.deepcopy(marked_loader.dataset)\n",
    "marked = forget_dataset.targets < 0\n",
    "forget_dataset.data = forget_dataset.data[marked]\n",
    "forget_dataset.targets = - forget_dataset.targets[marked] - 1\n",
    "forget_loader = replace_loader_dataset(train_loader_full, forget_dataset, batch_size=args.forget_bs, seed=seed, shuffle=True)\n",
    "\n",
    "retain_dataset = copy.deepcopy(marked_loader.dataset)\n",
    "marked = retain_dataset.targets >= 0\n",
    "retain_dataset.data = retain_dataset.data[marked]\n",
    "retain_dataset.targets = retain_dataset.targets[marked]\n",
    "retain_loader = replace_loader_dataset(train_loader_full, retain_dataset, batch_size=args.retain_bs, seed=seed, shuffle=True)\n",
    "\n",
    "assert(len(forget_dataset) + len(retain_dataset) == len(train_loader_full.dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "25\n",
      "475\n",
      "500\n",
      "500\n",
      "{0: 100, 1: 100, 2: 100, 3: 100, 4: 100}\n"
     ]
    }
   ],
   "source": [
    "print (len(forget_loader.dataset))\n",
    "print (len(retain_loader.dataset))\n",
    "print (len(test_loader_full.dataset))\n",
    "print (len(train_loader_full.dataset))\n",
    "from collections import Counter\n",
    "print(dict(Counter(train_loader_full.dataset.targets)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## SCRUB Forgetting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.optim = 'sgd'\n",
    "args.gamma = 1.0\n",
    "args.alpha = 0.5\n",
    "args.beta = 0.95\n",
    "args.smoothing = 0.5\n",
    "args.msteps = 5\n",
    "args.clip = 0.2\n",
    "args.sstart = 10\n",
    "args.kd_T = 2\n",
    "args.distill = 'kd'\n",
    "\n",
    "args.sgda_epochs = 10\n",
    "args.sgda_learning_rate = 0.02\n",
    "args.lr_decay_epochs = [5,8,9]\n",
    "args.lr_decay_rate = 0.1\n",
    "args.sgda_weight_decay = 0.1#5e-4\n",
    "args.sgda_momentum = 0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_t = copy.deepcopy(teacher)\n",
    "model_s = copy.deepcopy(student)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "#this is from https://github.com/ojus1/SmoothedGradientDescentAscent/blob/main/SGDA.py\n",
    "#For SGDA smoothing\n",
    "beta = 0.1\n",
    "def avg_fn(averaged_model_parameter, model_parameter, num_averaged): return (\n",
    "    1 - beta) * averaged_model_parameter + beta * model_parameter\n",
    "swa_model = torch.optim.swa_utils.AveragedModel(\n",
    "    model_s, avg_fn=avg_fn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "module_list = nn.ModuleList([])\n",
    "module_list.append(model_s)\n",
    "trainable_list = nn.ModuleList([])\n",
    "trainable_list.append(model_s)\n",
    "\n",
    "criterion_cls = nn.CrossEntropyLoss()\n",
    "criterion_div = DistillKL(args.kd_T)\n",
    "criterion_kd = DistillKL(args.kd_T)\n",
    "\n",
    "\n",
    "criterion_list = nn.ModuleList([])\n",
    "criterion_list.append(criterion_cls)    # classification loss\n",
    "criterion_list.append(criterion_div)    # KL divergence loss, original knowledge distillation\n",
    "criterion_list.append(criterion_kd)     # other knowledge distillation loss\n",
    "\n",
    "# optimizer\n",
    "if args.optim == \"sgd\":\n",
    "    optimizer = optim.SGD(trainable_list.parameters(),\n",
    "                          lr=args.sgda_learning_rate,\n",
    "                          momentum=args.sgda_momentum,\n",
    "                          weight_decay=args.sgda_weight_decay)\n",
    "elif args.optim == \"adam\": \n",
    "    optimizer = optim.Adam(trainable_list.parameters(),\n",
    "                          lr=args.sgda_learning_rate,\n",
    "                          weight_decay=args.sgda_weight_decay)\n",
    "elif args.optim == \"rmsp\":\n",
    "    optimizer = optim.RMSprop(trainable_list.parameters(),\n",
    "                          lr=args.sgda_learning_rate,\n",
    "                          momentum=args.sgda_momentum,\n",
    "                          weight_decay=args.sgda_weight_decay)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "module_list.append(model_t)\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    module_list.cuda()\n",
    "    criterion_list.cuda()\n",
    "    import torch.backends.cudnn as cudnn\n",
    "    cudnn.benchmark = True\n",
    "    swa_model.cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "acc_r, acc5_r, loss_r = validate(retain_loader, model_s, criterion_cls, args, True, prefix=\"train_lacuna5_resnet_before\")\n",
    "acc_f, acc5_f, loss_f = validate(forget_loader, model_s, criterion_cls, args, True, prefix=\"forget_lacuna5_resnet_before\")\n",
    "torch.save(model_s.state_dict(), 'final_model_weights.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'Namespace' object has no attribute 'sgda_epochs'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[61], line 5\u001b[0m\n\u001b[1;32m      3\u001b[0m acc_ts \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m      4\u001b[0m start_time \u001b[38;5;241m=\u001b[39m time\u001b[38;5;241m.\u001b[39mtime()\n\u001b[0;32m----> 5\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m epoch \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m1\u001b[39m, \u001b[43margs\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msgda_epochs\u001b[49m \u001b[38;5;241m+\u001b[39m \u001b[38;5;241m1\u001b[39m):\n\u001b[1;32m      7\u001b[0m     lr \u001b[38;5;241m=\u001b[39m sgda_adjust_learning_rate(epoch, args, optimizer)\n\u001b[1;32m      9\u001b[0m     \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m==> scrub unlearning ...\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'Namespace' object has no attribute 'sgda_epochs'"
     ]
    }
   ],
   "source": [
    "acc_rs = []\n",
    "acc_fs = []\n",
    "acc_ts = []\n",
    "start_time = time.time()\n",
    "for epoch in range(1, args.sgda_epochs + 1):\n",
    "\n",
    "    lr = sgda_adjust_learning_rate(epoch, args, optimizer)\n",
    "\n",
    "    print(\"==> scrub unlearning ...\")\n",
    "\n",
    "    acc_r, acc5_r, loss_r = validate(retain_loader, model_s, criterion_cls, args, True, prefix=\"train_lacuna5_resnet\")\n",
    "    acc_f, acc5_f, loss_f = validate(forget_loader, model_s, criterion_cls, args, True, prefix=\"forget_lacuna5_resnet\")\n",
    "    acc_rs.append(100-acc_r.item())\n",
    "    acc_fs.append(100-acc_f.item())\n",
    "\n",
    "    maximize_loss = 0\n",
    "    if epoch <= args.msteps:\n",
    "        maximize_loss = train_distill(epoch, forget_loader, module_list, swa_model, criterion_list, optimizer, args, \"maximize\")\n",
    "    train_acc, train_loss = train_distill(epoch, retain_loader, module_list, swa_model, criterion_list, optimizer, args, \"minimize\",)\n",
    "    if epoch >= args.sstart:\n",
    "        swa_model.update_parameters(model_s)\n",
    "\n",
    "    print (\"maximize loss: {:.2f}\\t minimize loss: {:.2f}\\t train_acc: {}\".format(maximize_loss, train_loss, train_acc))\n",
    "model = models.get_model('resnet', num_classes=5,filters_percentage=0.4) \n",
    "model = model.to('cuda')\n",
    "model.load_state_dict(torch.load('complete_weights.pth'))\n",
    "acc_t_final, acc5_t_final, loss_t_final = validate(test_loader_full, model_s, criterion_cls, args, False, prefix=\"test_cifar5_resnet_final\")\n",
    "test_error_rate_final = 100 - acc_t_final\n",
    "print(f\"Final Test Set Error Rate: {test_error_rate_final:.2f}%\")\n",
    "end_time = time.time()\n",
    "print(f\"Time taken: {end_time-start_time}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2rBhgyU/jMlkUnv37lXz589XPXv2VF9++WWlfX/77TdLXrG//vqrwW3fsmWLJddRx44d1ffff1/puUpMTFRffvmlGjt2rLrnnnsq7VvX10Fd83o1x2vSETnfI3IyFZPvcSar5bklH0aMGKHy8vKq7Lt69epKKeFdXV0rfShCzeUizhfsKKXUxx9/XOlY3t7eluBr2LBh6u233z5vsFOxXIRer69SLuL222+3fIHWR12DHaWU+uqrryqVbzAYDCogIKBSojZAvfjii1X2vfjiiys9/oiICBUREVEpQHvvvfeq/A3NgWhgYGClxHmOFuxs3bq1Ukp8o9GovL29Lc/jF198UeNrqrHBjlJa0sKK74dWrVpZgnBvb+8Gl4uoy7nNvv3220qlCcyp9c3/r0tq/vP5/vvvLYngzI/N/JoNCwuzvBaMRmO1+yckJKioqKhKr0M/P78qpT2qSz755ZdfVvoMCQsLUxEREWr48OHnbXd9VGyHuVRExedRp9PV+MPn1VdfrVRWws3NTQUEBFQqsQGor776qtJ+paWlqnv37pb1rVu3tryHv//++3q1/9dff630w0Wv16uAgIAqpWGaOthRqnlek47G+R6Rkzl06JB666231NVXX6169Oih/Pz8lMFgUG3atFGXXHKJWrhwYa1ZLk+fPq2eeeYZ1b9/f8sLvkOHDmrcuHHqgw8+sJRoMKtPsKOUUr/88osaM2aM8vHxUR4eHqpPnz7qlVdeUcXFxXWujWUymdR7772nBg0apLy9vZWXl5e64IIL1BdffFGfp6qS+gQ7SmmlG5599lk1aNAg5efnp/R6vfL19VX9+vVT//73v9WaNWuqzT6bmZmppk6dqrp161bpw+Tc8/78888qOjraEuh07txZPfzwwyopKanWL317D3aUUmr37t3q+uuvV4GBgcrV1VWFhoaq66+/Xv39999KqZpfU9YIdpTS6hzdc889KiwsTLm5uamwsDB1xx13qIMHDzb68df1/XDw4EF13333qc6dOyuj0ai8vLxUv3791OzZs6u8x8zq+8WyY8cOdd1116mgoCDl5uamOnbsqB599FF1+vRpSwbk4ODgGvcvLS1VX3zxhZowYYIKCQlRrq6uyt3dXXXs2FFdffXVauHChSo1NbXafb/88ks1YsSISnXXGps5/Fy//vqrmjFjhho5cqSKiIhQ7u7u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5OTkkJCQwB9//MGUKVN4//33AejRowehoaF8++23tGrVivDwcHQ6HQ888AC+vjV/NiYlJTF06FB69+7NgAEDCAsLIz09nZ9++onS0lKefPLsD7Hx48fzn//8hxdeeIEuXbowfvx4IiIiSE9P59ChQ/z555+8+OKL9OypTYS44IIL8PDw4M033yQnJ8cyZmn69On1+ls0Wr0mvjeDe++9VwEqNja20vJ9+/ZZ8hOUlpYqDw8Pdf/991fZf9y4capr1671Oqfk2XFshSVlqtOMn1XEUytUYmaBrZtTNyWFSr01UMsz8tPDjTtWcb5Ss1prx8pKrHVTk8mkxr+5XkU8tUK9tmpf484rnEJd85k4u+ry7CilVGlpqZo3b57q27evMhqNytvbW40aNUr99NNPVbatS06ZhIQEdd111ylfX1/VqlUrNXLkSPXHH3+of//73wpQ27dvr7LP33//rW688UYVGhqqXF1dVWBgoBowYICaPn262rt3b6VtN2/erEaNGqW8vb0tuXuOHDlS62PPzMxUs2bNUhdddJEKCQlRbm5uKjQ0VI0fP16tXr262n1+++03NXHiRBUUFKRcXV1V27Zt1QUXXKBeeOEFdfz48Urb/vzzz2rw4MHKw8PD0qbzsXaeHbsLdlavXq0A9dJLL1Va/vrrrytA/fnnn0oppa6//nrVpk0blZOTY9nm2LFjys3NTT311FP1OqcEO45t69EMFfHUCjXwhV+VyQrJxZrF2he04OS1rkoVZDb+eO8N1463+8fzbroyPllFPLVC9Z65SmXmF593e+HcJNixD8OHD1cuLi4qNzfX1k2xC9YOduxuzM6ll17KxIkTef7553nxxRdZs2YNr7zyCk8//TQTJkxgxIgRgFb7o6CggAkTJrBy5UqWLl3KFVdcQWBgYKMTLAnHEl9hvI4taq7UW8pu2PCGdv/y18DDr/HHrOO4HYBLe7WlR1tv8orLWLjB/mZNCOHMTp48WWXZokWL+Ouvvxg7dixeXg5a6sbO2V2wA/Ddd9/x2GOP8eGHH3LZZZfx3nvvMXXqVH744QfLNj169GDdunW4urpy7bXXMmXKFLp06cL69esle3ILszPRgTInm8ph2SNgKoMeE6CnlQZmWsbtnD/YcXE5OzPr07+Okl1QtYioEKJp9OnTh7Fjx/LII48wdepURo8eza233oq3tzfz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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "indices = list(range(0,len(acc_rs)))\n",
    "plt.plot(indices, acc_rs, marker='*', alpha=1, label='retain-set')\n",
    "plt.plot(indices, acc_fs, marker='o', alpha=1, label='forget-set')\n",
    "plt.legend(prop={'size': 14})\n",
    "plt.tick_params(labelsize=12)\n",
    "plt.title('scrub retain- and forget- set error',size=18)\n",
    "plt.xlabel('epoch',size=14)\n",
    "plt.ylabel('error',size=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.42105865478515625, 19.15789794921875, 68.6315803527832, 66.10526657104492, 45.47368621826172, 49.68421173095703, 0.21053314208984375, 7.62939453125e-06, 7.62939453125e-06, 7.62939453125e-06]\n",
      "[4.0, 0.0, 48.0, 64.0, 16.0, 12.0, 28.0, 32.0, 28.0, 28.0]\n"
     ]
    }
   ],
   "source": [
    "print (acc_rs)\n",
    "print (acc_fs)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
