{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\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 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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def pdb():\n",
    "    import pdb\n",
    "    pdb.set_trace"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 5,
   "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": 6,
   "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": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Activations along the path\n",
    "from sklearn.svm import SVC\n",
    "from sklearn.metrics import accuracy_score\n",
    "import datasets\n",
    "\n",
    "def perf_measure(y_actual, y_hat):\n",
    "    TP = 0\n",
    "    FP = 0\n",
    "    TN = 0\n",
    "    FN = 0\n",
    "\n",
    "    for i in range(len(y_hat)): \n",
    "        if y_actual[i]==y_hat[i]==1:\n",
    "           TP += 1\n",
    "        if y_hat[i]==1 and y_actual[i]!=y_hat[i]:\n",
    "           FP += 1\n",
    "        if y_actual[i]==y_hat[i]==0:\n",
    "           TN += 1\n",
    "        if y_hat[i]==0 and y_actual[i]!=y_hat[i]:\n",
    "           FN += 1\n",
    "\n",
    "    return TP, FP, TN, FN\n",
    "\n",
    "def entropy(p, dim = -1, keepdim = False):\n",
    "    return -torch.where(p > 0, p * p.log(), p.new([0.0])).sum(dim=dim, keepdim=keepdim)\n",
    "    #return (p * p.log()).sum(dim=dim, keepdim=keepdim)\n",
    "\n",
    "def collect_prob(data_loader, model):\n",
    "    data_loader = torch.utils.data.DataLoader(data_loader.dataset, batch_size=1, shuffle=False)\n",
    "    sampler = torch.utils.data.RandomSampler(data_loader.dataset, replacement=False, num_samples=4000)\n",
    "    data_loader_small = torch.utils.data.DataLoader(data_loader.dataset, batch_size=1, sampler=sampler, shuffle=False)\n",
    "    prob = []\n",
    "    with torch.no_grad():\n",
    "        for idx, batch in enumerate(tqdm(data_loader_small, leave=False)):\n",
    "            batch = [tensor.to(next(model.parameters()).device) for tensor in batch]\n",
    "            data, target = batch\n",
    "            output = model(data)\n",
    "            prob.append(F.softmax(output, dim=-1).data)\n",
    "    return torch.cat(prob)\n",
    "\n",
    "def get_membership_attack_data(retain_loader, forget_loader, test_loader, model):    \n",
    "    retain_prob = collect_prob(retain_loader, model)\n",
    "    forget_prob = collect_prob(forget_loader, model)\n",
    "    test_prob = collect_prob(test_loader, model)\n",
    "    \n",
    "    X_r = torch.cat([entropy(retain_prob), entropy(test_prob)]).cpu().numpy().reshape(-1, 1)\n",
    "    Y_r = np.concatenate([np.ones(len(retain_prob)), np.zeros(len(test_prob))])\n",
    "    \n",
    "    X_f = entropy(forget_prob).cpu().numpy().reshape(-1, 1)\n",
    "    Y_f = np.concatenate([np.ones(len(forget_prob))])    \n",
    "    return X_f, Y_f, X_r, Y_r\n",
    "\n",
    "def get_membership_attack_prob(retain_loader, forget_loader, test_loader, model):\n",
    "    X_f, Y_f, X_r, Y_r = get_membership_attack_data(retain_loader, forget_loader, test_loader, model)\n",
    "    #clf = SVC(C=3,gamma='auto',kernel='rbf')\n",
    "    clf = LogisticRegression(class_weight='balanced',solver='lbfgs',multi_class='multinomial')\n",
    "    clf.fit(X_r, Y_r)\n",
    "    results = clf.predict(X_f)\n",
    "    results1 = clf.predict(X_r)\n",
    "    acc = accuracy_score(results, Y_f)\n",
    "    train_ac = accuracy_score(results1, Y_r)\n",
    "    TP, FP, TN, FN = perf_measure(Y_r, results1)\n",
    "    FPR = FP/(FP+TN)\n",
    "    FNR = FN/(FN+TP)\n",
    "    \n",
    "    print (f\"TP:{TP}, FP{FP}, TN{TN}, FN{FN}\")\n",
    "    print (f\"false negative rate: {FN/(FN+TP)}\")\n",
    "    print (f\"false positive rate: {FP/(FP+TN)}\")\n",
    "    return acc, train_acc, FPR, FNR #results.mean(), results1.mean()\n",
    "    \n",
    "def plot_entropy_dist(model,retain_loader,forget_loader,test_loader_full, title, ax):\n",
    "    import matplotlib.pyplot as plt\n",
    "    import seaborn as sns\n",
    "    from matplotlib.ticker import FuncFormatter\n",
    "    #train_loader_full, valid_loader_full, test_loader_full = datasets.get_loaders(dataset, batch_size=100, seed=0, augment=False, shuffle=False)\n",
    "    #indexes = np.flatnonzero(np.array(train_loader_full.dataset.targets) == class_to_forget)\n",
    "    #replaced = np.random.RandomState(0).choice(indexes, size=100 if num_to_forget==100 else len(indexes), replace=False)\n",
    "    X_f, Y_f, X_r, Y_r = get_membership_attack_data(retain_loader,forget_loader,test_loader_full, model)\n",
    "    #np.savetxt('retain_prob.txt', X_r[Y_r==1])\n",
    "    #np.savetxt('forget_prob.txt', X_f)\n",
    "    #np.savetxt('test_prob.txt', X_r[Y_r==0])\n",
    "    sns.distplot(np.log(X_r[Y_r==1]).reshape(-1), kde=False, norm_hist=True, rug=False, label='retain', ax=plt)\n",
    "    sns.distplot(np.log(X_r[Y_r==0]).reshape(-1), kde=False, norm_hist=True, rug=False, label='test', ax=plt)\n",
    "    sns.distplot(np.log(X_f).reshape(-1), kde=False, norm_hist=True, rug=False, label='forget', ax=plt)\n",
    "    plt.legend(prop={'size': 14})\n",
    "    plt.tick_params(labelsize=12)\n",
    "    plt.title(title,size=18)\n",
    "    plt.xlabel('Log of Entropy',size=14)\n",
    "    plt.show()\n",
    "    plt.clf()\n",
    "\n",
    "\n",
    "def membership_attack(retain_loader,forget_loader,test_loader,model, name):\n",
    "    prob, train_acc, FPR, FNR = get_membership_attack_prob(retain_loader,forget_loader,test_loader,model)\n",
    "    print(\"Attack prob: \", prob)\n",
    "    return prob"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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=512, 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=512, 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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def activations_predictions(model,dataloader,name):\n",
    "    criterion = torch.nn.CrossEntropyLoss()\n",
    "    metrics=get_metrics(model,dataloader,criterion,False)\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",
    "    return _,_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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)\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 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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "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(model,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.01, threshold=thresh)\n",
    "    test_error = test(model, test_loader_full)['error']\n",
    "    forget_error = test(model, forget_loader)['error']\n",
    "    retain_error = test(model, retain_loader)['error']\n",
    "    print(f\"{name} ->\"\n",
    "          f\"\\tFull test error: {test_error:.2%}\"\n",
    "          f\"\\tForget error: {forget_error:.2%}\\tRetain error: {retain_error:.2%}\"\n",
    "          f\"\\tFine-tune time: {retrain_time+1} steps\")\n",
    "    #print(f\"{name} ->\"\n",
    "    #      f\"\\tFine-tune time: {retrain_time+1} steps\")\n",
    "    log_dict[f\"{name}_retrain_time\"]=retrain_time+1\n",
    "    return(dict(test_error=test_error, forget_error=forget_error, retain_error=retain_error, retrain_time=retrain_time))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_activations(model_scrubf, modelf0, delta_w_s, delta_w_m0, data_loader, \\\n",
    "                    loss_fn=nn.CrossEntropyLoss(),\\\n",
    "                    optimizer=torch.optim.SGD, \\\n",
    "                    seed=1,quiet=False):\n",
    "\n",
    "    model_scrubf.eval()\n",
    "    modelf0.eval()\n",
    "    \n",
    "    data_loader = torch.utils.data.DataLoader(data_loader.dataset, batch_size=1, shuffle=False)\n",
    "\n",
    "    \n",
    "    metrics = AverageMeter()    \n",
    "    num_classes = data_loader.dataset.targets.max().item() + 1\n",
    "    \n",
    "    for idx, batch in enumerate(tqdm(data_loader, leave=False)):\n",
    "        batch = [tensor.to(next(model_scrubf.parameters()).device) for tensor in batch]\n",
    "        input, target = batch\n",
    "        \n",
    "        output_sf = model_scrubf(input)\n",
    "        G_sf = []\n",
    "\n",
    "        for cls in range(num_classes):\n",
    "            grads = torch.autograd.grad(output_sf[0,cls],model_scrubf.parameters(),retain_graph=True)\n",
    "            grads = torch.cat([g.view(-1) for g in grads])\n",
    "            G_sf.append(grads)\n",
    "\n",
    "        grads = torch.autograd.grad(output_sf[0,cls],model_scrubf.parameters(),retain_graph=False)\n",
    "            \n",
    "        G_sf = torch.stack(G_sf)#.pow(2)\n",
    "        delta_f_sf_update = torch.matmul(G_sf,delta_w_s.sqrt()*torch.empty_like(delta_w_s).normal_())\n",
    "        G_sf = G_sf.pow(2)\n",
    "        delta_f_sf = torch.matmul(G_sf,delta_w_s)\n",
    "\n",
    "        output_m0 = modelf0(input)\n",
    "        G_m0 = []\n",
    "\n",
    "        for cls in range(num_classes):\n",
    "            grads = torch.autograd.grad(output_m0[0,cls],modelf0.parameters(),retain_graph=True)\n",
    "            grad_m0 = torch.cat([g.view(-1) for g in grads])\n",
    "            G_m0.append(grad_m0)\n",
    "\n",
    "        grads = torch.autograd.grad(output_m0[0,cls],modelf0.parameters(),retain_graph=False)\n",
    "            \n",
    "        G_m0 = torch.stack(G_m0).pow(2)\n",
    "        delta_f_m0 = torch.matmul(G_m0,delta_w_m0)\n",
    "        \n",
    "        kl = ((output_m0 - output_sf).pow(2)/delta_f_m0 + delta_f_sf/delta_f_m0 - torch.log(delta_f_sf/delta_f_m0) - 1).sum()\n",
    "        \n",
    "        torch.manual_seed(seed)\n",
    "        output_sf += delta_f_sf_update#delta_f_sf.sqrt()*torch.empty_like(delta_f_sf).normal_()\n",
    "        \n",
    "        loss = loss_fn(output_sf, target)\n",
    "        metrics.update(n=input.size(0), loss=loss.item(), error=get_error(output_sf, target), kl=kl.item())\n",
    "    \n",
    "    return metrics.avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "torch.cuda.is_available()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Pre-training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: lacuna100_resnet_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in lacuna100_resnet_1_0_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.987484888076782, \"error\": 0.923}\n",
      "Learning Rate : 0.1\n",
      "[0] dry_run metrics:{\"loss\": 3.395326801300049, \"error\": 0.83653125}\n",
      "Learning Rate : 0.1\n",
      "[0] test metrics:{\"loss\": 3.4219942169189452, \"error\": 0.8447}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 10.8 sec\n",
      "[1] train metrics:{\"loss\": 3.1922737522125244, \"error\": 0.78334375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.56 sec\n",
      "[2] train metrics:{\"loss\": 2.6385717277526854, \"error\": 0.63821875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.53 sec\n",
      "[3] train metrics:{\"loss\": 2.220917667865753, \"error\": 0.51859375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.45 sec\n",
      "[4] train metrics:{\"loss\": 1.9556603002548218, \"error\": 0.41671875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.41 sec\n",
      "[5] train metrics:{\"loss\": 1.722495491027832, \"error\": 0.32259375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.43 sec\n",
      "[6] train metrics:{\"loss\": 1.5956408495903016, \"error\": 0.26075}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.39 sec\n",
      "[7] train metrics:{\"loss\": 1.567377972126007, \"error\": 0.22371875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.47 sec\n",
      "[8] train metrics:{\"loss\": 1.5533827967643739, \"error\": 0.1940625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.37 sec\n",
      "[9] train metrics:{\"loss\": 1.523199393749237, \"error\": 0.16503125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.52 sec\n",
      "[10] train metrics:{\"loss\": 1.531425853729248, \"error\": 0.150625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.59 sec\n",
      "[11] train metrics:{\"loss\": 1.521689467906952, \"error\": 0.1343125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.37 sec\n",
      "[12] train metrics:{\"loss\": 1.5069730429649353, \"error\": 0.1225625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.47 sec\n",
      "[13] train metrics:{\"loss\": 1.5114346590042114, \"error\": 0.12234375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.53 sec\n",
      "[14] train metrics:{\"loss\": 1.517757547855377, \"error\": 0.1201875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 6.53 sec\n",
      "[15] train metrics:{\"loss\": 1.5435997090339661, \"error\": 0.1189375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.45 sec\n",
      "[16] train metrics:{\"loss\": 1.5590977020263672, \"error\": 0.11846875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.58 sec\n",
      "[17] train metrics:{\"loss\": 1.543018394470215, \"error\": 0.10815625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.61 sec\n",
      "[18] train metrics:{\"loss\": 1.5397232418060303, \"error\": 0.10703125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.44 sec\n",
      "[19] train metrics:{\"loss\": 1.5722574791908264, \"error\": 0.11421875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.45 sec\n",
      "[20] train metrics:{\"loss\": 1.5940280084609986, \"error\": 0.1075}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.52 sec\n",
      "[21] train metrics:{\"loss\": 1.5399379086494447, \"error\": 0.0955625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.49 sec\n",
      "[22] train metrics:{\"loss\": 1.5899784002304078, \"error\": 0.1098125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.5 sec\n",
      "[23] train metrics:{\"loss\": 1.6024198775291443, \"error\": 0.1053125}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.39 sec\n",
      "[24] train metrics:{\"loss\": 1.549412570476532, \"error\": 0.09359375}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.42 sec\n",
      "[25] train metrics:{\"loss\": 1.580799273967743, \"error\": 0.1025}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.45 sec\n",
      "[26] train metrics:{\"loss\": 1.577813358783722, \"error\": 0.10015625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.37 sec\n",
      "[27] train metrics:{\"loss\": 1.5733731870651244, \"error\": 0.09746875}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.36 sec\n",
      "[28] train metrics:{\"loss\": 1.586123302936554, \"error\": 0.10090625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.43 sec\n",
      "[29] train metrics:{\"loss\": 1.5767607717514038, \"error\": 0.094625}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.38 sec\n",
      "[30] train metrics:{\"loss\": 1.5994566655158997, \"error\": 0.1015}\n",
      "Learning Rate : 0.1\n",
      "Epoch Time: 5.48 sec\n",
      "Pure training time: 170.83 sec\n"
     ]
    }
   ],
   "source": [
    "%run main.py --dataset lacuna100 --dataroot=data/lacuna100 --model resnet --filters 1.0 --lr 0.1 --lossfn ce --num-classes 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train the original model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: lacuna10_resnet_1_0_forget_None_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in lacuna10_resnet_1_0_forget_None_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1_training]\n",
      "confuse mode: False\n",
      "split mode: train\n",
      "Number of Classes: 10\n",
      "Epoch: [0][0/25]\tTime 0.045 (0.045)\tData 0.007 (0.007)\tLoss 0.8869 (0.8869)\tAcc@1 87.500 (87.500)\tAcc@5 99.219 (99.219)\n",
      " * Acc@1 90.781 Acc@5 99.000\n",
      "[0] test metrics:{\"loss\": 0.20946366262435914, \"error\": 0.055999995708465575}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.62 sec\n",
      "Epoch: [1][0/25]\tTime 0.015 (0.015)\tData 0.008 (0.008)\tLoss 0.1985 (0.1985)\tAcc@1 92.969 (92.969)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 95.500 Acc@5 99.750\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [2][0/25]\tTime 0.013 (0.013)\tData 0.007 (0.007)\tLoss 0.0561 (0.0561)\tAcc@1 99.219 (99.219)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 98.250 Acc@5 99.969\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [3][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0369 (0.0369)\tAcc@1 99.219 (99.219)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.469 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [4][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0171 (0.0171)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.812 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [5][0/25]\tTime 0.013 (0.013)\tData 0.007 (0.007)\tLoss 0.0164 (0.0164)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.969 Acc@5 100.000\n",
      "[5] test metrics:{\"loss\": 0.11269214117527009, \"error\": 0.030999996662139893}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.56 sec\n",
      "Epoch: [6][0/25]\tTime 0.015 (0.015)\tData 0.007 (0.007)\tLoss 0.0156 (0.0156)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.969 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [7][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0074 (0.0074)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.969 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [8][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0066 (0.0066)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [9][0/25]\tTime 0.014 (0.014)\tData 0.006 (0.006)\tLoss 0.0062 (0.0062)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [10][0/25]\tTime 0.014 (0.014)\tData 0.006 (0.006)\tLoss 0.0055 (0.0055)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[10] test metrics:{\"loss\": 0.1133830133676529, \"error\": 0.030999996662139893}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.58 sec\n",
      "Epoch: [11][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0038 (0.0038)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [12][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0031 (0.0031)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [13][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0025 (0.0025)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [14][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0040 (0.0040)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [15][0/25]\tTime 0.014 (0.014)\tData 0.006 (0.006)\tLoss 0.0024 (0.0024)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[15] test metrics:{\"loss\": 0.11351716929674148, \"error\": 0.029999996662139893}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.56 sec\n",
      "Epoch: [16][0/25]\tTime 0.015 (0.015)\tData 0.007 (0.007)\tLoss 0.0025 (0.0025)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [17][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0029 (0.0029)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [18][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0023 (0.0023)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [19][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0021 (0.0021)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.43 sec\n",
      "Epoch: [20][0/25]\tTime 0.014 (0.014)\tData 0.006 (0.006)\tLoss 0.0020 (0.0020)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[20] test metrics:{\"loss\": 0.11552823621034622, \"error\": 0.02899999666213989}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.57 sec\n",
      "Epoch: [21][0/25]\tTime 0.015 (0.015)\tData 0.007 (0.007)\tLoss 0.0028 (0.0028)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [22][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0016 (0.0016)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [23][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0015 (0.0015)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [24][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0011 (0.0011)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [25][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0014 (0.0014)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[25] test metrics:{\"loss\": 0.11844244855642319, \"error\": 0.027999996662139894}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.56 sec\n",
      "Pure training time: 10.790000000000001 sec\n"
     ]
    }
   ],
   "source": [
    "%run main_merged.py --dataset lacuna10 --model resnet --dataroot=data/lacuna10/ --filters 1.0 --lr 0.01 \\\n",
    "--resume checkpoints/lacuna100_resnet_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_30.pt --disable-bn \\\n",
    "--weight-decay 5e-4 --batch-size 128 --epochs 26 --seed 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Retrain Forgetting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Checkpoint name: lacuna10_resnet_1_0_forget_[5]_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1\n",
      "[Logging in lacuna10_resnet_1_0_forget_[5]_lr_0_01_bs_128_ls_ce_wd_0_0005_seed_1_training]\n",
      "confuse mode: False\n",
      "split mode: train\n",
      "Number of Classes: 10\n",
      "Epoch: [0][0/25]\tTime 0.016 (0.016)\tData 0.007 (0.007)\tLoss 0.9343 (0.9343)\tAcc@1 82.812 (82.812)\tAcc@5 99.219 (99.219)\n",
      " * Acc@1 90.469 Acc@5 98.969\n",
      "[0] test metrics:{\"loss\": 0.18473745082737877, \"error\": 0.052222222222222225}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.59 sec\n",
      "Epoch: [1][0/25]\tTime 0.015 (0.015)\tData 0.006 (0.006)\tLoss 0.1682 (0.1682)\tAcc@1 94.531 (94.531)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 96.250 Acc@5 99.812\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [2][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0502 (0.0502)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 98.719 Acc@5 99.969\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [3][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0285 (0.0285)\tAcc@1 99.219 (99.219)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.531 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [4][0/25]\tTime 0.015 (0.015)\tData 0.008 (0.008)\tLoss 0.0157 (0.0157)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.875 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [5][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0134 (0.0134)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.969 Acc@5 100.000\n",
      "[5] test metrics:{\"loss\": 0.09016695853219264, \"error\": 0.023333333333333334}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.55 sec\n",
      "Epoch: [6][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0151 (0.0151)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.969 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [7][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0065 (0.0065)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 99.969 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [8][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0071 (0.0071)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [9][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0043 (0.0043)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [10][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0045 (0.0045)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[10] test metrics:{\"loss\": 0.08962296456202037, \"error\": 0.024444444444444446}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.56 sec\n",
      "Epoch: [11][0/25]\tTime 0.015 (0.015)\tData 0.007 (0.007)\tLoss 0.0031 (0.0031)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [12][0/25]\tTime 0.016 (0.016)\tData 0.008 (0.008)\tLoss 0.0021 (0.0021)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [13][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0019 (0.0019)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [14][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0031 (0.0031)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [15][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0021 (0.0021)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[15] test metrics:{\"loss\": 0.09083591905112068, \"error\": 0.024444444444444446}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.56 sec\n",
      "Epoch: [16][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0024 (0.0024)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [17][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0028 (0.0028)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [18][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0019 (0.0019)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [19][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0023 (0.0023)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [20][0/25]\tTime 0.013 (0.013)\tData 0.006 (0.006)\tLoss 0.0017 (0.0017)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[20] test metrics:{\"loss\": 0.09075596125175556, \"error\": 0.023333333333333334}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.56 sec\n",
      "Epoch: [21][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0034 (0.0034)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [22][0/25]\tTime 0.016 (0.016)\tData 0.007 (0.007)\tLoss 0.0011 (0.0011)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [23][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0016 (0.0016)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.41 sec\n",
      "Epoch: [24][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0010 (0.0010)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch Time: 0.42 sec\n",
      "Epoch: [25][0/25]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0015 (0.0015)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "[25] test metrics:{\"loss\": 0.09366644783980317, \"error\": 0.023333333333333334}\n",
      "Learning Rate : 0.01\n",
      "Epoch Time: 0.55 sec\n",
      "Pure training time: 10.89 sec\n"
     ]
    }
   ],
   "source": [
    "%run main_merged.py --dataset lacuna10 --model resnet --dataroot=data/lacuna10/ --filters 1 --lr 0.01 \\\n",
    "--resume checkpoints/lacuna100_resnet_1_0_forget_None_lr_0_1_bs_128_ls_ce_wd_0_0005_seed_1_30.pt --disable-bn \\\n",
    "--weight-decay 5e-4 --batch-size 128 --epochs 26 \\\n",
    "--forget-class 5 --seed 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Logs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict={}\n",
    "training_epochs=25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict['epoch']=training_epochs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "model0 = 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 - 4000#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",
    "\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()\n",
    "\n",
    "teacher = copy.deepcopy(model)\n",
    "student = copy.deepcopy(model)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Data Loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "confuse mode: False\n",
      "split mode: train\n",
      "confuse mode: False\n",
      "split mode: train\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=512, 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=256, seed=seed, shuffle=True)\n",
    "\n",
    "\n",
    "assert(len(forget_dataset) + len(retain_dataset) == len(train_loader_full.dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_dict['args']=args"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320\n",
      "2880\n",
      "1000\n",
      "3200\n",
      "{0: 320, 1: 320, 2: 320, 3: 320, 4: 320, 5: 320, 6: 320, 7: 320, 8: 320, 9: 320}\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": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.optim = 'sgd'\n",
    "args.gamma = 0.99\n",
    "args.alpha = 0.95\n",
    "args.beta = 0.9\n",
    "args.smoothing = 0.0\n",
    "args.msteps = 5\n",
    "args.clip = 0.2\n",
    "args.sstart = 5\n",
    "args.kd_T = 4\n",
    "args.distill = 'kd'\n",
    "\n",
    "args.sgda_batch_size = 128\n",
    "args.del_batch_size = 128\n",
    "args.sgda_epochs = 3\n",
    "args.sgda_learning_rate = 0.005\n",
    "args.lr_decay_epochs = [3,5,9]\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": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_t = copy.deepcopy(teacher)\n",
    "model_s = copy.deepcopy(student)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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": 31,
   "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": 32,
   "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": 33,
   "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 100.000 \n",
      "maximize loss: -17.97\t minimize loss: 0.32\t train_acc: 100.0\n",
      "==> SCRUB unlearning ...\n",
      " * Acc@1 100.000 \n",
      "maximize loss: -48.26\t minimize loss: 1.73\t train_acc: 100.0\n",
      "==> SCRUB unlearning ...\n",
      " * Acc@1 99.826 \n",
      "maximize loss: -112.02\t minimize loss: 7.60\t train_acc: 99.8263931274414\n"
     ]
    }
   ],
   "source": [
    "acc_rs = []\n",
    "acc_fs = []\n",
    "acc_ts = []\n",
    "acc_vs = []\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_lacuna10_resnet\")\n",
    "    acc_f, acc5_f, loss_f = validate(forget_loader, model_s, criterion_cls, args, True, prefix=\"forget_lacuna10_resnet\")\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",
    "    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",
    "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())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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.plot(indices, acc_vs, marker='.', alpha=1, label='valid-set')\n",
    "plt.legend(prop={'size': 14})\n",
    "plt.tick_params(labelsize=12)\n",
    "plt.title('SCRUB retain-, valid- and forget- set error',size=18)\n",
    "plt.xlabel('epoch',size=14)\n",
    "plt.ylabel('error',size=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Original"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Original_Model_D_r -> Loss:0.001, Error:0.0\n",
      "Original_Model_D_f -> Loss:0.001, Error:0.0\n",
      "Original_Model_D_t -> Loss:0.114, Error:0.028\n"
     ]
    }
   ],
   "source": [
    "m_D_r_activations,m_D_r_predictions=activations_predictions(copy.deepcopy(model),copy.deepcopy(retain_loader),'Original_Model_D_r')\n",
    "m_D_f_activations,m_D_f_predictions=activations_predictions(copy.deepcopy(model),copy.deepcopy(forget_loader),'Original_Model_D_f')\n",
    "m_D_t_activations,m_D_t_predictions=activations_predictions(copy.deepcopy(model),copy.deepcopy(test_loader_full),'Original_Model_D_t')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Retrain"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Retrain_Model_D_r -> Loss:0.001, Error:0.0\n",
      "Retrain_Model_D_f -> Loss:6.019, Error:1.0\n",
      "Retrain_Model_D_t -> Loss:0.65, Error:0.121\n"
     ]
    }
   ],
   "source": [
    "m0_D_r_activations,m0_D_r_predictions=activations_predictions(copy.deepcopy(model0),copy.deepcopy(retain_loader),'Retrain_Model_D_r')\n",
    "m0_D_f_activations,m0_D_f_predictions=activations_predictions(copy.deepcopy(model0),copy.deepcopy(forget_loader),'Retrain_Model_D_f')\n",
    "m0_D_t_activations,m0_D_t_predictions=activations_predictions(copy.deepcopy(model0),copy.deepcopy(test_loader_full),'Retrain_Model_D_t')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### SCRUB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SCRUB_D_r -> Loss:0.018, Error:0.004166666666666667\n",
      "SCRUB_D_f -> Loss:75.35, Error:1.0\n",
      "SCRUB_D_t -> Loss:7.592, Error:0.129\n"
     ]
    }
   ],
   "source": [
    "ntk_D_r_activations,ntk_D_r_predictions=activations_predictions(copy.deepcopy(model_s),copy.deepcopy(retain_loader),'SCRUB_D_r')\n",
    "ntk_D_f_activations,ntk_D_f_predictions=activations_predictions(copy.deepcopy(model_s),copy.deepcopy(forget_loader),'SCRUB_D_f')\n",
    "ntk_D_t_activations,ntk_D_t_predictions=activations_predictions(copy.deepcopy(model_s),copy.deepcopy(test_loader_full),'SCRUB_D_t')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Fisher Forgetting"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Fisher"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "modelf = copy.deepcopy(model)\n",
    "modelf0 = copy.deepcopy(model0)\n",
    "\n",
    "for p in itertools.chain(modelf.parameters(), modelf0.parameters()):\n",
    "    p.data0 = copy.deepcopy(p.data.clone())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "def hessian(dataset, model):\n",
    "    model.eval()\n",
    "    train_loader = torch.utils.data.DataLoader(dataset, batch_size=1, shuffle=False)\n",
    "    loss_fn = nn.CrossEntropyLoss()\n",
    "\n",
    "    for p in model.parameters():\n",
    "        p.grad_acc = 0\n",
    "        p.grad2_acc = 0\n",
    "    \n",
    "    for data, orig_target in tqdm(train_loader):\n",
    "        data, orig_target = data.to(args.device), orig_target.to(args.device)\n",
    "        output = model(data)\n",
    "        prob = F.softmax(output, dim=-1).data\n",
    "\n",
    "        for y in range(output.shape[1]):\n",
    "            target = torch.empty_like(orig_target).fill_(y)\n",
    "            loss = loss_fn(output, target)\n",
    "            model.zero_grad()\n",
    "            loss.backward(retain_graph=True)\n",
    "            for p in model.parameters():\n",
    "                if p.requires_grad:\n",
    "                    p.grad_acc += (orig_target == target).float() * p.grad.data\n",
    "                    p.grad2_acc += prob[:, y] * p.grad.data.pow(2)\n",
    "    for p in model.parameters():\n",
    "        p.grad_acc /= len(train_loader)\n",
    "        p.grad2_acc /= len(train_loader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2880/2880 [03:09<00:00, 15.18it/s]\n"
     ]
    }
   ],
   "source": [
    "hessian(retain_loader.dataset, modelf)\n",
    "#hessian(retain_loader.dataset, modelf0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_mean_var(p, is_base_dist=False, alpha=3e-6):\n",
    "    var = copy.deepcopy(1./(p.grad2_acc+1e-8))\n",
    "    var = var.clamp(max=1e3)\n",
    "    if p.size(0) == num_classes:\n",
    "        var = var.clamp(max=1e2)\n",
    "    var = alpha * var\n",
    "    \n",
    "    if p.ndim > 1:\n",
    "        var = var.mean(dim=1, keepdim=True).expand_as(p).clone()\n",
    "    if not is_base_dist:\n",
    "        mu = copy.deepcopy(p.data0.clone())\n",
    "    else:\n",
    "        mu = copy.deepcopy(p.data0.clone())\n",
    "    if p.size(0) == num_classes and num_to_forget is None:\n",
    "        mu[class_to_forget] = 0\n",
    "        var[class_to_forget] = 0.0001\n",
    "    if p.size(0) == num_classes:\n",
    "        # Last layer\n",
    "        var *= 10\n",
    "    elif p.ndim == 1:\n",
    "        # BatchNorm\n",
    "        var *= 10\n",
    "#         var*=1\n",
    "    return mu, var\n",
    "\n",
    "def kl_divergence_fisher(mu0, var0, mu1, var1):\n",
    "    return ((mu1 - mu0).pow(2)/var0 + var1/var0 - torch.log(var1/var0) - 1).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "fisher_dir = []\n",
    "alpha = 1e-7\n",
    "torch.manual_seed(seed)\n",
    "for i, p in enumerate(modelf.parameters()):\n",
    "    mu, var = get_mean_var(p, False, alpha=alpha)\n",
    "    p.data = mu + var.sqrt() * torch.empty_like(p.data0).normal_()\n",
    "    fisher_dir.append(var.sqrt().view(-1).cpu().detach().numpy())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Fisher Noise in Weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fisher_D_r -> Loss:0.005, Error:0.0\n",
      "Fisher_D_f -> Loss:3.554, Error:0.9875\n",
      "Fisher_D_t -> Loss:0.451, Error:0.12\n"
     ]
    }
   ],
   "source": [
    "fisher_D_r_activations,fisher_D_r_predictions=activations_predictions(copy.deepcopy(modelf),copy.deepcopy(retain_loader),'Fisher_D_r')\n",
    "fisher_D_f_activations,fisher_D_f_predictions=activations_predictions(copy.deepcopy(modelf),copy.deepcopy(forget_loader),'Fisher_D_f')\n",
    "fisher_D_t_activations,fisher_D_t_predictions=activations_predictions(copy.deepcopy(modelf),copy.deepcopy(test_loader_full),'Fisher_D_t')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Information in the Activations"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Finetune"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: [0][0/23]\tTime 0.040 (0.040)\tData 0.014 (0.014)\tLoss 0.0015 (0.0015)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [1][0/23]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0021 (0.0021)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [2][0/23]\tTime 0.017 (0.017)\tData 0.007 (0.007)\tLoss 0.0014 (0.0014)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [3][0/23]\tTime 0.016 (0.016)\tData 0.007 (0.007)\tLoss 0.0021 (0.0021)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [4][0/23]\tTime 0.015 (0.015)\tData 0.007 (0.007)\tLoss 0.0036 (0.0036)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [5][0/23]\tTime 0.015 (0.015)\tData 0.006 (0.006)\tLoss 0.0020 (0.0020)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [6][0/23]\tTime 0.016 (0.016)\tData 0.007 (0.007)\tLoss 0.0014 (0.0014)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [7][0/23]\tTime 0.015 (0.015)\tData 0.007 (0.007)\tLoss 0.0018 (0.0018)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [8][0/23]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0023 (0.0023)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n",
      "Epoch: [9][0/23]\tTime 0.014 (0.014)\tData 0.007 (0.007)\tLoss 0.0022 (0.0022)\tAcc@1 100.000 (100.000)\tAcc@5 100.000 (100.000)\n",
      " * Acc@1 100.000 Acc@5 100.000\n"
     ]
    }
   ],
   "source": [
    "model_ft = copy.deepcopy(model)\n",
    "retain_loader = replace_loader_dataset(train_loader_full,retain_dataset, seed=seed, batch_size=args.batch_size, shuffle=True)    \n",
    "finetune(model_ft, retain_loader, epochs=10, quiet=True, lr=0.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finetune_D_r -> Loss:0.001, Error:0.0\n",
      "Finetune_D_f -> Loss:0.0, Error:0.0\n",
      "Finetune_D_t -> Loss:0.105, Error:0.026\n"
     ]
    }
   ],
   "source": [
    "finetune_D_r_activations,finetune_D_r_predictions=activations_predictions(copy.deepcopy(model_ft),copy.deepcopy(retain_loader),'Finetune_D_r')\n",
    "finetune_D_f_activations,finetune_D_f_predictions=activations_predictions(copy.deepcopy(model_ft),copy.deepcopy(forget_loader),'Finetune_D_f')\n",
    "finetune_D_t_activations,finetune_D_t_predictions=activations_predictions(copy.deepcopy(model_ft),copy.deepcopy(test_loader_full),'Finetune_D_t')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Readouts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0008431148333053706\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                               \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Original ->\tFull test error: 2.80%\tForget error: 0.00%\tRetain error: 0.00%\tFine-tune time: 1 steps\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                               \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finetune ->\tFull test error: 2.60%\tForget error: 0.00%\tRetain error: 0.00%\tFine-tune time: 1 steps\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                               \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fisher ->\tFull test error: 12.00%\tForget error: 98.75%\tRetain error: 0.00%\tFine-tune time: 100 steps\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                               \r"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Retrain ->\tFull test error: 12.10%\tForget error: 100.00%\tRetain error: 0.00%\tFine-tune time: 100 steps\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                               "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SCRUB ->\tFull test error: 12.90%\tForget error: 100.00%\tRetain error: 0.42%\tFine-tune time: 100 steps\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r"
     ]
    }
   ],
   "source": [
    "try: readouts\n",
    "except: readouts = {}\n",
    "\n",
    "thresh=log_dict['Original_Model_D_f_loss']+1e-5\n",
    "print(thresh)\n",
    "readouts[\"e\"] = all_readouts(copy.deepcopy(model),thresh,'Original')\n",
    "readouts[\"a\"] = all_readouts(copy.deepcopy(model_ft),thresh,'Finetune')\n",
    "readouts[\"b\"] = all_readouts(copy.deepcopy(modelf),thresh,'Fisher')\n",
    "readouts[\"d\"] = all_readouts(copy.deepcopy(model0),thresh,'Retrain')\n",
    "readouts[\"d\"] = all_readouts(copy.deepcopy(model_s),thresh,'SCRUB')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Save Dictionary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2422/2828292684.py:82: UserWarning:  \n",
      "\n",
      "`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n",
      "\n",
      "Please adapt your code to use either `displot` (a figure-level function with\n",
      "similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "\n",
      "For a guide to updating your code to use the new functions, please see\n",
      "https://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n",
      "\n",
      "  sns.distplot(np.log(X_r[Y_r==1]).reshape(-1), kde=False, norm_hist=True, rug=False, label='retain', ax=plt)\n",
      "/tmp/ipykernel_2422/2828292684.py:83: UserWarning: \n",
      "\n",
      "`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n",
      "\n",
      "Please adapt your code to use either `displot` (a figure-level function with\n",
      "similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "\n",
      "For a guide to updating your code to use the new functions, please see\n",
      "https://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n",
      "\n",
      "  sns.distplot(np.log(X_r[Y_r==0]).reshape(-1), kde=False, norm_hist=True, rug=False, label='test', ax=plt)\n",
      "/tmp/ipykernel_2422/2828292684.py:84: UserWarning: \n",
      "\n",
      "`distplot` is a deprecated function and will be removed in seaborn v0.14.0.\n",
      "\n",
      "Please adapt your code to use either `displot` (a figure-level function with\n",
      "similar flexibility) or `histplot` (an axes-level function for histograms).\n",
      "\n",
      "For a guide to updating your code to use the new functions, please see\n",
      "https://gist.github.com/mwaskom/de44147ed2974457ad6372750bbe5751\n",
      "\n",
      "  sns.distplot(np.log(X_f).reshape(-1), kde=False, norm_hist=True, rug=False, label='forget', ax=plt)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                    \r"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                    \r"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAHSCAYAAADG7DBnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABHn0lEQVR4nO3deVyVZf7/8fcREEgEBLdIBZdwRzRLv5MlpObaohM/1Jpxa7PFbBpNw1H4TiYzo6XTPo0paWIuOM7kkjoJrZJWNlJauYAIWQrKARdkuX9/+OWMxwN4DoLcwOv5eJzHyHXf131/zt0ZeXvd130di2EYhgAAAEykUW0XAAAAcDkCCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCoAGISQkRBaLRcuXL6/tUgA4wb22CwBQP+3du1f/+Mc/5O/vr+nTp9d2OQDqGEZQANSIvXv3Ki4uTosXL67tUiRJHTt2VOfOneXn51fbpQBwAiMoABqEf//737VdAgAXMIICAABMh4ACNFARERGyWCyKjY1VUVGRFi1apL59+8rf318Wi0XJycm2fQ8dOqQnn3xSXbt2lY+Pj6677jp17dpV06dP19GjRx2ObbFYNGnSJElSRkaGLBaL3Ss2Nta278SJE2WxWDRx4kQZhqG///3vGjBggAIDAx0mtX711Vf63//9X91+++0KDg6Wl5eX/P391b9/f/3pT39SQUFBhe+3skmyZXUlJycrPz9fc+bMUZcuXeTt7a3AwECNGjVKqampLl9jAFXHLR6ggTt//rwiIiL02Wefyd3dXU2bNrXb/tZbb+nxxx9XUVGRJMnT01ONGjXSgQMHdODAAS1btkzr1q3TkCFDbH1atWqlc+fOyWq1qlGjRmrRooXdMX18fBzqMAxD/+///T+tW7dOjRo1kp+fnxo1sv831E033WT7c6NGjeTr66vTp08rNTVVqampeuedd7Rz5061bNmyStfip59+Up8+fXTw4EF5eXmpUaNGys3N1aZNm7Rt2zb961//0tChQ6t0bAAuMgA0SAMHDjQkGT4+PoaPj4+xbNky4+zZs4ZhGMbJkyeNnJwcY8OGDYYkw8PDw5g1a5aRnp5ulJaWGqWlpcaBAweMqKgoQ5Lh6+trZGRk2B1/2bJlhiQjODi40jomTJhgq8Pd3d1YuHChkZeXZxiGYeTn5xvZ2dm2fQcPHmy8/fbbRkZGhlFUVGQYhmGcPXvWSEpKMjp37mxIMkaPHl3ueYKDgw1JxrJlyxy2STIkGc2aNTO6detmfPjhh0ZJSYlRWlpqfPHFF7ZjBwcHGyUlJc5eYgBXgYACNFBlAUWS8c9//tNhe2FhoXHDDTcYkoylS5dWeJy7777bkGQ89dRTdu2uBhRJxl//+teqvBXDMAzj2LFjhqenp2GxWBzCkmE4F1BatGhh/Pzzzw7b//Of/9j2+eSTT6pcIwDnMQcFaOC6d++uu+66y6F9y5YtysrKUqtWrWzzScrz29/+VpL0wQcfXFUdzZo10yOPPFLl/jfccIN69eolwzD02WefVekYDz/8cLm3h3r27Kn27dtLkv7zn/9UuUYAzmMOCtDA3XrrreW2f/LJJ5KkU6dO6frrr6+w/4ULFyRdnAx7NW6++WY1bty40n1KS0u1evVqrV69Wnv37tWJEyd0/vx5h/2OHTtWpRr69etX4bagoCAdOXJEubm5VTo2ANcQUIAGrqIJpdnZ2ZIuBpCff/75isc5d+5cjdRR5uzZsxo1apR27txpa2vcuLECAgLk4eEhScrNzVVRUZHOnDlTpRounyB8KXf3i39dlk0WBlCzuMUDNHBubm7ltpeUlEiShg0bJuPifLUrvmqijjLz58/Xzp075e3trZdeekkZGRk6f/68cnJydPz4cR0/ftw2AnK1tQCofYygAChX69atJUn79u2r5UouWr16tSRp7ty5FX63z/Hjx69hRQBqEiMoAMpVNjclKyvLNh/FFWVrmFTXaEZmZqYkqXfv3uVuT09P18GDB6vlXABqHwEFQLnuuusu2+TYp556SmfPnq10/8snj/r6+kqSTp8+XS31lH3J3zfffFPu9lmzZlXLeQCYAwEFQLm8vLz02muvyWKx6KuvvtKtt96qDz74wPbUjiQdOXJEb775pm655Ra99tprdv179OghSbJarVqzZs1V1zNs2DBJ0vPPP6+kpCQVFxfbahg/frzWrFmjZs2aXfV5AJgDAQVAhe69916tWLFC1113nfbu3athw4apSZMmat68uby8vNShQwc9+uij2r17tywWi13fTp06adCgQZKk6Oho+fr6KiQkRCEhIVq8eLHLtTz//PNq1aqV8vPz9etf/1re3t7y9/dXhw4dlJiYqPnz5yssLKw63jYAEyCgAKjU/fffr4MHD2rOnDnq27evfHx8dPr0aXl5eSk8PFxPPPGEduzYoWeffdah77p16/T0008rNDRURUVFysjIUEZGRpVu+wQHB2vPnj2aMmWKgoKCJF0c5Rk1apQ++OADzZ49+2rfKgATsRg8jwcAAEyGERQAAGA6BBQAAGA6BBQAAGA6BBQAAGA6BBQAAGA6BBQAAGA6dfLLAktLS5Wdna2mTZs6LA4FAADMyTAM5efnKygoyPZ9XRWpkwElOztbbdu2re0yAABAFWRmZqpNmzaV7lMnA0rTpk0lXXyDZV9IBgAAzM1qtapt27a23+OVcTmgFBQUaM6cOVqzZo1yc3PVpUsXzZo1S2PHjq20X0REhFJSUirc/tNPP6l169ZO1VB2W8fX15eAAgBAHePM9AyXA8qYMWO0e/duxcfHKzQ0VKtWrdK4ceNUWlqq8ePHV9jvtddek9VqtWs7e/ashg0bpptuusnpcAIAAOo/lwLK5s2btX37dlsokaTIyEhlZGRoxowZio6OlpubW7l9u3Xr5tCWkJCgoqIiPfjgg1UoHQAA1FcuPWa8YcMG+fj4KCoqyq590qRJys7OVmpqqksnX7p0qXx8fBQdHe1SPwAAUL+5FFDS0tLUtWtXubvbD7yEhYXZtjvrxx9/1Mcff6yxY8fKx8fHlTIAAEA959ItnpycHHXo0MGhPSAgwLbdWUuXLpUkTZky5Yr7FhYWqrCw0Pbz5XNZAABA/eLySrKVzbx1dtG04uJiJSQkqHv37urfv/8V91+wYIH8/PxsL9ZAAQCgfnNpBCUwMLDcUZLc3FxJ/x1JuZLNmzfr+PHjevbZZ53af/bs2frd735n+7nsOWpXFRUVqaSkxOV+qHvc3Nzk4eFR22UAAKrIpYDSs2dPJSYmqri42G4eyr59+yRJPXr0cOo4S5cuVePGjfWb3/zGqf09PT3l6enpSql2rFarTp48aXebCPWfp6enmjdvzlo5AFAHuRRQRo8erbfeekvr16+3e/ImISFBQUFB6tev3xWPcfz4cW3evFljxoxRYGCg6xW7yGq1KisrSz4+PmrevLk8PDz4/p56zjAMFRUVKS8vT1lZWZJESAGAOsalgDJ8+HANGTJEU6dOldVqVadOnZSYmKitW7dq5cqVtjVQpkyZooSEBB06dEjBwcF2x0hISFBxcfE1W/vk5MmT8vHxUZs2bQgmDYi3t7eaNm2qY8eO6eTJkwQUAKhjXF5JNikpSTExMZo7d65tqfvExES7pe5LSkpUUlIiwzAc+r/99tsKCQnR4MGDr65yJxQVFamwsFDNmzcnnDRAFotFfn5+ysrKUlFREXNSAKAOsRjlpQiTs1qt8vPzU15eXqX/Mj5//ryOHDmikJAQeXt7X8MKYRbnzp1Tenq62rdvLy8vr9ouBwAaNGd/f0tVeMy4LmL0pOHivz0A1E0NIqAAAIC6hYACAABMx+VJskB1CQkJkSSlp6fXah0AUF+s/WGt3c9RoVEV7Gl+DT6grEo9WtslVGh8v3a1XYKd2NhYxcXFaefOnYqIiKjtcgAA9ViDDyioPf/+979ruwQAgEkRUFBrOnbsWNslAABMikmy9VxycrIsFotiY2P1+eefa+jQofL397c9fmsYht5++23deuut8vX11XXXXae+ffvq7bfftjtORESE4uLiJEmRkZGyWCyyWCy2eSSStHPnTk2ePFmdO3eWj4+PfHx81LdvX/3tb38rt7aQkBC7/tLF20gWi0XJyclas2aN+vTpI29vb11//fWaNm2azp07V30XBwBgWoygNBCfffaZXnjhBUVGRurhhx/W0aNHZRiGHnjgAa1atUqhoaEaP368GjdurO3bt2vKlCn67rvvtHDhQknSxIkTJUkpKSmaMGGCLVj4+/vbzvGnP/1JBw8eVP/+/TV69GidPn1aW7du1SOPPKLvv/9eixYtcrreV199VVu2bNE999yjiIgIbd26VS+//LJycnL07rvvVtdlAQCYFAGlgdi+fbuWLl2qyZMn29reeustrVq1SlOmTNEbb7xh+4bqCxcu6L777tOiRYs0btw43XTTTZo4caLS09OVkpKiiRMnljtJ9vXXX1f79u3t2oqLizVixAgtWbJETz31lNq1c27i7/bt2/Xll1+qc+fOkqT58+crPDxciYmJ+stf/qKgoKAqXgkAQF3ALZ4Gonfv3nbhRJJeeeUVNWnSRK+88ootnEhS48aNNX/+fElSYmKi0+e4PJxIkru7ux599FGVlJRo586dTh/rqaeesoUT6eKX/40bN06GYejLL790+jgAgLqJEZQG4pZbbrH7+ezZs9q3b5+CgoIUHx/vsH9RUZEk6cCBA06fIz8/XwsXLtQ//vEP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VkBAgHx8fDRw4EB99NFHtjrKm/fy0Ucf6a677lLz5s3l6empG2+8UXPmzNHZs2ft3kdkZKQkKS4uzvY+LBaL0tPTq/OSAQBMgls89VhZEFm8eLEkafr06ZKkkJAQGYah6OhoJSUlKTQ0VI8//rjOnDmjNWvWaNSoUVqyZImmTZvmcMy1a9dq27ZtGjVqlB577DHl5+dLkrKysvSrX/1KP/30k0aMGKFevXrp+++/15133mkLF5d744039Nhjj6lZs2a666671KJFC+3evVvz58/Xzp07tXPnTjVu3FgRERFKT09XQkKCBg4caHtfkuTv719dlwsAYCIElHosIiJCERERWr58uSTZTS5dsWKFkpKSNHDgQG3btk2NGzeWJMXExOimm27S73//e911111q37693TG3bNmibdu2afDgwXbts2bN0k8//aS//OUv+v3vf29rX758uSZNmuRQ23fffacnn3xS4eHh2rFjhwICAmzb4uPjNXv2bL388st65plnbIEkISFBERERTJIFgAaAWzwNVFlo+fOf/2wLJ5LUpk0bPf300yoqKtK7777r0O/ee+91CCeFhYVau3atWrVq5TDqMmHCBHXp0sXhOG+++aaKi4v117/+1S6cSNLMmTPVokULJSYmVvXtAQDqOEZQGqivv/5a3t7euuWWWxy2lY1Y7N2712Fbeft///33KiwsVN++fe3CjiRZLBb9z//8jw4cOGDXvmvXLknS1q1btWPHDodjenh4OPQBADQcBJQGymq1qm3btuVua926tSQpLy/PYVurVq3KPZYktWjRotzjldcnNzdXkjR//nznCgYANCjc4mmgfH199fPPP5e7razd19fXYZvFYin3WJJ04sSJSo9XXh+r1SrDMCp8AQAaJgJKA9W7d2+dO3dOX3zxhcO2lJQUSVJ4eLhTx+rcubM8PT315Zdf6sKFC3bbDMOw3c65VL9+/SSp3G3lcXNzkySVlJQ4tT8AoG4joDRQEyZMkCTNnj1bRUVFtvasrCy9+OKLcnd31/333+/UsTw9PXXffffp+PHj+utf/2q37Z133tH+/fsd+jz22GNyd3fXk08+qczMTIftp0+f1tdff237uWwi7bFjx5yqCQBQtzEHpYH6zW9+o6SkJG3cuFFhYWEaNWqUbR2UnJwcLVq0SB06dHD6eAsWLNCOHTs0Y8YM7dy5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Kjc3N6dPXlRUpPbt26tDhw766KOPnO5ntVrl5+envLw8+fr6Ot0PAID6prpCR1RoVLUcpzKu/P526RbPhg0b5OPjo6go+zcxadIkZWdnKzU11aVCPTw85O/vL3d3lwdyAABAPeZSQElLS1PXrl0dAkVYWJht+5WUlpaquLhY2dnZmjdvnn744Qc988wzrpQBAADqOZeGLnJyctShQweH9oCAANv2KxkxYoQ++OADSZKvr6/ee+89jRw5stI+hYWFKiwstP1stVpdKRsAANQxLj/FY7FYqrStzMsvv6wvvvhCGzdu1NChQxUdHa3ExMRK+yxYsEB+fn62V9u2bV0tGwAA1CEuBZTAwMByR0lyc3Ml/XckpTI33nijbr75Zt19991as2aNBg0apMcff1ylpaUV9pk9e7by8vJsr8zMTFfKBgAAdYxLAaVnz57av3+/iouL7dr37dsnSerRo4fLBdxyyy06deqUTpw4UeE+np6e8vX1tXsBAID6y6WAMnr0aBUUFGj9+vV27QkJCQoKClK/fv1cOrlhGEpJSZG/v78CAwNd6gsAAOovlybJDh8+XEOGDNHUqVNltVrVqVMnJSYmauvWrVq5cqVtDZQpU6YoISFBhw4dUnBwsCTpnnvuUa9evRQeHq7AwEBlZ2dr+fLlSklJ0auvvsqjxgAAwMblVJCUlKSYmBjNnTtXubm56tKlixITEzV27FjbPiUlJSopKdGla8DdeuutWrdunV555RVZrVb5+/urb9++ev/996/4FA8AAGhYXFpJ1ixYSRYAgItYSRYAAOAaIaAAAADTIaAAAADTIaAAAADTIaAAAADTIaAAAADTIaAAAADTIaAAAADTYX15AABM7tLF2K7FgmpmwAgKAAAwHQIKAAAwHW7xAABQh1TXd++YHSMoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdAgoAADAdNxruwAAAGBv7Q9ra7uEWscICgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB0CCgAAMB2XA0pBQYGmT5+uoKAgeXl5KTw8XKtXr75iv6SkJI0bN06dOnWSt7e3QkJC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Pz+n6ywqKjIWLlxo9OzZ0/D09DSaNm1qDBw40Ni4cWO5+6sGHjO+9BHhsus2YcIEp8+fn59vPPTQQ8b1119vNGrUyJBkzJs3z+78ZT+Xp6CgwPjDH/5ghIaGGo0bNzb8/f2N4cOHGx9//LHDvmWPGe/cudN48803jW7duhmenp5GmzZtjFmzZhlnz56t8Dzff/+9Iclo166dwyPUQENiMYxLxisB1Hv5+flq1aqVevbsqdTU1Noup16KjY1VXFycdu7cWe6j4ZVZs2aNoqOjFRcXp7lz59ZMgUAdwBwUoJ46c+aM8vPz7dpKSko0Y8YMnTt3rtw5E6hdhmHY5vVMmTKltssBahVzUIB66scff9SAAQM0dOhQdejQQfn5+fr444/13XffqXv37rbvz0Ht27dvn95//3199tlnSk1N1aOPPqobbrihtssCahUBBainbrjhBkVFRSklJUVbt25VcXGx2rVrp9///veKiYlRkyZNartE/J8vv/xSzz33nPz9/fXb3/5Wf/nLX2q7JKDWMQcFAACYDnNQAACA6RBQAACA6RBQAACA6RBQAACA6RBQAACA6RBQAACA6RBQAACA6RBQAACA6RBQAACA6fx/U7jxn7AunWcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                    \r"
     ]
    },
    {
     "data": {
      "image/png": "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OCoqSk2bNtXevXt17bXXqnr16vZekhkzZui2226TJN1www269957NXfuXM2aNUuzZs1SaGio0tLSVFBQoIceekjp6emaM2dOmTvHjh076q233tLIkSO1bt06NWvWTCEhIcrKylJ2draaNWumESNG6LHHHnNL7YC3oEcEQJHGjRunPXv26NFHH1Xr1q0VEBCglJQUBQUF6corr9STTz6pDRs26M4773TYz9fXV19//bXuv/9+RUZGKjMzUwcOHNCBAwecXgb34Ycf6tVXX1Xbtm0VGBiogoICXXvttfr000/1+uuvl9lzlKQRI0bou+++U79+/RQWFqbs7GxFRERowoQJ+v777+1jYAAUzWbON5oMAADATegRAQAAliGIAAAAyxBEAACAZQgiAADAMgQRAABgGYIIAACwTJmf0KygoECHDx9WtWrVnCYUAgAAZZMxRunp6QoPD7e/m8mVMh9EDh8+rPr161tdBgAAuAhJSUmqV69ekevLfBCpVq2apNMnUjhFNAAAKNvS0tJUv359++/xopT5IFJ4OyY4OJggAgBAOXO+YRUMVgUAAJa54CCSnp6uJ598UjfeeKNq1aolm82mmJgYl9tu27ZN3bt3V1BQkEJDQ3Xrrbdq3759Ja0ZAAB4iQsOIseOHdN7772n7Oxs3XLLLUVut2fPHkVFRSknJ0eLFi3Shx9+qF9++UXXXXed/vrrr5LUDAAAvMQFjxGJiIjQiRMnZLPZdPToUc2aNcvldpMnT5a/v7+++uor+9iODh066PLLL9eMGTP0/PPPl6xyAABQ7l1wj4jNZjvvwJO8vDx99dVX+tvf/uYwwDQiIkLR0dFaunTphVcKAAC8jlsGq/722286deqUWrdu7bSudevW+s9//qOsrCyX+2ZnZystLc3hAwAAvJNbHt89duyYJCksLMxpXVhYmIwxOnHihC655BKn9dOmTVNsbGyJa8jNzVV+fn6Jj4OyzcfHR35+flaXAQC4SG6dR+Rct3CKWjdhwgQ99thj9p8LJ0QprrS0NB09elTZ2dnFLxTlmr+/v2rWrMk8MwBQDrkliNSoUUPS/3pGznT8+HHZbDaFhoa63Nff31/+/v4X1W5aWpqSk5MVFBSkmjVrys/Pj/fTeDFjjHJzc5Wamqrk5GRJIowAQDnjliDSuHFjBQYGaseOHU7rduzYocsuu0wBAQGl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PlNCQoJeeOEFzZ49W/fff3+R+02YMEGpqan2T1JSkrtKrBAKw8kLL7zgcDusXr16evTRR5Wbm6v58+c77XfLLbc4hZDs7GwtXrxYderUcepFGTx4sJo1a+Z0nHfffVd5eXl67bXXHEKIJD355JOqVauWFi5ceLGnBwAo59zWIzJ+/HilpaXphx9+sN+Guf7661WzZk0NHTpU9957r7p27eq0n7+/v/z9/d1VVoWzfft2BQYG6qqrrnJaV9gD8cMPPzitc7X93r17lZ2drY4dOzqN8bHZbLr66qu1Z88eh+WbNm2SJK1atUpr1651Oqafn5/TPgCAisNtQeSHH35QixYtnMaCXHnllZKknTt3ugwiKF1paWmqX7++y3V169aVJKWmpjqtq1OnjstjSVKtWrVcHs/VPsePH5ckTZ06tXgFAwAqFLfdmgkPD9fPP/+sjIwMh+UbN26UdPrWANwvODhYf/75p8t1hcuDg4Od1tlsNpfHkqS//vrrnMdztU9aWpqMMUV+AAAVk9uCyNixY3X06FH16NFDixYt0rp16/Tcc8/pscceU4sWLdS7d293NY0ztGvXTqdOndL333/vtC4hIUGS1LZt22Idq2nTpvL399fWrVuVk5PjsM4YY78Nc6ZOnTpJkst1rvj4+EiS8vPzi7U9AKB8c1sQufnmm/X1118rODhYjzzyiPr27as5c+bogQce0Pr165lHxEMGDx4s6fQg4NzcXPvy5ORkvfTSS/L19dVdd91VrGP5+/vrtttu0x9//KHXXnvNYd3cuXO1e/dup30efPBB+fr66uGHH3Y58DglJUXbt2+3/1w4oPXQoUPFqgkAUL659V0z0dHRRc4tAc+45557tGTJEi1btkytW7dW37597fOIHDt2TDNnzlSjRo2Kfbxp06Zp7dq1GjdunOLi4tS2bVvt3btXX331lXr16qVVq1apUqX/5dtWrVrprbfe0qhRo9S0aVP16dNHjRs3Vlpamvbt26eEhAQNGTJE77zzjiSpWbNmCg8P1yeffKIqVaqoXr16stlsGjVqlNPkeACA8s+tQQTWs9ls+uyzz/Tqq69qzpw5ev3111W5cmW1b99ejz32mG6++eYLOl79+vW1ceNGPfXUU1q9erXi4+PVoUMHrV69WosXn36x4NljToYPH662bdvqpZde0vr16/Xll18qJCREDRo0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FjyL62A9rkHZwHUoG8rydbAZc77nagAAANzDbWNEAAAAzocgAgAALEMQAQAAliGIlAMZGRkaO3aswsPDFRAQoLZt2+qTTz4p1r5HjhzRkCFDVLNmTVWpUkVXX321vv76azdX7J0u9josWbJEd9xxhy677DIFBgYqMjJSd911l3799VcPVO19SvL34UyTJk2SzWYrck4jnFtJr8OyZcvUtWtXBQcHq2rVqmrZsqXee+89N1bsnUpyHeLi4tSjRw/Vrl1bQUFBat26tV577TXl5+e7ueqzlHwyd7hbjx49TGhoqHnnnXfMunXrzP33328kmfnz559zv6ysLNOqVStTr1498/HHH5vVq1eb/v37G19fXxMfH++h6r3HxV6Hq666ytx8883mww8/NPHx8WbevHmmefPmJigoyOzcudND1XuPi70OZ9q+fbvx9/c3derUMS1btnRjtd6rJNdh2rRpplKlSubBBx80K1euNGvXrjVvvPGGef311z1QuXe52OuwZs0aU6lSJRMVFWW++OILs2bNGvPwww8bSWbMmDEeqv40gkgZt3z5ciPJLFiwwGF5jx49THh4uMnLyyty3zfffNNIMhs2bLAvy83NNS1atDBXXXWV22r2RiW5Dn/++afTsuTkZOPn52eGDRtW6rV6s5Jch0K5ubmmbdu2ZsyYMaZr164EkYtQkuuwZcsWU6lSJfP888+7u0yvV5LrcNdddxl/f3+TkZHhsPzGG280wcHBbqm3KNyaKeOWLl2qoKAgDRzo+Kr2++67T4cPH9bmzZvPuW/Tpk119dVX25f5+vrq7rvv1vfff6/k5GS31e1tSnIdateu7bQsPDxc9erVU1LS+d+AjP8pyXUoNH36dB0/flxTp051V5leryTX4Y033pC/v78efvhhd5fp9UpyHfz8/FS5cmUFBgY6LA8NDVVAQIBb6i0KQaSM27lzp5o3b+7wvh5Jat26tX39ufYt3M7Vvj//XDqvua8ISnIdXNm3b58OHDigli1bllqNFUFJr8OuXbv0z3/+U2+//baCgoLcVqe3K8l1WL9+vZo3b67PP/9cTZs2lY+Pj+rVq6fx48crJyfHrXV7m5Jch5EjRyonJ0djxozR4cOHlZKSonnz5mnp0qV68skn3Vr32QgiZdyxY8dcvqm4cJmrNxyXxr5wVJrfZV5enoYNG6agoCA9+uijpVZjRVCS61BQUKChQ4fq1ltvVZ8+fdxWY0VQkuuQnJysX3/9VWPGjNGYMWO0du1aDRkyRDNmzNB9993ntpq9UUmuQ6dOnbRu3TotXbpUl156qapXr6777rtPU6dO1eOPP+62ml1x6xTvKB02m+2i1pV0Xzgqje/SGKNhw4bpm2++0eeff6769euXVnkVxsVeh5deekm//vqrvvzyS3eUVeFc7HUoKChQenq6w+s+oqOjlZmZqVdeeUWxsbG67LLLSr1eb3Wx12Hr1q0aMGCAOnXqpHfffVdVq1bVunXrNGnSJGVlZemZZ55xR7kuEUTKuBo1arhMtcePH5ckl2m4NPaFo9L4Lo0xuv/++/Xxxx9rzpw56t+/f6nX6e0u9jocPHhQkydP1vTp01W5cmWlpKRIOt07VVBQoJSUFPn7+zvdL4drJf3v0h9//KGePXs6LO/du7deeeUVbdu2jSBSTCW5DqNHj1adOnW0dOlS+0too6OjValSJcXExOiuu+5So0aN3FP4Wbg1U8ZdccUV2r17t/Ly8hyW79ixQ5LOOQfCFVdcYd/uQveFo5JcB+l/IeSjjz7SrFmzdPfdd7utVm92sddh3759OnXqlB555BFVr17d/vnuu++0e/duVa9eXRMmTHB7/d6iJH8fXI1bk07/HZGkSpX4tVRcJbkOP/zwgzp06GAPIYWuvPJKFRQUaPfu3aVfcFE8+owOLtiKFSuMJPPJJ584LO/Vq9d5H8966623jCSzadMm+7Lc3FzTsmVL06lTJ7fV7I1Kch0KCgrMsGHDjM1mM++99567S/VqF3sdTpw4YeLi4pw+bdq0MZGRkSYuLs78+uuvnjgFr1CSvw/vvvuuy3kuxowZYypVqmQSExPdUrM3Ksl1aNiwoWnVqpXTNk8//bSRZH744Qe31OwKQaQc6NGjh6levbp57733zLp168zw4cONJPPxxx/btxk6dKjx8fFx+EuclZVlWrZsaerXr2/mz59v1qxZYwYMGMCEZhfpYq/DQw89ZCSZoUOHmo0bNzp8tm3bZsWplGsXex1cYR6Ri3ex1yEnJ8e0b9/ehISEmFdffdWsWbPGPPXUU8bHx8c89NBDVpxKuXax1+G1114zkkzv3r3NF198YVavXm2eeuop4+vra7p37+7RcyCIlAPp6elmzJgxpm7duqZy5cqmdevWZuHChQ7bDB482Egy+/fvd1j+xx9/mHvvvdeEhYWZgIAA07lzZ7NmzRoPVu89LvY6REREGEkuPxEREZ49CS9Qkr8PZyOIXLySXIdjx46ZBx54wNSpU8f4+fmZJk2amBdffNHk5+d78Ay8Q0muw+eff266dOliatasaapWrWpatmxpnn32WadJztzNZsx/b8wBAAB4GKOCAACAZQgiAADAMgQRAABgGYIIAACwDEEEAABYhiACAAAsQxABAACWIYgAKJHU1FQ99NBDioiIkK+vr2w2mxITE60uC0A5QRABPCQxMVE2m029evWyupRSNW7cOL355ptq27atnn76aU2ZMkWhoaFFbh8fHy+bzXbOzy233FKimiIjIxUZGVmiYwDwDF+rCwBQvq1YsUJNmzbVsmXLLmi/Dh06qG/fvi7XNWvWrDRKA1AOEEQAlMjhw4d1/fXXX/B+HTt2VExMTOkXBKBc4dYMUEb9/PPPGjRokGrXri1/f381bNhQjz76qI4fP+5y+4SEBF1//fWqWrWqatSooUGDBikpKUlRUVGy2WzFbjcvL08vv/yy2rRpo8DAQIWEhCg6OlrLly932G7IkCGy2WwyxighIcF+W2XIkCElOW0nhbe0hgwZon379um2225T9erVVbVqVXXv3l0//vij07YHDhzQgQMHHG73FIaewltDMTEx2rhxo3r27KnQ0FCH7+jkyZOKiYlRs2bNFBAQoLCwMN10003asGGDU30xMTGy2WyKj4/X+++/r5YtWyogIEANGjTQhAkTlJWVZd923759qlSpkm666SaX53rixAkFBASoTZs2pfTtAWUfPSJAGbRhwwbdeOONys7O1m233abIyEht2rRJr7zyipYvX66NGzeqRo0a9u1Xr16tm266Sb6+vho0aJAuueQSxcfHq0uXLqpevXqx2zXGaNCgQVqyZImaNGmi0aNHKzMzU4sWLVLfvn316quvasyYMZKkW265RZGRkYqNjVVERIQ9gLRt27Y0vwq7xMREderUSS1atNDQoUP122+/admyZYqOjtbu3btVp04dhYaGasqUKXrllVckSWPHjrXvHxUV5XC8DRs26LnnnlN0dLRGjBihgwcPSpKys7N1ww03aNOmTWrfvr3Gjh2rI0eO6NNPP9Xq1av16aef6tZbb3Wqb+bMmYqPj9egQYPUt29frVixQtOnT9f27du1cuVK2Ww2NWrUSN27d9eqVat06NAh1atXz+EY8+bNU3Z2toYPH16q3x1Qpnn0Xb9ABbZ//34jyfTs2fOc2+Xn55vLL7/cSDKrVq1yWDdhwgQjyQwbNsy+LC8vz0RERJhKlSqZTZs2OWw/ZMgQI8kU96/63LlzjSTTtWtXk52dbV+elJRkateubfz8/My+ffsc9incvrji4uKMJNOhQwczZcoUl5+NGzfaty/83iSZ6dOnOxxr0qRJRpKZNm2aw/KIiAgTERFxzvYlmQ8++MBp/T/+8Q8jydx1112moKDAvvzHH380/v7+pnr16iYtLc2+fMqUKUaSCQgIMDt37rQvz83NNT169DCSzNy5c+3LFy9ebCSZ2NhYp7Zbt25tAgICzIkTJ1x/eYAXIogAHlLcILJ+/XojyfTu3dtpXUZGhqlRo4YJDAy0B4X4+HgjyQwYMMBp+6SkJOPj41PsINKtWzcjyWzevNlp3bRp04wk8+yzzzosv9ggcq7Pyy+/bN++8Htr2LChyc/PdzhW4bpbb73VYXlxgki7du1crm/UqJHx8/MzSUlJTuseeOABI8nMmzfPvqwwiAwfPtxp+3//+99Gkrnhhhvsy3JyckydOnVMZGSkQ9D5/vvvjSRz9913u6wL8FaMEQHKmO3bt0tyvpUgSVWrVlXHjh116tQp/fLLL5JkHyNxzTXXOG1fr149NWjQ4ILaDgwM1FVXXeW0rrCeH374odjHO5cHHnhA5vT/DDl9zrylUqhNmzaqVMnxP1mFtzZSUlIuuH1X55iWlqZ9+/bpsssuc7ptIp37O7juuuuclnXs2FGBgYEO2/v5+Wno0KFKTEzUmjVr7Ms/+OADSdL9999/gWcClG8EEaCMSUtLkyTVqVPH5fq6detKOj2R2Jnb16pVy+X2RR2nqLaL266nhYSEOC3z9T09zC0/P/+Cj+fqPC/0uz9T7dq1Xe5Tu3Ztp+2HDx8um82mWbNmSTo9OHbhwoVq0qSJunbtWvyTALwAQQQoY4KDgyVJf/75p8v1hcsLtyv8519//XXO7YvbdnHbLe9cPUl0od/9mY4cOeJynyNHjjiFqIYNG6pHjx5atmyZjh49qkWLFiktLY3eEFRIBBGgjGnXrp2k04+Znu3kyZPasmWLAgMD1bRpU0myP+rp6tHSQ4cOKSkp6YLaPnXqlL7//nundQkJCZLc91RMafLx8bmoXpLg4GA1atRI//nPf5ScnOy0/lzfwTfffOO0bMuWLTp16pTL7UeMGKGcnBzNnTtXH3zwgfz8/DR48OALrhko7wgiQBlz7bXXqnHjxlq5cqXWrl3rsG7atGk6evSo7rjjDlWuXFmS1KVLFzVo0EDLli1zChDPPPOM8vLyit124S/CCRMmKDc31748OTlZL730knx9fXXXXXdd7Kl5TFhYmI4ePeowh0dxDR48WLm5uZowYYKMMfblO3fu1EcffaSQkBCXU9DPmzdPP//8s/3nvLw8Pf300/Zjnq1///6qW7euZs6cqW+//VY333xzkbd3AG/GPCKAh+3YsaPISb/at2+vMWPGaPbs2erZs6f69OmjgQMHKiIiQps3b9a6devUuHFjTZ8+3b6Pj4+P3nnnHd18883q2rWrbr/9dtWtW1cJCQlKTk5WmzZt9NNPPxWrtnvuuUdLlizRsmXL1Lp1a/Xt29c+j8ixY8c0c+ZMNWrUqDS+Bm3ZsqXImVVDQ0NdDlgtrm7dumnLli3q16+frrvuOlWuXFldunRRly5dzrvvk08+qeXLl2vevHnavXu3brjhBv3111/69NNPlZubq7lz56patWpO+3Xv3l2dO3fW7bffrrCwMK1YsUI7d+5Uz549dffddztt7+vrq6FDh+q5556TxCBVVGAWPrEDVChnzodR1Kd///727X/66Sdz2223mZo1axo/Pz8TERFhxowZY/766y+Xx1+3bp3p0qWLCQwMNGFhYWbgwIHm4MGDplWrViYkJKTYdebm5poZM2aYK664wvj7+5tq1aqZrl27mmXLlrncXm54fPfMR28Lv7fBgwcXu/309HQzfPhwc8kll5hKlSoZSWbKlCkO7Rf+7EpGRoZ55plnTJMmTUzlypVNaGio6d27t/nmm2+cti18fDcuLs68++67pkWLFsbf39/Uq1fPjB8/3pw8ebLIdvbu3WskmQYNGjg9mgxUFDZjzuh7BOBV0tPTVadOHV1xxRXavHmz1eV4pZiYGMXGxiouLs7lI9fnsmjRIg0aNEixsbGaPHmyewoEyjjGiABeIDMzU+np6Q7L8vPzNW7cOJ06dcrlmAZYyxhjH3czbNgwq8sBLMMYEcAL/Prrr+rSpYt69uypRo0aKT09Xd9884127dqlli1b2t8PA+vt2LFDX331lTZs2KDNmzdr5MiRuvTSS60uC7AMQQTwApdeeqkGDhyohIQErVq1Snl5eWrQoIGeeOIJTZw4UVWrVrW6RPzX1q1b9fTTTys0NFT33nuvXnzxRatLAizFGBEAAGAZxogAAADLEEQAAIBlCCIAAMAyBBEAAGAZgggAALAMQQQAAFiGIAIAACxDEAEAAJYhiAAAAMv8PybAENOLRClrAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                                    \r"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAigAAAHSCAYAAADG7DBnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABCC0lEQVR4nO3deVwW9f7//+clIKAIBK64gMtxywXNsk56gNRc0hSLn0uLW5uVppWeSFP4nkxa1CxtMxPUxCTx2HHhqAlWRyXNFsmtVBTx5IYCbsgyvz/8cB2vAOVChAEe99vtuiXvmffMa8arePae98xYDMMwBAAAYCLVyrsAAACAPyOgAAAA0yGgAAAA0yGgAAAA0yGgAAAA0yGgAAAA0yGgAAAA0yGgAAAA0yGgAAAA0yGgACggNzdXs2fPVqdOnVSzZk1ZLBZZLBb985//VGBgoCwWi8LCwkplX6W9PQCVg2N5FwDAfCZMmKB58+ZJkqpXr6569epJklxcXMqzLABVCCMoAGxkZmbq448/liS99dZbunz5sv744w/98ccf6tOnj5o0aaJWrVqpdu3a5VwpgMqMERQANvbt26fs7GxJ0tixY2WxWGyWL168uDzKAlDFMIICwMbFixetf3ZzcyvHSgBUZQQUAJKkyMhIWSwWBQYGWtvyJ8de2369Sa05OTn65JNPFBgYqNq1a8vJyUne3t5q1aqVhgwZos8+++y6NRiGoQULFqhr165yd3dXrVq1dM8992jp0qU3rP/gwYMaN26c2rRpIzc3N9WoUUNt2rTRhAkTdPTo0eses5+fnyQpPj5egwYNUoMGDeTg4KCRI0fecL8Abg0u8QCQJLm6uqpevXq6cuWKzp49K0nWybGS5OXldd3+ubm56tevnzZu3Ght8/Dw0IULF5SWlqYDBw5oxYoVGj16dJH9g4ODtXr1ajk6OqpGjRrKzMzU9u3btX37dv32228KDw8vtO+CBQv03HPPWS9NOTs7q1q1atq3b5/27dunRYsW6csvv1SvXr2KrP+9997ThAkTZBiGPDw85ODgcN3jBXCLGQBwjfj4eEOSUdR/HgICAgxJxvTp023alyxZYkgyXFxcjE8//dTIzMw0DMMw8vLyjBMnThixsbHGQw89VOT2brvtNsPDw8OIjIw0Ll68aBiGYaSkpBgDBgwwJBnVqlUzDhw4UKD/qlWrDEmGk5OT8corrxjJyclGXl6ekZeXZ+zbt88ICQkxJBnu7u7GkSNHbPouWrTIWrODg4MxcuRI4+jRo4ZhGEZOTo7x+++/233+AJQOLvEAKBVbt26VJD3++OMaM2aMdf6KxWJR3bp1FRwcrC+//LLI/mfPntWqVas0YsQIubq6SpIaNWqkmJgY+fj4KC8vTytWrLDpc+XKFT3//POSpI8++kgzZ86Ur6+v9bJUq1attGLFCj344IPKyMjQ7NmzC9335cuXNXDgQC1atEiNGzeWJDk4OKh58+Y3d1IAlBgBBUCp8PT0lCT98ccfJep/7733KigoqEC7s7OzevfuLUn65ZdfbJatX79eqampqlevnkaNGlXkth9//HFJ0r///e8i1wkNDS1J2QBuEeagACgV/fr1U0REhL766iv17dtXjz/+uAICAuTj41Os/l27di1yWf420tLSbNq/++47SVdHXxo0aFBk/ytXrkiSjhw5UuhyV1dXde7cuVh1AigbBBQApaJbt2568803NXXqVMXFxSkuLk7S1cs0PXv21OOPP17oCEm+WrVqFbnM0fHqf6ryJ8HmO378uKSrAeTEiRM3rPHSpUuFtnt7e6taNQaUATPh30gApWbSpEk6fPiw5syZo0GDBqlu3bo6duyYIiMjdd999ykkJKRAyLgZubm5kqQ+ffrIMIxifQrDHTuA+RBQAJQqHx8fTZgwQatWrdKJEyf0yy+/6IknnpAkffnll/rwww9LbV/169eXJO3evbvUtgnAHAgoAG6p9u3ba8GCBbr33nslyeY5KTcrf5upqanW+SgAKgcCCoBSkZWVdd3l+bcOl+bllAEDBlgnx77wwgs2j+kvzJ8n2QIwLwIKgFIxaNAgjR49WuvXr9e5c+es7WlpaXr99df19ddfS7p6t09pcXFx0QcffCCLxaJdu3bp3nvv1b///W/rXTuSdPjwYX388ce666679MEHH5TavgHcWtzFA6BUXLp0SYsWLdKiRYskSe7u7pKkjIwM6zoPP/ywdT5KaRk0aJCWLFmip556Sj/99JP69OkjR0dHeXh46Pz58zYjOwMHDizVfQO4dQgoAErF+++/r/Xr12vLli367bff9Mcff+jy5cvy8fFRly5dNGLECA0ePPiW7PuRRx7Rfffdpw8++EBxcXH6/fffde7cObm5ualNmzbq1q2bBg0a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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#fig, ax = plt.subplots(5,1,figsize=(9,20))\n",
    "ax = [0,0,0,0,0]\n",
    "plot_entropy_dist(copy.deepcopy(model_s),retain_loader,forget_loader,test_loader_full, 'SCRUB',ax[4])\n",
    "plot_entropy_dist(copy.deepcopy(model),retain_loader,forget_loader,test_loader_full, 'original', ax[0])\n",
    "plot_entropy_dist(copy.deepcopy(model0),retain_loader,forget_loader,test_loader_full, 'retrain', ax[1])\n",
    "plot_entropy_dist(copy.deepcopy(model_ft),retain_loader,forget_loader,test_loader_full, 'finetuned',ax[2])\n",
    "plot_entropy_dist(copy.deepcopy(modelf),retain_loader,forget_loader,test_loader_full, 'fisher',ax[3])"
   ]
  }
 ],
 "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
}
