{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Supermasks in Superposition: Training and Task Inference\n",
    "\n",
    "<img src=\"images/teaser_supsup.png\">"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Packages loaded\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.optim as optim\n",
    "import torch.nn as nn\n",
    "import torch.autograd as autograd\n",
    "import torch.nn.functional as F\n",
    "\n",
    "import torchvision\n",
    "import numpy as np\n",
    "import math\n",
    "\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "print(\"Packages loaded\")\n",
    "# note at edits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>.container { width:100% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from IPython.core.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:100% !important; }</style>\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training\n",
    "\n",
    "We train our model using the procedure from \"What's Hidden in a Randomly Weighted Neural Network\" (Ramanujan et al. 2019). Below is a modification of the layers (using signed constant initialization) from this paper for our continual learning setup. As a deviation from this setup, we assume that an edge (u, v) is included in the subnetwork if its score is greater than 0, rather than use it's absolute magnitude to construct a threshold. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Subnetwork forward from hidden networks   \n",
    "class GetSubnet(autograd.Function):\n",
    "    @staticmethod\n",
    "    def forward(ctx, scores, k):\n",
    "        # Get the supermask by sorting the scores and using the top k%\n",
    "        out = scores.clone()\n",
    "        _, idx = scores.flatten().sort()\n",
    "        j = int((1 - k) * scores.numel())\n",
    "\n",
    "        # flat_out and out access the same memory.\n",
    "        flat_out = out.flatten()\n",
    "        flat_out[idx[:j]] = 0\n",
    "        flat_out[idx[j:]] = 1\n",
    "\n",
    "        return out\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, g):\n",
    "        # send the gradient g straight-through on the backward pass.\n",
    "        return g, None\n",
    "\n",
    "def mask_init(module):\n",
    "    scores = torch.Tensor(module.weight.size())\n",
    "    nn.init.kaiming_uniform_(scores, a=math.sqrt(5))\n",
    "    return scores\n",
    "\n",
    "\n",
    "def signed_constant(module):\n",
    "    fan = nn.init._calculate_correct_fan(module.weight, 'fan_in')\n",
    "    gain = nn.init.calculate_gain('relu')\n",
    "    std = gain / math.sqrt(fan)\n",
    "    module.weight.data = module.weight.data.sign() * std\n",
    "\n",
    "\n",
    "class MultitaskMaskLinear(nn.Linear):\n",
    "    def __init__(self, *args, num_tasks=1, sparsity=0.5, **kwargs):\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.num_tasks = num_tasks\n",
    "        self.sparsity = sparsity\n",
    "        self.scores = nn.ParameterList(\n",
    "            [\n",
    "                nn.Parameter(mask_init(self))\n",
    "                for _ in range(num_tasks)\n",
    "            ]\n",
    "        )\n",
    "        \n",
    "        # Keep weights untrained\n",
    "        self.weight.requires_grad = False\n",
    "        signed_constant(self)\n",
    "    \n",
    "    @torch.no_grad()\n",
    "    def cache_masks(self):\n",
    "        self.register_buffer(\n",
    "            \"stacked\",\n",
    "            torch.stack(\n",
    "                [\n",
    "                    GetSubnet.apply(self.scores[j], self.sparsity)\n",
    "                    for j in range(self.num_tasks)\n",
    "                ]\n",
    "            ),\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        if self.task < 0:\n",
    "            # Superimposed forward pass\n",
    "            alpha_weights = self.alphas[: self.num_tasks_learned]\n",
    "            idxs = (alpha_weights > 0).squeeze().view(self.num_tasks_learned)\n",
    "            if len(idxs.shape) == 0:\n",
    "                idxs = idxs.view(1)\n",
    "            subnet = (\n",
    "                alpha_weights[idxs]\n",
    "                * self.stacked[: self.num_tasks_learned][idxs]\n",
    "            ).sum(dim=0)\n",
    "        else:\n",
    "            # Subnet forward pass (given task info in self.task)\n",
    "            subnet = GetSubnet.apply(self.scores[self.task], self.sparsity)\n",
    "        w = self.weight * subnet\n",
    "        x = F.linear(x, w, self.bias)\n",
    "        return x\n",
    "\n",
    "\n",
    "    def __repr__(self):\n",
    "        return f\"MultitaskMaskLinear({self.shape()})\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BasisMultitaskMaskLinear(nn.Linear):\n",
    "    def __init__(self, *args, num_tasks=1, num_seed_tasks_learned=1, start_at_optimal=True, sparsity=0.5, **kwargs):\n",
    "        super().__init__(*args, **kwargs)\n",
    "        assert num_tasks >= num_seed_tasks_learned, \"Seed tasks cannot be more than total tasks!\"\n",
    "        self.num_tasks = num_tasks\n",
    "        self.num_seed_tasks_learned = num_seed_tasks_learned\n",
    "        self.sparsity = sparsity\n",
    "        self.scores = nn.ParameterList(\n",
    "            [\n",
    "                nn.Parameter(mask_init(self))\n",
    "                for _ in range(num_tasks)\n",
    "            ]\n",
    "        )\n",
    "        self.task = -1\n",
    "        \n",
    "        # Keep weights untrained\n",
    "        self.weight.requires_grad = False\n",
    "        for s in self.scores:\n",
    "            s.requires_grad = False\n",
    "        self.scores.requires_grad = False\n",
    "        if start_at_optimal:\n",
    "            self.basis_alphas = nn.ParameterList(\n",
    "                [\n",
    "                    nn.Parameter(torch.eye(self.num_seed_tasks_learned)[i])\n",
    "                    for i in range(self.num_seed_tasks_learned)\n",
    "                ]\n",
    "                +\n",
    "                [\n",
    "                    nn.Parameter(torch.ones(self.num_seed_tasks_learned)/self.num_seed_tasks_learned)\n",
    "                    for _ in range(self.num_seed_tasks_learned, self.num_tasks)\n",
    "                ]\n",
    "            )\n",
    "        else:\n",
    "            self.basis_alphas = nn.ParameterList(\n",
    "                [\n",
    "                    nn.Parameter(torch.ones(self.num_seed_tasks_learned)/self.num_seed_tasks_learned)\n",
    "                    for _ in range(self.num_tasks)\n",
    "                ]\n",
    "            )\n",
    "        \n",
    "        signed_constant(self)\n",
    "    \n",
    "    @torch.no_grad()\n",
    "    def cache_masks(self):\n",
    "        self.register_buffer(\n",
    "            \"stacked\",\n",
    "            torch.stack(\n",
    "                [\n",
    "                    GetSubnet.apply(self.scores[j], self.sparsity)\n",
    "                    for j in range(self.num_tasks)\n",
    "                ]\n",
    "            ),\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        if self.task < 0:\n",
    "            raise NotImplemented(\"Need task identity at inference time.\")\n",
    "        else:\n",
    "            # Subnet forward pass (given task info in self.task)\n",
    "            subnet = self.stacked[: self.num_seed_tasks_learned][0]\n",
    "            task_alpha = self.basis_alphas[self.task]\n",
    "            w = self.weight * subnet * task_alpha[0]\n",
    "            for i in range(1, self.num_seed_tasks_learned):\n",
    "                subnet = self.stacked[: self.num_seed_tasks_learned][i]\n",
    "                w += self.weight * subnet * task_alpha[i]\n",
    "        x = F.linear(x, w, self.bias)\n",
    "        return x\n",
    "\n",
    "\n",
    "    def __repr__(self):\n",
    "        return f\"BasisMultitaskMaskLinear({self.shape()})\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BasisMultitaskMaskLinearFrozen(nn.Linear):\n",
    "    def __init__(self, *args, num_tasks=1, num_seed_tasks_learned=1, start_at_optimal=True, sparsity=0.5, **kwargs):\n",
    "        super().__init__(*args, **kwargs)\n",
    "        assert num_tasks >= num_seed_tasks_learned, \"Seed tasks cannot be more than total tasks!\"\n",
    "        self.num_tasks = num_tasks\n",
    "        self.sparsity = sparsity\n",
    "        self.num_seed_tasks_learned = num_seed_tasks_learned\n",
    "        self.scores = nn.ParameterList(\n",
    "            [\n",
    "                nn.Parameter(mask_init(self))\n",
    "                for _ in range(num_tasks)\n",
    "            ]\n",
    "        )\n",
    "        self.task = -1\n",
    "        \n",
    "        # Keep weights untrained\n",
    "        self.weight.requires_grad = False\n",
    "        for s in self.scores:\n",
    "            s.requires_grad = False\n",
    "        self.scores.requires_grad = False\n",
    "        if start_at_optimal:\n",
    "            self.basis_alphas = nn.ParameterList(\n",
    "                [\n",
    "                    nn.Parameter(torch.eye(self.num_seed_tasks_learned)[i])\n",
    "                    for i in range(self.num_seed_tasks_learned)\n",
    "                ]\n",
    "                +\n",
    "                [\n",
    "                    nn.Parameter(torch.ones(self.num_seed_tasks_learned)/self.num_seed_tasks_learned)\n",
    "                    for _ in range(self.num_seed_tasks_learned, self.num_tasks)\n",
    "                ]\n",
    "            )\n",
    "        else:\n",
    "            self.basis_alphas = nn.ParameterList(\n",
    "                [\n",
    "                    nn.Parameter(torch.ones(self.num_seed_tasks_learned)/self.num_seed_tasks_learned)\n",
    "                    for _ in range(self.num_tasks)\n",
    "                ]\n",
    "            )\n",
    "        for a in self.basis_alphas:\n",
    "            a.requires_grad = False\n",
    "        self.basis_alphas.requires_grad = False\n",
    "        \n",
    "        signed_constant(self)\n",
    "    \n",
    "    @torch.no_grad()\n",
    "    def cache_masks(self):\n",
    "        self.register_buffer(\n",
    "            \"stacked\",\n",
    "            torch.stack(\n",
    "                [\n",
    "                    GetSubnet.apply(self.scores[j], self.sparsity)\n",
    "                    for j in range(self.num_tasks)\n",
    "                ]\n",
    "            ),\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        if self.task < 0:\n",
    "            raise NotImplemented(\"Need task identity at inference time.\")\n",
    "        else:\n",
    "            # Subnet forward pass (given task info in self.task)\n",
    "            subnet = self.stacked[: self.num_seed_tasks_learned][0]\n",
    "            task_alpha = self.basis_alphas[self.task]\n",
    "            w = self.weight * subnet * task_alpha[0]\n",
    "            for i in range(1, self.num_seed_tasks_learned):\n",
    "                subnet = self.stacked[: self.num_seed_tasks_learned][i]\n",
    "                w += self.weight * subnet * task_alpha[i]\n",
    "        x = F.linear(x, w, self.bias)\n",
    "        return x\n",
    "\n",
    "\n",
    "    def __repr__(self):\n",
    "        return f\"BasisMultitaskMaskLinearFrozen({self.shape()})\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "ValidConvs = [\n",
    "    MultitaskMaskLinear,\n",
    "    BasisMultitaskMaskLinear,\n",
    "    BasisMultitaskMaskLinearFrozen,\n",
    "]\n",
    "\n",
    "def isoftype(m, cls_lst):\n",
    "    return any([isinstance(m, c) for c in cls_lst])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Utility functions\n",
    "def set_model_task(model, task, verbose=True):\n",
    "    for n, m in model.named_modules():\n",
    "        if isoftype(m, ValidConvs):\n",
    "            if verbose:\n",
    "                print(f\"=> Set task of {n} to {task}\")\n",
    "            m.task = task\n",
    "\n",
    "def cache_masks(model):\n",
    "    for n, m in model.named_modules():\n",
    "        if isoftype(m, ValidConvs):\n",
    "            print(f\"=> Caching mask state for {n}\")\n",
    "            m.cache_masks()\n",
    "\n",
    "def set_num_tasks_learned(model, num_tasks_learned):\n",
    "    for n, m in model.named_modules():\n",
    "        if isoftype(m, ValidConvs):\n",
    "            print(f\"=> Setting learned tasks of {n} to {num_tasks_learned}\")\n",
    "            m.num_tasks_learned = num_tasks_learned\n",
    "\n",
    "def set_alphas(model, alphas, verbose=True):\n",
    "    for n, m in model.named_modules():\n",
    "        if isoftype(m, ValidConvs):\n",
    "            if verbose:\n",
    "                print(f\"=> Setting alphas for {n}\")\n",
    "            m.alphas = alphas"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Model\n",
    "\n",
    "For simplicity we use a simple 3-layer fully connected neural network. Note that you can make any neural by replacing a standard layer with its corresponding mask layer."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Multitask Model, a simple fully connected model in this case\n",
    "class MultitaskFC(nn.Module):\n",
    "    def __init__(self, hidden_size, num_tasks, sparsity):\n",
    "        super().__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            MultitaskMaskLinear(\n",
    "                784,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            MultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            MultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                100,\n",
    "                num_tasks=num_tasks,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            )\n",
    "        )\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return self.model(x.flatten(1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Multitask Model, a simple fully connected model in this case\n",
    "class BasisMultitaskFC(nn.Module):\n",
    "    def __init__(self, hidden_size, num_tasks, num_seed_tasks_learned, sparsity, start_at_optimal=True):\n",
    "        super().__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            BasisMultitaskMaskLinear(\n",
    "                784,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            BasisMultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            BasisMultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                100,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            )\n",
    "        )\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return self.model(x.flatten(1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BasisHiddenOnlyMultitaskFC(nn.Module):\n",
    "    def __init__(self, hidden_size, num_tasks, num_seed_tasks_learned, sparsity, start_at_optimal=True):\n",
    "        super().__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            BasisMultitaskMaskLinear(\n",
    "                784,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            BasisMultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            MultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                100,\n",
    "                num_tasks=num_tasks,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            )\n",
    "        )\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return self.model(x.flatten(1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "class BasisHiddenOnlyFrozenMultitaskFC(nn.Module):\n",
    "    def __init__(self, hidden_size, num_tasks, num_seed_tasks_learned, sparsity, start_at_optimal=True):\n",
    "        super().__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            BasisMultitaskMaskLinearFrozen(\n",
    "                784,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            BasisMultitaskMaskLinearFrozen(\n",
    "                hidden_size,\n",
    "                hidden_size,\n",
    "                num_tasks=num_tasks,\n",
    "                num_seed_tasks_learned=num_seed_tasks_learned,\n",
    "                start_at_optimal=start_at_optimal,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            ),\n",
    "            nn.ReLU(),\n",
    "            MultitaskMaskLinear(\n",
    "                hidden_size,\n",
    "                100,\n",
    "                num_tasks=num_tasks,\n",
    "                sparsity=sparsity,\n",
    "                bias=False\n",
    "            )\n",
    "        )\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return self.model(x.flatten(1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dataset \n",
    "\n",
    "Our \"base\" dataset is MNIST. Each task is a random permutation of the pixels of MNIST. Namely, given a dataset $\\{(x_i, y_i)\\}_i$ for each task $t$, we take a random permutation $S^t\\in S_{784}$ and construct a dataset $\\{(S^t(x_i), y_i)\\}_i$. \n",
    "\n",
    "Below we show this process and an example of a particular task. `MNISTPerm` uses an update task method to generate a particular sub-task. To assure these splits are reproducible, `MNISTPerm` takes a `seed` argument. In our paper we evaluate on seeds 0 through 4."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=493x269 at 0x7FC34DD67A90>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class MNISTPerm:\n",
    "    class permute(object):\n",
    "        def __call__(self, tensor):\n",
    "            out = tensor.flatten()\n",
    "            out = out[self.perm]\n",
    "            return out.view(1, 28, 28)\n",
    "\n",
    "        def __repr__(self):\n",
    "            return self.__class__.__name__\n",
    "\n",
    "    def __init__(self, seed=0):\n",
    "        super(MNISTPerm, self).__init__()\n",
    "        \n",
    "        data_root = \"mnist\"\n",
    "        self.permuter = self.permute()\n",
    "        self.seed = seed\n",
    "        train_dataset = torchvision.datasets.MNIST(\n",
    "            data_root,\n",
    "            train=True,\n",
    "            download=True,\n",
    "            transform=torchvision.transforms.Compose(\n",
    "                [\n",
    "                    torchvision.transforms.ToTensor(),\n",
    "                    torchvision.transforms.Normalize((0.1307,), (0.3081,)),\n",
    "                    self.permuter,\n",
    "                ]\n",
    "            ),\n",
    "        )\n",
    "\n",
    "        # Data loading code\n",
    "        self.train_loader = torch.utils.data.DataLoader(\n",
    "            train_dataset, batch_size=128, shuffle=True\n",
    "        )\n",
    "        self.val_loader = torch.utils.data.DataLoader(\n",
    "            torchvision.datasets.MNIST(\n",
    "                data_root,\n",
    "                train=False,\n",
    "                transform=torchvision.transforms.Compose(\n",
    "                    [\n",
    "                        torchvision.transforms.ToTensor(),\n",
    "                        torchvision.transforms.Normalize((0.1307,), (0.3081,)),\n",
    "                        self.permuter,\n",
    "                    ]\n",
    "                ),\n",
    "            ),\n",
    "            batch_size=128,\n",
    "            shuffle=False,\n",
    "        )\n",
    "\n",
    "    def update_task(self, i):\n",
    "        np.random.seed(i + self.seed)\n",
    "        self.permuter.__setattr__(\"perm\", np.random.permutation(784))\n",
    "    \n",
    "    def unpermute(self):\n",
    "        self.permuter.__setattr__(\"perm\", np.arange(784))\n",
    "\n",
    "mnist = MNISTPerm()\n",
    "\n",
    "# Showing some example images from MNISTPerm\n",
    "mnist.unpermute()\n",
    "batch, labels = next(iter(mnist.val_loader))\n",
    "\n",
    "mnist.update_task(0)\n",
    "task0, labels = next(iter(mnist.val_loader))\n",
    "\n",
    "torchvision.transforms.ToPILImage()(\n",
    "    torchvision.utils.make_grid(\n",
    "        torch.cat([batch, task0], dim=-1)[:64],\n",
    "        normalize=True,\n",
    "        padding=5,\n",
    "        pad_value=0.2\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Simple train and evaluation loops for classification"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Finding supermasks per task\n",
    "\n",
    "def train(model, trainloader, optimizer, epoch):\n",
    "    model.train()\n",
    "\n",
    "    criterion = nn.CrossEntropyLoss()\n",
    "    num_correct = 0\n",
    "    total_seen = 0\n",
    "    for i, (batch, labels) in tqdm(\n",
    "        enumerate(trainloader),\n",
    "        ascii=True,\n",
    "        total=len(trainloader)\n",
    "    ):\n",
    "        logits = model(batch)\n",
    "        loss = criterion(logits, labels)\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        if i % 20 == 0:\n",
    "            predictions = logits.argmax(dim=-1)\n",
    "            num_correct += (predictions == labels).float().sum()\n",
    "            total_seen += logits.size(0) \n",
    "            tqdm.write(\n",
    "                (f\"e{epoch} {i+1}/{len(trainloader)}\"\n",
    "                f\" => Loss {loss.item():0.4f}, \"\n",
    "                f\"Acc@1 {(num_correct / total_seen):0.4f}\"),\n",
    "                end=\"\\r\"\n",
    "            )\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def evaluate(model, val_loader, epoch):\n",
    "    model.eval()\n",
    "    num_correct = 0\n",
    "    total_seen = 0\n",
    "    for batch, labels in tqdm(\n",
    "        val_loader,\n",
    "        ascii=True,\n",
    "        total=len(val_loader)\n",
    "    ):\n",
    "        logits = model(batch)\n",
    "        predictions = logits.argmax(dim=-1)\n",
    "        num_correct += (predictions == labels).float().sum()\n",
    "        total_seen += logits.size(0) \n",
    "    \n",
    "\n",
    "    tqdm.write(\n",
    "        f\"Val Perf after {epoch + 1} epochs \"\n",
    "        f\"Acc@1 {(num_correct / total_seen):0.4f}\", \n",
    "    )\n",
    "    return num_correct / total_seen\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "For any scenario where task ID is given during train time, we simply train each supermask independently, one per task. We make use of our utility function `set_model_task` to do this. We use 5 tasks for demonstration purposes. Feel free to increase `num_tasks` in the following cell. In our paper we use as many as 2500 tasks with no drop in performance for either task inference or validation accuracy."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6232d93035434b3185c7e549a92db491",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3245, Acc@1 0.8503\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a6cc8fac99f14753b6e0e9e0f5dbee91",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9123\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 1\n",
      "=> Set task of model.0 to 1\n",
      "=> Set task of model.2 to 1\n",
      "=> Set task of model.4 to 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "65b0cdeeeada4c6d93b480cebaf423d1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3080, Acc@1 0.8350\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1b683c462bf24045a333ee76d65cc8ec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9123\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 2\n",
      "=> Setting learned tasks of model.2 to 2\n",
      "=> Setting learned tasks of model.4 to 2\n",
      "\n",
      "Training for task 2\n",
      "=> Set task of model.0 to 2\n",
      "=> Set task of model.2 to 2\n",
      "=> Set task of model.4 to 2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c4150fd6153a425b9122f4c098af3ee5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3267, Acc@1 0.8408\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d6a1869d4a8846e5938196efd2353d06",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9141\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 3\n",
      "=> Setting learned tasks of model.2 to 3\n",
      "=> Setting learned tasks of model.4 to 3\n",
      "\n",
      "Training for task 3\n",
      "=> Set task of model.0 to 3\n",
      "=> Set task of model.2 to 3\n",
      "=> Set task of model.4 to 3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "17a8aa86826648d79a49b2189ff452a5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3086, Acc@1 0.8369\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "420b712a2d4a4dc58e76963c8ad03a97",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9144\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 4\n",
      "=> Setting learned tasks of model.2 to 4\n",
      "=> Setting learned tasks of model.4 to 4\n",
      "\n",
      "Training for task 4\n",
      "=> Set task of model.0 to 4\n",
      "=> Set task of model.2 to 4\n",
      "=> Set task of model.4 to 4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c1a56f2b322f4a20861c177e0788218c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2680, Acc@1 0.8392\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b8f25a76c11418aab22b5f05e45bb9d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9112\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 5\n",
      "=> Setting learned tasks of model.2 to 5\n",
      "=> Setting learned tasks of model.4 to 5\n",
      "\n",
      "Training for task 5\n",
      "=> Set task of model.0 to 5\n",
      "=> Set task of model.2 to 5\n",
      "=> Set task of model.4 to 5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cd9b209433a84534bc72ccf581f53938",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3552, Acc@1 0.8206\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "432a4269abbb491a92b98d9c90eb839a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9153\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 6\n",
      "=> Setting learned tasks of model.2 to 6\n",
      "=> Setting learned tasks of model.4 to 6\n",
      "\n",
      "Training for task 6\n",
      "=> Set task of model.0 to 6\n",
      "=> Set task of model.2 to 6\n",
      "=> Set task of model.4 to 6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "57040ff235f84570a699606489cb09b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3098, Acc@1 0.8379\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "02b1e2f9948e4658b8e9754fd5e187e4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9124\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 7\n",
      "=> Setting learned tasks of model.2 to 7\n",
      "=> Setting learned tasks of model.4 to 7\n",
      "\n",
      "Training for task 7\n",
      "=> Set task of model.0 to 7\n",
      "=> Set task of model.2 to 7\n",
      "=> Set task of model.4 to 7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9770bdcf41064314af8913be886774d3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2037, Acc@1 0.8356\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3567286d2d244262bbea3f96e0e5fa4b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9112\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 8\n",
      "=> Setting learned tasks of model.2 to 8\n",
      "=> Setting learned tasks of model.4 to 8\n",
      "\n",
      "Training for task 8\n",
      "=> Set task of model.0 to 8\n",
      "=> Set task of model.2 to 8\n",
      "=> Set task of model.4 to 8\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c09d105144334465a11b9349493f5320",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3045, Acc@1 0.8467\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a9a3acbddc98403790be7696607bea82",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9154\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 9\n",
      "=> Setting learned tasks of model.2 to 9\n",
      "=> Setting learned tasks of model.4 to 9\n",
      "\n",
      "Training for task 9\n",
      "=> Set task of model.0 to 9\n",
      "=> Set task of model.2 to 9\n",
      "=> Set task of model.4 to 9\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "353a8dc37e1448bda101f0c16debb2c3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3043, Acc@1 0.8395\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d06492f5973348aa8f8e158f672428ea",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9143\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 10\n",
      "=> Setting learned tasks of model.2 to 10\n",
      "=> Setting learned tasks of model.4 to 10\n",
      "\n",
      "Training for task 10\n",
      "=> Set task of model.0 to 10\n",
      "=> Set task of model.2 to 10\n",
      "=> Set task of model.4 to 10\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b41245572814ff69ee551042afb22d8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2701, Acc@1 0.8340\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fd4b9a4cadd5451eb5e39ab76ea3daa0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9144\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 11\n",
      "=> Setting learned tasks of model.2 to 11\n",
      "=> Setting learned tasks of model.4 to 11\n",
      "\n",
      "Training for task 11\n",
      "=> Set task of model.0 to 11\n",
      "=> Set task of model.2 to 11\n",
      "=> Set task of model.4 to 11\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "52c2a4f4016d4bdbbf7b905df3029702",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3938, Acc@1 0.8333\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b0ebe094f6394e5aaea20870d670597d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9104\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 12\n",
      "=> Setting learned tasks of model.2 to 12\n",
      "=> Setting learned tasks of model.4 to 12\n",
      "\n",
      "Training for task 12\n",
      "=> Set task of model.0 to 12\n",
      "=> Set task of model.2 to 12\n",
      "=> Set task of model.4 to 12\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "db3744e2c18443c69bd687bcb737ff82",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4059, Acc@1 0.8382\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7f51b6692f1f408ab4696dfa24431979",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9161\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 13\n",
      "=> Setting learned tasks of model.2 to 13\n",
      "=> Setting learned tasks of model.4 to 13\n",
      "\n",
      "Training for task 13\n",
      "=> Set task of model.0 to 13\n",
      "=> Set task of model.2 to 13\n",
      "=> Set task of model.4 to 13\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "770d3d1e51f442b78530d829e7f1a369",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3382, Acc@1 0.8431\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "254bb8d3e1c547efaddc7b08521c5b33",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9120\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 14\n",
      "=> Setting learned tasks of model.2 to 14\n",
      "=> Setting learned tasks of model.4 to 14\n",
      "\n",
      "Training for task 14\n",
      "=> Set task of model.0 to 14\n",
      "=> Set task of model.2 to 14\n",
      "=> Set task of model.4 to 14\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8513dc1d85964c89b3fd24914ee911af",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3124, Acc@1 0.8337\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "94d9dda920e3447580f4cd655914a25a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9123\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 15\n",
      "=> Setting learned tasks of model.2 to 15\n",
      "=> Setting learned tasks of model.4 to 15\n",
      "\n",
      "Training for task 15\n",
      "=> Set task of model.0 to 15\n",
      "=> Set task of model.2 to 15\n",
      "=> Set task of model.4 to 15\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d818b81e2ab94ad1a0e9098604ee65a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4136, Acc@1 0.8327\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "195e846296034d6bb6e071a7eae6e12c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9117\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 16\n",
      "=> Setting learned tasks of model.2 to 16\n",
      "=> Setting learned tasks of model.4 to 16\n",
      "\n",
      "Training for task 16\n",
      "=> Set task of model.0 to 16\n",
      "=> Set task of model.2 to 16\n",
      "=> Set task of model.4 to 16\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0acc2b1000744542aee637964ed0d187",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2937, Acc@1 0.8356\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "52f091c8a114464988daf31d3fa16292",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9107\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 17\n",
      "=> Setting learned tasks of model.2 to 17\n",
      "=> Setting learned tasks of model.4 to 17\n",
      "\n",
      "Training for task 17\n",
      "=> Set task of model.0 to 17\n",
      "=> Set task of model.2 to 17\n",
      "=> Set task of model.4 to 17\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4162db5c546e49c8993bd0071f06454c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3734, Acc@1 0.8320\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4cb445af057040238d47dce01176609e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9143\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 18\n",
      "=> Setting learned tasks of model.2 to 18\n",
      "=> Setting learned tasks of model.4 to 18\n",
      "\n",
      "Training for task 18\n",
      "=> Set task of model.0 to 18\n",
      "=> Set task of model.2 to 18\n",
      "=> Set task of model.4 to 18\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "10ba5900941c4511a15ed9f3c245d917",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3568, Acc@1 0.8369\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e73e41c492684945aae395d6cb3e6d8d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9106\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 19\n",
      "=> Setting learned tasks of model.2 to 19\n",
      "=> Setting learned tasks of model.4 to 19\n",
      "\n",
      "Training for task 19\n",
      "=> Set task of model.0 to 19\n",
      "=> Set task of model.2 to 19\n",
      "=> Set task of model.4 to 19\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "28fe7bcd3c5540ae867e3c69619bced1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3247, Acc@1 0.8424\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4fcb780d83c34a9ab336dcc8a888395b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9048\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 20\n",
      "=> Setting learned tasks of model.2 to 20\n",
      "=> Setting learned tasks of model.4 to 20\n",
      "\n",
      "Training for task 20\n",
      "=> Set task of model.0 to 20\n",
      "=> Set task of model.2 to 20\n",
      "=> Set task of model.4 to 20\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "11c30f17ae6b420da71b2e7be6358856",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4031, Acc@1 0.8411\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "67c7a2751bc84d01baa368c4c863eda9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9109\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 21\n",
      "=> Setting learned tasks of model.2 to 21\n",
      "=> Setting learned tasks of model.4 to 21\n",
      "\n",
      "Training for task 21\n",
      "=> Set task of model.0 to 21\n",
      "=> Set task of model.2 to 21\n",
      "=> Set task of model.4 to 21\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2bd551c7d9404f7bbf6824cb10da3bf7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2920, Acc@1 0.8473\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0fe4a3c0cece46e1b3c136cd16cf190a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9132\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 22\n",
      "=> Setting learned tasks of model.2 to 22\n",
      "=> Setting learned tasks of model.4 to 22\n",
      "\n",
      "Training for task 22\n",
      "=> Set task of model.0 to 22\n",
      "=> Set task of model.2 to 22\n",
      "=> Set task of model.4 to 22\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ecb60af3daad4a49b8a68fb99a2a5fab",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2815, Acc@1 0.8447\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fc9805606a60454598c50c40c5683b4c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9125\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 23\n",
      "=> Setting learned tasks of model.2 to 23\n",
      "=> Setting learned tasks of model.4 to 23\n",
      "\n",
      "Training for task 23\n",
      "=> Set task of model.0 to 23\n",
      "=> Set task of model.2 to 23\n",
      "=> Set task of model.4 to 23\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9aaad04985464149a2a21c922b32bb6f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2969, Acc@1 0.8464\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "37df95f4cef6435a88237b98ab93af7b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9118\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 24\n",
      "=> Setting learned tasks of model.2 to 24\n",
      "=> Setting learned tasks of model.4 to 24\n",
      "\n",
      "Training for task 24\n",
      "=> Set task of model.0 to 24\n",
      "=> Set task of model.2 to 24\n",
      "=> Set task of model.4 to 24\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "847ac505ec8b43d68dd87b8863035c51",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4044, Acc@1 0.8385\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "656d19b9f5a8460c8868eded57cd27a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9130\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 25\n",
      "=> Setting learned tasks of model.2 to 25\n",
      "=> Setting learned tasks of model.4 to 25\n",
      "\n",
      "Training for task 25\n",
      "=> Set task of model.0 to 25\n",
      "=> Set task of model.2 to 25\n",
      "=> Set task of model.4 to 25\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d5974ba4cbee4038b33388e9eb1f2d66",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4173, Acc@1 0.8369\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "248ec065c33c4d9288f4f675bbcc710d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9115\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 26\n",
      "=> Setting learned tasks of model.2 to 26\n",
      "=> Setting learned tasks of model.4 to 26\n",
      "\n",
      "Training for task 26\n",
      "=> Set task of model.0 to 26\n",
      "=> Set task of model.2 to 26\n",
      "=> Set task of model.4 to 26\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f583695cd5c34e5f819e1d142b9d6315",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3948, Acc@1 0.8366\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "473742784fc34a0c873e5249a16eb694",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9131\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 27\n",
      "=> Setting learned tasks of model.2 to 27\n",
      "=> Setting learned tasks of model.4 to 27\n",
      "\n",
      "Training for task 27\n",
      "=> Set task of model.0 to 27\n",
      "=> Set task of model.2 to 27\n",
      "=> Set task of model.4 to 27\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "75226c792a874c86bd39e829d6b04b7f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2693, Acc@1 0.8434\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2561a99f1c424a7abab7525f737429fc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9118\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 28\n",
      "=> Setting learned tasks of model.2 to 28\n",
      "=> Setting learned tasks of model.4 to 28\n",
      "\n",
      "Training for task 28\n",
      "=> Set task of model.0 to 28\n",
      "=> Set task of model.2 to 28\n",
      "=> Set task of model.4 to 28\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a0cca6f00a814c2cb98d8918ec7935eb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2965, Acc@1 0.8340\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7b77101f9b84ca19fb9829aa556210d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9121\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 29\n",
      "=> Setting learned tasks of model.2 to 29\n",
      "=> Setting learned tasks of model.4 to 29\n",
      "\n",
      "Training for task 29\n",
      "=> Set task of model.0 to 29\n",
      "=> Set task of model.2 to 29\n",
      "=> Set task of model.4 to 29\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ccb408694b324b0caf844acdda2c9b76",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3118, Acc@1 0.8382\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "16f352a3e6224aedbe928bcd75ef466d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9135\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 30\n",
      "=> Setting learned tasks of model.2 to 30\n",
      "=> Setting learned tasks of model.4 to 30\n",
      "\n",
      "Training for task 30\n",
      "=> Set task of model.0 to 30\n",
      "=> Set task of model.2 to 30\n",
      "=> Set task of model.4 to 30\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "247a7760ee4e4631b8722e2c8863762b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2714, Acc@1 0.8330\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "52c8c0a6264b43189d45c95d08e641c8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9107\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 31\n",
      "=> Setting learned tasks of model.2 to 31\n",
      "=> Setting learned tasks of model.4 to 31\n",
      "\n",
      "Training for task 31\n",
      "=> Set task of model.0 to 31\n",
      "=> Set task of model.2 to 31\n",
      "=> Set task of model.4 to 31\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "71ab5726faa940c79a2a7ff3d15bdd56",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2569, Acc@1 0.8542\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7fdc016bf35a4cdf90ed717ad848b060",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9081\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 32\n",
      "=> Setting learned tasks of model.2 to 32\n",
      "=> Setting learned tasks of model.4 to 32\n",
      "\n",
      "Training for task 32\n",
      "=> Set task of model.0 to 32\n",
      "=> Set task of model.2 to 32\n",
      "=> Set task of model.4 to 32\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "42f1a75bc2214faf8ab7d24d294d0919",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4106, Acc@1 0.8366\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b8e4af1c8eb645eaa666c46ce50a61cf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9130\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 33\n",
      "=> Setting learned tasks of model.2 to 33\n",
      "=> Setting learned tasks of model.4 to 33\n",
      "\n",
      "Training for task 33\n",
      "=> Set task of model.0 to 33\n",
      "=> Set task of model.2 to 33\n",
      "=> Set task of model.4 to 33\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b46c48ff9b1b4307bbb6cbfa265f635b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3629, Acc@1 0.8424\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9da199d5e70c46dcb9d0ee14a6c671b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9117\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 34\n",
      "=> Setting learned tasks of model.2 to 34\n",
      "=> Setting learned tasks of model.4 to 34\n",
      "\n",
      "Training for task 34\n",
      "=> Set task of model.0 to 34\n",
      "=> Set task of model.2 to 34\n",
      "=> Set task of model.4 to 34\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2828ca1cb5734b4ebb40ffa3a0a2661c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3691, Acc@1 0.8421\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a9d8f94d3d324f15a07492854c16f013",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9147\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 35\n",
      "=> Setting learned tasks of model.2 to 35\n",
      "=> Setting learned tasks of model.4 to 35\n",
      "\n",
      "Training for task 35\n",
      "=> Set task of model.0 to 35\n",
      "=> Set task of model.2 to 35\n",
      "=> Set task of model.4 to 35\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "77e2cc0087ce48bcab08a007a5bb3f13",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3246, Acc@1 0.8376\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "93243869f1fa4ba884f2857e8725e76e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9117\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 36\n",
      "=> Setting learned tasks of model.2 to 36\n",
      "=> Setting learned tasks of model.4 to 36\n",
      "\n",
      "Training for task 36\n",
      "=> Set task of model.0 to 36\n",
      "=> Set task of model.2 to 36\n",
      "=> Set task of model.4 to 36\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5eeb00685e724c04998751d24db865a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2534, Acc@1 0.8320\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "025d2af1c6934141a915d7e96cdc5f43",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9124\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 37\n",
      "=> Setting learned tasks of model.2 to 37\n",
      "=> Setting learned tasks of model.4 to 37\n",
      "\n",
      "Training for task 37\n",
      "=> Set task of model.0 to 37\n",
      "=> Set task of model.2 to 37\n",
      "=> Set task of model.4 to 37\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "669e853dffbc4bb889820ab1a8216e8b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2380, Acc@1 0.8483\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "78df17ec3813490582de6918766b7a43",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9122\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 38\n",
      "=> Setting learned tasks of model.2 to 38\n",
      "=> Setting learned tasks of model.4 to 38\n",
      "\n",
      "Training for task 38\n",
      "=> Set task of model.0 to 38\n",
      "=> Set task of model.2 to 38\n",
      "=> Set task of model.4 to 38\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4945f49d5c7145fd9f1e1bae2d277b9f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3894, Acc@1 0.8438\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "87f1eac5785d403ba04888b3accf6f06",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9070\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 39\n",
      "=> Setting learned tasks of model.2 to 39\n",
      "=> Setting learned tasks of model.4 to 39\n",
      "\n",
      "Training for task 39\n",
      "=> Set task of model.0 to 39\n",
      "=> Set task of model.2 to 39\n",
      "=> Set task of model.4 to 39\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "937f62480a7347f78893ca0381904c25",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2793, Acc@1 0.8379\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9666f37032f94504ab1a49d1f3ab08dc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9134\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 40\n",
      "=> Setting learned tasks of model.2 to 40\n",
      "=> Setting learned tasks of model.4 to 40\n",
      "\n",
      "Training for task 40\n",
      "=> Set task of model.0 to 40\n",
      "=> Set task of model.2 to 40\n",
      "=> Set task of model.4 to 40\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8f4132bb73b6403983361d3fc701bbfc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3157, Acc@1 0.8307\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "07923f5ea4fb46ba8f629808a4d092f2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9108\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 41\n",
      "=> Setting learned tasks of model.2 to 41\n",
      "=> Setting learned tasks of model.4 to 41\n",
      "\n",
      "Training for task 41\n",
      "=> Set task of model.0 to 41\n",
      "=> Set task of model.2 to 41\n",
      "=> Set task of model.4 to 41\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e7aa63c540da4863b951457ac46a1836",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4216, Acc@1 0.8464\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5f9ddb4563aa47c286ba389b7a64d9fe",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9113\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 42\n",
      "=> Setting learned tasks of model.2 to 42\n",
      "=> Setting learned tasks of model.4 to 42\n",
      "\n",
      "Training for task 42\n",
      "=> Set task of model.0 to 42\n",
      "=> Set task of model.2 to 42\n",
      "=> Set task of model.4 to 42\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5a6756689961455e8011760fbc1dd39b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2464, Acc@1 0.8395\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c8ee45c8d37b49afa9be9a8c1845fb42",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9129\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 43\n",
      "=> Setting learned tasks of model.2 to 43\n",
      "=> Setting learned tasks of model.4 to 43\n",
      "\n",
      "Training for task 43\n",
      "=> Set task of model.0 to 43\n",
      "=> Set task of model.2 to 43\n",
      "=> Set task of model.4 to 43\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "500e24d0da8d4ddfbf8a1c673263a8f2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2216, Acc@1 0.8431\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3dda0146ee9a40079fcdbfad41931149",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9119\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 44\n",
      "=> Setting learned tasks of model.2 to 44\n",
      "=> Setting learned tasks of model.4 to 44\n",
      "\n",
      "Training for task 44\n",
      "=> Set task of model.0 to 44\n",
      "=> Set task of model.2 to 44\n",
      "=> Set task of model.4 to 44\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "571e5f04d5404418b44c4b4e1cc1faa6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2885, Acc@1 0.8418\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c69732a604ea48d88f6b6be0ec816461",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9113\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 45\n",
      "=> Setting learned tasks of model.2 to 45\n",
      "=> Setting learned tasks of model.4 to 45\n",
      "\n",
      "Training for task 45\n",
      "=> Set task of model.0 to 45\n",
      "=> Set task of model.2 to 45\n",
      "=> Set task of model.4 to 45\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "834df73aba9c4dbc8229035a2cc57ab3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3408, Acc@1 0.8389\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e8b9265aba1d48e2a3d5c6c7e487748c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9126\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 46\n",
      "=> Setting learned tasks of model.2 to 46\n",
      "=> Setting learned tasks of model.4 to 46\n",
      "\n",
      "Training for task 46\n",
      "=> Set task of model.0 to 46\n",
      "=> Set task of model.2 to 46\n",
      "=> Set task of model.4 to 46\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0cbc43f1933e4e0cb416cec676fe2a1f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3094, Acc@1 0.8447\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "83a29c1e39fb4faea8daea63c5bf3915",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9136\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 47\n",
      "=> Setting learned tasks of model.2 to 47\n",
      "=> Setting learned tasks of model.4 to 47\n",
      "\n",
      "Training for task 47\n",
      "=> Set task of model.0 to 47\n",
      "=> Set task of model.2 to 47\n",
      "=> Set task of model.4 to 47\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "165a97dc39c64e73881984930c1bb130",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3136, Acc@1 0.8457\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "880aa4398daf49289647429a378d2318",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9144\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 48\n",
      "=> Setting learned tasks of model.2 to 48\n",
      "=> Setting learned tasks of model.4 to 48\n",
      "\n",
      "Training for task 48\n",
      "=> Set task of model.0 to 48\n",
      "=> Set task of model.2 to 48\n",
      "=> Set task of model.4 to 48\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59d4b95042224009ad9942c3e83ad843",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3547, Acc@1 0.8418\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4e67db1f70c842a584b9785897fb31d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9133\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 49\n",
      "=> Setting learned tasks of model.2 to 49\n",
      "=> Setting learned tasks of model.4 to 49\n",
      "\n",
      "Training for task 49\n",
      "=> Set task of model.0 to 49\n",
      "=> Set task of model.2 to 49\n",
      "=> Set task of model.4 to 49\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1368eb4d65d44b22a59d0d59e46952c2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3256, Acc@1 0.8327\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b8aaaeb0afe54e1e949fed9a5263cd3e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9127\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 50\n",
      "=> Setting learned tasks of model.2 to 50\n",
      "=> Setting learned tasks of model.4 to 50\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Task ID given during train time\n",
    "from IPython.display import clear_output\n",
    "\n",
    "num_tasks = 50 # For demonstration purposes, we go up to 2500 in our paper\n",
    "model = MultitaskFC(hidden_size=300, num_tasks=num_tasks, sparsity=0.25)\n",
    "\n",
    "for task in range(num_tasks):\n",
    "    print(f\"Training for task {task}\")\n",
    "    set_model_task(model, task)\n",
    "    mnist.update_task(task)\n",
    "\n",
    "    optimizer = optim.RMSprop([p for p in model.parameters() if p.requires_grad], lr=1e-4)\n",
    "    # Train for 1 epoch\n",
    "    for e in range(1):\n",
    "        train(model, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "        print(\"Validation\")\n",
    "        print(\"============\")\n",
    "        acc1 = evaluate(model, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "    cache_masks(model)\n",
    "    print()\n",
    "    set_num_tasks_learned(model, task + 1)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.9123\n",
      "Per task performance\n",
      "Task 0: 0.9123\n",
      "Task 1: 0.9123\n",
      "Task 2: 0.9141\n",
      "Task 3: 0.9144\n",
      "Task 4: 0.9112\n",
      "Task 5: 0.9153\n",
      "Task 6: 0.9124\n",
      "Task 7: 0.9112\n",
      "Task 8: 0.9154\n",
      "Task 9: 0.9143\n",
      "Task 10: 0.9144\n",
      "Task 11: 0.9104\n",
      "Task 12: 0.9161\n",
      "Task 13: 0.9120\n",
      "Task 14: 0.9123\n",
      "Task 15: 0.9117\n",
      "Task 16: 0.9107\n",
      "Task 17: 0.9143\n",
      "Task 18: 0.9106\n",
      "Task 19: 0.9048\n",
      "Task 20: 0.9109\n",
      "Task 21: 0.9132\n",
      "Task 22: 0.9125\n",
      "Task 23: 0.9118\n",
      "Task 24: 0.9130\n",
      "Task 25: 0.9115\n",
      "Task 26: 0.9131\n",
      "Task 27: 0.9118\n",
      "Task 28: 0.9121\n",
      "Task 29: 0.9135\n",
      "Task 30: 0.9107\n",
      "Task 31: 0.9081\n",
      "Task 32: 0.9130\n",
      "Task 33: 0.9117\n",
      "Task 34: 0.9147\n",
      "Task 35: 0.9117\n",
      "Task 36: 0.9124\n",
      "Task 37: 0.9122\n",
      "Task 38: 0.9070\n",
      "Task 39: 0.9134\n",
      "Task 40: 0.9108\n",
      "Task 41: 0.9113\n",
      "Task 42: 0.9129\n",
      "Task 43: 0.9119\n",
      "Task 44: 0.9113\n",
      "Task 45: 0.9126\n",
      "Task 46: 0.9136\n",
      "Task 47: 0.9144\n",
      "Task 48: 0.9133\n",
      "Task 49: 0.9127\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(model, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(model, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['supsup_mnist'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Multimask Same Task "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_masks_to_create = 40"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "loaders = {}\n",
    "for i in range(num_masks_to_create):\n",
    "    loaders[i] = MNISTPerm()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "weight_dict = {k: v for k,v in model.state_dict().items() if k.endswith('weight')}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Task ID given during train time\n",
    "from IPython.display import clear_output\n",
    "\n",
    "model_map = {}\n",
    "for i in range(num_masks_to_create):\n",
    "    modeli = MultitaskFC(hidden_size=300, num_tasks=1, sparsity=0.25)\n",
    "    sdi = modeli.state_dict()\n",
    "    sdi.update(weight_dict)\n",
    "    modeli.load_state_dict(sdi)\n",
    "    model_map[i] = modeli"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3c424e7510a64f009c3b52c40c41242e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3358, Acc@1 0.8366\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "040fee6cb34d418eaccd49114e6629c5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9164\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8a5d5f96853d43f7b542bbc3d73b16d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4087, Acc@1 0.8359\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4627876d8a594633918353c3cca49ee7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9085\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "148d115c019c491ea511a9542baddd68",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2240, Acc@1 0.8493\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cc6bcaade656441b94f55af26901020d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9067\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2aaf115af1984db3885b7763959bccd9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2797, Acc@1 0.8431\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e99a304f060d40f3877f95923c21a56e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9161\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "61b93ebf27f749d998381381728bed7b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2619, Acc@1 0.8402\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "94f0774a42e04e458cb4480f4a3abce3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9101\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2a612ade49444627a594ecb243e19e4c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2333, Acc@1 0.8509\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b9c565fdbf724ea4b12e17d8537cd9f5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9151\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "99c2dbfa275d4ebabe6605ca9564fdc0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3669, Acc@1 0.8314\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5d8e3e7d7d6d4c08b6018d85aa06c89a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9112\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b63a429083624d67bf793b7809d23fc3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4344, Acc@1 0.8395\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cddbd5f2524d412bbe3ef6f71f695b19",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9132\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3b74b935cd6a4c86ad169172dc2898b2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3648, Acc@1 0.8405\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e12947e6af8a48678a44975fc989f218",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9135\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e8fef889b994ea79d003297958884fb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3109, Acc@1 0.8473\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1aff32b1096243bf962860d158796f0d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9142\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "daf0993d7bb84fcba484638c083d0f7b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2800, Acc@1 0.8363\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e6a1d320aa214dbbb216ddef67546f3c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9140\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d6daa4aa11374f04a75ab4885c93d09f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3516, Acc@1 0.8385\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7607b747845e46e4b12226ae4dd83852",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9133\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fa182b94ba3d4d1b8316526764d139e4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2635, Acc@1 0.8356\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8102e12fca204eeb93d27241f5cce46f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9124\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "827931efcbb74cd58e0740d65342e3d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3482, Acc@1 0.8454\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "10328b50816448a795f08f6e989a1aa9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9153\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d20611dc368344128978dfbd85684f3a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.1974, Acc@1 0.8356\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e7e99815d36e46ef8c08cea72256c23e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9114\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d5d67e3f5e8e425e858be1404a30cd3e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3033, Acc@1 0.8369\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "efc8f044c8b940228cb96b444b97777f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9119\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "af7a7b417c334af6b97fe82adba68038",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2982, Acc@1 0.8415\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bbefbc356d47487cbb5aa0f9b0206fa0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9145\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b6493f7d295d44d38cd03ca2414fc353",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3697, Acc@1 0.8438\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e6e2b9464d2444198ca5500e4f392e6a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9121\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "32e95646541143f6ab708460f013fd1b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3314, Acc@1 0.8441\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b088367c4d8f4a469a2a683ace3212fc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9151\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f7a671ac5cf547a6ab77efe5c455b66d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2264, Acc@1 0.8395\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5a1d2417322a4af38602a8c81eb7871f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9136\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c6b8200cb4c64ef68bf0998f56131315",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2762, Acc@1 0.8294\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "70915b9facc8409c8d0a2274418e7789",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9102\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "02a91ce368b54ceeabe0b04ee5eb543f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3649, Acc@1 0.8304\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cfb166abc9f644259880db6aa560f60a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9141\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f4242dd29d8e49b4a64d03ac09d404de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3203, Acc@1 0.8330\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "abddd7638fd14ce688171d9a757da016",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9140\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "84d97c9eea27414496243c627e8a7f56",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3110, Acc@1 0.8424\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "de10af5885334a29ae0d5fa344a834fa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9077\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef125b0797d9408eb433d176ddafc749",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3506, Acc@1 0.8307\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7a273da0c954adeb0a833467d4ef629",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9101\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f87b810977434e0e84864bffd6173bfc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4260, Acc@1 0.8408\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "33303a13b5134fc09eb6913c395c29ad",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9109\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "428a8e3b77224082b0cfb90311603f97",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3874, Acc@1 0.8389\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bfa333a5acdb44de8196fb21d1cb4e51",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9114\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1bd21634a6e14597bca4cd94c9ec3b20",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2733, Acc@1 0.8467\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ba53c4b1d71546fabfe276a09f1f0871",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9116\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f85edf717224645931289b84d07fa0c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3966, Acc@1 0.8434\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5870cb94f8424670a5a6f45e11a154a8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9098\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "01e26c5991fa4fd88909570fb1f10d91",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2999, Acc@1 0.8402\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "19b8ac69f9744acc8da4e7ac277e44b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9120\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8af3d960c4dc43b4aa44c43745c8e0a2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4134, Acc@1 0.8343\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7408995a9334ca4b316b35508f71ebf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9107\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f9b1b0c06014700876ffc913e39fcdd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4034, Acc@1 0.8402\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f373b2992bf347428af4fbef84de7e5f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9151\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dcd073c1ae964192b55aba805ac2b97c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3331, Acc@1 0.8330\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7b64150608d64f76adeb1b35ecfec5b4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9131\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8a7b7e384653405a990188f095068765",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4425, Acc@1 0.8258\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ae88c110f34941f4a1a0f82a717d9405",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9042\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1e2a5a7c26c24c0f8f2dc804c3853ace",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3012, Acc@1 0.8428\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c95deb6bb228492b92c1f195dbb12876",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9107\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4300cdf76de84d5980a627068d881cb7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3654, Acc@1 0.8369\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f23e0174c9cd4fe597b47f5105a8bf3e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9114\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "14e31efc367f472a9e5cfd9b34058bec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4089, Acc@1 0.8288\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a73162ed59b94b9a9c0db015067eb08b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9138\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e4417d76b7ed48e6841b0593dff88baf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3379, Acc@1 0.8545\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0116cbd97f8d4991838c0622ee3e4958",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9143\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "812477b178a14eeda95bdef20498226b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.2193, Acc@1 0.8411\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ff778334d1d74cb19bf48a821ea875b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9100\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cf076fc84f3b4f61a7e5eba8e0a50794",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.3955, Acc@1 0.8382\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4f9fad6082794a0b98b34a94e584365d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.9147\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for idx, modeli in model_map.items():\n",
    "    for task in range(1):\n",
    "        print(f\"Training for task {task}\")\n",
    "        set_model_task(modeli, task)\n",
    "        mnisti = loaders[idx]\n",
    "        mnisti.update_task(task)\n",
    "\n",
    "        optimizer1 = optim.RMSprop([p for p in modeli.parameters() if p.requires_grad], lr=1e-4)\n",
    "        # Train for 1 epoch\n",
    "        for e in range(1):\n",
    "            train(modeli, mnisti.train_loader, optimizer1, e)\n",
    "            \n",
    "            print(\"Validation\")\n",
    "            print(\"============\")\n",
    "            acc1 = evaluate(modeli, mnisti.val_loader, e)\n",
    "\n",
    "\n",
    "        cache_masks(modeli)\n",
    "        print()\n",
    "        set_num_tasks_learned(modeli, task + 1)\n",
    "        print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "def overlap(mask1, mask2):\n",
    "    assert mask1.shape == mask2.shape\n",
    "    count_same = (mask1 + mask2 - 1).abs().sum()\n",
    "    return count_same / (1.0*(mask1.shape[0] * mask1.shape[1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "from itertools import product"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Layer: 0, Models: (0, 1), Overlap: 0.6442686915397644\n",
      "Layer: 0, Models: (0, 2), Overlap: 0.6420068144798279\n",
      "Layer: 0, Models: (0, 3), Overlap: 0.6416071653366089\n",
      "Layer: 0, Models: (0, 4), Overlap: 0.6425085067749023\n",
      "Layer: 0, Models: (0, 5), Overlap: 0.6434183716773987\n",
      "Layer: 0, Models: (0, 6), Overlap: 0.6419727802276611\n",
      "Layer: 0, Models: (0, 7), Overlap: 0.6440390944480896\n",
      "Layer: 0, Models: (0, 8), Overlap: 0.6413435339927673\n",
      "Layer: 0, Models: (0, 9), Overlap: 0.6436904668807983\n",
      "Layer: 0, Models: (0, 10), Overlap: 0.6424234509468079\n",
      "Layer: 0, Models: (0, 11), Overlap: 0.642380952835083\n",
      "Layer: 0, Models: (0, 12), Overlap: 0.6446598768234253\n",
      "Layer: 0, Models: (0, 13), Overlap: 0.6445407867431641\n",
      "Layer: 0, Models: (0, 14), Overlap: 0.6431037187576294\n",
      "Layer: 0, Models: (1, 0), Overlap: 0.6442686915397644\n",
      "Layer: 0, Models: (1, 2), Overlap: 0.6431037187576294\n",
      "Layer: 0, Models: (1, 3), Overlap: 0.6416666507720947\n",
      "Layer: 0, Models: (1, 4), Overlap: 0.6440390944480896\n",
      "Layer: 0, Models: (1, 5), Overlap: 0.6425254940986633\n",
      "Layer: 0, Models: (1, 6), Overlap: 0.6416581869125366\n",
      "Layer: 0, Models: (1, 7), Overlap: 0.6420323252677917\n",
      "Layer: 0, Models: (1, 8), Overlap: 0.6436649560928345\n",
      "Layer: 0, Models: (1, 9), Overlap: 0.641403079032898\n",
      "Layer: 0, Models: (1, 10), Overlap: 0.6407908201217651\n",
      "Layer: 0, Models: (1, 11), Overlap: 0.6429081559181213\n",
      "Layer: 0, Models: (1, 12), Overlap: 0.6443537473678589\n",
      "Layer: 0, Models: (1, 13), Overlap: 0.6424319744110107\n",
      "Layer: 0, Models: (1, 14), Overlap: 0.6422789096832275\n",
      "Layer: 0, Models: (2, 0), Overlap: 0.6420068144798279\n",
      "Layer: 0, Models: (2, 1), Overlap: 0.6431037187576294\n",
      "Layer: 0, Models: (2, 3), Overlap: 0.6403401494026184\n",
      "Layer: 0, Models: (2, 4), Overlap: 0.6411564350128174\n",
      "Layer: 0, Models: (2, 5), Overlap: 0.6420833468437195\n",
      "Layer: 0, Models: (2, 6), Overlap: 0.6428911685943604\n",
      "Layer: 0, Models: (2, 7), Overlap: 0.6417772173881531\n",
      "Layer: 0, Models: (2, 8), Overlap: 0.6430526971817017\n",
      "Layer: 0, Models: (2, 9), Overlap: 0.6430187225341797\n",
      "Layer: 0, Models: (2, 10), Overlap: 0.6417261958122253\n",
      "Layer: 0, Models: (2, 11), Overlap: 0.6415390968322754\n",
      "Layer: 0, Models: (2, 12), Overlap: 0.642397940158844\n",
      "Layer: 0, Models: (2, 13), Overlap: 0.6407908201217651\n",
      "Layer: 0, Models: (2, 14), Overlap: 0.641198992729187\n",
      "Layer: 0, Models: (3, 0), Overlap: 0.6416071653366089\n",
      "Layer: 0, Models: (3, 1), Overlap: 0.6416666507720947\n",
      "Layer: 0, Models: (3, 2), Overlap: 0.6403401494026184\n",
      "Layer: 0, Models: (3, 4), Overlap: 0.6422789096832275\n",
      "Layer: 0, Models: (3, 5), Overlap: 0.6435034275054932\n",
      "Layer: 0, Models: (3, 6), Overlap: 0.6430612206459045\n",
      "Layer: 0, Models: (3, 7), Overlap: 0.6421428322792053\n",
      "Layer: 0, Models: (3, 8), Overlap: 0.6419302821159363\n",
      "Layer: 0, Models: (3, 9), Overlap: 0.6398554444313049\n",
      "Layer: 0, Models: (3, 10), Overlap: 0.6423469185829163\n",
      "Layer: 0, Models: (3, 11), Overlap: 0.6413435339927673\n",
      "Layer: 0, Models: (3, 12), Overlap: 0.6426530480384827\n",
      "Layer: 0, Models: (3, 13), Overlap: 0.6420323252677917\n",
      "Layer: 0, Models: (3, 14), Overlap: 0.6423044204711914\n",
      "Layer: 0, Models: (4, 0), Overlap: 0.6425085067749023\n",
      "Layer: 0, Models: (4, 1), Overlap: 0.6440390944480896\n",
      "Layer: 0, Models: (4, 2), Overlap: 0.6411564350128174\n",
      "Layer: 0, Models: (4, 3), Overlap: 0.6422789096832275\n",
      "Layer: 0, Models: (4, 5), Overlap: 0.6440561413764954\n",
      "Layer: 0, Models: (4, 6), Overlap: 0.6417602300643921\n",
      "Layer: 0, Models: (4, 7), Overlap: 0.6431887745857239\n",
      "Layer: 0, Models: (4, 8), Overlap: 0.6428826451301575\n",
      "Layer: 0, Models: (4, 9), Overlap: 0.6428741216659546\n",
      "Layer: 0, Models: (4, 10), Overlap: 0.6434693932533264\n",
      "Layer: 0, Models: (4, 11), Overlap: 0.6424149870872498\n",
      "Layer: 0, Models: (4, 12), Overlap: 0.6440561413764954\n",
      "Layer: 0, Models: (4, 13), Overlap: 0.6428231000900269\n",
      "Layer: 0, Models: (4, 14), Overlap: 0.6432738304138184\n",
      "Layer: 0, Models: (5, 0), Overlap: 0.6434183716773987\n",
      "Layer: 0, Models: (5, 1), Overlap: 0.6425254940986633\n",
      "Layer: 0, Models: (5, 2), Overlap: 0.6420833468437195\n",
      "Layer: 0, Models: (5, 3), Overlap: 0.6435034275054932\n",
      "Layer: 0, Models: (5, 4), Overlap: 0.6440561413764954\n",
      "Layer: 0, Models: (5, 6), Overlap: 0.6419387459754944\n",
      "Layer: 0, Models: (5, 7), Overlap: 0.6435799598693848\n",
      "Layer: 0, Models: (5, 8), Overlap: 0.6425425410270691\n",
      "Layer: 0, Models: (5, 9), Overlap: 0.6417602300643921\n",
      "Layer: 0, Models: (5, 10), Overlap: 0.6444302797317505\n",
      "Layer: 0, Models: (5, 11), Overlap: 0.6434949040412903\n",
      "Layer: 0, Models: (5, 12), Overlap: 0.6461054682731628\n",
      "Layer: 0, Models: (5, 13), Overlap: 0.6448724269866943\n",
      "Layer: 0, Models: (5, 14), Overlap: 0.6428996324539185\n",
      "Layer: 0, Models: (6, 0), Overlap: 0.6419727802276611\n",
      "Layer: 0, Models: (6, 1), Overlap: 0.6416581869125366\n",
      "Layer: 0, Models: (6, 2), Overlap: 0.6428911685943604\n",
      "Layer: 0, Models: (6, 3), Overlap: 0.6430612206459045\n",
      "Layer: 0, Models: (6, 4), Overlap: 0.6417602300643921\n",
      "Layer: 0, Models: (6, 5), Overlap: 0.6419387459754944\n",
      "Layer: 0, Models: (6, 7), Overlap: 0.6426105499267578\n",
      "Layer: 0, Models: (6, 8), Overlap: 0.6430867314338684\n",
      "Layer: 0, Models: (6, 9), Overlap: 0.6405867338180542\n",
      "Layer: 0, Models: (6, 10), Overlap: 0.6417602300643921\n",
      "Layer: 0, Models: (6, 11), Overlap: 0.6419897675514221\n",
      "Layer: 0, Models: (6, 12), Overlap: 0.641598641872406\n",
      "Layer: 0, Models: (6, 13), Overlap: 0.6422278881072998\n",
      "Layer: 0, Models: (6, 14), Overlap: 0.6424744725227356\n",
      "Layer: 0, Models: (7, 0), Overlap: 0.6440390944480896\n",
      "Layer: 0, Models: (7, 1), Overlap: 0.6420323252677917\n",
      "Layer: 0, Models: (7, 2), Overlap: 0.6417772173881531\n",
      "Layer: 0, Models: (7, 3), Overlap: 0.6421428322792053\n",
      "Layer: 0, Models: (7, 4), Overlap: 0.6431887745857239\n",
      "Layer: 0, Models: (7, 5), Overlap: 0.6435799598693848\n",
      "Layer: 0, Models: (7, 6), Overlap: 0.6426105499267578\n",
      "Layer: 0, Models: (7, 8), Overlap: 0.6425254940986633\n",
      "Layer: 0, Models: (7, 9), Overlap: 0.6419642567634583\n",
      "Layer: 0, Models: (7, 10), Overlap: 0.641785740852356\n",
      "Layer: 0, Models: (7, 11), Overlap: 0.6441581845283508\n",
      "Layer: 0, Models: (7, 12), Overlap: 0.6435714364051819\n",
      "Layer: 0, Models: (7, 13), Overlap: 0.6427381038665771\n",
      "Layer: 0, Models: (7, 14), Overlap: 0.6424404978752136\n",
      "Layer: 0, Models: (8, 0), Overlap: 0.6413435339927673\n",
      "Layer: 0, Models: (8, 1), Overlap: 0.6436649560928345\n",
      "Layer: 0, Models: (8, 2), Overlap: 0.6430526971817017\n",
      "Layer: 0, Models: (8, 3), Overlap: 0.6419302821159363\n",
      "Layer: 0, Models: (8, 4), Overlap: 0.6428826451301575\n",
      "Layer: 0, Models: (8, 5), Overlap: 0.6425425410270691\n",
      "Layer: 0, Models: (8, 6), Overlap: 0.6430867314338684\n",
      "Layer: 0, Models: (8, 7), Overlap: 0.6425254940986633\n",
      "Layer: 0, Models: (8, 9), Overlap: 0.6418452262878418\n",
      "Layer: 0, Models: (8, 10), Overlap: 0.6425595283508301\n",
      "Layer: 0, Models: (8, 11), Overlap: 0.6419302821159363\n",
      "Layer: 0, Models: (8, 12), Overlap: 0.6428316235542297\n",
      "Layer: 0, Models: (8, 13), Overlap: 0.6412925124168396\n",
      "Layer: 0, Models: (8, 14), Overlap: 0.6418622732162476\n",
      "Layer: 0, Models: (9, 0), Overlap: 0.6436904668807983\n",
      "Layer: 0, Models: (9, 1), Overlap: 0.641403079032898\n",
      "Layer: 0, Models: (9, 2), Overlap: 0.6430187225341797\n",
      "Layer: 0, Models: (9, 3), Overlap: 0.6398554444313049\n",
      "Layer: 0, Models: (9, 4), Overlap: 0.6428741216659546\n",
      "Layer: 0, Models: (9, 5), Overlap: 0.6417602300643921\n",
      "Layer: 0, Models: (9, 6), Overlap: 0.6405867338180542\n",
      "Layer: 0, Models: (9, 7), Overlap: 0.6419642567634583\n",
      "Layer: 0, Models: (9, 8), Overlap: 0.6418452262878418\n",
      "Layer: 0, Models: (9, 10), Overlap: 0.6438520550727844\n",
      "Layer: 0, Models: (9, 11), Overlap: 0.6440731287002563\n",
      "Layer: 0, Models: (9, 12), Overlap: 0.6432822942733765\n",
      "Layer: 0, Models: (9, 13), Overlap: 0.6415646076202393\n",
      "Layer: 0, Models: (9, 14), Overlap: 0.6434183716773987\n",
      "Layer: 0, Models: (10, 0), Overlap: 0.6424234509468079\n",
      "Layer: 0, Models: (10, 1), Overlap: 0.6407908201217651\n",
      "Layer: 0, Models: (10, 2), Overlap: 0.6417261958122253\n",
      "Layer: 0, Models: (10, 3), Overlap: 0.6423469185829163\n",
      "Layer: 0, Models: (10, 4), Overlap: 0.6434693932533264\n",
      "Layer: 0, Models: (10, 5), Overlap: 0.6444302797317505\n",
      "Layer: 0, Models: (10, 6), Overlap: 0.6417602300643921\n",
      "Layer: 0, Models: (10, 7), Overlap: 0.641785740852356\n",
      "Layer: 0, Models: (10, 8), Overlap: 0.6425595283508301\n",
      "Layer: 0, Models: (10, 9), Overlap: 0.6438520550727844\n",
      "Layer: 0, Models: (10, 11), Overlap: 0.6440646052360535\n",
      "Layer: 0, Models: (10, 12), Overlap: 0.6436224579811096\n",
      "Layer: 0, Models: (10, 13), Overlap: 0.6434693932533264\n",
      "Layer: 0, Models: (10, 14), Overlap: 0.6450340151786804\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Layer: 0, Models: (11, 0), Overlap: 0.642380952835083\n",
      "Layer: 0, Models: (11, 1), Overlap: 0.6429081559181213\n",
      "Layer: 0, Models: (11, 2), Overlap: 0.6415390968322754\n",
      "Layer: 0, Models: (11, 3), Overlap: 0.6413435339927673\n",
      "Layer: 0, Models: (11, 4), Overlap: 0.6424149870872498\n",
      "Layer: 0, Models: (11, 5), Overlap: 0.6434949040412903\n",
      "Layer: 0, Models: (11, 6), Overlap: 0.6419897675514221\n",
      "Layer: 0, Models: (11, 7), Overlap: 0.6441581845283508\n",
      "Layer: 0, Models: (11, 8), Overlap: 0.6419302821159363\n",
      "Layer: 0, Models: (11, 9), Overlap: 0.6440731287002563\n",
      "Layer: 0, Models: (11, 10), Overlap: 0.6440646052360535\n",
      "Layer: 0, Models: (11, 12), Overlap: 0.6443962454795837\n",
      "Layer: 0, Models: (11, 13), Overlap: 0.6433163285255432\n",
      "Layer: 0, Models: (11, 14), Overlap: 0.643146276473999\n",
      "Layer: 0, Models: (12, 0), Overlap: 0.6446598768234253\n",
      "Layer: 0, Models: (12, 1), Overlap: 0.6443537473678589\n",
      "Layer: 0, Models: (12, 2), Overlap: 0.642397940158844\n",
      "Layer: 0, Models: (12, 3), Overlap: 0.6426530480384827\n",
      "Layer: 0, Models: (12, 4), Overlap: 0.6440561413764954\n",
      "Layer: 0, Models: (12, 5), Overlap: 0.6461054682731628\n",
      "Layer: 0, Models: (12, 6), Overlap: 0.641598641872406\n",
      "Layer: 0, Models: (12, 7), Overlap: 0.6435714364051819\n",
      "Layer: 0, Models: (12, 8), Overlap: 0.6428316235542297\n",
      "Layer: 0, Models: (12, 9), Overlap: 0.6432822942733765\n",
      "Layer: 0, Models: (12, 10), Overlap: 0.6436224579811096\n",
      "Layer: 0, Models: (12, 11), Overlap: 0.6443962454795837\n",
      "Layer: 0, Models: (12, 13), Overlap: 0.6429591774940491\n",
      "Layer: 0, Models: (12, 14), Overlap: 0.6425085067749023\n",
      "Layer: 0, Models: (13, 0), Overlap: 0.6445407867431641\n",
      "Layer: 0, Models: (13, 1), Overlap: 0.6424319744110107\n",
      "Layer: 0, Models: (13, 2), Overlap: 0.6407908201217651\n",
      "Layer: 0, Models: (13, 3), Overlap: 0.6420323252677917\n",
      "Layer: 0, Models: (13, 4), Overlap: 0.6428231000900269\n",
      "Layer: 0, Models: (13, 5), Overlap: 0.6448724269866943\n",
      "Layer: 0, Models: (13, 6), Overlap: 0.6422278881072998\n",
      "Layer: 0, Models: (13, 7), Overlap: 0.6427381038665771\n",
      "Layer: 0, Models: (13, 8), Overlap: 0.6412925124168396\n",
      "Layer: 0, Models: (13, 9), Overlap: 0.6415646076202393\n",
      "Layer: 0, Models: (13, 10), Overlap: 0.6434693932533264\n",
      "Layer: 0, Models: (13, 11), Overlap: 0.6433163285255432\n",
      "Layer: 0, Models: (13, 12), Overlap: 0.6429591774940491\n",
      "Layer: 0, Models: (13, 14), Overlap: 0.6424915194511414\n",
      "Layer: 0, Models: (14, 0), Overlap: 0.6431037187576294\n",
      "Layer: 0, Models: (14, 1), Overlap: 0.6422789096832275\n",
      "Layer: 0, Models: (14, 2), Overlap: 0.641198992729187\n",
      "Layer: 0, Models: (14, 3), Overlap: 0.6423044204711914\n",
      "Layer: 0, Models: (14, 4), Overlap: 0.6432738304138184\n",
      "Layer: 0, Models: (14, 5), Overlap: 0.6428996324539185\n",
      "Layer: 0, Models: (14, 6), Overlap: 0.6424744725227356\n",
      "Layer: 0, Models: (14, 7), Overlap: 0.6424404978752136\n",
      "Layer: 0, Models: (14, 8), Overlap: 0.6418622732162476\n",
      "Layer: 0, Models: (14, 9), Overlap: 0.6434183716773987\n",
      "Layer: 0, Models: (14, 10), Overlap: 0.6450340151786804\n",
      "Layer: 0, Models: (14, 11), Overlap: 0.643146276473999\n",
      "Layer: 0, Models: (14, 12), Overlap: 0.6425085067749023\n",
      "Layer: 0, Models: (14, 13), Overlap: 0.6424915194511414\n",
      "Layer: 2, Models: (0, 1), Overlap: 0.6286888718605042\n",
      "Layer: 2, Models: (0, 2), Overlap: 0.627488911151886\n",
      "Layer: 2, Models: (0, 3), Overlap: 0.6290666460990906\n",
      "Layer: 2, Models: (0, 4), Overlap: 0.6279777884483337\n",
      "Layer: 2, Models: (0, 5), Overlap: 0.6282444596290588\n",
      "Layer: 2, Models: (0, 6), Overlap: 0.6275555491447449\n",
      "Layer: 2, Models: (0, 7), Overlap: 0.6270444393157959\n",
      "Layer: 2, Models: (0, 8), Overlap: 0.6290444731712341\n",
      "Layer: 2, Models: (0, 9), Overlap: 0.6263777613639832\n",
      "Layer: 2, Models: (0, 10), Overlap: 0.6280888915061951\n",
      "Layer: 2, Models: (0, 11), Overlap: 0.6261110901832581\n",
      "Layer: 2, Models: (0, 12), Overlap: 0.6290000081062317\n",
      "Layer: 2, Models: (0, 13), Overlap: 0.6305111050605774\n",
      "Layer: 2, Models: (0, 14), Overlap: 0.6279777884483337\n",
      "Layer: 2, Models: (1, 0), Overlap: 0.6286888718605042\n",
      "Layer: 2, Models: (1, 2), Overlap: 0.6300222277641296\n",
      "Layer: 2, Models: (1, 3), Overlap: 0.6257555484771729\n",
      "Layer: 2, Models: (1, 4), Overlap: 0.6300888657569885\n",
      "Layer: 2, Models: (1, 5), Overlap: 0.6279110908508301\n",
      "Layer: 2, Models: (1, 6), Overlap: 0.6282888650894165\n",
      "Layer: 2, Models: (1, 7), Overlap: 0.6282444596290588\n",
      "Layer: 2, Models: (1, 8), Overlap: 0.630466639995575\n",
      "Layer: 2, Models: (1, 9), Overlap: 0.6252889037132263\n",
      "Layer: 2, Models: (1, 10), Overlap: 0.626022219657898\n",
      "Layer: 2, Models: (1, 11), Overlap: 0.6263333559036255\n",
      "Layer: 2, Models: (1, 12), Overlap: 0.6264888644218445\n",
      "Layer: 2, Models: (1, 13), Overlap: 0.6262444257736206\n",
      "Layer: 2, Models: (1, 14), Overlap: 0.6269111037254333\n",
      "Layer: 2, Models: (2, 0), Overlap: 0.627488911151886\n",
      "Layer: 2, Models: (2, 1), Overlap: 0.6300222277641296\n",
      "Layer: 2, Models: (2, 3), Overlap: 0.6281777620315552\n",
      "Layer: 2, Models: (2, 4), Overlap: 0.6251111030578613\n",
      "Layer: 2, Models: (2, 5), Overlap: 0.6285111308097839\n",
      "Layer: 2, Models: (2, 6), Overlap: 0.6268666386604309\n",
      "Layer: 2, Models: (2, 7), Overlap: 0.6261777877807617\n",
      "Layer: 2, Models: (2, 8), Overlap: 0.6272222399711609\n",
      "Layer: 2, Models: (2, 9), Overlap: 0.6268444657325745\n",
      "Layer: 2, Models: (2, 10), Overlap: 0.6269555687904358\n",
      "Layer: 2, Models: (2, 11), Overlap: 0.6276666522026062\n",
      "Layer: 2, Models: (2, 12), Overlap: 0.6276222467422485\n",
      "Layer: 2, Models: (2, 13), Overlap: 0.6286444664001465\n",
      "Layer: 2, Models: (2, 14), Overlap: 0.6263333559036255\n",
      "Layer: 2, Models: (3, 0), Overlap: 0.6290666460990906\n",
      "Layer: 2, Models: (3, 1), Overlap: 0.6257555484771729\n",
      "Layer: 2, Models: (3, 2), Overlap: 0.6281777620315552\n",
      "Layer: 2, Models: (3, 4), Overlap: 0.6252666711807251\n",
      "Layer: 2, Models: (3, 5), Overlap: 0.6285555362701416\n",
      "Layer: 2, Models: (3, 6), Overlap: 0.6297333240509033\n",
      "Layer: 2, Models: (3, 7), Overlap: 0.6268888711929321\n",
      "Layer: 2, Models: (3, 8), Overlap: 0.6275110840797424\n",
      "Layer: 2, Models: (3, 9), Overlap: 0.6270889043807983\n",
      "Layer: 2, Models: (3, 10), Overlap: 0.6283555626869202\n",
      "Layer: 2, Models: (3, 11), Overlap: 0.6277111172676086\n",
      "Layer: 2, Models: (3, 12), Overlap: 0.6276222467422485\n",
      "Layer: 2, Models: (3, 13), Overlap: 0.6285555362701416\n",
      "Layer: 2, Models: (3, 14), Overlap: 0.6282888650894165\n",
      "Layer: 2, Models: (4, 0), Overlap: 0.6279777884483337\n",
      "Layer: 2, Models: (4, 1), Overlap: 0.6300888657569885\n",
      "Layer: 2, Models: (4, 2), Overlap: 0.6251111030578613\n",
      "Layer: 2, Models: (4, 3), Overlap: 0.6252666711807251\n",
      "Layer: 2, Models: (4, 5), Overlap: 0.6273777484893799\n",
      "Layer: 2, Models: (4, 6), Overlap: 0.6269111037254333\n",
      "Layer: 2, Models: (4, 7), Overlap: 0.625844419002533\n",
      "Layer: 2, Models: (4, 8), Overlap: 0.6270666718482971\n",
      "Layer: 2, Models: (4, 9), Overlap: 0.6284000277519226\n",
      "Layer: 2, Models: (4, 10), Overlap: 0.6263777613639832\n",
      "Layer: 2, Models: (4, 11), Overlap: 0.6273555755615234\n",
      "Layer: 2, Models: (4, 12), Overlap: 0.6287111043930054\n",
      "Layer: 2, Models: (4, 13), Overlap: 0.6274444460868835\n",
      "Layer: 2, Models: (4, 14), Overlap: 0.6284444332122803\n",
      "Layer: 2, Models: (5, 0), Overlap: 0.6282444596290588\n",
      "Layer: 2, Models: (5, 1), Overlap: 0.6279110908508301\n",
      "Layer: 2, Models: (5, 2), Overlap: 0.6285111308097839\n",
      "Layer: 2, Models: (5, 3), Overlap: 0.6285555362701416\n",
      "Layer: 2, Models: (5, 4), Overlap: 0.6273777484893799\n",
      "Layer: 2, Models: (5, 6), Overlap: 0.6282666921615601\n",
      "Layer: 2, Models: (5, 7), Overlap: 0.6281333565711975\n",
      "Layer: 2, Models: (5, 8), Overlap: 0.6286222338676453\n",
      "Layer: 2, Models: (5, 9), Overlap: 0.6287333369255066\n",
      "Layer: 2, Models: (5, 10), Overlap: 0.6277333498001099\n",
      "Layer: 2, Models: (5, 11), Overlap: 0.629622220993042\n",
      "Layer: 2, Models: (5, 12), Overlap: 0.6284000277519226\n",
      "Layer: 2, Models: (5, 13), Overlap: 0.6294000148773193\n",
      "Layer: 2, Models: (5, 14), Overlap: 0.6266666650772095\n",
      "Layer: 2, Models: (6, 0), Overlap: 0.6275555491447449\n",
      "Layer: 2, Models: (6, 1), Overlap: 0.6282888650894165\n",
      "Layer: 2, Models: (6, 2), Overlap: 0.6268666386604309\n",
      "Layer: 2, Models: (6, 3), Overlap: 0.6297333240509033\n",
      "Layer: 2, Models: (6, 4), Overlap: 0.6269111037254333\n",
      "Layer: 2, Models: (6, 5), Overlap: 0.6282666921615601\n",
      "Layer: 2, Models: (6, 7), Overlap: 0.6283777952194214\n",
      "Layer: 2, Models: (6, 8), Overlap: 0.6278889179229736\n",
      "Layer: 2, Models: (6, 9), Overlap: 0.6282888650894165\n",
      "Layer: 2, Models: (6, 10), Overlap: 0.627488911151886\n",
      "Layer: 2, Models: (6, 11), Overlap: 0.629622220993042\n",
      "Layer: 2, Models: (6, 12), Overlap: 0.6271555423736572\n",
      "Layer: 2, Models: (6, 13), Overlap: 0.6294666528701782\n",
      "Layer: 2, Models: (6, 14), Overlap: 0.6269333362579346\n",
      "Layer: 2, Models: (7, 0), Overlap: 0.6270444393157959\n",
      "Layer: 2, Models: (7, 1), Overlap: 0.6282444596290588\n",
      "Layer: 2, Models: (7, 2), Overlap: 0.6261777877807617\n",
      "Layer: 2, Models: (7, 3), Overlap: 0.6268888711929321\n",
      "Layer: 2, Models: (7, 4), Overlap: 0.625844419002533\n",
      "Layer: 2, Models: (7, 5), Overlap: 0.6281333565711975\n",
      "Layer: 2, Models: (7, 6), Overlap: 0.6283777952194214\n",
      "Layer: 2, Models: (7, 8), Overlap: 0.6254444718360901\n",
      "Layer: 2, Models: (7, 9), Overlap: 0.6281999945640564\n",
      "Layer: 2, Models: (7, 10), Overlap: 0.6270666718482971\n",
      "Layer: 2, Models: (7, 11), Overlap: 0.6252889037132263\n",
      "Layer: 2, Models: (7, 12), Overlap: 0.6284888982772827\n",
      "Layer: 2, Models: (7, 13), Overlap: 0.6277777552604675\n",
      "Layer: 2, Models: (7, 14), Overlap: 0.6274222135543823\n",
      "Layer: 2, Models: (8, 0), Overlap: 0.6290444731712341\n",
      "Layer: 2, Models: (8, 1), Overlap: 0.630466639995575\n",
      "Layer: 2, Models: (8, 2), Overlap: 0.6272222399711609\n",
      "Layer: 2, Models: (8, 3), Overlap: 0.6275110840797424\n",
      "Layer: 2, Models: (8, 4), Overlap: 0.6270666718482971\n",
      "Layer: 2, Models: (8, 5), Overlap: 0.6286222338676453\n",
      "Layer: 2, Models: (8, 6), Overlap: 0.6278889179229736\n",
      "Layer: 2, Models: (8, 7), Overlap: 0.6254444718360901\n",
      "Layer: 2, Models: (8, 9), Overlap: 0.6280444264411926\n",
      "Layer: 2, Models: (8, 10), Overlap: 0.6265555620193481\n",
      "Layer: 2, Models: (8, 11), Overlap: 0.6263777613639832\n",
      "Layer: 2, Models: (8, 12), Overlap: 0.6272222399711609\n",
      "Layer: 2, Models: (8, 13), Overlap: 0.6282666921615601\n",
      "Layer: 2, Models: (8, 14), Overlap: 0.6276666522026062\n",
      "Layer: 2, Models: (9, 0), Overlap: 0.6263777613639832\n",
      "Layer: 2, Models: (9, 1), Overlap: 0.6252889037132263\n",
      "Layer: 2, Models: (9, 2), Overlap: 0.6268444657325745\n",
      "Layer: 2, Models: (9, 3), Overlap: 0.6270889043807983\n",
      "Layer: 2, Models: (9, 4), Overlap: 0.6284000277519226\n",
      "Layer: 2, Models: (9, 5), Overlap: 0.6287333369255066\n",
      "Layer: 2, Models: (9, 6), Overlap: 0.6282888650894165\n",
      "Layer: 2, Models: (9, 7), Overlap: 0.6281999945640564\n",
      "Layer: 2, Models: (9, 8), Overlap: 0.6280444264411926\n",
      "Layer: 2, Models: (9, 10), Overlap: 0.6288444399833679\n",
      "Layer: 2, Models: (9, 11), Overlap: 0.6254000067710876\n",
      "Layer: 2, Models: (9, 12), Overlap: 0.6267777681350708\n",
      "Layer: 2, Models: (9, 13), Overlap: 0.6273999810218811\n",
      "Layer: 2, Models: (9, 14), Overlap: 0.6284888982772827\n",
      "Layer: 2, Models: (10, 0), Overlap: 0.6280888915061951\n",
      "Layer: 2, Models: (10, 1), Overlap: 0.626022219657898\n",
      "Layer: 2, Models: (10, 2), Overlap: 0.6269555687904358\n",
      "Layer: 2, Models: (10, 3), Overlap: 0.6283555626869202\n",
      "Layer: 2, Models: (10, 4), Overlap: 0.6263777613639832\n",
      "Layer: 2, Models: (10, 5), Overlap: 0.6277333498001099\n",
      "Layer: 2, Models: (10, 6), Overlap: 0.627488911151886\n",
      "Layer: 2, Models: (10, 7), Overlap: 0.6270666718482971\n",
      "Layer: 2, Models: (10, 8), Overlap: 0.6265555620193481\n",
      "Layer: 2, Models: (10, 9), Overlap: 0.6288444399833679\n",
      "Layer: 2, Models: (10, 11), Overlap: 0.6275333166122437\n",
      "Layer: 2, Models: (10, 12), Overlap: 0.6278889179229736\n",
      "Layer: 2, Models: (10, 13), Overlap: 0.628933310508728\n",
      "Layer: 2, Models: (10, 14), Overlap: 0.6277111172676086\n",
      "Layer: 2, Models: (11, 0), Overlap: 0.6261110901832581\n",
      "Layer: 2, Models: (11, 1), Overlap: 0.6263333559036255\n",
      "Layer: 2, Models: (11, 2), Overlap: 0.6276666522026062\n",
      "Layer: 2, Models: (11, 3), Overlap: 0.6277111172676086\n",
      "Layer: 2, Models: (11, 4), Overlap: 0.6273555755615234\n",
      "Layer: 2, Models: (11, 5), Overlap: 0.629622220993042\n",
      "Layer: 2, Models: (11, 6), Overlap: 0.629622220993042\n",
      "Layer: 2, Models: (11, 7), Overlap: 0.6252889037132263\n",
      "Layer: 2, Models: (11, 8), Overlap: 0.6263777613639832\n",
      "Layer: 2, Models: (11, 9), Overlap: 0.6254000067710876\n",
      "Layer: 2, Models: (11, 10), Overlap: 0.6275333166122437\n",
      "Layer: 2, Models: (11, 12), Overlap: 0.6293333172798157\n",
      "Layer: 2, Models: (11, 13), Overlap: 0.6272222399711609\n",
      "Layer: 2, Models: (11, 14), Overlap: 0.6275777816772461\n",
      "Layer: 2, Models: (12, 0), Overlap: 0.6290000081062317\n",
      "Layer: 2, Models: (12, 1), Overlap: 0.6264888644218445\n",
      "Layer: 2, Models: (12, 2), Overlap: 0.6276222467422485\n",
      "Layer: 2, Models: (12, 3), Overlap: 0.6276222467422485\n",
      "Layer: 2, Models: (12, 4), Overlap: 0.6287111043930054\n",
      "Layer: 2, Models: (12, 5), Overlap: 0.6284000277519226\n",
      "Layer: 2, Models: (12, 6), Overlap: 0.6271555423736572\n",
      "Layer: 2, Models: (12, 7), Overlap: 0.6284888982772827\n",
      "Layer: 2, Models: (12, 8), Overlap: 0.6272222399711609\n",
      "Layer: 2, Models: (12, 9), Overlap: 0.6267777681350708\n",
      "Layer: 2, Models: (12, 10), Overlap: 0.6278889179229736\n",
      "Layer: 2, Models: (12, 11), Overlap: 0.6293333172798157\n",
      "Layer: 2, Models: (12, 13), Overlap: 0.6276888847351074\n",
      "Layer: 2, Models: (12, 14), Overlap: 0.628000020980835\n",
      "Layer: 2, Models: (13, 0), Overlap: 0.6305111050605774\n",
      "Layer: 2, Models: (13, 1), Overlap: 0.6262444257736206\n",
      "Layer: 2, Models: (13, 2), Overlap: 0.6286444664001465\n",
      "Layer: 2, Models: (13, 3), Overlap: 0.6285555362701416\n",
      "Layer: 2, Models: (13, 4), Overlap: 0.6274444460868835\n",
      "Layer: 2, Models: (13, 5), Overlap: 0.6294000148773193\n",
      "Layer: 2, Models: (13, 6), Overlap: 0.6294666528701782\n",
      "Layer: 2, Models: (13, 7), Overlap: 0.6277777552604675\n",
      "Layer: 2, Models: (13, 8), Overlap: 0.6282666921615601\n",
      "Layer: 2, Models: (13, 9), Overlap: 0.6273999810218811\n",
      "Layer: 2, Models: (13, 10), Overlap: 0.628933310508728\n",
      "Layer: 2, Models: (13, 11), Overlap: 0.6272222399711609\n",
      "Layer: 2, Models: (13, 12), Overlap: 0.6276888847351074\n",
      "Layer: 2, Models: (13, 14), Overlap: 0.6291999816894531\n",
      "Layer: 2, Models: (14, 0), Overlap: 0.6279777884483337\n",
      "Layer: 2, Models: (14, 1), Overlap: 0.6269111037254333\n",
      "Layer: 2, Models: (14, 2), Overlap: 0.6263333559036255\n",
      "Layer: 2, Models: (14, 3), Overlap: 0.6282888650894165\n",
      "Layer: 2, Models: (14, 4), Overlap: 0.6284444332122803\n",
      "Layer: 2, Models: (14, 5), Overlap: 0.6266666650772095\n",
      "Layer: 2, Models: (14, 6), Overlap: 0.6269333362579346\n",
      "Layer: 2, Models: (14, 7), Overlap: 0.6274222135543823\n",
      "Layer: 2, Models: (14, 8), Overlap: 0.6276666522026062\n",
      "Layer: 2, Models: (14, 9), Overlap: 0.6284888982772827\n",
      "Layer: 2, Models: (14, 10), Overlap: 0.6277111172676086\n",
      "Layer: 2, Models: (14, 11), Overlap: 0.6275777816772461\n",
      "Layer: 2, Models: (14, 12), Overlap: 0.628000020980835\n",
      "Layer: 2, Models: (14, 13), Overlap: 0.6291999816894531\n",
      "Layer: 4, Models: (0, 1), Overlap: 0.6425999999046326\n",
      "Layer: 4, Models: (0, 2), Overlap: 0.6404666900634766\n",
      "Layer: 4, Models: (0, 3), Overlap: 0.6422666907310486\n",
      "Layer: 4, Models: (0, 4), Overlap: 0.6403999924659729\n",
      "Layer: 4, Models: (0, 5), Overlap: 0.645799994468689\n",
      "Layer: 4, Models: (0, 6), Overlap: 0.6409333348274231\n",
      "Layer: 4, Models: (0, 7), Overlap: 0.6425333619117737\n",
      "Layer: 4, Models: (0, 8), Overlap: 0.644266664981842\n",
      "Layer: 4, Models: (0, 9), Overlap: 0.6464666724205017\n",
      "Layer: 4, Models: (0, 10), Overlap: 0.6478666663169861\n",
      "Layer: 4, Models: (0, 11), Overlap: 0.644266664981842\n",
      "Layer: 4, Models: (0, 12), Overlap: 0.6394000053405762\n",
      "Layer: 4, Models: (0, 13), Overlap: 0.6417999863624573\n",
      "Layer: 4, Models: (0, 14), Overlap: 0.6392666697502136\n",
      "Layer: 4, Models: (1, 0), Overlap: 0.6425999999046326\n",
      "Layer: 4, Models: (1, 2), Overlap: 0.6406000256538391\n",
      "Layer: 4, Models: (1, 3), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (1, 4), Overlap: 0.6403999924659729\n",
      "Layer: 4, Models: (1, 5), Overlap: 0.6447333097457886\n",
      "Layer: 4, Models: (1, 6), Overlap: 0.642133355140686\n",
      "Layer: 4, Models: (1, 7), Overlap: 0.6419333219528198\n",
      "Layer: 4, Models: (1, 8), Overlap: 0.6417333483695984\n",
      "Layer: 4, Models: (1, 9), Overlap: 0.6444666385650635\n",
      "Layer: 4, Models: (1, 10), Overlap: 0.6478666663169861\n",
      "Layer: 4, Models: (1, 11), Overlap: 0.6428666710853577\n",
      "Layer: 4, Models: (1, 12), Overlap: 0.6422666907310486\n",
      "Layer: 4, Models: (1, 13), Overlap: 0.644266664981842\n",
      "Layer: 4, Models: (1, 14), Overlap: 0.6443333625793457\n",
      "Layer: 4, Models: (2, 0), Overlap: 0.6404666900634766\n",
      "Layer: 4, Models: (2, 1), Overlap: 0.6406000256538391\n",
      "Layer: 4, Models: (2, 3), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (2, 4), Overlap: 0.6424000263214111\n",
      "Layer: 4, Models: (2, 5), Overlap: 0.6394666433334351\n",
      "Layer: 4, Models: (2, 6), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (2, 7), Overlap: 0.6439999938011169\n",
      "Layer: 4, Models: (2, 8), Overlap: 0.6448666453361511\n",
      "Layer: 4, Models: (2, 9), Overlap: 0.6430666446685791\n",
      "Layer: 4, Models: (2, 10), Overlap: 0.6425999999046326\n",
      "Layer: 4, Models: (2, 11), Overlap: 0.6420666575431824\n",
      "Layer: 4, Models: (2, 12), Overlap: 0.6434666514396667\n",
      "Layer: 4, Models: (2, 13), Overlap: 0.6458666920661926\n",
      "Layer: 4, Models: (2, 14), Overlap: 0.6396666765213013\n",
      "Layer: 4, Models: (3, 0), Overlap: 0.6422666907310486\n",
      "Layer: 4, Models: (3, 1), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (3, 2), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (3, 4), Overlap: 0.6418666839599609\n",
      "Layer: 4, Models: (3, 5), Overlap: 0.6425999999046326\n",
      "Layer: 4, Models: (3, 6), Overlap: 0.6467333436012268\n",
      "Layer: 4, Models: (3, 7), Overlap: 0.6462666392326355\n",
      "Layer: 4, Models: (3, 8), Overlap: 0.6460666656494141\n",
      "Layer: 4, Models: (3, 9), Overlap: 0.6460000276565552\n",
      "Layer: 4, Models: (3, 10), Overlap: 0.6471333503723145\n",
      "Layer: 4, Models: (3, 11), Overlap: 0.6449333429336548\n",
      "Layer: 4, Models: (3, 12), Overlap: 0.6480000019073486\n",
      "Layer: 4, Models: (3, 13), Overlap: 0.6449333429336548\n",
      "Layer: 4, Models: (3, 14), Overlap: 0.646399974822998\n",
      "Layer: 4, Models: (4, 0), Overlap: 0.6403999924659729\n",
      "Layer: 4, Models: (4, 1), Overlap: 0.6403999924659729\n",
      "Layer: 4, Models: (4, 2), Overlap: 0.6424000263214111\n",
      "Layer: 4, Models: (4, 3), Overlap: 0.6418666839599609\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Layer: 4, Models: (4, 5), Overlap: 0.6474666595458984\n",
      "Layer: 4, Models: (4, 6), Overlap: 0.638866662979126\n",
      "Layer: 4, Models: (4, 7), Overlap: 0.643666684627533\n",
      "Layer: 4, Models: (4, 8), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (4, 9), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (4, 10), Overlap: 0.6452000141143799\n",
      "Layer: 4, Models: (4, 11), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (4, 12), Overlap: 0.6408666372299194\n",
      "Layer: 4, Models: (4, 13), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (4, 14), Overlap: 0.6388000249862671\n",
      "Layer: 4, Models: (5, 0), Overlap: 0.645799994468689\n",
      "Layer: 4, Models: (5, 1), Overlap: 0.6447333097457886\n",
      "Layer: 4, Models: (5, 2), Overlap: 0.6394666433334351\n",
      "Layer: 4, Models: (5, 3), Overlap: 0.6425999999046326\n",
      "Layer: 4, Models: (5, 4), Overlap: 0.6474666595458984\n",
      "Layer: 4, Models: (5, 6), Overlap: 0.644599974155426\n",
      "Layer: 4, Models: (5, 7), Overlap: 0.6451333165168762\n",
      "Layer: 4, Models: (5, 8), Overlap: 0.6448666453361511\n",
      "Layer: 4, Models: (5, 9), Overlap: 0.6451333165168762\n",
      "Layer: 4, Models: (5, 10), Overlap: 0.6447333097457886\n",
      "Layer: 4, Models: (5, 11), Overlap: 0.6475333571434021\n",
      "Layer: 4, Models: (5, 12), Overlap: 0.6467333436012268\n",
      "Layer: 4, Models: (5, 13), Overlap: 0.646133303642273\n",
      "Layer: 4, Models: (5, 14), Overlap: 0.6415333151817322\n",
      "Layer: 4, Models: (6, 0), Overlap: 0.6409333348274231\n",
      "Layer: 4, Models: (6, 1), Overlap: 0.642133355140686\n",
      "Layer: 4, Models: (6, 2), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (6, 3), Overlap: 0.6467333436012268\n",
      "Layer: 4, Models: (6, 4), Overlap: 0.638866662979126\n",
      "Layer: 4, Models: (6, 5), Overlap: 0.644599974155426\n",
      "Layer: 4, Models: (6, 7), Overlap: 0.6424000263214111\n",
      "Layer: 4, Models: (6, 8), Overlap: 0.6452000141143799\n",
      "Layer: 4, Models: (6, 9), Overlap: 0.6502000093460083\n",
      "Layer: 4, Models: (6, 10), Overlap: 0.6431333422660828\n",
      "Layer: 4, Models: (6, 11), Overlap: 0.6469333171844482\n",
      "Layer: 4, Models: (6, 12), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (6, 13), Overlap: 0.6448666453361511\n",
      "Layer: 4, Models: (6, 14), Overlap: 0.6423333287239075\n",
      "Layer: 4, Models: (7, 0), Overlap: 0.6425333619117737\n",
      "Layer: 4, Models: (7, 1), Overlap: 0.6419333219528198\n",
      "Layer: 4, Models: (7, 2), Overlap: 0.6439999938011169\n",
      "Layer: 4, Models: (7, 3), Overlap: 0.6462666392326355\n",
      "Layer: 4, Models: (7, 4), Overlap: 0.643666684627533\n",
      "Layer: 4, Models: (7, 5), Overlap: 0.6451333165168762\n",
      "Layer: 4, Models: (7, 6), Overlap: 0.6424000263214111\n",
      "Layer: 4, Models: (7, 8), Overlap: 0.6428666710853577\n",
      "Layer: 4, Models: (7, 9), Overlap: 0.6405333280563354\n",
      "Layer: 4, Models: (7, 10), Overlap: 0.6470000147819519\n",
      "Layer: 4, Models: (7, 11), Overlap: 0.6430000066757202\n",
      "Layer: 4, Models: (7, 12), Overlap: 0.6421999931335449\n",
      "Layer: 4, Models: (7, 13), Overlap: 0.6425333619117737\n",
      "Layer: 4, Models: (7, 14), Overlap: 0.6460000276565552\n",
      "Layer: 4, Models: (8, 0), Overlap: 0.644266664981842\n",
      "Layer: 4, Models: (8, 1), Overlap: 0.6417333483695984\n",
      "Layer: 4, Models: (8, 2), Overlap: 0.6448666453361511\n",
      "Layer: 4, Models: (8, 3), Overlap: 0.6460666656494141\n",
      "Layer: 4, Models: (8, 4), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (8, 5), Overlap: 0.6448666453361511\n",
      "Layer: 4, Models: (8, 6), Overlap: 0.6452000141143799\n",
      "Layer: 4, Models: (8, 7), Overlap: 0.6428666710853577\n",
      "Layer: 4, Models: (8, 9), Overlap: 0.6440666913986206\n",
      "Layer: 4, Models: (8, 10), Overlap: 0.6434666514396667\n",
      "Layer: 4, Models: (8, 11), Overlap: 0.6480000019073486\n",
      "Layer: 4, Models: (8, 12), Overlap: 0.64246666431427\n",
      "Layer: 4, Models: (8, 13), Overlap: 0.6377999782562256\n",
      "Layer: 4, Models: (8, 14), Overlap: 0.6438666582107544\n",
      "Layer: 4, Models: (9, 0), Overlap: 0.6464666724205017\n",
      "Layer: 4, Models: (9, 1), Overlap: 0.6444666385650635\n",
      "Layer: 4, Models: (9, 2), Overlap: 0.6430666446685791\n",
      "Layer: 4, Models: (9, 3), Overlap: 0.6460000276565552\n",
      "Layer: 4, Models: (9, 4), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (9, 5), Overlap: 0.6451333165168762\n",
      "Layer: 4, Models: (9, 6), Overlap: 0.6502000093460083\n",
      "Layer: 4, Models: (9, 7), Overlap: 0.6405333280563354\n",
      "Layer: 4, Models: (9, 8), Overlap: 0.6440666913986206\n",
      "Layer: 4, Models: (9, 10), Overlap: 0.644599974155426\n",
      "Layer: 4, Models: (9, 11), Overlap: 0.6442000269889832\n",
      "Layer: 4, Models: (9, 12), Overlap: 0.6422666907310486\n",
      "Layer: 4, Models: (9, 13), Overlap: 0.6433333158493042\n",
      "Layer: 4, Models: (9, 14), Overlap: 0.6438666582107544\n",
      "Layer: 4, Models: (10, 0), Overlap: 0.6478666663169861\n",
      "Layer: 4, Models: (10, 1), Overlap: 0.6478666663169861\n",
      "Layer: 4, Models: (10, 2), Overlap: 0.6425999999046326\n",
      "Layer: 4, Models: (10, 3), Overlap: 0.6471333503723145\n",
      "Layer: 4, Models: (10, 4), Overlap: 0.6452000141143799\n",
      "Layer: 4, Models: (10, 5), Overlap: 0.6447333097457886\n",
      "Layer: 4, Models: (10, 6), Overlap: 0.6431333422660828\n",
      "Layer: 4, Models: (10, 7), Overlap: 0.6470000147819519\n",
      "Layer: 4, Models: (10, 8), Overlap: 0.6434666514396667\n",
      "Layer: 4, Models: (10, 9), Overlap: 0.644599974155426\n",
      "Layer: 4, Models: (10, 11), Overlap: 0.6443333625793457\n",
      "Layer: 4, Models: (10, 12), Overlap: 0.6435999870300293\n",
      "Layer: 4, Models: (10, 13), Overlap: 0.6462666392326355\n",
      "Layer: 4, Models: (10, 14), Overlap: 0.6462000012397766\n",
      "Layer: 4, Models: (11, 0), Overlap: 0.644266664981842\n",
      "Layer: 4, Models: (11, 1), Overlap: 0.6428666710853577\n",
      "Layer: 4, Models: (11, 2), Overlap: 0.6420666575431824\n",
      "Layer: 4, Models: (11, 3), Overlap: 0.6449333429336548\n",
      "Layer: 4, Models: (11, 4), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (11, 5), Overlap: 0.6475333571434021\n",
      "Layer: 4, Models: (11, 6), Overlap: 0.6469333171844482\n",
      "Layer: 4, Models: (11, 7), Overlap: 0.6430000066757202\n",
      "Layer: 4, Models: (11, 8), Overlap: 0.6480000019073486\n",
      "Layer: 4, Models: (11, 9), Overlap: 0.6442000269889832\n",
      "Layer: 4, Models: (11, 10), Overlap: 0.6443333625793457\n",
      "Layer: 4, Models: (11, 12), Overlap: 0.640333354473114\n",
      "Layer: 4, Models: (11, 13), Overlap: 0.6447333097457886\n",
      "Layer: 4, Models: (11, 14), Overlap: 0.6423333287239075\n",
      "Layer: 4, Models: (12, 0), Overlap: 0.6394000053405762\n",
      "Layer: 4, Models: (12, 1), Overlap: 0.6422666907310486\n",
      "Layer: 4, Models: (12, 2), Overlap: 0.6434666514396667\n",
      "Layer: 4, Models: (12, 3), Overlap: 0.6480000019073486\n",
      "Layer: 4, Models: (12, 4), Overlap: 0.6408666372299194\n",
      "Layer: 4, Models: (12, 5), Overlap: 0.6467333436012268\n",
      "Layer: 4, Models: (12, 6), Overlap: 0.6432666778564453\n",
      "Layer: 4, Models: (12, 7), Overlap: 0.6421999931335449\n",
      "Layer: 4, Models: (12, 8), Overlap: 0.64246666431427\n",
      "Layer: 4, Models: (12, 9), Overlap: 0.6422666907310486\n",
      "Layer: 4, Models: (12, 10), Overlap: 0.6435999870300293\n",
      "Layer: 4, Models: (12, 11), Overlap: 0.640333354473114\n",
      "Layer: 4, Models: (12, 13), Overlap: 0.63919997215271\n",
      "Layer: 4, Models: (12, 14), Overlap: 0.6444000005722046\n",
      "Layer: 4, Models: (13, 0), Overlap: 0.6417999863624573\n",
      "Layer: 4, Models: (13, 1), Overlap: 0.644266664981842\n",
      "Layer: 4, Models: (13, 2), Overlap: 0.6458666920661926\n",
      "Layer: 4, Models: (13, 3), Overlap: 0.6449333429336548\n",
      "Layer: 4, Models: (13, 4), Overlap: 0.6450666785240173\n",
      "Layer: 4, Models: (13, 5), Overlap: 0.646133303642273\n",
      "Layer: 4, Models: (13, 6), Overlap: 0.6448666453361511\n",
      "Layer: 4, Models: (13, 7), Overlap: 0.6425333619117737\n",
      "Layer: 4, Models: (13, 8), Overlap: 0.6377999782562256\n",
      "Layer: 4, Models: (13, 9), Overlap: 0.6433333158493042\n",
      "Layer: 4, Models: (13, 10), Overlap: 0.6462666392326355\n",
      "Layer: 4, Models: (13, 11), Overlap: 0.6447333097457886\n",
      "Layer: 4, Models: (13, 12), Overlap: 0.63919997215271\n",
      "Layer: 4, Models: (13, 14), Overlap: 0.6396666765213013\n",
      "Layer: 4, Models: (14, 0), Overlap: 0.6392666697502136\n",
      "Layer: 4, Models: (14, 1), Overlap: 0.6443333625793457\n",
      "Layer: 4, Models: (14, 2), Overlap: 0.6396666765213013\n",
      "Layer: 4, Models: (14, 3), Overlap: 0.646399974822998\n",
      "Layer: 4, Models: (14, 4), Overlap: 0.6388000249862671\n",
      "Layer: 4, Models: (14, 5), Overlap: 0.6415333151817322\n",
      "Layer: 4, Models: (14, 6), Overlap: 0.6423333287239075\n",
      "Layer: 4, Models: (14, 7), Overlap: 0.6460000276565552\n",
      "Layer: 4, Models: (14, 8), Overlap: 0.6438666582107544\n",
      "Layer: 4, Models: (14, 9), Overlap: 0.6438666582107544\n",
      "Layer: 4, Models: (14, 10), Overlap: 0.6462000012397766\n",
      "Layer: 4, Models: (14, 11), Overlap: 0.6423333287239075\n",
      "Layer: 4, Models: (14, 12), Overlap: 0.6444000005722046\n",
      "Layer: 4, Models: (14, 13), Overlap: 0.6396666765213013\n"
     ]
    }
   ],
   "source": [
    "task = 0\n",
    "for layer, modelidx in product([0,2,4], product([i for i in range(15)], [i for i in range(15)])):\n",
    "    modeli, modelj = modelidx\n",
    "    if modeli == modelj:\n",
    "        continue\n",
    "    print('Layer: {}, Models: ({}, {}), Overlap: {}'.format(layer, modeli, modelj,\n",
    "        overlap(model_map[modeli].state_dict()['model.{}.stacked'.format(layer)][task],\n",
    "                model_map[modelj].state_dict()['model.{}.stacked'.format(layer)][task])))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Basis Masks "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model Initialization (Only New Tasks)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks = 50 # For demonstration purposes, we go up to 2500 in our paper\n",
    "num_seed_tasks_learned = 40\n",
    "basis_model = BasisMultitaskFC(hidden_size=300, num_tasks=num_tasks, num_seed_tasks_learned=num_seed_tasks_learned, start_at_optimal=True, sparsity=0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n"
     ]
    }
   ],
   "source": [
    "seed_dict = model.state_dict()\n",
    "basis_dict = basis_model.state_dict()\n",
    "load_dict = {k: seed_dict[k] for k in basis_model.state_dict().keys() if k in seed_dict.keys()}\n",
    "basis_dict.update(load_dict)\n",
    "basis_model.load_state_dict(basis_dict, False)\n",
    "cache_masks(basis_model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 40\n",
      "=> Set task of model.0 to 40\n",
      "=> Set task of model.2 to 40\n",
      "=> Set task of model.4 to 40\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "12352b8ce94b4b9c8347a82e8904c408",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5575, Acc@1 0.3060\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "289ee319a5d9463e86169450972592a8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4635\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "274e11d85faf4dd5a96a8fb3e7e8996b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2256, Acc@1 0.5085\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "43d7125a662e44fbbad809bd8384b262",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5387\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 41\n",
      "=> Setting learned tasks of model.2 to 41\n",
      "=> Setting learned tasks of model.4 to 41\n",
      "\n",
      "Training for task 41\n",
      "=> Set task of model.0 to 41\n",
      "=> Set task of model.2 to 41\n",
      "=> Set task of model.4 to 41\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2b4cf053bef3489486e391d12a49f34b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6740, Acc@1 0.2939\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ba4e3c0a7bb849729d424cd5f688864a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4347\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "94d0d55c840c423c9d6c1eb0bc347a8b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3222, Acc@1 0.5059\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "68fdc474e3cb4db89801afa7693406c2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5479\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 42\n",
      "=> Setting learned tasks of model.2 to 42\n",
      "=> Setting learned tasks of model.4 to 42\n",
      "\n",
      "Training for task 42\n",
      "=> Set task of model.0 to 42\n",
      "=> Set task of model.2 to 42\n",
      "=> Set task of model.4 to 42\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "54c605d55f99452a889354600100956c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4927, Acc@1 0.3356\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5fcaf41634be411483ea2ddbf25925a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5106\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6f85c0ff73eb476ea24c3599fbe5804e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4507, Acc@1 0.5417\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3c80a4badb1c4dbfa4c47718fb9591c4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5857\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 43\n",
      "=> Setting learned tasks of model.2 to 43\n",
      "=> Setting learned tasks of model.4 to 43\n",
      "\n",
      "Training for task 43\n",
      "=> Set task of model.0 to 43\n",
      "=> Set task of model.2 to 43\n",
      "=> Set task of model.4 to 43\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "08ac2bd9f0394f5d82a24f3aaf0f96a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4743, Acc@1 0.3158\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2651708032e54b05b413398faad0c7d9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4667\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6305f3e5042e4110a60eb9879da0b042",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3278, Acc@1 0.4801\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "109c01ea7a854ca89d7deae8c255c17e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5370\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 44\n",
      "=> Setting learned tasks of model.2 to 44\n",
      "=> Setting learned tasks of model.4 to 44\n",
      "\n",
      "Training for task 44\n",
      "=> Set task of model.0 to 44\n",
      "=> Set task of model.2 to 44\n",
      "=> Set task of model.4 to 44\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7b1fbc815fef4bf78815123d891a11ec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6210, Acc@1 0.3037\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "da9675980ab54ca1b9667094bc40f54b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4761\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "30b8e88de44b4e64812bf573ec783bfe",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3181, Acc@1 0.5358\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ea3baed95aaf47aaa1f370fcedce22a5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5858\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 45\n",
      "=> Setting learned tasks of model.2 to 45\n",
      "=> Setting learned tasks of model.4 to 45\n",
      "\n",
      "Training for task 45\n",
      "=> Set task of model.0 to 45\n",
      "=> Set task of model.2 to 45\n",
      "=> Set task of model.4 to 45\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e7689db7c0b448199024c5aa9c80c734",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6129, Acc@1 0.3278\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e2018b5f777b49da8bbd54b5753a03dd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4716\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "969272aa036944cb93e4289c9a8b99ae",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2530, Acc@1 0.5091\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bfd7a52c1915430d94356aacc9bd28ec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5631\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 46\n",
      "=> Setting learned tasks of model.2 to 46\n",
      "=> Setting learned tasks of model.4 to 46\n",
      "\n",
      "Training for task 46\n",
      "=> Set task of model.0 to 46\n",
      "=> Set task of model.2 to 46\n",
      "=> Set task of model.4 to 46\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "97006274fad845ab85ea94a94360bad9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7034, Acc@1 0.2809\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b220061a9aa1459b84a509892ad238b2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4134\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dab4c11a08104f3ba3f1e1a737194b64",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3144, Acc@1 0.4990\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ab2bf627720544be870063fb9314c482",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5414\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 47\n",
      "=> Setting learned tasks of model.2 to 47\n",
      "=> Setting learned tasks of model.4 to 47\n",
      "\n",
      "Training for task 47\n",
      "=> Set task of model.0 to 47\n",
      "=> Set task of model.2 to 47\n",
      "=> Set task of model.4 to 47\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9e63834c30eb482295ec75b22dc5a0fa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5168, Acc@1 0.3210\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ceb5a4732af548e2ae0e1e0ead504686",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4992\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "56d39cee4d0d45debc25acb6d17be56a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3096, Acc@1 0.5485\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2c6b6a20581d49f0a43270d116d228c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5841\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 48\n",
      "=> Setting learned tasks of model.2 to 48\n",
      "=> Setting learned tasks of model.4 to 48\n",
      "\n",
      "Training for task 48\n",
      "=> Set task of model.0 to 48\n",
      "=> Set task of model.2 to 48\n",
      "=> Set task of model.4 to 48\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d45c679f24cd4ae79fb2a4bf7696dfa9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7470, Acc@1 0.3314\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a833e319eb004c90b62e58d4c6b04443",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4122\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5c29e8e550264f58a14966c3db857266",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3437, Acc@1 0.4801\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "77ef5032bfd642b8ba3875292b7b15a5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5157\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 49\n",
      "=> Setting learned tasks of model.2 to 49\n",
      "=> Setting learned tasks of model.4 to 49\n",
      "\n",
      "Training for task 49\n",
      "=> Set task of model.0 to 49\n",
      "=> Set task of model.2 to 49\n",
      "=> Set task of model.4 to 49\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "15ac642df2db40fb998b28950f611158",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4629, Acc@1 0.3324\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3cea4ca9deb6453bb0c179b48b287545",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5028\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6fceaa14863d4bee9e1cff126a7892cc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3120, Acc@1 0.5462\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e6aa17c3a5274f5d82dc5d8127e3349d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5697\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 50\n",
      "=> Setting learned tasks of model.2 to 50\n",
      "=> Setting learned tasks of model.4 to 50\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for task in range(num_seed_tasks_learned, num_tasks):\n",
    "    print(f\"Training for task {task}\")\n",
    "    set_model_task(basis_model, task)\n",
    "    mnist.update_task(task)\n",
    "\n",
    "    optimizer = optim.RMSprop([p for p in basis_model.parameters() if p.requires_grad], lr=1e-3)\n",
    "    # Train for 1 epoch\n",
    "    for e in range(2):\n",
    "        train(basis_model, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "        print(\"Validation\")\n",
    "        print(\"============\")\n",
    "        acc1 = evaluate(basis_model, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "    cache_masks(basis_model)\n",
    "    print()\n",
    "    set_num_tasks_learned(basis_model, task + 1)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.8412\n",
      "Per task performance\n",
      "Task 0: 0.9123\n",
      "Task 1: 0.9123\n",
      "Task 2: 0.9141\n",
      "Task 3: 0.9144\n",
      "Task 4: 0.9112\n",
      "Task 5: 0.9153\n",
      "Task 6: 0.9124\n",
      "Task 7: 0.9112\n",
      "Task 8: 0.9154\n",
      "Task 9: 0.9143\n",
      "Task 10: 0.9144\n",
      "Task 11: 0.9104\n",
      "Task 12: 0.9161\n",
      "Task 13: 0.9120\n",
      "Task 14: 0.9123\n",
      "Task 15: 0.9117\n",
      "Task 16: 0.9107\n",
      "Task 17: 0.9143\n",
      "Task 18: 0.9106\n",
      "Task 19: 0.9048\n",
      "Task 20: 0.9109\n",
      "Task 21: 0.9132\n",
      "Task 22: 0.9125\n",
      "Task 23: 0.9118\n",
      "Task 24: 0.9130\n",
      "Task 25: 0.9115\n",
      "Task 26: 0.9131\n",
      "Task 27: 0.9118\n",
      "Task 28: 0.9121\n",
      "Task 29: 0.9135\n",
      "Task 30: 0.9107\n",
      "Task 31: 0.9081\n",
      "Task 32: 0.9130\n",
      "Task 33: 0.9117\n",
      "Task 34: 0.9147\n",
      "Task 35: 0.9117\n",
      "Task 36: 0.9124\n",
      "Task 37: 0.9122\n",
      "Task 38: 0.9070\n",
      "Task 39: 0.9134\n",
      "Task 40: 0.5387\n",
      "Task 41: 0.5479\n",
      "Task 42: 0.5857\n",
      "Task 43: 0.5370\n",
      "Task 44: 0.5858\n",
      "Task 45: 0.5631\n",
      "Task 46: 0.5414\n",
      "Task 47: 0.5841\n",
      "Task 48: 0.5157\n",
      "Task 49: 0.5697\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(basis_model, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(basis_model, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['basis_mnist'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model Initialization (Cross task analysis) -- Using 1 mask from task 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks = 10 # For demonstration purposes, we go up to 2500 in our paper\n",
    "num_seed_tasks_learned = 1\n",
    "basis_model_f = BasisMultitaskFC(hidden_size=300,\n",
    "                            num_tasks=num_tasks, num_seed_tasks_learned=num_seed_tasks_learned, start_at_optimal=True, sparsity=0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "custom_state_dict = basis_model_f.state_dict().copy()\n",
    "custom_state_dict.update({k:v for k,v in model.state_dict().items() if k in custom_state_dict.keys()})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "for k in custom_state_dict.keys():\n",
    "    if k.startswith('model.0.scores.'):\n",
    "        custom_state_dict[k] = model.state_dict()['model.0.scores.0']\n",
    "    elif k.startswith('model.2.scores.'):\n",
    "        custom_state_dict[k] = model.state_dict()['model.2.scores.0']\n",
    "    elif k.startswith('model.4.scores.'):\n",
    "        custom_state_dict[k] = model.state_dict()['model.4.scores.0']\n",
    "    elif k.startswith('model.0.basis_alphas.'):\n",
    "        custom_state_dict[k] = custom_state_dict['model.0.basis_alphas.0'] \n",
    "    elif k.startswith('model.2.basis_alphas.'):\n",
    "        custom_state_dict[k] = custom_state_dict['model.2.basis_alphas.0']\n",
    "    elif k.startswith('model.4.basis_alphas.'):\n",
    "        custom_state_dict[k] = custom_state_dict['model.4.basis_alphas.0']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n"
     ]
    }
   ],
   "source": [
    "basis_model_f.load_state_dict(custom_state_dict, False)\n",
    "cache_masks(basis_model_f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# for task in range(0, num_tasks):\n",
    "#     print(f\"Training for task {task}\")\n",
    "#     set_model_task(basis_model_hidf, task)\n",
    "#     mnist.update_task(task)\n",
    "\n",
    "#     optimizer = optim.RMSprop([p for p in basis_model_hidf.parameters() if p.requires_grad], lr=1e-3)\n",
    "#     # Train for 1 epoch\n",
    "#     for e in range(1):\n",
    "#         train(basis_model_hidf, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "#         print(\"Validation\")\n",
    "#         print(\"============\")\n",
    "#         acc1 = evaluate(basis_model_hidf, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "#     cache_masks(basis_model_hidf)\n",
    "#     print()\n",
    "#     set_num_tasks_learned(basis_model_hidf, task + 1)\n",
    "#     print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.2064\n",
      "Per task performance\n",
      "Task 0: 0.9123\n",
      "Task 1: 0.1757\n",
      "Task 2: 0.1208\n",
      "Task 3: 0.0909\n",
      "Task 4: 0.1220\n",
      "Task 5: 0.1697\n",
      "Task 6: 0.0895\n",
      "Task 7: 0.1300\n",
      "Task 8: 0.1562\n",
      "Task 9: 0.0971\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(basis_model_f, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(basis_model_f, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['basis_mnist_frozen'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model Initialization (Only New Tasks) , 15 masks all from task 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks = 50 # For demonstration purposes, we go up to 2500 in our paper\n",
    "num_seed_tasks_learned = 40\n",
    "basis_model_zeros = BasisMultitaskFC(hidden_size=300, num_tasks=num_tasks, num_seed_tasks_learned=num_seed_tasks_learned, start_at_optimal=False, sparsity=0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed_dict = basis_model_zeros.state_dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": [
    "update_dict = seed_dict.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "assert all([(model_map[0].state_dict()['model.0.weight'] == model_map[i].state_dict()['model.0.weight']).all() for i in range(1,15)])\n",
    "update_dict['model.0.weight'] = model_map[0].state_dict()['model.0.weight']\n",
    "for task in range(40):\n",
    "    for layer in [0,2,4]:\n",
    "        update_dict['model.{}.scores.{}'.format(layer, task)] = model_map[task].state_dict()['model.{}.scores.0'.format(layer)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n"
     ]
    }
   ],
   "source": [
    "seed_dict.update(update_dict)\n",
    "basis_model_zeros.load_state_dict(seed_dict, False)\n",
    "cache_masks(basis_model_zeros)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(40, 50)"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_seed_tasks_learned, num_tasks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fcf2bb60026a4df285217b3c6708e6c0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2727, Acc@1 0.4873\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd34e80abaf74eae9a5592ee45332056",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.6603\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "787b8aa2f7554694ab8f543e6fc40450",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.7342, Acc@1 0.6813\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "02ca270c8b494640bfcafcaa7101caf5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.7368\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 1\n",
      "=> Set task of model.0 to 1\n",
      "=> Set task of model.2 to 1\n",
      "=> Set task of model.4 to 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "15dbacb01bbc48efb798cd5585c339f5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3861, Acc@1 0.2601\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d4b951dd837c4b46af64937728b9d0f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3328\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0cd53cdf67e14b88aa7b7fe8914ba0f0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9235, Acc@1 0.3633\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "12380c195a5c44c796146fa502177a6d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4151\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 2\n",
      "=> Setting learned tasks of model.2 to 2\n",
      "=> Setting learned tasks of model.4 to 2\n",
      "\n",
      "Training for task 2\n",
      "=> Set task of model.0 to 2\n",
      "=> Set task of model.2 to 2\n",
      "=> Set task of model.4 to 2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4b85fb8786984b4386ae3204a7e6d6d5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4043, Acc@1 0.1973\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bb98ff36049c49f58f2013bd87488589",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3644\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "da6b1adf62f9402fac7a30976539f43a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8489, Acc@1 0.4277\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1f5bd6c5e56c4905b6fc213395230ff9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4784\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 3\n",
      "=> Setting learned tasks of model.2 to 3\n",
      "=> Setting learned tasks of model.4 to 3\n",
      "\n",
      "Training for task 3\n",
      "=> Set task of model.0 to 3\n",
      "=> Set task of model.2 to 3\n",
      "=> Set task of model.4 to 3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "885b3baf10c542c1a69c431ec14af66e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4157, Acc@1 0.2337\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4f9da5af4eed4745bb1e40e8e0dc0e67",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3305\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7f87541b91404d9ba80d7d6b47fd49ca",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1181, Acc@1 0.3717\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6593cccb7077434d87d57eb9f78063c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4355\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 4\n",
      "=> Setting learned tasks of model.2 to 4\n",
      "=> Setting learned tasks of model.4 to 4\n",
      "\n",
      "Training for task 4\n",
      "=> Set task of model.0 to 4\n",
      "=> Set task of model.2 to 4\n",
      "=> Set task of model.4 to 4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a0a08b3cd7ad42df9e488b4bd3834bf6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.6504, Acc@1 0.2673\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "74eb80f0bd3248fab803f0733053e059",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3558\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "33d8616aa3d0463d9138ec548fe08c8d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0980, Acc@1 0.3786\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b0dcc1aefe6a4280b2c90def728dd4a2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4009\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 5\n",
      "=> Setting learned tasks of model.2 to 5\n",
      "=> Setting learned tasks of model.4 to 5\n",
      "\n",
      "Training for task 5\n",
      "=> Set task of model.0 to 5\n",
      "=> Set task of model.2 to 5\n",
      "=> Set task of model.4 to 5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "435da82f5f934c14a07ebda8424f7e5e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1977, Acc@1 0.2497\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5cc08b67ad1e4fc8b7f9cbb465875d24",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3817\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f294a1ddc40c402b8d8867b240646963",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0180, Acc@1 0.4193\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "138a805b1150494e929966d57ce8db95",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4539\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 6\n",
      "=> Setting learned tasks of model.2 to 6\n",
      "=> Setting learned tasks of model.4 to 6\n",
      "\n",
      "Training for task 6\n",
      "=> Set task of model.0 to 6\n",
      "=> Set task of model.2 to 6\n",
      "=> Set task of model.4 to 6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1a230bf4aa5c46e3b9a10be0d81eeb99",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1989, Acc@1 0.2542\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "faf6ed9fda884c9fbde9ebb3acd5f8cd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3667\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "41fa3b9a9d5c422992af79de8ef4de9f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8722, Acc@1 0.4255\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2022ad896b2549a2a06ee8c1d08a2c6f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4617\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 7\n",
      "=> Setting learned tasks of model.2 to 7\n",
      "=> Setting learned tasks of model.4 to 7\n",
      "\n",
      "Training for task 7\n",
      "=> Set task of model.0 to 7\n",
      "=> Set task of model.2 to 7\n",
      "=> Set task of model.4 to 7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0e5c302c1cc047e58aeb014dd2a02d84",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2299, Acc@1 0.2747\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6edcbcd220fc40a78a274bd46f8fcb3a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4151\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a46a7fb3040c4613863e141f2d3d1a83",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6078, Acc@1 0.4486\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b0360f4adff4a23b38080995f583779",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4837\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 8\n",
      "=> Setting learned tasks of model.2 to 8\n",
      "=> Setting learned tasks of model.4 to 8\n",
      "\n",
      "Training for task 8\n",
      "=> Set task of model.0 to 8\n",
      "=> Set task of model.2 to 8\n",
      "=> Set task of model.4 to 8\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7db22a6ca6a347d7beec0bd9d324f3f4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3511, Acc@1 0.2497\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f00ffa8a94a24c7aba903a1cecb92255",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3436\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9a171b893792444c8322d2fa1c771893",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1813, Acc@1 0.3786\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "efc844d350d9404b8c7c3a05068bf980",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4303\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 9\n",
      "=> Setting learned tasks of model.2 to 9\n",
      "=> Setting learned tasks of model.4 to 9\n",
      "\n",
      "Training for task 9\n",
      "=> Set task of model.0 to 9\n",
      "=> Set task of model.2 to 9\n",
      "=> Set task of model.4 to 9\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0dda3d86fa2d4e619ec519cd9814e6d7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4587, Acc@1 0.2197\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f183d8b66b0c44d09ea133da43c4809f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3464\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "edb92b3fe5de491c86560989964e8f98",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9897, Acc@1 0.3857\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0b91ead281494a6d9b6899268611b44f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4440\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 10\n",
      "=> Setting learned tasks of model.2 to 10\n",
      "=> Setting learned tasks of model.4 to 10\n",
      "\n",
      "Training for task 10\n",
      "=> Set task of model.0 to 10\n",
      "=> Set task of model.2 to 10\n",
      "=> Set task of model.4 to 10\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c9b07c80c55c48cdaffe5a29841eed47",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3140, Acc@1 0.2464\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d44e734f980a4aaea10b7db4975b199b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3392\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a611054fa76246e18f20a393f8672ce1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6871, Acc@1 0.4225\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dcfa92b2ea3e4f0da58425c5af9d5f90",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4875\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 11\n",
      "=> Setting learned tasks of model.2 to 11\n",
      "=> Setting learned tasks of model.4 to 11\n",
      "\n",
      "Training for task 11\n",
      "=> Set task of model.0 to 11\n",
      "=> Set task of model.2 to 11\n",
      "=> Set task of model.4 to 11\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "34b71d37030f48779cb197c915bb14d5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1211, Acc@1 0.2510\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "41bdc245611643d5a9efc806e2d16c5d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3768\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6a8cba96373d41d486d7da3683f097ae",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9153, Acc@1 0.4277\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "62d2aa4d92fe493eb189f5535dc854f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4595\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 12\n",
      "=> Setting learned tasks of model.2 to 12\n",
      "=> Setting learned tasks of model.4 to 12\n",
      "\n",
      "Training for task 12\n",
      "=> Set task of model.0 to 12\n",
      "=> Set task of model.2 to 12\n",
      "=> Set task of model.4 to 12\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "99c3a36ba08047a890bbc28118242073",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5549, Acc@1 0.2487\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "37ce2068db8846869315961a6f8a288f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3574\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8d70af1c5de64f7d8982080981cf0775",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2367, Acc@1 0.4134\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "25eb4e2747d14cf7bba5622276744179",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4698\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 13\n",
      "=> Setting learned tasks of model.2 to 13\n",
      "=> Setting learned tasks of model.4 to 13\n",
      "\n",
      "Training for task 13\n",
      "=> Set task of model.0 to 13\n",
      "=> Set task of model.2 to 13\n",
      "=> Set task of model.4 to 13\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "905c9f7c3870431b96d7a5c3e78b7eb6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.6820, Acc@1 0.2171\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4064115921a84ad1bfc87ade195def8c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2928\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0a5d9fed87c8404f80e5d363dde29874",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4180, Acc@1 0.3291\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "608639e20a914c87bdb21c5c72034239",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3818\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 14\n",
      "=> Setting learned tasks of model.2 to 14\n",
      "=> Setting learned tasks of model.4 to 14\n",
      "\n",
      "Training for task 14\n",
      "=> Set task of model.0 to 14\n",
      "=> Set task of model.2 to 14\n",
      "=> Set task of model.4 to 14\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "75511557bb7c4451afca8dea91093160",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9552, Acc@1 0.2578\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "16457e38e0a949a7a3b6416fad8c091f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3831\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e6bd183713ec4415af649021f7cbfce5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0810, Acc@1 0.4248\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "180bb6669cac464eae8359a9cd422799",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4741\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 15\n",
      "=> Setting learned tasks of model.2 to 15\n",
      "=> Setting learned tasks of model.4 to 15\n",
      "\n",
      "Training for task 15\n",
      "=> Set task of model.0 to 15\n",
      "=> Set task of model.2 to 15\n",
      "=> Set task of model.4 to 15\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0189bec471b94c75a1c4221a938994b4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4303, Acc@1 0.2393\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0bdefa00288a4d548ef77f94472d5a8f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3245\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b63913cb2ffb4f568387e0e803c40ee7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1425, Acc@1 0.3750\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2c37341fec434befbe055e425de21f32",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4464\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 16\n",
      "=> Setting learned tasks of model.2 to 16\n",
      "=> Setting learned tasks of model.4 to 16\n",
      "\n",
      "Training for task 16\n",
      "=> Set task of model.0 to 16\n",
      "=> Set task of model.2 to 16\n",
      "=> Set task of model.4 to 16\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0119dd744201465ab6f44a74ae94db48",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.9931, Acc@1 0.2422\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d733319f3633414da54d3703cd03aafc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3170\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bc12eb184d0148d29c02cfa07121527d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2592, Acc@1 0.3454\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "185fa654760a4370b8beabfaf7a08725",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3961\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 17\n",
      "=> Setting learned tasks of model.2 to 17\n",
      "=> Setting learned tasks of model.4 to 17\n",
      "\n",
      "Training for task 17\n",
      "=> Set task of model.0 to 17\n",
      "=> Set task of model.2 to 17\n",
      "=> Set task of model.4 to 17\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "625e262a476c480f80843cb2d20b48df",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1518, Acc@1 0.2718\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ecd826be195c434286f5ee1ebcb54028",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3553\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f343ecca4bce4e41b5218d880457360c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9674, Acc@1 0.3861\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c9ec3fb9936b4ab9bbda5ccf3a716cf8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4242\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 18\n",
      "=> Setting learned tasks of model.2 to 18\n",
      "=> Setting learned tasks of model.4 to 18\n",
      "\n",
      "Training for task 18\n",
      "=> Set task of model.0 to 18\n",
      "=> Set task of model.2 to 18\n",
      "=> Set task of model.4 to 18\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ad82caacdd8947f1873a49961770ceee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4037, Acc@1 0.2552\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a4b965de785742c48515f7a1b3c6e2de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3591\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "181999db82514c32aa9fd0b8de489e0c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9298, Acc@1 0.3763\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "79135b6433454c94835ccc0c78ae170f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4421\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 19\n",
      "=> Setting learned tasks of model.2 to 19\n",
      "=> Setting learned tasks of model.4 to 19\n",
      "\n",
      "Training for task 19\n",
      "=> Set task of model.0 to 19\n",
      "=> Set task of model.2 to 19\n",
      "=> Set task of model.4 to 19\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2bf45c99b07b4a67ae66e0b6423a59de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1799, Acc@1 0.2588\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "535764a3b382467fb55107f658106e38",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3394\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f11ad06273b3424692f8e7dc2af8246a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8805, Acc@1 0.3799\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "db93016ba4a24d9da3f198ba65b75276",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4175\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 20\n",
      "=> Setting learned tasks of model.2 to 20\n",
      "=> Setting learned tasks of model.4 to 20\n",
      "\n",
      "Training for task 20\n",
      "=> Set task of model.0 to 20\n",
      "=> Set task of model.2 to 20\n",
      "=> Set task of model.4 to 20\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b327676e25d74795ae6d60d744b71d19",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5869, Acc@1 0.2292\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "634c61b4fcbc49f784c91418a1a83e77",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3071\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "56d599e4e402434ab7c13c99928c298e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1436, Acc@1 0.3529\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "beb901a443c64f8db089684f3beb4d95",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3809\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 21\n",
      "=> Setting learned tasks of model.2 to 21\n",
      "=> Setting learned tasks of model.4 to 21\n",
      "\n",
      "Training for task 21\n",
      "=> Set task of model.0 to 21\n",
      "=> Set task of model.2 to 21\n",
      "=> Set task of model.4 to 21\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fa9decdb8dbe43139ba83df1d9a0a587",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4498, Acc@1 0.2581\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "41a7005c41de496282f6254c0a62fecc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3561\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7100f346972a4a4ca733f47eb1608f8f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0036, Acc@1 0.3952\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "62f52e6192ed400f97b0af6fd9f785b7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4604\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 22\n",
      "=> Setting learned tasks of model.2 to 22\n",
      "=> Setting learned tasks of model.4 to 22\n",
      "\n",
      "Training for task 22\n",
      "=> Set task of model.0 to 22\n",
      "=> Set task of model.2 to 22\n",
      "=> Set task of model.4 to 22\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "86128e2a657b4a9a9e27687d370cfc47",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5834, Acc@1 0.1986\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0ef354052b6744dd8b113900c352740a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2711\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "132bde2d5ca44fba95f0bbb598388a16",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3709, Acc@1 0.3066\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "99fcd95aeeaf4e37b10ae0998b8c7aac",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3377\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 23\n",
      "=> Setting learned tasks of model.2 to 23\n",
      "=> Setting learned tasks of model.4 to 23\n",
      "\n",
      "Training for task 23\n",
      "=> Set task of model.0 to 23\n",
      "=> Set task of model.2 to 23\n",
      "=> Set task of model.4 to 23\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "be558a4089734855ac941404f61271d4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5690, Acc@1 0.2715\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "76cb3eec1d3548f6acf29e774e43c083",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3654\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "682bbf1e617c4b0a8c40fa0bcd3eee8d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1652, Acc@1 0.3786\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fff5e33c6ff04eb9b255c247c0ac7042",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4300\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 24\n",
      "=> Setting learned tasks of model.2 to 24\n",
      "=> Setting learned tasks of model.4 to 24\n",
      "\n",
      "Training for task 24\n",
      "=> Set task of model.0 to 24\n",
      "=> Set task of model.2 to 24\n",
      "=> Set task of model.4 to 24\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6df1270d7c0b4129abadb9a674ae9f45",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2410, Acc@1 0.2301\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d103ecaa54d443b3ba370b49ad8f0664",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3229\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8fd061c0376640a7a13d34fd24ee8bfd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9825, Acc@1 0.3717\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1df74667acc74a8086ecf8ba4409ebeb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4404\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 25\n",
      "=> Setting learned tasks of model.2 to 25\n",
      "=> Setting learned tasks of model.4 to 25\n",
      "\n",
      "Training for task 25\n",
      "=> Set task of model.0 to 25\n",
      "=> Set task of model.2 to 25\n",
      "=> Set task of model.4 to 25\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7bf366e34d5e423cbd5830404db9555a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.7082, Acc@1 0.2132\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cae9768727664d2e8de90631ad73dce1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3214\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "28bcc8e1fc524d03b438681a29406a5e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9693, Acc@1 0.3698\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c064be28c430439b9505055cc7bbcf3a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4103\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 26\n",
      "=> Setting learned tasks of model.2 to 26\n",
      "=> Setting learned tasks of model.4 to 26\n",
      "\n",
      "Training for task 26\n",
      "=> Set task of model.0 to 26\n",
      "=> Set task of model.2 to 26\n",
      "=> Set task of model.4 to 26\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e17c3493cd944400b873e85d1a52ad5e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4598, Acc@1 0.2122\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "33f56605de874c39b115aa017a93a011",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2930\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b4d565190d5f48679f4147469de68737",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1258, Acc@1 0.3522\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "722ba158fbd34f36a8ff6a9cacc714cf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3929\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 27\n",
      "=> Setting learned tasks of model.2 to 27\n",
      "=> Setting learned tasks of model.4 to 27\n",
      "\n",
      "Training for task 27\n",
      "=> Set task of model.0 to 27\n",
      "=> Set task of model.2 to 27\n",
      "=> Set task of model.4 to 27\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f16ab20021224fa4a389c2ef6e00d805",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1566, Acc@1 0.2591\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8e97b953e1e64dcf8fffb727f1842084",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3726\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fec7ab52a0114b53b37d3d9f8867f111",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7281, Acc@1 0.4463\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "783cbe377f3c4c7b98f8d72574be0fb9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4968\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 28\n",
      "=> Setting learned tasks of model.2 to 28\n",
      "=> Setting learned tasks of model.4 to 28\n",
      "\n",
      "Training for task 28\n",
      "=> Set task of model.0 to 28\n",
      "=> Set task of model.2 to 28\n",
      "=> Set task of model.4 to 28\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f9062d9ac2e4ef7866d37b346281340",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4295, Acc@1 0.2259\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "06fe719c089f4bb199bc07ea9754b61a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3318\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5a301fd48c974501884b2088509ea97c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3543, Acc@1 0.3711\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "50f4b0115e364adcaf1a580617ccd367",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4113\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 29\n",
      "=> Setting learned tasks of model.2 to 29\n",
      "=> Setting learned tasks of model.4 to 29\n",
      "\n",
      "Training for task 29\n",
      "=> Set task of model.0 to 29\n",
      "=> Set task of model.2 to 29\n",
      "=> Set task of model.4 to 29\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d351b19c0de64411880329c571979b15",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0055, Acc@1 0.2998\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f389178b7b234000877880a5743d5591",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4027\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59220eb45eae457d9154a72eccb82a4d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5769, Acc@1 0.4639\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "89b34014816e41b0be8ce41b1f2f38c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5109\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 30\n",
      "=> Setting learned tasks of model.2 to 30\n",
      "=> Setting learned tasks of model.4 to 30\n",
      "\n",
      "Training for task 30\n",
      "=> Set task of model.0 to 30\n",
      "=> Set task of model.2 to 30\n",
      "=> Set task of model.4 to 30\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2fcf1cdb0ffa463886a25e413d0e33cb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.8344, Acc@1 0.2106\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d027e5b7dd9b472887258883820c5409",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3071\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1fb161c58d034d008dac643f212bcddf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3086, Acc@1 0.3903\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "faae36b371444b479c31ca7170a74ad6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4432\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 31\n",
      "=> Setting learned tasks of model.2 to 31\n",
      "=> Setting learned tasks of model.4 to 31\n",
      "\n",
      "Training for task 31\n",
      "=> Set task of model.0 to 31\n",
      "=> Set task of model.2 to 31\n",
      "=> Set task of model.4 to 31\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ca08d2f7790e411cbba3c35a927ec2b2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5683, Acc@1 0.2327\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "28c7fb96fc9c4f52805ab19aa16a8886",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2891\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9c7cdbea5b404776a93903f57234809f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3556, Acc@1 0.3548\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3ecbcbe9cb8f40c8826cb2397852fd1d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4013\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 32\n",
      "=> Setting learned tasks of model.2 to 32\n",
      "=> Setting learned tasks of model.4 to 32\n",
      "\n",
      "Training for task 32\n",
      "=> Set task of model.0 to 32\n",
      "=> Set task of model.2 to 32\n",
      "=> Set task of model.4 to 32\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6bb051201b904e1abc4e555f6b5d24be",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5819, Acc@1 0.2474\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c6a970f2c418455899309609bcfb7a56",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2991\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "46ebaa11d6264f579f529c790eb209cf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1479, Acc@1 0.3561\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f17befed66fb4eecb48882e1f1e06671",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4416\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 33\n",
      "=> Setting learned tasks of model.2 to 33\n",
      "=> Setting learned tasks of model.4 to 33\n",
      "\n",
      "Training for task 33\n",
      "=> Set task of model.0 to 33\n",
      "=> Set task of model.2 to 33\n",
      "=> Set task of model.4 to 33\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cd6c152dff5147f8a9758a4231ec0565",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2435, Acc@1 0.2640\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3a50817c0f4341a18f6f44759fdaf827",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3651\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0fc79445caeb452b920c87e6eaaf905d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9583, Acc@1 0.4131\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0c23e5dd66a645ffacc378e5ced8886b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4518\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 34\n",
      "=> Setting learned tasks of model.2 to 34\n",
      "=> Setting learned tasks of model.4 to 34\n",
      "\n",
      "Training for task 34\n",
      "=> Set task of model.0 to 34\n",
      "=> Set task of model.2 to 34\n",
      "=> Set task of model.4 to 34\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "abda90d5ea2741e0878b3990541d0d6c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4046, Acc@1 0.2601\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5ce50ef30c69497fb87c684192114f77",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3572\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0de8571514584d2284c220ad575d478a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0925, Acc@1 0.3900\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a4e884b731bb4eb0aaf41768c1d84ae6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3983\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 35\n",
      "=> Setting learned tasks of model.2 to 35\n",
      "=> Setting learned tasks of model.4 to 35\n",
      "\n",
      "Training for task 35\n",
      "=> Set task of model.0 to 35\n",
      "=> Set task of model.2 to 35\n",
      "=> Set task of model.4 to 35\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e996cc70d5a34b25acacae92696445f3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2641, Acc@1 0.2682\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "27caa24ffb5e4bb79b105937d7c9fc5f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3566\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4ec7921c5b1748b8b8e7cb0b41dd8e67",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1285, Acc@1 0.3779\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "68ae3efb694645fba532492098837fa4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4406\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 36\n",
      "=> Setting learned tasks of model.2 to 36\n",
      "=> Setting learned tasks of model.4 to 36\n",
      "\n",
      "Training for task 36\n",
      "=> Set task of model.0 to 36\n",
      "=> Set task of model.2 to 36\n",
      "=> Set task of model.4 to 36\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "71e71bc42d2943df9fdebc1398e51983",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.7068, Acc@1 0.2135\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b05b5f0df28c44c8ab35ff9169100938",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2959\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8fb096d3f2c5448490e0eb57291300cb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0305, Acc@1 0.3743\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "719b515b4b8140b9b3a152fc900d70ba",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4531\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 37\n",
      "=> Setting learned tasks of model.2 to 37\n",
      "=> Setting learned tasks of model.4 to 37\n",
      "\n",
      "Training for task 37\n",
      "=> Set task of model.0 to 37\n",
      "=> Set task of model.2 to 37\n",
      "=> Set task of model.4 to 37\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0431501d621c4174891a5b49cc5116c4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3022, Acc@1 0.2689\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7c965b6a9a9040458742e4914adedde9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3610\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1e60182d46164e8eb712424d7ff8a0c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1937, Acc@1 0.3870\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59711b9291ce4eb6ba1480ecfa9cdbe7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4474\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 38\n",
      "=> Setting learned tasks of model.2 to 38\n",
      "=> Setting learned tasks of model.4 to 38\n",
      "\n",
      "Training for task 38\n",
      "=> Set task of model.0 to 38\n",
      "=> Set task of model.2 to 38\n",
      "=> Set task of model.4 to 38\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7cca5481effd4b779297c5848c45e92e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3533, Acc@1 0.2318\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5c671ab479b4405d861179b06adfcade",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3427\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4de1571f33564e1aae1101417bee6ba8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8881, Acc@1 0.3906\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f0f38cd85179445a85d0ce3f36330bc8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4239\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 39\n",
      "=> Setting learned tasks of model.2 to 39\n",
      "=> Setting learned tasks of model.4 to 39\n",
      "\n",
      "Training for task 39\n",
      "=> Set task of model.0 to 39\n",
      "=> Set task of model.2 to 39\n",
      "=> Set task of model.4 to 39\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ec49e1643d954cc8be2562cb6b329cb4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4511, Acc@1 0.2357\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d864f33f2cf7475ca39f87b3d321b220",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3338\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "50ab648354fb4a298466f823f2eb8f8e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9118, Acc@1 0.3812\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eb0e531fa30a449884a76e06f134469e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4386\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 40\n",
      "=> Setting learned tasks of model.2 to 40\n",
      "=> Setting learned tasks of model.4 to 40\n",
      "\n",
      "Training for task 40\n",
      "=> Set task of model.0 to 40\n",
      "=> Set task of model.2 to 40\n",
      "=> Set task of model.4 to 40\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "766e3e2ce955419fba56ee4fabf5e758",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1661, Acc@1 0.2669\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "13543607d24d4a68bc64fb1fb59743f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3439\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "40112954e1534d7fa2fdf4c265e97794",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7186, Acc@1 0.4284\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e55686568334455ca54d1d8ba3f9a219",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4938\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 41\n",
      "=> Setting learned tasks of model.2 to 41\n",
      "=> Setting learned tasks of model.4 to 41\n",
      "\n",
      "Training for task 41\n",
      "=> Set task of model.0 to 41\n",
      "=> Set task of model.2 to 41\n",
      "=> Set task of model.4 to 41\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2c0ba13b0e49413eb01141ba842f65e9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4715, Acc@1 0.2253\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "13f857d0bdbe42d0a5c018dd6a2bdb14",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3250\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1d305e1568c64fb78525f965e938ccd8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9654, Acc@1 0.3512\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f04dac4ce67249ebae0c988e82ea8a7f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4052\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 42\n",
      "=> Setting learned tasks of model.2 to 42\n",
      "=> Setting learned tasks of model.4 to 42\n",
      "\n",
      "Training for task 42\n",
      "=> Set task of model.0 to 42\n",
      "=> Set task of model.2 to 42\n",
      "=> Set task of model.4 to 42\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e566b4e2956f40798ab9e595e7e49294",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3716, Acc@1 0.2607\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4b2d2e4146a1486596f7a19665fbd5d7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3582\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "824c5f554e0644ddb13a07b198e7a115",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9665, Acc@1 0.4163\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d1836d4ab8f941b1946c932df6defe53",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4701\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 43\n",
      "=> Setting learned tasks of model.2 to 43\n",
      "=> Setting learned tasks of model.4 to 43\n",
      "\n",
      "Training for task 43\n",
      "=> Set task of model.0 to 43\n",
      "=> Set task of model.2 to 43\n",
      "=> Set task of model.4 to 43\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "34c9c6def3404851980c5757c8fe0e14",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1066, Acc@1 0.2194\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bc4f9b323a1a49709bcfe0492cde2808",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3385\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "440fb405930948b6963949490e235067",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7115, Acc@1 0.4105\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b2c09589611c4855bdc50bb81cda96ef",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4701\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 44\n",
      "=> Setting learned tasks of model.2 to 44\n",
      "=> Setting learned tasks of model.4 to 44\n",
      "\n",
      "Training for task 44\n",
      "=> Set task of model.0 to 44\n",
      "=> Set task of model.2 to 44\n",
      "=> Set task of model.4 to 44\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f40b6a0439e4447386bdc308a6c84a3d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3469, Acc@1 0.2646\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e8adb90e2180492e9684d66ffc44f79c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3904\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8ff4cffefa4d49398361797f575f59dd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7400, Acc@1 0.4469\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a235d3af9d57467f808c349ac4b9f393",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4976\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 45\n",
      "=> Setting learned tasks of model.2 to 45\n",
      "=> Setting learned tasks of model.4 to 45\n",
      "\n",
      "Training for task 45\n",
      "=> Set task of model.0 to 45\n",
      "=> Set task of model.2 to 45\n",
      "=> Set task of model.4 to 45\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "53bf446ae3674b7eb7d40160a33c4da3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.7321, Acc@1 0.1992\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "66fa65c21e5b4661a27d214264873371",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3067\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4977d8c00332406f9fe4e6495d895499",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0412, Acc@1 0.3490\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d7e2aa8f437d45e6946f8bb19315c8a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4105\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 46\n",
      "=> Setting learned tasks of model.2 to 46\n",
      "=> Setting learned tasks of model.4 to 46\n",
      "\n",
      "Training for task 46\n",
      "=> Set task of model.0 to 46\n",
      "=> Set task of model.2 to 46\n",
      "=> Set task of model.4 to 46\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9d0301d37655444ebf63596d83e77d32",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1310, Acc@1 0.2529\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b568a08160d546d3aca60005d5efd8a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3724\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "39f01dc1c4f84a529966edb7526b72af",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6993, Acc@1 0.4160\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "132f78d3f53443a98de27ba73fd1cb3f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4434\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 47\n",
      "=> Setting learned tasks of model.2 to 47\n",
      "=> Setting learned tasks of model.4 to 47\n",
      "\n",
      "Training for task 47\n",
      "=> Set task of model.0 to 47\n",
      "=> Set task of model.2 to 47\n",
      "=> Set task of model.4 to 47\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "585840b0021240f0afc26764c9f8077c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2997, Acc@1 0.2422\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5e28991ae60a4990899808e24bc41284",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3484\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "15066e1434ba4344bfbcc2f57e7f15e5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1371, Acc@1 0.3887\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "aeec1b4b14004cef8e7e430880bd0092",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4485\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 48\n",
      "=> Setting learned tasks of model.2 to 48\n",
      "=> Setting learned tasks of model.4 to 48\n",
      "\n",
      "Training for task 48\n",
      "=> Set task of model.0 to 48\n",
      "=> Set task of model.2 to 48\n",
      "=> Set task of model.4 to 48\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "708dda6d73cf4e3f809b8c1dbd2d2f04",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1702, Acc@1 0.2601\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a9735fff024f474d925fc33ac9909e18",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3473\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d804d43afbac4ac9873c7c6dde66c4c7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1318, Acc@1 0.3802\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5f1b221fca6c463fa3b92a203241fccd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4441\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 49\n",
      "=> Setting learned tasks of model.2 to 49\n",
      "=> Setting learned tasks of model.4 to 49\n",
      "\n",
      "Training for task 49\n",
      "=> Set task of model.0 to 49\n",
      "=> Set task of model.2 to 49\n",
      "=> Set task of model.4 to 49\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7a99fa44674f41a586eff9c37d8371b9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.8852, Acc@1 0.2074\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "11b6ef5d6f24416ab337bd1070bdf7a5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2877\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0a46f3cb0f2b4ff18878598b63d1eea4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3573, Acc@1 0.3210\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4ced4ea018914d8d83f39d7c9ed881c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.3758\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 50\n",
      "=> Setting learned tasks of model.2 to 50\n",
      "=> Setting learned tasks of model.4 to 50\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for task in range(0, num_tasks):\n",
    "    print(f\"Training for task {task}\")\n",
    "    set_model_task(basis_model_zeros, task)\n",
    "    mnist.update_task(task)\n",
    "\n",
    "    optimizer = optim.RMSprop([p for p in basis_model_zeros.parameters() if p.requires_grad], lr=1e-3)\n",
    "    # Train for 1 epoch\n",
    "    for e in range(2):\n",
    "        train(basis_model_zeros, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "        print(\"Validation\")\n",
    "        print(\"============\")\n",
    "        acc1 = evaluate(basis_model_zeros, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "    cache_masks(basis_model_zeros)\n",
    "    print()\n",
    "    set_num_tasks_learned(basis_model_zeros, task + 1)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.4442\n",
      "Per task performance\n",
      "Task 0: 0.7368\n",
      "Task 1: 0.4151\n",
      "Task 2: 0.4784\n",
      "Task 3: 0.4355\n",
      "Task 4: 0.4009\n",
      "Task 5: 0.4539\n",
      "Task 6: 0.4617\n",
      "Task 7: 0.4837\n",
      "Task 8: 0.4303\n",
      "Task 9: 0.4440\n",
      "Task 10: 0.4875\n",
      "Task 11: 0.4595\n",
      "Task 12: 0.4698\n",
      "Task 13: 0.3818\n",
      "Task 14: 0.4741\n",
      "Task 15: 0.4464\n",
      "Task 16: 0.3961\n",
      "Task 17: 0.4242\n",
      "Task 18: 0.4421\n",
      "Task 19: 0.4175\n",
      "Task 20: 0.3809\n",
      "Task 21: 0.4604\n",
      "Task 22: 0.3377\n",
      "Task 23: 0.4300\n",
      "Task 24: 0.4404\n",
      "Task 25: 0.4103\n",
      "Task 26: 0.3929\n",
      "Task 27: 0.4968\n",
      "Task 28: 0.4113\n",
      "Task 29: 0.5109\n",
      "Task 30: 0.4432\n",
      "Task 31: 0.4013\n",
      "Task 32: 0.4416\n",
      "Task 33: 0.4518\n",
      "Task 34: 0.3983\n",
      "Task 35: 0.4406\n",
      "Task 36: 0.4531\n",
      "Task 37: 0.4474\n",
      "Task 38: 0.4239\n",
      "Task 39: 0.4386\n",
      "Task 40: 0.4938\n",
      "Task 41: 0.4052\n",
      "Task 42: 0.4701\n",
      "Task 43: 0.4701\n",
      "Task 44: 0.4976\n",
      "Task 45: 0.4105\n",
      "Task 46: 0.4434\n",
      "Task 47: 0.4485\n",
      "Task 48: 0.4441\n",
      "Task 49: 0.3758\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(basis_model_zeros, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(basis_model_zeros, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['basis_mnist_task_zero_only'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Except Final Layer"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model Initialization (Only New Tasks)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks = 50 # For demonstration purposes, we go up to 2500 in our paper\n",
    "num_seed_tasks_learned = 40\n",
    "basis_model_hid = BasisHiddenOnlyMultitaskFC(hidden_size=300, num_tasks=num_tasks, num_seed_tasks_learned=num_seed_tasks_learned, start_at_optimal=False, sparsity=0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n"
     ]
    }
   ],
   "source": [
    "seed_dict_hid = model.state_dict()\n",
    "basis_dict_hid = basis_model_hid.state_dict()\n",
    "load_dict_hid = {k: seed_dict_hid[k] for k in basis_model_hid.state_dict().keys() if k in seed_dict_hid.keys()}\n",
    "basis_dict_hid.update(load_dict_hid)\n",
    "basis_model_hid.load_state_dict(basis_dict_hid, False)\n",
    "cache_masks(basis_model_hid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 40\n",
      "=> Set task of model.0 to 40\n",
      "=> Set task of model.2 to 40\n",
      "=> Set task of model.4 to 40\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cda8d50fd1034fd4ab54cbe5d51c6440",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9281, Acc@1 0.2803\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "754b176557c944698eb57605f24e8e82",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4800\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "042c272090164afc9107ba9aa0881eef",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3655, Acc@1 0.5576\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4ead9d05f1524ca9a65be304f27a349a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6253\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fb776d7cbeee4c03aa995e24b65c55ac",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2554, Acc@1 0.6315\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7036a59706147cb87384a730957319d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6318\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 41\n",
      "=> Setting learned tasks of model.2 to 41\n",
      "=> Setting learned tasks of model.4 to 41\n",
      "\n",
      "Training for task 41\n",
      "=> Set task of model.0 to 41\n",
      "=> Set task of model.2 to 41\n",
      "=> Set task of model.4 to 41\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "507db8a9ac424285a71e8885e474c017",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9140, Acc@1 0.3161\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3aee551670854bcfbfd06da6b5e1ca4b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5086\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef68db3ff1fb4d688018f2c5075f5d44",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2596, Acc@1 0.5885\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e0e73a3530394856854e1aada814083c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6416\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "52751e5f6b274e88a27fc830688b67c0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2363, Acc@1 0.6230\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c5fcf280787e49a8898c95a81bc49f95",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6002\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 42\n",
      "=> Setting learned tasks of model.2 to 42\n",
      "=> Setting learned tasks of model.4 to 42\n",
      "\n",
      "Training for task 42\n",
      "=> Set task of model.0 to 42\n",
      "=> Set task of model.2 to 42\n",
      "=> Set task of model.4 to 42\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3d6b6503d6f04dfea7b1e331a784a981",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9570, Acc@1 0.3001\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dfe653c3dcef4981be893d48aecca6e7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5048\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bc108b3f4912482aa55c0b4a3124fea8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3541, Acc@1 0.6064\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "24634b3c7beb4436ba4754009933c244",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6486\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "36585e25383f4b2f913095b5c45e8e6b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3125, Acc@1 0.6572\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7fecef77632944dba9d7729d6f418cbf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6370\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 43\n",
      "=> Setting learned tasks of model.2 to 43\n",
      "=> Setting learned tasks of model.4 to 43\n",
      "\n",
      "Training for task 43\n",
      "=> Set task of model.0 to 43\n",
      "=> Set task of model.2 to 43\n",
      "=> Set task of model.4 to 43\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e52e9ed40d614f1e90ed8ea779b2613c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8119, Acc@1 0.2933\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3c9a6e07243b420bb2fe74eecda441e5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5181\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "845610e7729d472fab18c7fda7372d15",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3644, Acc@1 0.5911\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "52171efae0e3426dbcd06b0bee0907d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6218\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a701f7618b904a66bd5635de1086ce9b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.0710, Acc@1 0.6423\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d6c3367dc71b40ae8fb017ecb2c46ae3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6509\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 44\n",
      "=> Setting learned tasks of model.2 to 44\n",
      "=> Setting learned tasks of model.4 to 44\n",
      "\n",
      "Training for task 44\n",
      "=> Set task of model.0 to 44\n",
      "=> Set task of model.2 to 44\n",
      "=> Set task of model.4 to 44\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0e40c97c01684be3b9275f4db3782172",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7881, Acc@1 0.3268\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e52af504c343463fa117b35891807185",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5283\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "62a64207b8b9483a88a83855f7571ecd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4443, Acc@1 0.6087\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4045234f366445a1a2977d2e1a8ae5e4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6404\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dbf5c61ec3f8476d936ed25e8489b150",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.1917, Acc@1 0.6436\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e3bf5d8deac543ccb51ca1117a32773c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6442\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 45\n",
      "=> Setting learned tasks of model.2 to 45\n",
      "=> Setting learned tasks of model.4 to 45\n",
      "\n",
      "Training for task 45\n",
      "=> Set task of model.0 to 45\n",
      "=> Set task of model.2 to 45\n",
      "=> Set task of model.4 to 45\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b7bb30f6537044f5b37ed998b673aea3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8745, Acc@1 0.2650\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b5508468fb14a3f9a85140c3eebddf0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5081\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "39ae018abe5447099adeeaee3ef9f31f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4135, Acc@1 0.5833\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e4c9591998904b9581165e4affd74ede",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6443\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "826786e03d104fb3a770770779be122f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2032, Acc@1 0.6234\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "05630bfddda04751a051b0cc8456af7e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6428\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 46\n",
      "=> Setting learned tasks of model.2 to 46\n",
      "=> Setting learned tasks of model.4 to 46\n",
      "\n",
      "Training for task 46\n",
      "=> Set task of model.0 to 46\n",
      "=> Set task of model.2 to 46\n",
      "=> Set task of model.4 to 46\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e3fc8bdc01794718a55dce1d0c141c85",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8048, Acc@1 0.3307\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1f82e6a5a5ad44fb856f1548aa1a6bf1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5452\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "53aee18834a747349ba5d4f160748cee",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2577, Acc@1 0.6045\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f79873875fa847fab30dda639caccc75",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6538\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fdb2a652658440aa8d473b9725283a15",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2813, Acc@1 0.6348\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4223364c0d374316b6d0b90d93df6405",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6332\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 47\n",
      "=> Setting learned tasks of model.2 to 47\n",
      "=> Setting learned tasks of model.4 to 47\n",
      "\n",
      "Training for task 47\n",
      "=> Set task of model.0 to 47\n",
      "=> Set task of model.2 to 47\n",
      "=> Set task of model.4 to 47\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fd60a5acd2b14974bc7dce6e10c3313d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8084, Acc@1 0.3682\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f925ee0fa3e04508a440b67d26105403",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5755\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f3248c4e3c7746849a39a267c498599a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2316, Acc@1 0.6439\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e799a714565c46299f904e1db85d65d7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6690\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "543e590b02a54ead9d0a6f1d7bb4c87d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.0443, Acc@1 0.6719\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7f4cc7762f7d484484c3cfc1c86b3296",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.7052\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 48\n",
      "=> Setting learned tasks of model.2 to 48\n",
      "=> Setting learned tasks of model.4 to 48\n",
      "\n",
      "Training for task 48\n",
      "=> Set task of model.0 to 48\n",
      "=> Set task of model.2 to 48\n",
      "=> Set task of model.4 to 48\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c6e91093e49042a9bd431241e1bb7837",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9075, Acc@1 0.3245\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d5141ec291e44de0ae12d9898db8830a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5343\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c54f5e87f2514d0fa0515d957f5d5ca9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2964, Acc@1 0.6061\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "427278661a04471a8c10e9d3a3a2451b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6518\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0bdcb1181bd44305bd06c576daedc99d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.1945, Acc@1 0.6650\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d7c17209eb5948758ad3a347625ac6ce",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6433\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 49\n",
      "=> Setting learned tasks of model.2 to 49\n",
      "=> Setting learned tasks of model.4 to 49\n",
      "\n",
      "Training for task 49\n",
      "=> Set task of model.0 to 49\n",
      "=> Set task of model.2 to 49\n",
      "=> Set task of model.4 to 49\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "99addfb907cb437cb02b1282204eba1a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8816, Acc@1 0.3298\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "309a12ce2d6542f4b30c6c77541376fb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5559\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "15c49b28e1f548e284453f2c8fc231c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6589, Acc@1 0.5908\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ed5e31781de54e9a9847b1b5b5914860",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6141\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "50e7e717cd6b43458e3812912127e262",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3841, Acc@1 0.6289\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "432eed86c16e47348788ad7b00238b04",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 3 epochs Acc@1 0.6051\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 50\n",
      "=> Setting learned tasks of model.2 to 50\n",
      "=> Setting learned tasks of model.4 to 50\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for task in range(num_seed_tasks_learned, num_tasks):\n",
    "    print(f\"Training for task {task}\")\n",
    "    set_model_task(basis_model_hid, task)\n",
    "    mnist.update_task(task)\n",
    "\n",
    "    optimizer = optim.RMSprop([p for p in basis_model_hid.parameters() if p.requires_grad], lr=1e-4)\n",
    "    # Train for 1 epoch\n",
    "    for e in range(3):\n",
    "        train(basis_model_hid, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "        print(\"Validation\")\n",
    "        print(\"============\")\n",
    "        acc1 = evaluate(basis_model_hid, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "    cache_masks(basis_model_hid)\n",
    "    print()\n",
    "    set_num_tasks_learned(basis_model_hid, task + 1)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.2411\n",
      "Per task performance\n",
      "Task 0: 0.1718\n",
      "Task 1: 0.1531\n",
      "Task 2: 0.1028\n",
      "Task 3: 0.0967\n",
      "Task 4: 0.1245\n",
      "Task 5: 0.1657\n",
      "Task 6: 0.1721\n",
      "Task 7: 0.1577\n",
      "Task 8: 0.1821\n",
      "Task 9: 0.1869\n",
      "Task 10: 0.1477\n",
      "Task 11: 0.1202\n",
      "Task 12: 0.1618\n",
      "Task 13: 0.1658\n",
      "Task 14: 0.1348\n",
      "Task 15: 0.1851\n",
      "Task 16: 0.1105\n",
      "Task 17: 0.1303\n",
      "Task 18: 0.1568\n",
      "Task 19: 0.0799\n",
      "Task 20: 0.2302\n",
      "Task 21: 0.1543\n",
      "Task 22: 0.1290\n",
      "Task 23: 0.0885\n",
      "Task 24: 0.1640\n",
      "Task 25: 0.1039\n",
      "Task 26: 0.1175\n",
      "Task 27: 0.1531\n",
      "Task 28: 0.1436\n",
      "Task 29: 0.1612\n",
      "Task 30: 0.1066\n",
      "Task 31: 0.1268\n",
      "Task 32: 0.1448\n",
      "Task 33: 0.1130\n",
      "Task 34: 0.1544\n",
      "Task 35: 0.1157\n",
      "Task 36: 0.0926\n",
      "Task 37: 0.1972\n",
      "Task 38: 0.1520\n",
      "Task 39: 0.1064\n",
      "Task 40: 0.6318\n",
      "Task 41: 0.6002\n",
      "Task 42: 0.6370\n",
      "Task 43: 0.6509\n",
      "Task 44: 0.6442\n",
      "Task 45: 0.6428\n",
      "Task 46: 0.6332\n",
      "Task 47: 0.7052\n",
      "Task 48: 0.6433\n",
      "Task 49: 0.6051\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(basis_model_hid, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(basis_model_hid, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['basis_hybrid_mnist'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model Initialization (Cross task analysis, retraining last layer) -- Using 1 mask from task 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks = 10 # For demonstration purposes, we go up to 2500 in our paper\n",
    "num_seed_tasks_learned = 1\n",
    "basis_model_hidf = BasisHiddenOnlyFrozenMultitaskFC(hidden_size=300,\n",
    "                            num_tasks=num_tasks, num_seed_tasks_learned=num_seed_tasks_learned, start_at_optimal=True, sparsity=0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "custom_state_dict = basis_model_hidf.state_dict().copy()\n",
    "custom_state_dict.update({k:v for k,v in model.state_dict().items() if k in custom_state_dict.keys()})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "for k in custom_state_dict.keys():\n",
    "    if k.startswith('model.0.scores.'):\n",
    "        custom_state_dict[k] = model.state_dict()['model.0.scores.0']\n",
    "    elif k.startswith('model.2.scores.'):\n",
    "        custom_state_dict[k] = model.state_dict()['model.2.scores.0']\n",
    "    elif k.startswith('model.0.basis_alphas.'):\n",
    "        custom_state_dict[k] = custom_state_dict['model.0.basis_alphas.0'] \n",
    "    elif k.startswith('model.2.basis_alphas.'):\n",
    "        custom_state_dict[k] = custom_state_dict['model.2.basis_alphas.0']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n"
     ]
    }
   ],
   "source": [
    "basis_model_hidf.load_state_dict(custom_state_dict, False)\n",
    "cache_masks(basis_model_hidf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 1\n",
      "=> Set task of model.0 to 1\n",
      "=> Set task of model.2 to 1\n",
      "=> Set task of model.4 to 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3e335c02b610449f91567cb4f2fcd7fa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4096, Acc@1 0.2702\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0b7e4d2d5a814c5595cffcb701c12f9c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3463\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 2\n",
      "=> Setting learned tasks of model.2 to 2\n",
      "=> Setting learned tasks of model.4 to 2\n",
      "\n",
      "Training for task 2\n",
      "=> Set task of model.0 to 2\n",
      "=> Set task of model.2 to 2\n",
      "=> Set task of model.4 to 2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f6e720d80e4e452480142894c89b1bda",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.5502, Acc@1 0.2451\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "43d9fbf4aa6045ca8eafbe331bac7e2a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3827\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 3\n",
      "=> Setting learned tasks of model.2 to 3\n",
      "=> Setting learned tasks of model.4 to 3\n",
      "\n",
      "Training for task 3\n",
      "=> Set task of model.0 to 3\n",
      "=> Set task of model.2 to 3\n",
      "=> Set task of model.4 to 3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f860607c72cd4f44add0f676ed9c4045",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4968, Acc@1 0.2005\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ea8f320471cc49f39c8db8d9fa02a256",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2707\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 4\n",
      "=> Setting learned tasks of model.2 to 4\n",
      "=> Setting learned tasks of model.4 to 4\n",
      "\n",
      "Training for task 4\n",
      "=> Set task of model.0 to 4\n",
      "=> Set task of model.2 to 4\n",
      "=> Set task of model.4 to 4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9694ec0c7f374713b2dc3cc697e9385a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4649, Acc@1 0.2331\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e2dc37e47c3d4a45aa4bc67ad8936ca3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.1992\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 5\n",
      "=> Setting learned tasks of model.2 to 5\n",
      "=> Setting learned tasks of model.4 to 5\n",
      "\n",
      "Training for task 5\n",
      "=> Set task of model.0 to 5\n",
      "=> Set task of model.2 to 5\n",
      "=> Set task of model.4 to 5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "55f45b4909f642c0bee48a4c46bd876e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3769, Acc@1 0.2923\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "33a9602073bc476298897c1376e6cf7e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4007\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 6\n",
      "=> Setting learned tasks of model.2 to 6\n",
      "=> Setting learned tasks of model.4 to 6\n",
      "\n",
      "Training for task 6\n",
      "=> Set task of model.0 to 6\n",
      "=> Set task of model.2 to 6\n",
      "=> Set task of model.4 to 6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4505f65c064d418a9eec115d44fd1ab3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4231, Acc@1 0.2080\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "66b62849933c435cbb05d08c612d1c68",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.2606\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 7\n",
      "=> Setting learned tasks of model.2 to 7\n",
      "=> Setting learned tasks of model.4 to 7\n",
      "\n",
      "Training for task 7\n",
      "=> Set task of model.0 to 7\n",
      "=> Set task of model.2 to 7\n",
      "=> Set task of model.4 to 7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8775f8cf47484156b4888768a6af709e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3559, Acc@1 0.2445\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a17924754e4c452e887765cc45a7891b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3329\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 8\n",
      "=> Setting learned tasks of model.2 to 8\n",
      "=> Setting learned tasks of model.4 to 8\n",
      "\n",
      "Training for task 8\n",
      "=> Set task of model.0 to 8\n",
      "=> Set task of model.2 to 8\n",
      "=> Set task of model.4 to 8\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "592148d2db75492890438617195f6ec8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.6467, Acc@1 0.2624\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e9e55591cb274e4197d1ebeacf93f0c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3485\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 9\n",
      "=> Setting learned tasks of model.2 to 9\n",
      "=> Setting learned tasks of model.4 to 9\n",
      "\n",
      "Training for task 9\n",
      "=> Set task of model.0 to 9\n",
      "=> Set task of model.2 to 9\n",
      "=> Set task of model.4 to 9\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "122b7152b81a41c7a217fc4a42ab3f9b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2962, Acc@1 0.2357\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e1526a091a7a4cbf96cf26c1315fd1db",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3030\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 10\n",
      "=> Setting learned tasks of model.2 to 10\n",
      "=> Setting learned tasks of model.4 to 10\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for task in range(num_seed_tasks_learned, num_tasks):\n",
    "    print(f\"Training for task {task}\")\n",
    "    set_model_task(basis_model_hidf, task)\n",
    "    mnist.update_task(task)\n",
    "\n",
    "    optimizer = optim.RMSprop([p for p in basis_model_hidf.parameters() if p.requires_grad], lr=1e-4)\n",
    "    # Train for 1 epoch\n",
    "    for e in range(1):\n",
    "        train(basis_model_hidf, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "        print(\"Validation\")\n",
    "        print(\"============\")\n",
    "        acc1 = evaluate(basis_model_hidf, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "    cache_masks(basis_model_hidf)\n",
    "    print()\n",
    "    set_num_tasks_learned(basis_model_hidf, task + 1)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.3757\n",
      "Per task performance\n",
      "Task 0: 0.9123\n",
      "Task 1: 0.3463\n",
      "Task 2: 0.3827\n",
      "Task 3: 0.2707\n",
      "Task 4: 0.1992\n",
      "Task 5: 0.4007\n",
      "Task 6: 0.2606\n",
      "Task 7: 0.3329\n",
      "Task 8: 0.3485\n",
      "Task 9: 0.3030\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(basis_model_hidf, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(basis_model_hidf, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['basis_hybrid_mnist_frozen'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Model Initialization (Only New Tasks), 40 masks from task 0 only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_tasks = 50 # For demonstration purposes, we go up to 2500 in our paper\n",
    "num_seed_tasks_learned = 40\n",
    "basis_model_zero_sh = BasisHiddenOnlyMultitaskFC(hidden_size=300, num_tasks=num_tasks, \n",
    "                                num_seed_tasks_learned=num_seed_tasks_learned, start_at_optimal=False, sparsity=0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed_dict = basis_model_zero_sh.state_dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [],
   "source": [
    "update_dict = seed_dict.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [],
   "source": [
    "assert all([(model_map[0].state_dict()['model.0.weight'] == model_map[i].state_dict()['model.0.weight']).all() for i in range(1,15)])\n",
    "update_dict['model.0.weight'] = model_map[0].state_dict()['model.0.weight']\n",
    "for task in range(40):\n",
    "    for layer in [0,2]:\n",
    "        update_dict['model.{}.scores.{}'.format(layer, task)] = model_map[task].state_dict()['model.{}.scores.0'.format(layer)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n"
     ]
    }
   ],
   "source": [
    "seed_dict.update(update_dict)\n",
    "basis_model_zero_sh.load_state_dict(seed_dict, False)\n",
    "cache_masks(basis_model_zero_sh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(40, 50)"
      ]
     },
     "execution_count": 117,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_seed_tasks_learned, num_tasks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training for task 0\n",
      "=> Set task of model.0 to 0\n",
      "=> Set task of model.2 to 0\n",
      "=> Set task of model.4 to 0\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c2768b7c03034db692a6b6c26c7ab7df",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.2034, Acc@1 0.4098\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "777def344da64a7b8f5f84eab9ac8743",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.6935\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cccf0e79e89142a0a8748ee70b8c432b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 0.4785, Acc@1 0.7415\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f23d09657d6f4670b50aedfecc68e90c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.7975\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 1\n",
      "=> Setting learned tasks of model.2 to 1\n",
      "=> Setting learned tasks of model.4 to 1\n",
      "\n",
      "Training for task 1\n",
      "=> Set task of model.0 to 1\n",
      "=> Set task of model.2 to 1\n",
      "=> Set task of model.4 to 1\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5be188ab0bb94965a3ff82cc98d3448e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9924, Acc@1 0.3083\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "be0edf2541b44043ae0dc920682e322d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5228\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "593202e3929143419a0a781a89339d9c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3771, Acc@1 0.5775\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cfbbef26ba02427d9127d6f3cde84f46",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6276\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 2\n",
      "=> Setting learned tasks of model.2 to 2\n",
      "=> Setting learned tasks of model.4 to 2\n",
      "\n",
      "Training for task 2\n",
      "=> Set task of model.0 to 2\n",
      "=> Set task of model.2 to 2\n",
      "=> Set task of model.4 to 2\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cef5238fae30489a81be92a89f7ba19c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3171, Acc@1 0.2604\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8b7be1f5fe3e47d0a80415192dd458b1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4323\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4da5bdf593a34bcd874ce530e25ea7a4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6549, Acc@1 0.5293\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "64d2f99d8d064066bae7345798ffdba2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5823\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 3\n",
      "=> Setting learned tasks of model.2 to 3\n",
      "=> Setting learned tasks of model.4 to 3\n",
      "\n",
      "Training for task 3\n",
      "=> Set task of model.0 to 3\n",
      "=> Set task of model.2 to 3\n",
      "=> Set task of model.4 to 3\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd381ef03bc24bc3b65ede3a6978f998",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9372, Acc@1 0.2894\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d1c8225fd6a34b7eaba0bfc7b2b3dada",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4860\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "46558335165149bda43779ee0117470e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5180, Acc@1 0.5345\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c397708b57a54bb89c13ab83e50103aa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5874\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 4\n",
      "=> Setting learned tasks of model.2 to 4\n",
      "=> Setting learned tasks of model.4 to 4\n",
      "\n",
      "Training for task 4\n",
      "=> Set task of model.0 to 4\n",
      "=> Set task of model.2 to 4\n",
      "=> Set task of model.4 to 4\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "aa4268870e094d8795889a13248aaa74",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2453, Acc@1 0.2559\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2c29ebb5ab534b39918f9a5373cc398b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4470\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f378a5fddd8b4a16878e2f723758d50f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7920, Acc@1 0.4993\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f5f43c21cc8b446396b8a3732746da51",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5553\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 5\n",
      "=> Setting learned tasks of model.2 to 5\n",
      "=> Setting learned tasks of model.4 to 5\n",
      "\n",
      "Training for task 5\n",
      "=> Set task of model.0 to 5\n",
      "=> Set task of model.2 to 5\n",
      "=> Set task of model.4 to 5\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "afab73294941431a8f954e01419f08b4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9094, Acc@1 0.2939\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3588fe995ec84e349ac02c9f53c1678a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4925\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "019077d758dc4bbcb29a4bf2ec5a3140",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4306, Acc@1 0.5557\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "748b1250390742af8698194e659e9ca0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6169\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 6\n",
      "=> Setting learned tasks of model.2 to 6\n",
      "=> Setting learned tasks of model.4 to 6\n",
      "\n",
      "Training for task 6\n",
      "=> Set task of model.0 to 6\n",
      "=> Set task of model.2 to 6\n",
      "=> Set task of model.4 to 6\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "beb6dc591e1342339a7de71ccd6f410b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0946, Acc@1 0.2650\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0f0cd1a985694a698599cda5ba409586",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4852\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "edb8715f3093400892d1570602c87c5b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5732, Acc@1 0.5430\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "32563b085d1d41ca8ca48426bbc2e522",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6039\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 7\n",
      "=> Setting learned tasks of model.2 to 7\n",
      "=> Setting learned tasks of model.4 to 7\n",
      "\n",
      "Training for task 7\n",
      "=> Set task of model.0 to 7\n",
      "=> Set task of model.2 to 7\n",
      "=> Set task of model.4 to 7\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2530983a7c0540b2802db37e0061be76",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8896, Acc@1 0.3057\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cfa904cfa6604b7d813d15bfbbdc7dd2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5360\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b01c39023e2941b9a4595c3c15d9166a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4254, Acc@1 0.6087\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8d31d4b7e4294e4388395cf2da3eb0dc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6550\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 8\n",
      "=> Setting learned tasks of model.2 to 8\n",
      "=> Setting learned tasks of model.4 to 8\n",
      "\n",
      "Training for task 8\n",
      "=> Set task of model.0 to 8\n",
      "=> Set task of model.2 to 8\n",
      "=> Set task of model.4 to 8\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4c36cb1d79594d72b0ee06fa39a30a07",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4104, Acc@1 0.2230\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a374732d3bd24e1a8f5903af3f3985d2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4618\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6ccea47b734c44e3b46ea6aa62257a4d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7487, Acc@1 0.5114\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e411eb65680c467f9e036490d80a250d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5928\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 9\n",
      "=> Setting learned tasks of model.2 to 9\n",
      "=> Setting learned tasks of model.4 to 9\n",
      "\n",
      "Training for task 9\n",
      "=> Set task of model.0 to 9\n",
      "=> Set task of model.2 to 9\n",
      "=> Set task of model.4 to 9\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dade97cae1a641439d6d0c18452cc42d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0476, Acc@1 0.3008\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "26244da4cdf04846a8e834a4128bda5d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5266\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b61b6d6d884b4f9296db3d99b1245078",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4236, Acc@1 0.5827\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "42133549f5784b3eb66cfb090b67ae95",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6393\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 10\n",
      "=> Setting learned tasks of model.2 to 10\n",
      "=> Setting learned tasks of model.4 to 10\n",
      "\n",
      "Training for task 10\n",
      "=> Set task of model.0 to 10\n",
      "=> Set task of model.2 to 10\n",
      "=> Set task of model.4 to 10\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fc8a32a0a6944b4a945cc3bb5983ce19",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0776, Acc@1 0.2897\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "96c0d506cdce48fbb1f46383940a054f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5086\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8ca325104a9b40cba7e671ba9875e53f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3950, Acc@1 0.5599\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f758cdf7dd3c47fc94c2066916147446",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6088\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 11\n",
      "=> Setting learned tasks of model.2 to 11\n",
      "=> Setting learned tasks of model.4 to 11\n",
      "\n",
      "Training for task 11\n",
      "=> Set task of model.0 to 11\n",
      "=> Set task of model.2 to 11\n",
      "=> Set task of model.4 to 11\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "27e07c9952cc41f8ad6356a5e4532bfd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0807, Acc@1 0.2197\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a9b92c3432d9454582cceda1067ebd38",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4324\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b9b69a4b46ea4f6e8dc827177dccb03d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5193, Acc@1 0.5505\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d8daa7c59ac744ee83b1f9e44e5b71e9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6289\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 12\n",
      "=> Setting learned tasks of model.2 to 12\n",
      "=> Setting learned tasks of model.4 to 12\n",
      "\n",
      "Training for task 12\n",
      "=> Set task of model.0 to 12\n",
      "=> Set task of model.2 to 12\n",
      "=> Set task of model.4 to 12\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dedaea7513e34c3b97be87beb7ffc6e4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2721, Acc@1 0.2373\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f0d0c5802a27435aad3fa0ff40ca623b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3667\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cd3cf8c8ea1a48d8ade7ede88a264ec3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9665, Acc@1 0.4414\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5b4f7fb5005d40cc852058ff21a090d0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.4964\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 13\n",
      "=> Setting learned tasks of model.2 to 13\n",
      "=> Setting learned tasks of model.4 to 13\n",
      "\n",
      "Training for task 13\n",
      "=> Set task of model.0 to 13\n",
      "=> Set task of model.2 to 13\n",
      "=> Set task of model.4 to 13\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ec396ff2f8da469593b6f790b24c7ea6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1453, Acc@1 0.2562\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eaf6107acb9d4b1cad8c9113540579d8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4275\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "18ee7c5c91d44ef993138807ecc0bd65",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5668, Acc@1 0.5270\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "51bf7b9fd9494ee690abb6a8a2a2331a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5944\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 14\n",
      "=> Setting learned tasks of model.2 to 14\n",
      "=> Setting learned tasks of model.4 to 14\n",
      "\n",
      "Training for task 14\n",
      "=> Set task of model.0 to 14\n",
      "=> Set task of model.2 to 14\n",
      "=> Set task of model.4 to 14\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "12150bd622304c33b44b8b688152607f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9322, Acc@1 0.3138\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e208e5dc5eb4664bd28ae0bc92ae4aa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4775\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6d30b3a520d44de286b500fd4ce8b2bf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3939, Acc@1 0.5680\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "090a7aa877194ab78b94d1e38dd0a211",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6039\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 15\n",
      "=> Setting learned tasks of model.2 to 15\n",
      "=> Setting learned tasks of model.4 to 15\n",
      "\n",
      "Training for task 15\n",
      "=> Set task of model.0 to 15\n",
      "=> Set task of model.2 to 15\n",
      "=> Set task of model.4 to 15\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7d4fab4a6389430c980102bcf031ddeb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0746, Acc@1 0.2380\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c144d4bac3bb4eb1864498d730549a80",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4421\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c86692fa391549dfbb11e1c4314c9864",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5912, Acc@1 0.5303\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "450782a6d0aa4833a411acb81ae86aec",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5837\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 16\n",
      "=> Setting learned tasks of model.2 to 16\n",
      "=> Setting learned tasks of model.4 to 16\n",
      "\n",
      "Training for task 16\n",
      "=> Set task of model.0 to 16\n",
      "=> Set task of model.2 to 16\n",
      "=> Set task of model.4 to 16\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "095d61b30ba540a5ab81981f1df52750",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1759, Acc@1 0.2546\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5329febf993c48828c8489690043d984",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4098\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fbd170e21ec147e98a151ae6dfe19236",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8197, Acc@1 0.4762\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7a224d96be054bb79fb779b692cb074e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5528\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 17\n",
      "=> Setting learned tasks of model.2 to 17\n",
      "=> Setting learned tasks of model.4 to 17\n",
      "\n",
      "Training for task 17\n",
      "=> Set task of model.0 to 17\n",
      "=> Set task of model.2 to 17\n",
      "=> Set task of model.4 to 17\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7bb90e4bebf44a25945e0307f7ecc67f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9920, Acc@1 0.2682\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "91be42b184be47709f923bf1313552b8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4392\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c7ca87642b5643969b2283197a733b28",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4652, Acc@1 0.5358\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3199bf7cb325489fb94ab86f76b54b6f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5962\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 18\n",
      "=> Setting learned tasks of model.2 to 18\n",
      "=> Setting learned tasks of model.4 to 18\n",
      "\n",
      "Training for task 18\n",
      "=> Set task of model.0 to 18\n",
      "=> Set task of model.2 to 18\n",
      "=> Set task of model.4 to 18\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c8568fc9f2834ca58ab9d2342b0e7944",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2272, Acc@1 0.2458\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5de3257182af4027b185f4e453661a93",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3857\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "76e9cd635baf45f388110353625e2532",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7491, Acc@1 0.4974\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "96228c81801245d0892938f2f5032fe0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5621\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 19\n",
      "=> Setting learned tasks of model.2 to 19\n",
      "=> Setting learned tasks of model.4 to 19\n",
      "\n",
      "Training for task 19\n",
      "=> Set task of model.0 to 19\n",
      "=> Set task of model.2 to 19\n",
      "=> Set task of model.4 to 19\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7fb44d8a5b7e4b17a52a93e1087628ef",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0231, Acc@1 0.2985\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5dfdc6651c844e48b79d21c5a2b41617",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4926\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c0021693cc5546839cf80477f5fd2442",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5135, Acc@1 0.5752\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "93bd83de8ea14223bff30a3578f71005",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6361\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 20\n",
      "=> Setting learned tasks of model.2 to 20\n",
      "=> Setting learned tasks of model.4 to 20\n",
      "\n",
      "Training for task 20\n",
      "=> Set task of model.0 to 20\n",
      "=> Set task of model.2 to 20\n",
      "=> Set task of model.4 to 20\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "47f5016188644b93972df28ba71ed330",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1964, Acc@1 0.2692\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1907a1658ae448acbe1f131ec252b826",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4321\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c9c112af4e9b44d8a6fdd1f8896dc347",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6423, Acc@1 0.5169\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "73e15fd0c07c4f478c3214f52ad9fbdb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5812\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 21\n",
      "=> Setting learned tasks of model.2 to 21\n",
      "=> Setting learned tasks of model.4 to 21\n",
      "\n",
      "Training for task 21\n",
      "=> Set task of model.0 to 21\n",
      "=> Set task of model.2 to 21\n",
      "=> Set task of model.4 to 21\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f5ee6aac46da42d4a30126c90e0e2e16",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9549, Acc@1 0.2816\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c6a0fae2e5bf4ac3993c91cc0776542f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5196\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "805d0cef470b4fada407ac30b86a865a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3614, Acc@1 0.5729\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0db61cab60224d61ac9c4d4d9fab9c25",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6272\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 22\n",
      "=> Setting learned tasks of model.2 to 22\n",
      "=> Setting learned tasks of model.4 to 22\n",
      "\n",
      "Training for task 22\n",
      "=> Set task of model.0 to 22\n",
      "=> Set task of model.2 to 22\n",
      "=> Set task of model.4 to 22\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "02c9356f93fe4095a1af8ea31fa0f097",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0822, Acc@1 0.2871\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eae137b0a9e44c1ebc1982e9fe2c2af0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4976\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2dacd41578624343ad415717b44a0068",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5472, Acc@1 0.5586\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2c6ebf512a924ac3b657a16404d5d98b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6218\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 23\n",
      "=> Setting learned tasks of model.2 to 23\n",
      "=> Setting learned tasks of model.4 to 23\n",
      "\n",
      "Training for task 23\n",
      "=> Set task of model.0 to 23\n",
      "=> Set task of model.2 to 23\n",
      "=> Set task of model.4 to 23\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bbc77b751adc4df29239a6046cd4dfc4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0807, Acc@1 0.2793\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2ab4d1184baa4ae692b59c7f66157260",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4830\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d6668dfdfe314e65a117349f58dd6cb5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4835, Acc@1 0.5758\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "77223310c2c44e5389c39b0d32b7e3ff",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6378\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 24\n",
      "=> Setting learned tasks of model.2 to 24\n",
      "=> Setting learned tasks of model.4 to 24\n",
      "\n",
      "Training for task 24\n",
      "=> Set task of model.0 to 24\n",
      "=> Set task of model.2 to 24\n",
      "=> Set task of model.4 to 24\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5b7374359d1b418394b323e8cde671f4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0157, Acc@1 0.2878\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8b01bd7593bb4b3eb3ab2616613927f0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4744\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c0125bee4d974b009aed2243b83b4b20",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6090, Acc@1 0.5544\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a1d41f165fa8451095d17174180757d8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6017\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 25\n",
      "=> Setting learned tasks of model.2 to 25\n",
      "=> Setting learned tasks of model.4 to 25\n",
      "\n",
      "Training for task 25\n",
      "=> Set task of model.0 to 25\n",
      "=> Set task of model.2 to 25\n",
      "=> Set task of model.4 to 25\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "10b2368af43e41e89b21d2269349482b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2134, Acc@1 0.2565\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8368b0b5b7d54ffbb45cd0b7e61faede",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4117\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a0bcf695a5264f9aad95606f2bb2ca73",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7054, Acc@1 0.4928\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f06278f273b4a8a99c3d5a700ac21c6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5391\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 26\n",
      "=> Setting learned tasks of model.2 to 26\n",
      "=> Setting learned tasks of model.4 to 26\n",
      "\n",
      "Training for task 26\n",
      "=> Set task of model.0 to 26\n",
      "=> Set task of model.2 to 26\n",
      "=> Set task of model.4 to 26\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "84922eed5de249fc95bb845f587fe0c9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.9947, Acc@1 0.2741\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3a6c0b8130c4448497f03444881ee596",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4610\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d4e73406dfc144fd91c04c8d15dfefc2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4589, Acc@1 0.5524\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "032676e53e8742e0bb1e2ce8f94cae94",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6241\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 27\n",
      "=> Setting learned tasks of model.2 to 27\n",
      "=> Setting learned tasks of model.4 to 27\n",
      "\n",
      "Training for task 27\n",
      "=> Set task of model.0 to 27\n",
      "=> Set task of model.2 to 27\n",
      "=> Set task of model.4 to 27\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c811a64f490a4ad98641f2b8f57c6262",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8899, Acc@1 0.3187\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "71b6a9cf54324abd8b56c14fe7180463",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5316\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c1a9936da9574c99a23ee074df0de876",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3814, Acc@1 0.5944\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5d957dcc51d1403397ec96df0506d0e9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6468\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 28\n",
      "=> Setting learned tasks of model.2 to 28\n",
      "=> Setting learned tasks of model.4 to 28\n",
      "\n",
      "Training for task 28\n",
      "=> Set task of model.0 to 28\n",
      "=> Set task of model.2 to 28\n",
      "=> Set task of model.4 to 28\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3b886735af9a469886439fc97097c86b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1215, Acc@1 0.2809\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0cc7ee7627004a68a05551af43fb5bb3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4400\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c1e55e661fa94e47898cacf714331b78",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6337, Acc@1 0.5078\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e669737c61474f67abe409de8f2e4b4c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6081\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 29\n",
      "=> Setting learned tasks of model.2 to 29\n",
      "=> Setting learned tasks of model.4 to 29\n",
      "\n",
      "Training for task 29\n",
      "=> Set task of model.0 to 29\n",
      "=> Set task of model.2 to 29\n",
      "=> Set task of model.4 to 29\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "565f2869a3a44b8c8547b848edac2fbb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0459, Acc@1 0.2604\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6698ad3f0aae450dab5a18e489e8773e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4952\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "07cda6aa35624b019ee8ebff2c731686",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4024, Acc@1 0.5550\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "74612c10b8314aa695197e4e3318b896",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6235\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 30\n",
      "=> Setting learned tasks of model.2 to 30\n",
      "=> Setting learned tasks of model.4 to 30\n",
      "\n",
      "Training for task 30\n",
      "=> Set task of model.0 to 30\n",
      "=> Set task of model.2 to 30\n",
      "=> Set task of model.4 to 30\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "af8746ddfe4249a9b535ca705b71007c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.3054, Acc@1 0.2650\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b36c486e2860499caa8709a42304e703",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3820\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b7d9709a93c841d5955e84fbf355146b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6622, Acc@1 0.4785\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3f8cc27a5e7747d480727faad88d78cb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5439\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 31\n",
      "=> Setting learned tasks of model.2 to 31\n",
      "=> Setting learned tasks of model.4 to 31\n",
      "\n",
      "Training for task 31\n",
      "=> Set task of model.0 to 31\n",
      "=> Set task of model.2 to 31\n",
      "=> Set task of model.4 to 31\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ff267d5b2d98468ab013451b15f7c157",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0728, Acc@1 0.2923\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7326afdee97a4d538497d46854c7feb3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4116\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bf6d3fba2715475bbdf1842cfe0380f2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6790, Acc@1 0.5280\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c6c5773b88084098bc5a85524c078288",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6180\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 32\n",
      "=> Setting learned tasks of model.2 to 32\n",
      "=> Setting learned tasks of model.4 to 32\n",
      "\n",
      "Training for task 32\n",
      "=> Set task of model.0 to 32\n",
      "=> Set task of model.2 to 32\n",
      "=> Set task of model.4 to 32\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7d1527465c21447e80b18db5542e5b94",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0788, Acc@1 0.2321\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b0c676d8bc74a16a2732354410bdace",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3802\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cc8f7512195244318e444f899d54008b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6997, Acc@1 0.4740\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "046ca9d5b3494ef99528f4e647980bab",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5326\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 33\n",
      "=> Setting learned tasks of model.2 to 33\n",
      "=> Setting learned tasks of model.4 to 33\n",
      "\n",
      "Training for task 33\n",
      "=> Set task of model.0 to 33\n",
      "=> Set task of model.2 to 33\n",
      "=> Set task of model.4 to 33\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c6f957cb45264735b5a4819557d9b071",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2559, Acc@1 0.2305\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3d56c34285ed41c98ba2f641c8d00e80",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4170\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b6325c8b0a1c4be3af8617d4aac809e1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6936, Acc@1 0.5000\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8ef1d1614e2e44608da87b090656c952",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5622\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 34\n",
      "=> Setting learned tasks of model.2 to 34\n",
      "=> Setting learned tasks of model.4 to 34\n",
      "\n",
      "Training for task 34\n",
      "=> Set task of model.0 to 34\n",
      "=> Set task of model.2 to 34\n",
      "=> Set task of model.4 to 34\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6305b5e852a54e6aa7560201f386fe8c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4050, Acc@1 0.2240\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8ae2fe2427994d8bbd9ee1b62be3ae3d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4244\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "898696d95e4644049056beb0c8e51766",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8511, Acc@1 0.4974\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0c1e68f7130f482f9a4df0b8ff828c01",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5398\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 35\n",
      "=> Setting learned tasks of model.2 to 35\n",
      "=> Setting learned tasks of model.4 to 35\n",
      "\n",
      "Training for task 35\n",
      "=> Set task of model.0 to 35\n",
      "=> Set task of model.2 to 35\n",
      "=> Set task of model.4 to 35\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9211819ae5864f0db9a4f3308c62d8cd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1095, Acc@1 0.2340\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2d2249ce552f47d49f7b6197b5767d28",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4717\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "40e8b61ea6b04a3b8d136d15cb708565",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5683, Acc@1 0.5443\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dcb5f4af9123496abe92253d8a3a7b18",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5965\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 36\n",
      "=> Setting learned tasks of model.2 to 36\n",
      "=> Setting learned tasks of model.4 to 36\n",
      "\n",
      "Training for task 36\n",
      "=> Set task of model.0 to 36\n",
      "=> Set task of model.2 to 36\n",
      "=> Set task of model.4 to 36\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b07e3b5ba326496fb54085e433839d14",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1974, Acc@1 0.2350\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "03dc7c13c77e4d839364a96415341ea9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4053\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9a7b838577764d9eb8166a474ac8f4be",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8563, Acc@1 0.5000\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "89eac5c14b4a4540b83c8c6c1c262ca4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5153\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 37\n",
      "=> Setting learned tasks of model.2 to 37\n",
      "=> Setting learned tasks of model.4 to 37\n",
      "\n",
      "Training for task 37\n",
      "=> Set task of model.0 to 37\n",
      "=> Set task of model.2 to 37\n",
      "=> Set task of model.4 to 37\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5112064dc0874ab1b289329470338d22",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2925, Acc@1 0.2331\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3c44d17a80324e73ae3fd62372822ea7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3901\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "80d1080af8294ce38584ea9c68606ce5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8642, Acc@1 0.4792\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7945f3a2a2da4f858798d529064d97ef",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5290\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 38\n",
      "=> Setting learned tasks of model.2 to 38\n",
      "=> Setting learned tasks of model.4 to 38\n",
      "\n",
      "Training for task 38\n",
      "=> Set task of model.0 to 38\n",
      "=> Set task of model.2 to 38\n",
      "=> Set task of model.4 to 38\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "57c25922f1104494a2434973e2e5f410",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1567, Acc@1 0.2969\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d247448988b54d7d84218b25191f44bb",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4646\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f5f684082c8f4eb6a09d67c2b615e1bc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6993, Acc@1 0.5326\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "756848b1fa024497b5ac9b893416e5bf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5938\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 39\n",
      "=> Setting learned tasks of model.2 to 39\n",
      "=> Setting learned tasks of model.4 to 39\n",
      "\n",
      "Training for task 39\n",
      "=> Set task of model.0 to 39\n",
      "=> Set task of model.2 to 39\n",
      "=> Set task of model.4 to 39\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5e98b16b136c427ebd45b3e47485855c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1808, Acc@1 0.2454\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "387e36a44de3452a974020f788ba2470",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4506\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1c55d48629ec4d948d234e29008950d5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5985, Acc@1 0.5251\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7fc9347ff3cf46abac6cf7212ff45e95",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5993\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 40\n",
      "=> Setting learned tasks of model.2 to 40\n",
      "=> Setting learned tasks of model.4 to 40\n",
      "\n",
      "Training for task 40\n",
      "=> Set task of model.0 to 40\n",
      "=> Set task of model.2 to 40\n",
      "=> Set task of model.4 to 40\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "82c1e9ae3a884970a331518683cb1492",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1846, Acc@1 0.2572\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f5c149d665bf4419b3da624bc0cb9f1d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4325\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "849140887f094beba06564859c467348",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6575, Acc@1 0.5146\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6fc0aa18ad0b4e0dbd86ab97aa7e5a5a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5908\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 41\n",
      "=> Setting learned tasks of model.2 to 41\n",
      "=> Setting learned tasks of model.4 to 41\n",
      "\n",
      "Training for task 41\n",
      "=> Set task of model.0 to 41\n",
      "=> Set task of model.2 to 41\n",
      "=> Set task of model.4 to 41\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1f572121bb8248b8a85eddc8ae34b1d1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0979, Acc@1 0.2441\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1b40d49995ab49278636a9ff6b012a6a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4216\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b553d9ba1ff34c7793819398566d1530",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6874, Acc@1 0.5026\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2848a61d35594eec9cc5a15194605189",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5667\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 42\n",
      "=> Setting learned tasks of model.2 to 42\n",
      "=> Setting learned tasks of model.4 to 42\n",
      "\n",
      "Training for task 42\n",
      "=> Set task of model.0 to 42\n",
      "=> Set task of model.2 to 42\n",
      "=> Set task of model.4 to 42\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1eac7426e2084a2e87a1ffa39c4ed76c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1439, Acc@1 0.2357\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2f25737a19124c59908ef0329faf5612",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4126\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9b860ac8708c4079bf661dce92805066",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.4997, Acc@1 0.5436\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4f8fb81ac3af452a8074e1e8f41b190e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6050\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 43\n",
      "=> Setting learned tasks of model.2 to 43\n",
      "=> Setting learned tasks of model.4 to 43\n",
      "\n",
      "Training for task 43\n",
      "=> Set task of model.0 to 43\n",
      "=> Set task of model.2 to 43\n",
      "=> Set task of model.4 to 43\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cdcca250bc8049a9848a55a10a6dec85",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0552, Acc@1 0.2520\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "be0aaf94f6c74516afd5deb4cec5de09",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4570\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a134ccb016784372a1aab5e109408e30",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.5639, Acc@1 0.5130\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "413314198b244c93a032e2129eb3a691",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6045\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 44\n",
      "=> Setting learned tasks of model.2 to 44\n",
      "=> Setting learned tasks of model.4 to 44\n",
      "\n",
      "Training for task 44\n",
      "=> Set task of model.0 to 44\n",
      "=> Set task of model.2 to 44\n",
      "=> Set task of model.4 to 44\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "90284eca042042dd9163aac47f1f24c5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.0255, Acc@1 0.2627\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e62e7197d2d94c72ad4e4d60f6d6cc07",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4213\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "59e7e727097a4f0487075a3ceb6ae9b3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6356, Acc@1 0.5013\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cf8f9374b86240ecbf4f0f4bdbcaeb42",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5648\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 45\n",
      "=> Setting learned tasks of model.2 to 45\n",
      "=> Setting learned tasks of model.4 to 45\n",
      "\n",
      "Training for task 45\n",
      "=> Set task of model.0 to 45\n",
      "=> Set task of model.2 to 45\n",
      "=> Set task of model.4 to 45\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "68b2c4e405184a488db220727fcc791a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.2914, Acc@1 0.2415\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6eacc99164ac4449813d1c65c42b8cdf",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4374\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "21433d3cf0d340e8bb90afff65f139f6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7430, Acc@1 0.5130\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e509da438fcd4796b1f5c69540c30834",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5782\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 46\n",
      "=> Setting learned tasks of model.2 to 46\n",
      "=> Setting learned tasks of model.4 to 46\n",
      "\n",
      "Training for task 46\n",
      "=> Set task of model.0 to 46\n",
      "=> Set task of model.2 to 46\n",
      "=> Set task of model.4 to 46\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "efab91afc7394f749fb6ab195e4432ac",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.8855, Acc@1 0.3454\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e01886901d3248efa13efe9afbd7feb5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5087\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3ff5628bcf5248ac83e8d4ac32cbefdc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.3328, Acc@1 0.5745\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e630d1ec74404271a919c69cedbc84ae",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6323\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 47\n",
      "=> Setting learned tasks of model.2 to 47\n",
      "=> Setting learned tasks of model.4 to 47\n",
      "\n",
      "Training for task 47\n",
      "=> Set task of model.0 to 47\n",
      "=> Set task of model.2 to 47\n",
      "=> Set task of model.4 to 47\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "28145588e61e45ea8b015ddd686050d6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1218, Acc@1 0.2871\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6ea14d96ba064a17865899e81726c9b3",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.5095\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "783fd9fd880c47f3991cd31c9d648760",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6784, Acc@1 0.5755\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "14e474b3e011454ba18832bdf740a171",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.6278\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 48\n",
      "=> Setting learned tasks of model.2 to 48\n",
      "=> Setting learned tasks of model.4 to 48\n",
      "\n",
      "Training for task 48\n",
      "=> Set task of model.0 to 48\n",
      "=> Set task of model.2 to 48\n",
      "=> Set task of model.4 to 48\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dd40a18ed3a64632b6cf31f7fcef026b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.1371, Acc@1 0.2412\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cdd4d8bd69fd4e21b0e8aca4766b50e5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.3851\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b399e3d46eea4f16848ca27a9ac58624",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.7507, Acc@1 0.4727\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "05e65462d4cc4f39923cc286c6fec515",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5461\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 49\n",
      "=> Setting learned tasks of model.2 to 49\n",
      "=> Setting learned tasks of model.4 to 49\n",
      "\n",
      "Training for task 49\n",
      "=> Set task of model.0 to 49\n",
      "=> Set task of model.2 to 49\n",
      "=> Set task of model.4 to 49\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "05a4d0104b2944fba80329af268a3485",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 2.4320, Acc@1 0.2624\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2e1c22620eb44054a1ab4657a567a1de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 1 epochs Acc@1 0.4323\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9f0574d203f24b9f9bc363d002bd6192",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/469 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation => Loss 1.6666, Acc@1 0.5023\n",
      "============\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e76aad17259847b98f626a4701507e1c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/79 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Val Perf after 2 epochs Acc@1 0.5746\n",
      "=> Caching mask state for model.0\n",
      "=> Caching mask state for model.2\n",
      "=> Caching mask state for model.4\n",
      "\n",
      "=> Setting learned tasks of model.0 to 50\n",
      "=> Setting learned tasks of model.2 to 50\n",
      "=> Setting learned tasks of model.4 to 50\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for task in range(0, num_tasks):\n",
    "    print(f\"Training for task {task}\")\n",
    "    set_model_task(basis_model_zero_sh, task)\n",
    "    mnist.update_task(task)\n",
    "\n",
    "    optimizer = optim.RMSprop([p for p in basis_model_zero_sh.parameters() if p.requires_grad], lr=1e-4)\n",
    "    # Train for 1 epoch\n",
    "    for e in range(2):\n",
    "        train(basis_model_zero_sh, mnist.train_loader, optimizer, e)\n",
    "        \n",
    "        print(\"Validation\")\n",
    "        print(\"============\")\n",
    "        acc1 = evaluate(basis_model_zero_sh, mnist.val_loader, e)\n",
    "        \n",
    "    \n",
    "    cache_masks(basis_model_zero_sh)\n",
    "    print()\n",
    "    set_num_tasks_learned(basis_model_zero_sh, task + 1)\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average top 1 performance: 0.5951\n",
      "Per task performance\n",
      "Task 0: 0.7975\n",
      "Task 1: 0.6276\n",
      "Task 2: 0.5823\n",
      "Task 3: 0.5874\n",
      "Task 4: 0.5553\n",
      "Task 5: 0.6169\n",
      "Task 6: 0.6039\n",
      "Task 7: 0.6550\n",
      "Task 8: 0.5928\n",
      "Task 9: 0.6393\n",
      "Task 10: 0.6088\n",
      "Task 11: 0.6289\n",
      "Task 12: 0.4964\n",
      "Task 13: 0.5944\n",
      "Task 14: 0.6039\n",
      "Task 15: 0.5837\n",
      "Task 16: 0.5528\n",
      "Task 17: 0.5962\n",
      "Task 18: 0.5621\n",
      "Task 19: 0.6361\n",
      "Task 20: 0.5812\n",
      "Task 21: 0.6272\n",
      "Task 22: 0.6218\n",
      "Task 23: 0.6378\n",
      "Task 24: 0.6017\n",
      "Task 25: 0.5391\n",
      "Task 26: 0.6241\n",
      "Task 27: 0.6468\n",
      "Task 28: 0.6081\n",
      "Task 29: 0.6235\n",
      "Task 30: 0.5439\n",
      "Task 31: 0.6180\n",
      "Task 32: 0.5326\n",
      "Task 33: 0.5622\n",
      "Task 34: 0.5398\n",
      "Task 35: 0.5965\n",
      "Task 36: 0.5153\n",
      "Task 37: 0.5290\n",
      "Task 38: 0.5938\n",
      "Task 39: 0.5993\n",
      "Task 40: 0.5908\n",
      "Task 41: 0.5667\n",
      "Task 42: 0.6050\n",
      "Task 43: 0.6045\n",
      "Task 44: 0.5648\n",
      "Task 45: 0.5782\n",
      "Task 46: 0.6323\n",
      "Task 47: 0.6278\n",
      "Task 48: 0.5461\n",
      "Task 49: 0.5746\n"
     ]
    }
   ],
   "source": [
    "# When task ID we can simply set the mask and evaluate\n",
    "\n",
    "gg_performance = []\n",
    "for task in range(num_tasks):\n",
    "    set_model_task(basis_model_zero_sh, task)\n",
    "    mnist.update_task(task)\n",
    "    acc1 = evaluate(basis_model_zero_sh, mnist.val_loader, 0)\n",
    "    gg_performance.append(acc1.item())\n",
    "\n",
    "clear_output()\n",
    "    \n",
    "print(f\"Average top 1 performance: {(sum(gg_performance) / len(gg_performance)):.4f}\")\n",
    "\n",
    "print(\"Per task performance\")\n",
    "for t in range(num_tasks):\n",
    "    print(f\"Task {t}: {gg_performance[t]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "performance_map['basis_hybrid_mnist_task_zero_only'] = gg_performance.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [],
   "source": [
    "perf_map_copy = performance_map.copy()\n",
    "for k in performance_map.keys():\n",
    "    if 'frozen' in k:\n",
    "        perf_map_copy[k] = [0.0]*40 + performance_map[k]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(perf_map_copy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [],
   "source": [
    "df.loc[:40, 'Seen'] = True\n",
    "df.loc[40:, 'Seen'] = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='Task'>"
      ]
     },
     "execution_count": 135,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df.reset_index().rename(columns={'index': 'Task'}).set_index('Task')[[c for c in df.columns if 'hybrid' not in c]].loc[40:].plot(figsize=(20,8)) #.style.background_gradient(low=df.min().min(), high=df.max().max(), axis=1).plot()"
   ]
  }
 ],
 "metadata": {
  "@webio": {
   "lastCommId": null,
   "lastKernelId": null
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
