{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_27082/2162111138.py:25: 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",
    "from sklearn.metrics import confusion_matrix\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",
    "\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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Metrics1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import *\n",
    "def get_metrics(model,dataloader,criterion,samples_correctness=False,use_bn=False,delta_w=None,scrub_act=False):\n",
    "    activations=[]\n",
    "    predictions=[]\n",
    "    if use_bn:\n",
    "        model.train()\n",
    "        dataloader = torch.utils.data.DataLoader(retain_loader.dataset, batch_size=128, shuffle=True)\n",
    "        for i in range(10):\n",
    "            for batch_idx, (data, target) in enumerate(dataloader):\n",
    "                data, target = data.to(args.device), target.to(args.device)            \n",
    "                output = model(data)\n",
    "    dataloader = torch.utils.data.DataLoader(dataloader.dataset, batch_size=1, shuffle=False)\n",
    "    model.eval()\n",
    "    metrics = AverageMeter()\n",
    "    mult = 0.5 if args.lossfn=='mse' else 1\n",
    "    for batch_idx, (data, target) in enumerate(dataloader):\n",
    "        data, target = data.to(args.device), target.to(args.device)            \n",
    "        if args.lossfn=='mse':\n",
    "            target=(2*target-1)\n",
    "            target = target.type(torch.cuda.FloatTensor).unsqueeze(1)\n",
    "        if 'mnist' in args.dataset:\n",
    "            data=data.view(data.shape[0],-1)\n",
    "        output = model(data)\n",
    "        loss = mult*criterion(output, target)\n",
    "        if samples_correctness:\n",
    "            activations.append(torch.nn.functional.softmax(output,dim=1).cpu().detach().numpy().squeeze())\n",
    "            predictions.append(get_error(output,target))\n",
    "        metrics.update(n=data.size(0), loss=loss.item(), error=get_error(output, target))\n",
    "    if samples_correctness:\n",
    "        return metrics.avg,np.stack(activations),np.array(predictions)\n",
    "    else:\n",
    "        return metrics.avg\n",
    "\n",
    "def activations_predictions(model,dataloader,name):\n",
    "    criterion = torch.nn.CrossEntropyLoss()\n",
    "    metrics,activations,predictions=get_metrics(model,dataloader,criterion,True)\n",
    "    print(f\"{name} -> Loss:{np.round(metrics['loss'],3)}, Error:{metrics['error']}\")\n",
    "    log_dict[f\"{name}_loss\"]=metrics['loss']\n",
    "    log_dict[f\"{name}_error\"]=metrics['error']\n",
    "\n",
    "    return activations,predictions\n",
    "\n",
    "def predictions_distance(l1,l2,name):\n",
    "    dist = np.sum(np.abs(l1-l2))\n",
    "    print(f\"Predictions Distance {name} -> {dist}\")\n",
    "    log_dict[f\"{name}_predictions\"]=dist\n",
    "\n",
    "def activations_distance(a1,a2,name):\n",
    "    dist = np.linalg.norm(a1-a2,ord=1,axis=1).mean()\n",
    "    print(f\"Activations Distance {name} -> {dist}\")\n",
    "    log_dict[f\"{name}_activations\"]=dist\n",
    "\n",
    "def interclass_confusion(model, dataloader, class_to_forget, name):\n",
    "    criterion = torch.nn.CrossEntropyLoss()\n",
    "    dataloader = torch.utils.data.DataLoader(dataloader.dataset, batch_size=128, shuffle=False)\n",
    "    model.eval()\n",
    "    reals=[]\n",
    "    predicts=[]\n",
    "    for batch_idx, (data, target) in enumerate(dataloader):\n",
    "        data, target = data.to(args.device), target.to(args.device) \n",
    "        if 'mnist' in args.dataset:\n",
    "            data=data.view(data.shape[0],-1)\n",
    "        output = model(data)\n",
    "        probs = torch.nn.functional.softmax(output, dim=1)\n",
    "        predict = np.argmax(probs.cpu().detach().numpy(),axis=1)\n",
    "        reals = reals + list(target.cpu().detach().numpy())\n",
    "        predicts = predicts + list(predict)\n",
    "    \n",
    "    classes = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]\n",
    "    cm = confusion_matrix(reals, predicts, labels=classes)\n",
    "    counts = 0\n",
    "    for i in range(len(cm)):\n",
    "        if i != class_to_forget[0]:\n",
    "            counts += cm[class_to_forget[0]][i]\n",
    "        if i != class_to_forget[1]:\n",
    "            counts += cm[class_to_forget[1]][i]\n",
    "    \n",
    "    ic_err = counts / (np.sum(cm[class_to_forget[0]]) + np.sum(cm[class_to_forget[1]]))\n",
    "    fgt = cm[class_to_forget[0]][class_to_forget[1]] + cm[class_to_forget[1]][class_to_forget[0]]\n",
    "    #print (cm)\n",
    "    return ic_err, fgt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Helper and Utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import *\n",
    "def get_metrics(model,dataloader,criterion,samples_correctness=False,use_bn=False,delta_w=None,scrub_act=False):\n",
    "    activations=[]\n",
    "    predictions=[]\n",
    "    if use_bn:\n",
    "        model.train()\n",
    "        dataloader = torch.utils.data.DataLoader(retain_loader.dataset, batch_size=128, shuffle=True)\n",
    "        for i in range(10):\n",
    "            for batch_idx, (data, target) in enumerate(dataloader):\n",
    "                data, target = data.to(args.device), target.to(args.device)            \n",
    "                output = model(data)\n",
    "    dataloader = torch.utils.data.DataLoader(dataloader.dataset, batch_size=1, shuffle=False)\n",
    "    model.eval()\n",
    "    metrics = AverageMeter()\n",
    "    mult = 0.5 if args.lossfn=='mse' else 1\n",
    "    for batch_idx, (data, target) in enumerate(dataloader):\n",
    "        data, target = data.to(args.device), target.to(args.device)            \n",
    "        if args.lossfn=='mse':\n",
    "            target=(2*target-1)\n",
    "            target = target.type(torch.cuda.FloatTensor).unsqueeze(1)\n",
    "        if 'mnist' in args.dataset:\n",
    "            data=data.view(data.shape[0],-1)\n",
    "        output = model(data)\n",
    "        if scrub_act:\n",
    "            G = []\n",
    "            for cls in range(num_classes):\n",
    "                grads = torch.autograd.grad(output[0,cls],model.parameters(),retain_graph=True)\n",
    "                grads = torch.cat([g.view(-1) for g in grads])\n",
    "                G.append(grads)\n",
    "            grads = torch.autograd.grad(output_sf[0,cls],model_scrubf.parameters(),retain_graph=False)\n",
    "            G = torch.stack(G).pow(2)\n",
    "            delta_f = torch.matmul(G,delta_w)\n",
    "            output += delta_f.sqrt()*torch.empty_like(delta_f).normal_()\n",
    "\n",
    "        loss = mult*criterion(output, target)\n",
    "        if samples_correctness:\n",
    "            activations.append(torch.nn.functional.softmax(output,dim=1).cpu().detach().numpy().squeeze())\n",
    "            predictions.append(get_error(output,target))\n",
    "        metrics.update(n=data.size(0), loss=loss.item(), error=get_error(output, target))\n",
    "    if samples_correctness:\n",
    "        return metrics.avg,np.stack(activations),np.array(predictions)\n",
    "    else:\n",
    "        return metrics.avg\n",
    "\n",
    "def l2_penalty(model,model_init,weight_decay):\n",
    "    l2_loss = 0\n",
    "    for (k,p),(k_init,p_init) in zip(model.named_parameters(),model_init.named_parameters()):\n",
    "        if p.requires_grad:\n",
    "            l2_loss += (p-p_init).pow(2).sum()\n",
    "    l2_loss *= (weight_decay/2.)\n",
    "    return l2_loss\n",
    "\n",
    "def run_train_epoch(model: nn.Module, model_init, data_loader: torch.utils.data.DataLoader, \n",
    "                    loss_fn: nn.Module,\n",
    "                    optimizer: torch.optim.SGD, split: str, epoch: int, ignore_index=None,\n",
    "                    negative_gradient=False, negative_multiplier=-1, random_labels=False,\n",
    "                    quiet=False,delta_w=None,scrub_act=False):\n",
    "    model.eval()\n",
    "    metrics = AverageMeter()    \n",
    "    num_labels = data_loader.dataset.targets.max().item() + 1\n",
    "    \n",
    "    with torch.set_grad_enabled(split != 'test'):\n",
    "        for idx, batch in enumerate(tqdm(data_loader, leave=False)):\n",
    "            batch = [tensor.to(next(model.parameters()).device) for tensor in batch]\n",
    "            input, target = batch\n",
    "            output = model(input)\n",
    "            if split=='test' and scrub_act:\n",
    "                G = []\n",
    "                for cls in range(num_classes):\n",
    "                    grads = torch.autograd.grad(output[0,cls],model.parameters(),retain_graph=True)\n",
    "                    grads = torch.cat([g.view(-1) for g in grads])\n",
    "                    G.append(grads)\n",
    "                grads = torch.autograd.grad(output_sf[0,cls],model_scrubf.parameters(),retain_graph=False)\n",
    "                G = torch.stack(G).pow(2)\n",
    "                delta_f = torch.matmul(G,delta_w)\n",
    "                output += delta_f.sqrt()*torch.empty_like(delta_f).normal_()\n",
    "            loss = loss_fn(output, target) + l2_penalty(model,model_init,args.weight_decay)\n",
    "            metrics.update(n=input.size(0), loss=loss_fn(output,target).item(), error=get_error(output, target))\n",
    "            \n",
    "            if split != 'test':\n",
    "                model.zero_grad()\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "    if not quiet:\n",
    "        log_metrics(split, metrics, epoch)\n",
    "    return metrics.avg\n",
    "\n",
    "def run_neggrad_epoch(model: nn.Module, model_init, data_loader: torch.utils.data.DataLoader, \n",
    "                    forget_loader: torch.utils.data.DataLoader,\n",
    "                    alpha: float,\n",
    "                    loss_fn: nn.Module,\n",
    "                    optimizer: torch.optim.SGD, split: str, epoch: int, ignore_index=None,\n",
    "                    quiet=False):\n",
    "    model.eval()\n",
    "    metrics = AverageMeter()    \n",
    "    num_labels = data_loader.dataset.targets.max().item() + 1\n",
    "    \n",
    "    with torch.set_grad_enabled(split != 'test'):\n",
    "        for idx, (batch_retain,batch_forget) in enumerate(tqdm(zip(data_loader,cycle(forget_loader)), leave=False)):\n",
    "            batch_retain = [tensor.to(next(model.parameters()).device) for tensor in batch_retain]\n",
    "            batch_forget = [tensor.to(next(model.parameters()).device) for tensor in batch_forget]\n",
    "            input_r, target_r = batch_retain\n",
    "            input_f, target_f = batch_forget\n",
    "            output_r = model(input_r)\n",
    "            output_f = model(input_f)\n",
    "            loss = alpha*(loss_fn(output_r, target_r) + l2_penalty(model,model_init,args.weight_decay)) - (1-alpha)*loss_fn(output_f, target_f)\n",
    "            metrics.update(n=input_r.size(0), loss=loss_fn(output_r,target_r).item(), error=get_error(output_r, target_r))\n",
    "            if split != 'test':\n",
    "                model.zero_grad()\n",
    "                loss.backward()\n",
    "                optimizer.step()\n",
    "    if not quiet:\n",
    "        log_metrics(split, metrics, epoch)\n",
    "    return metrics.avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(model, data_loader):\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "    model_init=copy.deepcopy(model)\n",
    "    return run_train_epoch(model, model_init, data_loader, loss_fn, optimizer=None, split='test', epoch=epoch, ignore_index=None, quiet=True)\n",
    "\n",
    "def readout_retrain(model, data_loader, test_loader, lr=0.1, epochs=500, threshold=0.01, quiet=True):\n",
    "    torch.manual_seed(seed)\n",
    "    model = copy.deepcopy(model)\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=lr, weight_decay=0.0)\n",
    "    sampler = torch.utils.data.RandomSampler(data_loader.dataset, replacement=True, num_samples=500)\n",
    "    data_loader_small = torch.utils.data.DataLoader(data_loader.dataset, batch_size=data_loader.batch_size, sampler=sampler, num_workers=data_loader.num_workers)\n",
    "    metrics = []\n",
    "    model_init=copy.deepcopy(model)\n",
    "    for epoch in range(epochs):\n",
    "        metrics.append(run_train_epoch(model, model_init, test_loader, loss_fn, optimizer, split='test', epoch=epoch, ignore_index=None, quiet=quiet))\n",
    "        if metrics[-1]['loss'] <= threshold:\n",
    "            break\n",
    "        run_train_epoch(model, model_init, data_loader_small, loss_fn, optimizer, split='train', epoch=epoch, ignore_index=None, quiet=quiet)\n",
    "    return epoch, metrics\n",
    "\n",
    "def extract_retrain_time(metrics, threshold=0.1):\n",
    "    losses = np.array([m['loss'] for m in metrics])\n",
    "    return np.argmax(losses < threshold)\n",
    "\n",
    "def all_readouts(test_loader, retain_loader, forget_loader, model, wandb=None,thresh=0.1,name='method'):\n",
    "    #train_loader = torch.utils.data.DataLoader(train_loader_full.dataset, batch_size=args.batch_size, shuffle=True)\n",
    "    #retrain_time, _ = readout_retrain(model, train_loader, forget_loader, epochs=100, lr=0.1, threshold=thresh)\n",
    "    test_error = test(model, test_loader)['error']\n",
    "    forget_error = test(model, forget_loader)['error']\n",
    "    retain_error = test(model, retain_loader)['error']\n",
    "    ic_err_test, fgt_test = interclass_confusion(model, test_loader, class_to_forget, name)\n",
    "    ic_err_retain, fgt_retain = interclass_confusion(model, retain_loader, class_to_forget, name)\n",
    "    print(f\"{name} ->\"\n",
    "          f\"\\ttest: {test_error:.2%}\"\n",
    "          f\"\\tForget: {forget_error:.2%}\\tRetain: {retain_error:.2%}\"\n",
    "          f\"\\tIC-test: {ic_err_test}\\tfgt-test: {fgt_test}\"\n",
    "          f\"\\tIC-retain: {ic_err_retain}\\tfgt-retain: {fgt_retain}\")\n",
    "    #log_dict[f\"{name}_retrain_time\"]=retrain_time+1\n",
    "    if wandb is not None:\n",
    "        #wandb.log({f\"{name}_RLT\": retrain_time + 1})\n",
    "        wandb.log({f\"{name}_test_error\": test_error})\n",
    "        wandb.log({f\"{name}_retain_error\": retain_error})\n",
    "        wandb.log({f\"{name}_forget_error\": forget_error})\n",
    "        wandb.log({f\"{name}_IC_err_test\": ic_err_test})\n",
    "        wandb.log({f\"{name}_IC_err_retain\": ic_err_retain})\n",
    "        wandb.log({f\"{name}_fgt_test\": fgt_test})\n",
    "        wandb.log({f\"{name}_fgt_retain\": fgt_retain})\n",
    "    return(dict(test_error=test_error, forget_error=forget_error, retain_error=retain_error))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Forgetting helper functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def finetune(model: nn.Module, data_loader: torch.utils.data.DataLoader, lr=0.01, epochs=10, quiet=False):\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=lr, weight_decay=0.0)\n",
    "    model_init=copy.deepcopy(model)\n",
    "    for epoch in range(epochs):\n",
    "        run_train_epoch(model, model_init, data_loader, loss_fn, optimizer, split='train', epoch=epoch, ignore_index=None, quiet=quiet)\n",
    "        #train_vanilla(epoch, data_loader, model, loss_fn, optimizer, args)\n",
    "\n",
    "def negative_grad(model: nn.Module, data_loader: torch.utils.data.DataLoader, forget_loader: torch.utils.data.DataLoader, alpha: float, lr=0.01, epochs=10, quiet=False, args=None):\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=lr, weight_decay=0.0)\n",
    "    model_init=copy.deepcopy(model)\n",
    "    for epoch in range(epochs):\n",
    "        #run_neggrad_epoch(model, model_init, data_loader, forget_loader, alpha, loss_fn, optimizer, split='train', epoch=epoch, ignore_index=None, quiet=quiet)\n",
    "        train_negrad(epoch, data_loader, forget_loader, model, loss_fn, optimizer,  alpha, args)\n",
    "\n",
    "def fk_fientune(model: nn.Module, data_loader: torch.utils.data.DataLoader, args, lr=0.01, epochs=10, quiet=False):\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=lr, weight_decay=0.0005)\n",
    "    model_init=copy.deepcopy(model)\n",
    "    for epoch in range(epochs):\n",
    "        sgda_adjust_learning_rate(epoch, args, optimizer)\n",
    "        #train_vanilla(epoch, data_loader, model, loss_fn, optimizer, args)\n",
    "        run_train_epoch(model, model_init, data_loader, loss_fn, optimizer, split='train', epoch=epoch, ignore_index=None, quiet=quiet)\n",
    "\n",
    "def pdb():\n",
    "    import pdb\n",
    "    pdb.set_trace\n",
    "    \n",
    "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}')\n",
    "    \n",
    "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)\n",
    "\n",
    "def print_param_shape(model):\n",
    "    for k,p in model.named_parameters():\n",
    "        print(k,p.shape)\n",
    "\n",
    "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)\n",
    "\n",
    "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": "markdown",
   "metadata": {},
   "source": [
    "### Pre-training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: cifar100_allcnn_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in cifar100_allcnn_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_training]\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "confuse mode: False\n",
      "split mode: None\n",
      "Number of Classes: 100\n",
      "[0] train metrics:{\"loss\": 3.9548908950805663, \"error\": 0.9099}\n",
      "Learning Rate : 0.1\n",
      "[0] dry_run metrics:{\"loss\": 3.6569058528900147, \"error\": 0.864325}\n",
      "Learning Rate : 0.1\n",
      "[0] test metrics:{\"loss\": 3.669260646820068, \"error\": 0.8685}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 9.4 sec\n",
      "[1] train metrics:{\"loss\": 3.4458515224456785, \"error\": 0.82415}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.5 sec\n",
      "[2] train metrics:{\"loss\": 3.016041721725464, \"error\": 0.729925}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.2 sec\n",
      "[3] train metrics:{\"loss\": 2.711107554626465, \"error\": 0.65535}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.23 sec\n",
      "[4] train metrics:{\"loss\": 2.496060283279419, \"error\": 0.593225}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.43 sec\n",
      "[5] train metrics:{\"loss\": 2.329194931793213, \"error\": 0.538525}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.61 sec\n",
      "[6] train metrics:{\"loss\": 2.2086135860443115, \"error\": 0.49755}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.58 sec\n",
      "[7] train metrics:{\"loss\": 2.123908861541748, \"error\": 0.462825}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.48 sec\n",
      "[8] train metrics:{\"loss\": 2.049863201332092, \"error\": 0.431325}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.48 sec\n",
      "[9] train metrics:{\"loss\": 1.9988761100769044, \"error\": 0.40755}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.55 sec\n",
      "[10] train metrics:{\"loss\": 1.9432452823638915, \"error\": 0.379025}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.56 sec\n",
      "[11] train metrics:{\"loss\": 1.9131594074249267, \"error\": 0.35665}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.65 sec\n",
      "[12] train metrics:{\"loss\": 1.8789236625671386, \"error\": 0.332075}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.53 sec\n",
      "[13] train metrics:{\"loss\": 1.8584274074554443, \"error\": 0.31195}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.63 sec\n",
      "[14] train metrics:{\"loss\": 1.835866969680786, \"error\": 0.29505}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.61 sec\n",
      "[15] train metrics:{\"loss\": 1.8279486743927003, \"error\": 0.2791}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.52 sec\n",
      "[16] train metrics:{\"loss\": 1.8283887172698974, \"error\": 0.26425}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.48 sec\n",
      "[17] train metrics:{\"loss\": 1.7811426517486573, \"error\": 0.240475}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.74 sec\n",
      "[18] train metrics:{\"loss\": 1.7966106941223146, \"error\": 0.23225}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.09 sec\n",
      "[19] train metrics:{\"loss\": 1.791147449493408, \"error\": 0.21845}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 7.0 sec\n",
      "[20] train metrics:{\"loss\": 1.7986805698394774, \"error\": 0.20865}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.94 sec\n",
      "[21] train metrics:{\"loss\": 1.802754467010498, \"error\": 0.20475}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.61 sec\n",
      "[22] train metrics:{\"loss\": 1.793176968383789, \"error\": 0.19225}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.7 sec\n",
      "[23] train metrics:{\"loss\": 1.8183617504119873, \"error\": 0.19235}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.73 sec\n",
      "[24] train metrics:{\"loss\": 1.7976149871826173, \"error\": 0.17805}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.65 sec\n",
      "[25] train metrics:{\"loss\": 1.8099366149902343, \"error\": 0.178875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.85 sec\n",
      "[26] train metrics:{\"loss\": 1.791230718421936, \"error\": 0.168925}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 6.34 sec\n",
      "[27] train metrics:{\"loss\": 1.8296453895568847, \"error\": 0.176575}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.51 sec\n",
      "[28] train metrics:{\"loss\": 1.79987815284729, \"error\": 0.16505}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.56 sec\n",
      "[29] train metrics:{\"loss\": 1.8186018115997316, \"error\": 0.16935}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.43 sec\n",
      "[30] train metrics:{\"loss\": 1.8211508485794068, \"error\": 0.1652}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 4.45 sec\n",
      "Pure training time: 147.35000000000002 sec\n"
     ]
    }
   ],
   "source": [
    "%run main.py --dataset cifar100 --dataroot=data/cifar100/ --model allcnn --filters 1.0 --lr 0.1 --lossfn ce --num-classes 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Original"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "#%run main.py --dataset small_lacuna6 --model allcnn --dataroot=data/lacuna10/ --filters 1.0 --lr 0.001 \\\n",
    "#--resume checkpoints/lacuna100_allcnn_1_0_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": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: cifar10_resnet_1_0_forget_None_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in cifar10_resnet_1_0_forget_None_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1_training]\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "confuse mode: True\n",
      "split mode: train\n",
      "[22462  6646 36135 23850  1434  5306 18141  4049 11418 10150 21959  2340\n",
      " 28237 23045 33372 17719 28726 24235 36477 30535 34830 13742  9505  9925\n",
      "  8968  5340 32206 23111 36876 37753 18138   346  9984 33198 10884 17838\n",
      "  5290 34800  8839 26496 22062 19691 25490 32745 29623 37043 38544 16174\n",
      " 26055 17790 13062  3564 33467 19387 12727 10616  5925 38573 20823 25972\n",
      "  2232 39091 16018 31897  6216 31382  9265  4834 15220 13636 20376 17239\n",
      "  3784 30964 11139 32269 25536 37777  9464 31770 12377 14878 22419 35384\n",
      " 33593 13768  8813 14913  1918  3157 22036 26124 26696 32374   359 18794\n",
      " 37201 12935 39835  6800 34930 21153  1332   444 26453 22013  2780 28519\n",
      " 32137 33713  9783 18691  5872  5426 26608  5517 26355 34576 15284  9727\n",
      " 11908 16177  5566 33238 31572 31990  6716 36313 26521  8618 25781 10358\n",
      "  9601   341  6301 36220 15826  3522  4898 31528 28091 12132 15300  5732\n",
      " 10974 23654 30805 26574  5750  7350 19049 24064  7229  8594 31711 15489\n",
      " 21523 27315  8146 28736 36469 37611 32999 39736 27867 33821 34312  3036\n",
      " 11154 19416 37108 22615 36649 11823  7061 36430 18557 37081  8899 29319\n",
      "  9990 26523 33672  7326 39648 21642   132  4050  6683  5979 20121 36524\n",
      " 22540 33421 27229 13730 29155 25346  2670   732]\n",
      "Number of Classes: 10\n",
      "[0] train metrics:{\"loss\": 0.8994579604148865, \"error\": 0.31465}\n",
      "Learning Rate : 0.01\n",
      "[0] test metrics:{\"loss\": 0.6736513387680054, \"error\": 0.2306}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 8.65 sec\n",
      "[1] train metrics:{\"loss\": 0.5806631664276123, \"error\": 0.19635}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 7.16 sec\n",
      "[2] train metrics:{\"loss\": 0.44068201198577883, \"error\": 0.14615}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.96 sec\n",
      "[3] train metrics:{\"loss\": 0.3294310111761093, \"error\": 0.105}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.99 sec\n",
      "[4] train metrics:{\"loss\": 0.23757381939888, \"error\": 0.07145}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.99 sec\n",
      "[5] train metrics:{\"loss\": 0.15486119554042815, \"error\": 0.0413}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 7.24 sec\n",
      "[6] train metrics:{\"loss\": 0.09451916145086288, \"error\": 0.018575}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.84 sec\n",
      "[7] train metrics:{\"loss\": 0.0700134416103363, \"error\": 0.009625}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.77 sec\n",
      "[8] train metrics:{\"loss\": 0.05248799537420273, \"error\": 0.003975}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 7.41 sec\n",
      "[9] train metrics:{\"loss\": 0.03984407194852829, \"error\": 0.00035}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.7 sec\n",
      "[10] train metrics:{\"loss\": 0.03694459772706032, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.84 sec\n",
      "[11] train metrics:{\"loss\": 0.03580245625972748, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.79 sec\n",
      "[12] train metrics:{\"loss\": 0.03495487071871758, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.84 sec\n",
      "[13] train metrics:{\"loss\": 0.03420322653055191, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 7.04 sec\n",
      "[14] train metrics:{\"loss\": 0.03351431832909584, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.89 sec\n",
      "[15] train metrics:{\"loss\": 0.0328611094892025, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.9 sec\n",
      "[16] train metrics:{\"loss\": 0.032256303888559344, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 9.8 sec\n",
      "[17] train metrics:{\"loss\": 0.031692172318696976, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.9 sec\n",
      "[18] train metrics:{\"loss\": 0.031148864424228668, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.9 sec\n",
      "[19] train metrics:{\"loss\": 0.030647821056842803, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.77 sec\n",
      "[20] train metrics:{\"loss\": 0.030150964498519898, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.81 sec\n",
      "[21] train metrics:{\"loss\": 0.02969496927857399, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 10.49 sec\n",
      "[22] train metrics:{\"loss\": 0.02928686562180519, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 7.74 sec\n",
      "[23] train metrics:{\"loss\": 0.028866908860206604, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.95 sec\n",
      "[24] train metrics:{\"loss\": 0.028454023391008377, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 6.92 sec\n",
      "[25] train metrics:{\"loss\": 0.028074368637800218, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 7.07 sec\n",
      "Pure training time: 187.73000000000002 sec\n"
     ]
    }
   ],
   "source": [
    "%run main.py --dataset cifar10 --model resnet --dataroot=data/cifar10/ --filters 1.0 --lr 0.01 \\\n",
    "--resume checkpoints/cifar100_resnet_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_30.pt --disable-bn \\\n",
    "--weight-decay 0.0005 --batch-size 128 --epochs 26 --seed 1 \\\n",
    "--split train --confuse-mode --forget-class 0,1 --num-to-forget 200"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Retrain"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "#%run main.py --dataset small_lacuna6 --model allcnn --dataroot=data/lacuna10/ --filters 1.0 --lr 0.001 \\\n",
    "#--resume checkpoints/lacuna100_allcnn_1_0_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,1,2,3,4,5 --num-to-forget 300 --seed 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: cifar10_resnet_1_0_forget_[0, 1]_num_200_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in cifar10_resnet_1_0_forget_[0, 1]_num_200_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1_training]\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "confuse mode: True\n",
      "split mode: forget\n",
      "[22462  6646 36135 23850  1434  5306 18141  4049 11418 10150 21959  2340\n",
      " 28237 23045 33372 17719 28726 24235 36477 30535 34830 13742  9505  9925\n",
      "  8968  5340 32206 23111 36876 37753 18138   346  9984 33198 10884 17838\n",
      "  5290 34800  8839 26496 22062 19691 25490 32745 29623 37043 38544 16174\n",
      " 26055 17790 13062  3564 33467 19387 12727 10616  5925 38573 20823 25972\n",
      "  2232 39091 16018 31897  6216 31382  9265  4834 15220 13636 20376 17239\n",
      "  3784 30964 11139 32269 25536 37777  9464 31770 12377 14878 22419 35384\n",
      " 33593 13768  8813 14913  1918  3157 22036 26124 26696 32374   359 18794\n",
      " 37201 12935 39835  6800 34930 21153  1332   444 26453 22013  2780 28519\n",
      " 32137 33713  9783 18691  5872  5426 26608  5517 26355 34576 15284  9727\n",
      " 11908 16177  5566 33238 31572 31990  6716 36313 26521  8618 25781 10358\n",
      "  9601   341  6301 36220 15826  3522  4898 31528 28091 12132 15300  5732\n",
      " 10974 23654 30805 26574  5750  7350 19049 24064  7229  8594 31711 15489\n",
      " 21523 27315  8146 28736 36469 37611 32999 39736 27867 33821 34312  3036\n",
      " 11154 19416 37108 22615 36649 11823  7061 36430 18557 37081  8899 29319\n",
      "  9990 26523 33672  7326 39648 21642   132  4050  6683  5979 20121 36524\n",
      " 22540 33421 27229 13730 29155 25346  2670   732]\n",
      "Number of Classes: 10\n",
      "[0] train metrics:{\"loss\": 0.8776707893371583, \"error\": 0.310325}\n",
      "Learning Rate : 0.01\n",
      "[0] test metrics:{\"loss\": 0.6726855438232422, \"error\": 0.2333}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 13.37 sec\n",
      "[1] train metrics:{\"loss\": 0.5546332703590393, \"error\": 0.19135}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 12.42 sec\n",
      "[2] train metrics:{\"loss\": 0.411030176115036, \"error\": 0.1398}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 12.96 sec\n",
      "[3] train metrics:{\"loss\": 0.30049551043510436, \"error\": 0.0975}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 12.73 sec\n",
      "[4] train metrics:{\"loss\": 0.21082578921318054, \"error\": 0.065275}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 11.56 sec\n",
      "[5] train metrics:{\"loss\": 0.13203115015029906, \"error\": 0.035125}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 13.43 sec\n",
      "[6] train metrics:{\"loss\": 0.08035368938446046, \"error\": 0.015675}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 12.76 sec\n",
      "[7] train metrics:{\"loss\": 0.05315162697434425, \"error\": 0.004475}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 13.06 sec\n",
      "[8] train metrics:{\"loss\": 0.041563900208473205, \"error\": 0.001025}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 11.91 sec\n",
      "[9] train metrics:{\"loss\": 0.03547775356173515, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 12.82 sec\n",
      "[10] train metrics:{\"loss\": 0.0340896775662899, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 12.9 sec\n",
      "[11] train metrics:{\"loss\": 0.03323477267026901, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 18.9 sec\n",
      "[12] train metrics:{\"loss\": 0.03250679121613503, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 14.16 sec\n",
      "[13] train metrics:{\"loss\": 0.03184912375807762, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 21.5 sec\n",
      "[14] train metrics:{\"loss\": 0.031240232867002487, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.34 sec\n",
      "[15] train metrics:{\"loss\": 0.030659463116526602, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.77 sec\n",
      "[16] train metrics:{\"loss\": 0.030124190509319304, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 24.72 sec\n",
      "[17] train metrics:{\"loss\": 0.02962413500249386, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.47 sec\n",
      "[18] train metrics:{\"loss\": 0.029126183646917343, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 24.81 sec\n",
      "[19] train metrics:{\"loss\": 0.028692543506622314, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 24.27 sec\n",
      "[20] train metrics:{\"loss\": 0.028240641552209855, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.48 sec\n",
      "[21] train metrics:{\"loss\": 0.02783956998884678, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.2 sec\n",
      "[22] train metrics:{\"loss\": 0.02746837635934353, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.05 sec\n",
      "[23] train metrics:{\"loss\": 0.027107982075214386, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.72 sec\n",
      "[24] train metrics:{\"loss\": 0.02672754344344139, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 25.81 sec\n",
      "[25] train metrics:{\"loss\": 0.026383602434396743, \"error\": 0.0}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 26.14 sec\n",
      "Pure training time: 496.11 sec\n"
     ]
    }
   ],
   "source": [
    "%run main.py --dataset cifar10 --model resnet --dataroot=data/cifar10/ --filters 1.0 --lr 0.01 \\\n",
    "--resume checkpoints/cifar100_resnet_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_30.pt --disable-bn \\\n",
    "--weight-decay 0.0005 --batch-size 128 --epochs 26 --seed 1 \\\n",
    "--split forget --confuse-mode --forget-class 0,1 --num-to-forget 200"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Logs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict={}\n",
    "training_epochs=25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict['epoch']=training_epochs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Number of Parameters: 11175178\n"
     ]
    }
   ],
   "source": [
    "parameter_count(copy.deepcopy(model))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Loads checkpoints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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 - 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": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict['args']=args"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Distance: 10.362852075030466\n",
      "Normalized Distance: 0.09396269883651323\n"
     ]
    }
   ],
   "source": [
    "log_dict['dist_Original_Original_init']= distance(model_init,model)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Data Loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.retain_bs = 32\n",
    "args.forget_bs = 32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "confuse mode: True\n",
      "split mode: train\n",
      "[22462  6646 36135 23850  1434  5306 18141  4049 11418 10150 21959  2340\n",
      " 28237 23045 33372 17719 28726 24235 36477 30535 34830 13742  9505  9925\n",
      "  8968  5340 32206 23111 36876 37753 18138   346  9984 33198 10884 17838\n",
      "  5290 34800  8839 26496 22062 19691 25490 32745 29623 37043 38544 16174\n",
      " 26055 17790 13062  3564 33467 19387 12727 10616  5925 38573 20823 25972\n",
      "  2232 39091 16018 31897  6216 31382  9265  4834 15220 13636 20376 17239\n",
      "  3784 30964 11139 32269 25536 37777  9464 31770 12377 14878 22419 35384\n",
      " 33593 13768  8813 14913  1918  3157 22036 26124 26696 32374   359 18794\n",
      " 37201 12935 39835  6800 34930 21153  1332   444 26453 22013  2780 28519\n",
      " 32137 33713  9783 18691  5872  5426 26608  5517 26355 34576 15284  9727\n",
      " 11908 16177  5566 33238 31572 31990  6716 36313 26521  8618 25781 10358\n",
      "  9601   341  6301 36220 15826  3522  4898 31528 28091 12132 15300  5732\n",
      " 10974 23654 30805 26574  5750  7350 19049 24064  7229  8594 31711 15489\n",
      " 21523 27315  8146 28736 36469 37611 32999 39736 27867 33821 34312  3036\n",
      " 11154 19416 37108 22615 36649 11823  7061 36430 18557 37081  8899 29319\n",
      "  9990 26523 33672  7326 39648 21642   132  4050  6683  5979 20121 36524\n",
      " 22540 33421 27229 13730 29155 25346  2670   732]\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "confuse mode: True\n",
      "split mode: forget\n",
      "[22462  6646 36135 23850  1434  5306 18141  4049 11418 10150 21959  2340\n",
      " 28237 23045 33372 17719 28726 24235 36477 30535 34830 13742  9505  9925\n",
      "  8968  5340 32206 23111 36876 37753 18138   346  9984 33198 10884 17838\n",
      "  5290 34800  8839 26496 22062 19691 25490 32745 29623 37043 38544 16174\n",
      " 26055 17790 13062  3564 33467 19387 12727 10616  5925 38573 20823 25972\n",
      "  2232 39091 16018 31897  6216 31382  9265  4834 15220 13636 20376 17239\n",
      "  3784 30964 11139 32269 25536 37777  9464 31770 12377 14878 22419 35384\n",
      " 33593 13768  8813 14913  1918  3157 22036 26124 26696 32374   359 18794\n",
      " 37201 12935 39835  6800 34930 21153  1332   444 26453 22013  2780 28519\n",
      " 32137 33713  9783 18691  5872  5426 26608  5517 26355 34576 15284  9727\n",
      " 11908 16177  5566 33238 31572 31990  6716 36313 26521  8618 25781 10358\n",
      "  9601   341  6301 36220 15826  3522  4898 31528 28091 12132 15300  5732\n",
      " 10974 23654 30805 26574  5750  7350 19049 24064  7229  8594 31711 15489\n",
      " 21523 27315  8146 28736 36469 37611 32999 39736 27867 33821 34312  3036\n",
      " 11154 19416 37108 22615 36649 11823  7061 36430 18557 37081  8899 29319\n",
      "  9990 26523 33672  7326 39648 21642   132  4050  6683  5979 20121 36524\n",
      " 22540 33421 27229 13730 29155 25346  2670   732]\n"
     ]
    }
   ],
   "source": [
    "train_loader_full, valid_loader_full, test_loader_full = datasets.get_loaders(dataset, split=\"train\",confuse_mode=True,class_to_replace=class_to_forget, num_indexes_to_replace=num_to_forget, batch_size=args.batch_size, seed=seed, root=args.dataroot, augment=False, shuffle=True)\n",
    "marked_loader, _, _ = datasets.get_loaders(dataset, split=\"forget\", confuse_mode=True,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": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "200\n",
      "39800\n",
      "10000\n",
      "40000\n",
      "{6: 4000, 9: 4000, 4: 4000, 1: 4000, 2: 4000, 8: 4000, 3: 4000, 7: 4000, 5: 4000, 0: 4000}\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": [
    "# SGDA Forgetting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.optim = 'sgd'\n",
    "args.gamma = 1\n",
    "args.alpha = 0.01\n",
    "args.beta = 0\n",
    "args.smoothing = 0.5\n",
    "args.msteps = 2\n",
    "args.clip = 0.5\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.0005\n",
    "args.lr_decay_epochs = [7,10,10]\n",
    "args.lr_decay_rate = 0.1\n",
    "args.sgda_weight_decay = 5e-4\n",
    "args.sgda_momentum = 0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_t = copy.deepcopy(teacher)\n",
    "model_s = copy.deepcopy(student)\n",
    "#model_s = models.get_model(arch, num_classes=num_classes, filters_percentage=filters).to(args.device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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": 22,
   "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": 23,
   "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": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.093 \n",
      "maximize loss: -12.73\t minimize loss: 0.59\t train_acc: 87.09296417236328\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.417 \n",
      "maximize loss: -11.21\t minimize loss: 0.57\t train_acc: 87.41708374023438\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.445 \n",
      "maximize loss: 0.00\t minimize loss: 0.52\t train_acc: 87.4447250366211\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.585 \n",
      "maximize loss: 0.00\t minimize loss: 0.52\t train_acc: 87.5854263305664\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.510 \n",
      "maximize loss: 0.00\t minimize loss: 0.52\t train_acc: 87.51004791259766\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.307 \n",
      "maximize loss: 0.00\t minimize loss: 0.52\t train_acc: 87.30653381347656\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.420 \n",
      "maximize loss: 0.00\t minimize loss: 0.52\t train_acc: 87.41959381103516\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.188 \n",
      "maximize loss: 0.00\t minimize loss: 0.47\t train_acc: 87.18843841552734\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 86.940 \n",
      "maximize loss: 0.00\t minimize loss: 0.47\t train_acc: 86.939697265625\n",
      "==> SCRUB unlearning ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zihao/anaconda3/envs/zihao/lib/python3.10/site-packages/torch/nn/_reduction.py:42: UserWarning: size_average and reduce args will be deprecated, please use reduction='sum' instead.\n",
      "  warnings.warn(warning.format(ret))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * Acc@1 87.090 \n",
      "maximize loss: 0.00\t minimize loss: 0.47\t train_acc: 87.0904541015625\n"
     ]
    }
   ],
   "source": [
    "t1 = time.time()\n",
    "acc_rs = []\n",
    "acc_fs = []\n",
    "acc_vs = []\n",
    "ic_rs = []\n",
    "ic_vs = []\n",
    "fgt_rs = []\n",
    "fgt_vs = []\n",
    "for epoch in range(1, args.sgda_epochs + 1):\n",
    "\n",
    "    lr = sgda_adjust_learning_rate(epoch, args, optimizer)\n",
    "    print(\"==> SCRUB unlearning ...\")\n",
    "    ic_r, fgt_r = interclass_confusion(model_s, retain_loader, class_to_forget, \"SCRUB\")\n",
    "    ic_v, fgt_v = interclass_confusion(model_s, valid_loader_full, class_to_forget, \"SCRUB\")\n",
    "    ic_rs.append(ic_r)\n",
    "    ic_vs.append(ic_v)\n",
    "    fgt_rs.append(fgt_r)\n",
    "    fgt_vs.append(fgt_v)\n",
    "\n",
    "    acc_r, acc5_r, loss_r = validate(retain_loader, model_s, criterion_cls, args, True)\n",
    "    acc_f, acc5_f, loss_f = validate(forget_loader, model_s, criterion_cls, args, True)\n",
    "    acc_v, acc5_v, loss_v = validate(valid_loader_full, model_s, criterion_cls, args, True)\n",
    "    acc_rs.append(100-acc_r.item())\n",
    "    acc_fs.append(100-acc_f.item())\n",
    "    acc_vs.append(100-acc_v.item())\n",
    "\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",
    "    \n",
    "    print (\"maximize loss: {:.2f}\\t minimize loss: {:.2f}\\t train_acc: {}\".format(maximize_loss, train_loss, train_acc))\n",
    "ic_r, fgt_r = interclass_confusion(model_s, retain_loader, class_to_forget, \"SCRUB\")\n",
    "ic_v, fgt_v = interclass_confusion(model_s, valid_loader_full, class_to_forget, \"SCRUB\")\n",
    "ic_rs.append(ic_r)\n",
    "ic_vs.append(ic_v)\n",
    "fgt_rs.append(fgt_r)\n",
    "fgt_vs.append(fgt_v)\n",
    "acc_r, acc5_r, loss_r = validate(retain_loader, model_s, criterion_cls, args, True)\n",
    "acc_f, acc5_f, loss_f = validate(forget_loader, model_s, criterion_cls, args, True)\n",
    "acc_tv, acc5_v, loss_v = validate(valid_loader_full, model_s, criterion_cls, args, True)\n",
    "acc_rs.append(100-acc_r.item())\n",
    "acc_fs.append(100-acc_f.item())\n",
    "acc_vs.append(100-acc_v.item())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2192536/2812292199.py:16: UserWarning: FigureCanvasAgg is non-interactive, and thus cannot be shown\n",
      "  fig.show()\n"
     ]
    },
    {
     "data": {
      "image/png": "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aJH69+/v0WNX9Puqoue5PtdVCdVs0SITGiIipMsus7saAACAGmXbtm1yOBy64YYb7C7F63yuqxKqmXNQ9DXXSPXq2VsLAADA35o1a6Zff/1VkZGRdpfiVXfeeaeuvPJKNW/e3O5S3CI4+JOMDGnuXPOYQdEAAMCH1KlTR6eddprdZXhd48aN1bhxY7vLqBC6KvmTmTOlnBypUydzAwAA/mf1amngQHPvQ8rqAnTw4EFNmDBBZ555purVq1c40c2jjz5a4YXNWrRooRYtWujAgQO6++67FR8fr6CgIJexFD/99JOuvPJKNWnSRMHBwUpISNBdd92lffv2Fe4zY8YMJSYmSpLeffddORyOwtvixYslSbt379Zjjz2m7t27Kzo6WiEhIWrRooVuv/12paenl6ht3LhxLl9//L/Fli1bdNlll6lhw4aqV6+ezj77bG3YsKFi/6geRouDv7As6c03zWNWigYAwH+9954Z8/j++1LnznZXU66MjAz169dPmzZtUocOHTRy5EgVFBTof//7n5555hndc889atCgQYWOlZ2drYEDB+rgwYO68MILFRwcXLjA8Oeff64rrrhCgYGBuuiiixQfH69NmzZp8uTJmj9/vlauXKmGDRuqQ4cOGjVqlF5++WW1b99eQ4YMKTx+ixYtJEnJycl64YUXdNZZZ6lbt26qU6eO1q1bp6lTp2r+/Plau3Zthbtjbdu2Td26dVPbtm110003afPmzfrss880YMAA/frrr2UukFxdCA7+YsUKadMmqW5d6aqr7K4GAABUhGVJR45U/Tg7dkj79kkOhzR7ttk2a5Z0xRXmPU46SapKH/u6dc2xPez222/Xpk2b9NBDD+nJJ590eW3Pnj2qX79+hY+VlpamM888Uz/88IPCwsIKt+/bt0/Dhw9XVFSUfvjhB5exBrNmzdLVV1+tf//733r11VfVoUMHjR49Wi+//LI6dOigcePGlXifgQMHKi0trURt7733nq6//npNnjxZDz/8cIVqXrJkiZ5++mndf//9hdseffRRPfHEE3rnnXf0wAMPVPjzewJdlfyFs7XhiiskPxt0BABAjXXkiFS/ftVvbdtKffpIvXtLe/eaY+/da5736WNer8rxPRFujrNnzx59/PHHatWqVakn6DExMQoKOrFr4M8995xLaJDMCX1WVpYmTpxYYoDyVVddpU6dOmm2M2xVQHR0dKmBZvjw4YqIiNA333xT4WMlJibqvvvuc9k2YsQISdKqVasqfBxPocXBH2RlSXPmmMcMigYAADXA6tWrZVmWBgwYoDp16pS774wZM7Rt2zaXbUOGDFGHDh0Kn4eGhuqMM84o8bUrVqwovP/zzz9LvH7s2DFlZGQoIyOjwoOY586dqzfeeENr167VX3/9pfz8/MLXdu/eXaFjSFL79u0VEOB6nT8uLk6SWeDY2wgO/mDWLHMloE0bqWdPu6sBAAAVVbeudOiQZ461fr1pYTje999LxU6wK6Vu3ap9fSmcJ8bNmjVzu++MGTO0ZMkSl20tWrRwCQ7R0dFylNKdav/+/ZKk1157rdz3OHz4cIWCwwsvvKB7771XUVFRGjRokOLi4gpbOSZNmqTs7Gy3x3AqbSyEs5WleBjxFoKDPyg+KLoa+h8CAIBq4nB4bt0lZxedgACpoKDoPizMJ9d2cg563rVrl9t9i89IVJbSQoOkwpWSf/75Z7Vr167C9ZUmLy9Pjz/+uJo2bar169crKiqq8DXLsvTss89W6fh2Y4xDbbdunbRmjRQcLA0fbnc1AADALtHRUmyslJQkvf66uY+NNdt9UOfOnRUQEKBFixZVeNrVyujWrZskafny5RXaPzAwUFLpV/wzMjKUmZmp7t27u4QGyXS9Onr0aBWrtRfBobZzrhQ9dKhUQxYXAQAA1SAuTtq2TVq5UrrtNnO/bZvZ7oNiYmJ06aWXavPmzRo/fnyJ19PT05WXl1fl97nxxhsVHh6uhx9+WBs3bizx+pEjRwrHQUhSw4YN5XA4tHPnzhL7RkdHKywsTGvXrtWRYgPG//rrL911111VrtVudFWqzY4ckT74wDxmUDQAAAgJKXrscLg+90FTpkzRL7/8oieffFLz5s3TwIEDZVmWfv/9dy1YsEB79uyp8DoOZYmKitKsWbN0+eWXq3379jrvvPN02mmn6dixY9q+fbuWLFminj176uuvv5Yk1a9fX126dFFycrJuvPFGtW7dWgEBAbr66qvVvHlz3X777XrhhRfUvn17XXjhhcrKytJXX32lhIQENW3a1AP/KvYhONRmH38sZWZKiYlmhUgAAIAapHHjxlqxYoWef/55ffTRR5o8ebJCQ0OVmJioBx54QPU8NDbjggsu0Lp16/Tcc8/pm2++0cKFC1WvXj3FxcXpxhtv1LXXXuuy//vvv68xY8bov//9rzIzM2VZlrp3767mzZtr4sSJatSokWbMmKEpU6YoJiZGV155pcaPH1/lMRR2c1iWZdldRE2QlZWlyMhIZWZmFg6i8Xl9+piZEp58UnroIburAQAAZTh27Ji2bt2qxMREhYaG2l0OaomKfl9V9DyXMQ611f/+Z0JDYKB0ww12VwMAAIAajuBQWzkHRV9wgVTD+9MBAADAfgSH2ig7W3r3XfOYQdEAAADwAIJDbfT551JGhmlpGDzY7moAAABQCxAcaiPnStE33SQFMXEWAAAAqo7gUNts3SotXGge33STvbUAAACg1iA41DZvv23uzznHrN8AAAAAeADBoTbJyysKDgyKBgAAgAcRHGqTr7+Wdu+WGjeWLr7Y7moAAABQixAcahPnoOjrr5dCQuytBQAAALUKwaG22L1b+vJL83jECHtrAQAAQK1DcKgtZsyQ8vOl3r2lNm3srgYAAAC1DMGhNigokN56yzxmUDQAAACqAcGhNli0yKzfEBkpXX653dUAAACcsG3btsnhcOiGG26wu5QT0qJFC7Vo0cLuMryC4FAbOAdFX3ONVLeuvbUAAACgVgqyuwBUUUaG9Omn5jHdlAAAQA3VrFkz/frrr4qMjLS7FJSB4FDTvf++lJMjJSVJHTvaXQ0AAPBh+fnS0qVSaqrUpInUp48UGGh3VUadOnV02mmn2V0GykFXpZrMsoq6KdHaAAAAyjF3rtSihTRggHT11ea+RQuz3ReUNcbh4MGDmjBhgs4880zVq1dPkZGR6tixox599FHl5uaWe8z33ntPDodDjz/+eKmv//DDD3I4HBpRbCr7RYsW6aabbtKpp56q+vXrq379+urcubOmTZtW5c9Y0xEcarLly6VffzXjGq6+2u5qAACAj5o7V7rsMmnnTtftu3aZ7b4SHo6XkZGh7t2767HHHlNgYKBGjhypm266SbGxsXrmmWd0+PDhcr/+kksuUd26dfXBBx+U+vrMmTMlScOHDy/c9swzzyg5OVldunTRnXfeqWuvvVYZGRm67bbbdM8993juw9VAdFWqyZytDcOGSRER9tYCAAA8zrKkI0eqdoz8fOnuu82xSju+wyGNGiWdfXbluy3VrWuO42m33367Nm3apIceekhPPvmky2t79uxR/fr1y/36+vXra+jQofrggw+0atUq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66+/dtn/wQcftCRZI0aMcNnetWtXS5I1bdq0ErWmpKQUPt66dWthLU8//bTLfo888oglyZo4ceIJ/EsAgP+ixQEA4NaoUaP0yiuvaOnSperdu7fLawUFBYqNjVXz5s21evXqwhaHU089Vb/++qscDkfhvkePHlVCQoIOHTqkAwcOKDg4WEuXLlXfvn01ePBgzZs3z+XYhw8fVkJCgo4cOVK4/6pVq9S1a1f17dtXS5YsKbduZ4tDYmKi/vzzTwUEBJR47ZJLLtEnn3zigX8lAKjdguwuAADg+1asWCFJ+vrrr/XNN9+UeL1OnTr63//+57KtV69eLqFBksLCwpSUlKSvv/5av//+u9q1a6d169ZJkvr371/iuPXq1VPnzp01f/78wv1//PFHSdKgQYMqXH/79u1dQoMkxcXFSZIOHDhQ4eMAgD8jOAAA3HKOGXjyyScr/DXR0dGlbneOJ8jMzJQkZWVluWw/XmxsrMv+zhP9Zs2aVbiWyMjIEtuCgsyfwPz8/AofBwD8GbMqAQDcioiIkGRO8i3LKvNWXHp6eqnH2rNnj6Sik3nnsZ3by9rfuV+DBg0kSbt27arCJwIAnCiCAwDArW7dukkq6rJUET/88EOJMHH06FGtWbNGYWFhOuWUUyRJHTt2lGSmcT3ekSNHtHr1aoWFhenUU0+VJHXt2lWStGDBghP+HACAyiM4AADcuv322xUUFKS77rpLKSkpJV4/cOBA4VgFp99++01vv/22y7bnnntOe/fu1VVXXaXg4GBJZixEq1at9NVXX5UYPzFx4kRlZGS47N+lSxd17dpVycnJevPNN0vUQksEAFQPxjgAANxq166dpkyZon/+85869dRTdf7556tVq1bKysrSli1btGTJEt1www16/fXXC79m0KBBuv322/Xll1+WWMfhqaeeKtwvICBAM2bM0Lnnnqvzzz9fl19+uRISErRy5Up99913atWqlZ5++mmXembOnKn+/fvr1ltv1fvvv68ePXro2LFj2rhxo9atW6d9+/Z57d8GAPwFLQ4AgAq55ZZbtHz5cl188cVavny5XnrpJX388cfKyMjQmDFjNHr0aJf9e/TooYULFyojI0Mvv/yyVq5cqSuvvFI//PBDiYHQvXv31ooVK3TxxRdrwYIFev7557V582bdfffdWrFihaKiolz2b926tdauXatRo0Zp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srKyFBkZ6fY8t1aMcThRTZo0UUJCgv74448y9wkJCVFISIgXqwIAAAB8l190VTrevn37lJKSoiZNmthdCgAAAFAj1IoWh0OHDunPP/8sfL5161atX79ejRo1UqNGjTRu3DhdeumlatKkibZt26aHHnpIjRs31tChQ22sGgAAAKg5akVwWL16tQYMGFD4fOzYsZKk66+/XlOnTtXPP/+s9957TwcOHFCTJk00YMAAzZkzR+Hh4XaVDAAAANQotW5wdHWp6KARAAAAoCap6HmuX45xAAAAAHBiCA4AAAAA3CI4AAAAAHCL4AAAAADALYIDAAAAALcIDgAAAADcIjgAAAAAcMurwWHChAmaOXOmN98SAAAAgAd4NTg88cQT+vnnn735lgAAAAA8wKvBISEhQfv37/fmWwIAAADwAK8Gh6uuukrz589XZmamN98WAAAAQBV5NTg88sgjOvPMMzVw4EB9+eWXSk9P9+bbAwAAAKikIG++WVhYmCTJsixddNFFZe7ncDiUl5fnrbIAAAAAuOHV4NCnTx85HA5vviUAAAAAD/BqcFi8eLE33w4AAACAh7AAHAAAAAC3vNriUNyuXbu0YcMGZWZmKiIiQh06dFCzZs3sKgcAAABAObweHLZs2aKRI0fq22+/LfHaWWedpSlTpujkk0/2dlkAAAAAyuHV4LBz50716tVLe/bsUZs2bdS3b1/FxsZqz549Wrp0qb755hv16dNHP/74o+Lj471ZGgAAAIByeDU4jBs3Tnv27NG0adN08803l3h9+vTpuvXWWzVhwgS9+eab3iwNAAAAQDkclmVZ3nqz+Ph4JSUl6b///W+Z+wwZMkSrV6/Wzp07vVVWhWRlZSkyMrJwTAYAAABQG1T0PNersyqlp6fr9NNPL3ef008/XXv37vVSRQAAAAAqwqvBISoqShs3bix3n02bNikqKspLFQEAAACoCK8Gh3PPPVdffPGFpk+fXurrb7/9tr744gudd9553iwLAAAAgBteHeOQkpKizp07KyMjQ23btlW/fv0UExOjPXv2KDk5WRs3blTjxo21evVqn5tViTEOAAAAqI0qep7r1VmV4uPj9f3332vkyJFatGhRiW5LAwYM0NSpU30uNAAAAAD+zusLwLVu3Vrffvutdu7cqXXr1ikrK6tw5WgCAwAAAOCbvBocBg4cqN69e2vChAmK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aCjefvtt/P777+jWrRvKysoQHx+Ps2fPIjs7W2vfGyIiY8EWByIiapC33noLJ0+exPDhw3Hy5El89dVX2LZtG+7du4epU6diypQpKud369YNBw4cwL1797Bq1SqcPn0a48aNw/Hjx2sMhO7ZsydOnTqF4cOHIyIiAitWrEBSUhI++OADnDp1Co0aNVI5PyAgAHFxcZg8eTLS09Px9ddfY8OGDSgqKsLHH3+s6W8FEZFR4joORESkVtXrOCxYsAALFy4UuxwiIlITtjgQEREREVG9GByIiIiIiKheDA5ERERERFQvjnEgIiIiIqJ6scWBiIiIiIjqxeBARERERET1YnAgIiIiIqJ6MTgQEREREVG9GByIiIiIiKheDA5ERERERFQvBgciIiIiIqoXgwMREREREdWLwYGIiIiIiOrF4EBERERERPVicCAiIiIionoxOBARERERUb0YHIiIiIiIqF4MDkREREREVC8GByIiIiIiqheDAxERERER1YvBgYiIiIiI6mUqdgH6QqFQ4Pbt27C1tYVEIhG7HCIiIiIitRAEAYWFhfD09IRUWne7AoNDA92+fRteXl5il0FEREREpBFpaWlo0qRJnccZHBrI1tYWwP1vqJ2dncjVEBERERGpR0FBAby8vJT3u3VhcGig6u5JdnZ2DA5EREREZHDq647PwdFERERERFQvBgciIiIiIqoXgwMREREREdWLwYGIiIiIiOrF4EBERERERPVicCAiIiIionoxOBARERERUb0YHIiIiIiIqF4MDqTzIiMj0bp1a0RGRopdChEREZHRYnAgnSYIAubOnYuEhATMnTsXgiCIXRIRERGRUWJwIJ0WERGBmJgYAEBMTAwiIiJEroiIiIjIODE4kM4SBAHz5s2DRCIBAEgkEsyZM4etDkREREQiYHAgnVXd2lAdFARBwNmzZzFhwgRUVFSIXB0RERGRcWFwIJ1U3dpgYmJS49jatWvRunVr7Nixg60PRERERFrC4EA6qbq1QS6X13o8KSkJo0aNQp8+fZRjIIiIiIhIcxgcSOdUtzZIpbX/eEqlUnh4eMDCwgJHjx5F586d8dJLLyE1NVXLlRIREREZDwYH0jkVFRVITU2FQqGo9bhCoYAgCLh06RJeeeUVAMDGjRvRokULfPTRRygsLNRmuURERERGgcGBdI5MJkNMTAxiY2PRsmVL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us7g+AYiIiIiaii9DQ67d+8GAOzfvx/79++vcbx6XbuWLVvi8OHDmDVrFkaPHg1TU1P069cPK1asQKNGjbRas655cCpWIiIiIqJH0duVo7XN0FaOzs7OhouLCwAgNze3zkHiRERERGTYDH7laHo61eMbAgICGBqIiIiIqF4MDkaKA6OJiIiI6HEwOBgpDowmIiIiosfB4GCk2OJARERERI+DwcEI3blzB+np6ZBKpejQoYPY5RARERGRHmBwMELVrQ2tW7eGtbW1yNUQERERkT5gcDBCHN9ARERERI+LwcEIceE3IiIiInpcDA5GRhAEDowmIiIiosfG4GBkbt68iXv37sHMzAxBQUFil0NEREREeoLBwchUtzYEBQVBJpOJXA0RERER6QsGByPDgdFERERE9CQYHIwMxzcQERER0ZNgcDAiCoVCGRzY4kBEREREj4PBwYhcv34dBQUFsLCwQJs2bcQuh4iIiIj0CIODEalubejQoQNMTU1FroaIiIiI9AmDgxHhwm9ERERE9KQYHIwIB0YTERER0ZNicDASVVVViIuLA8CB0URERET0+BgcjERCQgJKS0tha2uL5s2bi10OEREREekZBgcjUT2+ITg4GFIp33YiIiIiejy8gzQSHN9ARERERE+DwcFIVLc4cHwDERERET0JBgcjUF5ejvPnzwNgiwMRERERPRkGByNw8eJFVFZWwtnZGb6+vmKXQ0RERER6iMHBCDzYTUkikYhcDRERERHpIwYHI8CB0URERET0tBgcjAAHRhMRERHR02JwMHAlJSWIj48HwBYHIiIiInpyDA4G7uzZs1AoFPDw8ICnp6fY5RARERGRnmJwMHDV3ZTY2kBERERET4PBwcBVD4zm+AYiIiIiehoMDgaOLQ5EREREpA4MDgYsPz8f165dA8AWByIiIiJ6OgwOBiw2NhYA4OvrCxcXF5GrISIiIiJ9xuBgwLjwGxERERGpC4ODAePCb0RERESkLgwOBowtDkRERESkLgwOBiorKwspKSkAgI4dO4pbDBERERHpPQYHA1Xd2tCiRQvY29uLXA0RERER6TsGBwPFbkpEREREpE4MDgaKA6OJiIiISJ30NjgUFhZi5syZGDhwIBo1agSJRIKFCxfWem5cXBz69+8PGxsbODg4YOTIkUhOTtZuwVrGFgciIiIiUie9DQ7Z2dlYu3Yt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wWCrAxERERFpm8EHB2dn51pbFXJycgCg1tYIAJDJZLCzs1PZtC0iIgIxMTGQy+Uq+9nqQERERETaZvDBoW3btkhISEBVVZXK/osXLwIAAgMDxSirXtWtDVJp7W+RVCplqwMRERERaY3BB4fnnnsORUVF2L59u8r+X3/9FZ6enujSpYtIlT1aRUUFUlNToVAoaj2uUCiQlpaGiooKLVdGRERERMbI4BeAGzRoEAYMGIB3330XBQUFaNasGTZv3oz9+/djw4YNDVrDQQwymQwxMTHIysqq8xxXV1fIZDItVkVERERExsrgF4ADgKKiInz00UfYsmULcnJy0LJlS8yZMwfjxo1r8DXEXACOiIiIiEhTGnqfaxTBQR0YHIiIiIjIEHHlaCIiIiIiUhsGByIiIiIiqheDAxERERER1YvBgYiIiIiI6sXgQERERERE9WJwICIiIiKiehn8AnDqUj1rbUFBgciVEBERERGpT/X9bX2rNDA4NFBhYSEAwMvLS+RKiIiIiIjUr7CwEPb29nUe5wJwDaRQKHD79m3Y2tpCIpFo/fkLCgrg5eWFtLQ0LkBnZPjeGy++98aJ77vx4ntvvMR+7wVBQGFhITw9PSGV1j2SgS0ODSSVStGkSROxy4CdnR3/MzFSfO+NF99748T33XjxvTdeYr73j2ppqMbB0UREREREVC8GByIiIiIiqheDg56QyWRYsGABZDKZ2KWQlvG9N158740T33fjxffeeOnLe8/B0UREREREVC+2OBARERERUb0YHIiIiIiIqF4MDkREREREVC8GByIiIiIiqheDg44rKirClClT4OnpCQsLC7Rv3x7h4eFil0UadujQIbzxxhto2bIlrK2t0bhxYwwfPhyxsbFil0Za9tNPP0EikcDGxkbsUkgLjh07hsGDB8PR0RGWlpYICAjAp59+KnZZpGFnz57FiBEj4OnpCSsrK7Rs2RKffPIJSkpKxC6N1KSwsBAzZ87EwIED0ahRI0gkEixcuLDWc+Pi4tC/f3/Y2NjAwcEBI0eORHJysnYLrgODg44bOXIkfv31VyxYsAD79u1DSEgIxo8fj02bNoldGmnQDz/8gJSUFEyePBl79+7FqlWrkJmZia5du+LQoUNil0dakp6ejunTp8PT01PsUkgLNm3ahD59+sDe3h6//fYb9u7di1mzZoGTHxq2y5cvo3v3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",
      "text/plain": [
       "<Figure size 900x1500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "fig, ax = plt.subplots(3,1,figsize=(9,15))\n",
    "indices = list(range(0,len(ic_rs)))\n",
    "ax[0].plot(indices, ic_rs, marker='*', color='red', alpha=1, label='ic-retain')\n",
    "ax[0].plot(indices, ic_vs, marker='o', color='blue', alpha=1, label='ic-val')\n",
    "ax[1].plot(indices, acc_rs, marker='*', color='green', alpha=1, label='acc-retain')\n",
    "ax[1].plot(indices, acc_vs, marker='o', color='brown', alpha=1, label='acc-valid')\n",
    "ax[2].plot(indices, acc_fs, marker='^', color='black', alpha=1, label='acc-forget')\n",
    "ax[0].legend(prop={'size': 14})\n",
    "ax[1].legend(prop={'size': 14})\n",
    "plt.tick_params(labelsize=12)\n",
    "ax[0].set_xlabel('epoch',size=14)\n",
    "ax[0].set_ylabel('error',size=14)\n",
    "ax[1].set_xlabel('epoch',size=14)\n",
    "ax[1].set_ylabel('error',size=14)\n",
    "fig.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Finetune"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_ft = copy.deepcopy(model)\n",
    "args.ft_bs = 64\n",
    "retain_loader = replace_loader_dataset(train_loader_full,retain_dataset, seed=seed, batch_size=args.ft_bs, shuffle=True)  \n",
    "finetune(model_ft, retain_loader, epochs=10, quiet=True, lr=0.01)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Negative Gradient"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.ng_alpha = 0.9999\n",
    "args.ng_epochs = 10\n",
    "args.ng_lr = 0.01\n",
    "model_ng = copy.deepcopy(model)\n",
    "args.ng_bs = 128\n",
    "retain_loader = replace_loader_dataset(train_loader_full,retain_dataset, seed=seed, batch_size=args.ng_bs, shuffle=True)\n",
    "negative_grad(model_ng, retain_loader, forget_loader, alpha=args.ng_alpha, epochs=args.ng_epochs, quiet=True, lr=args.ng_lr, args=args)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Catastrophic Forgetting k layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.lr_decay_epochs = [10,15,20]\n",
    "args.cfk_lr = 0.01\n",
    "args.cfk_epochs = 10\n",
    "args.cfk_bs = 128\n",
    "retain_loader = replace_loader_dataset(train_loader_full,retain_dataset, seed=seed, batch_size=args.cfk_bs, shuffle=True)\n",
    "\n",
    "model_cfk = copy.deepcopy(model)\n",
    "\n",
    "for param in model_cfk.parameters():\n",
    "    param.requires_grad_(False)\n",
    "\n",
    "if args.model == 'allcnn':\n",
    "    layers = [9]\n",
    "    for k in layers:\n",
    "        for param in model_cfk.features[k].parameters():\n",
    "            param.requires_grad_(True)\n",
    "    \n",
    "elif args.model == \"resnet\":\n",
    "    for param in model_cfk.layer4.parameters():\n",
    "        param.requires_grad_(True)\n",
    "\n",
    "else:\n",
    "    raise NotImplementedError\n",
    "\n",
    "\n",
    "\n",
    "fk_fientune(model_cfk, retain_loader, args=args, epochs=args.cfk_epochs, quiet=True, lr=args.cfk_lr)\n",
    "cfk_time = t2-t1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Exact Unlearning k layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.lr_decay_epochs = [10,15,20]\n",
    "args.euk_lr = 0.01\n",
    "args.euk_epochs = training_epochs\n",
    "args.euk_bs = 64\n",
    "retain_loader = replace_loader_dataset(train_loader_full,retain_dataset, seed=seed, batch_size=args.euk_bs, shuffle=True)\n",
    "model_euk = copy.deepcopy(model)\n",
    "\n",
    "for param in model_euk.parameters():\n",
    "    param.requires_grad_(False)\n",
    "\n",
    "if args.model == 'allcnn':\n",
    "    with torch.no_grad():\n",
    "        for k in layers:\n",
    "            for i in range(0,3):\n",
    "                try:\n",
    "                    model_euk.features[k][i].weight.copy_(model_initial.features[k][i].weight)\n",
    "                except:\n",
    "                    print (\"block {}, layer {} does not have weights\".format(k,i))\n",
    "                try:\n",
    "                    model_euk.features[k][i].bias.copy_(model_initial.features[k][i].bias)\n",
    "                except:\n",
    "                    print (\"block {}, layer {} does not have bias\".format(k,i))\n",
    "        model_euk.classifier[0].weight.copy_(model_initial.classifier[0].weight)\n",
    "        model_euk.classifier[0].bias.copy_(model_initial.classifier[0].bias)\n",
    "    \n",
    "    for k in layers:\n",
    "        for param in model_euk.features[k].parameters():\n",
    "            param.requires_grad_(True)\n",
    "    \n",
    "elif args.model == \"resnet\":\n",
    "    with torch.no_grad():\n",
    "        for i in range(0,2):\n",
    "            try:\n",
    "                model_euk.layer4[i].bn1.weight.copy_(model_initial.layer4[i].bn1.weight)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have weight\".format(i))\n",
    "            try:\n",
    "                model_euk.layer4[i].bn1.bias.copy_(model_initial.layer4[i].bn1.bias)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have bias\".format(i))\n",
    "            try:\n",
    "                model_euk.layer4[i].conv1.weight.copy_(model_initial.layer4[i].conv1.weight)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have weight\".format(i))\n",
    "            try:\n",
    "                model_euk.layer4[i].conv1.bias.copy_(model_initial.layer4[i].conv1.bias)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have bias\".format(i))\n",
    "\n",
    "            try:\n",
    "                model_euk.layer4[i].bn2.weight.copy_(model_initial.layer4[i].bn2.weight)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have weight\".format(i))\n",
    "            try:\n",
    "                model_euk.layer4[i].bn2.bias.copy_(model_initial.layer4[i].bn2.bias)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have bias\".format(i))\n",
    "            try:\n",
    "                model_euk.layer4[i].conv2.weight.copy_(model_initial.layer4[i].conv2.weight)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have weight\".format(i))\n",
    "            try:\n",
    "                model_euk.layer4[i].conv2.bias.copy_(model_initial.layer4[i].conv2.bias)\n",
    "            except:\n",
    "                print (\"block 4, layer {} does not have bias\".format(i))\n",
    "\n",
    "        model_euk.layer4[0].shortcut[0].weight.copy_(model_initial.layer4[0].shortcut[0].weight)\n",
    "        \n",
    "    for param in model_euk.layer4.parameters():\n",
    "        param.requires_grad_(True)\n",
    "\n",
    "else:\n",
    "    raise NotImplementedError\n",
    "\n",
    "fk_fientune(model_euk, retain_loader, epochs=args.euk_epochs, quiet=True, lr=args.euk_lr, args=args)\n",
    "euk_time = t2-t1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Readouts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_loader_full, valid_loader_full, test_loader_full = datasets.get_loaders(dataset, split=\"train\",confuse_mode=True,class_to_replace=class_to_forget, num_indexes_to_replace=num_to_forget, batch_size=args.batch_size, seed=seed, root=args.dataroot, augment=False, shuffle=True)\n",
    "marked_loader, _, _ = datasets.get_loaders(dataset, split=\"forget\", confuse_mode=True,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": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "try: readouts\n",
    "except: readouts = {}\n",
    "\n",
    "#_,_=activations_predictions(copy.deepcopy(model),forget_loader,'Original_Model_D_f')\n",
    "#thresh=log_dict['Original_Model_D_f_loss']+1e-5\n",
    "#print(thresh)\n",
    "readouts[\"a\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model),thresh=None,name='Original')\n",
    "readouts[\"b\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model0),thresh=None,name='Retrain')\n",
    "readouts[\"c\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model_ft),thresh=None,name='Finetune')\n",
    "readouts[\"d\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model_ng),thresh=None,name='NegGrad')\n",
    "readouts[\"e\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model_cfk),thresh=None,name='CF-k')\n",
    "readouts[\"f\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model_euk),thresh=None,name='EU-k')\n",
    "readouts[\"h\"] = all_readouts(test_loader_full, retain_loader, forget_loader, copy.deepcopy(model_s),thresh=None,name='SCRUB')"
   ]
  }
 ],
 "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
