{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "from argparse import ArgumentParser\n",
    "import math\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch import nn\n",
    "import torch.nn.functional as F\n",
    "from tqdm import tqdm, trange\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "from itertools import product\n",
    "import random\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "torch.set_default_dtype(torch.float64)\n",
    "plt.rcParams[\"image.cmap\"] = \"RdYlBu\"\n",
    "plt.rcParams['axes.prop_cycle'] = plt.cycler(linestyle=['-', ':', '-.', '--']) * plt.cycler(color=plt.cm.tab20.colors)\n",
    "\n",
    "#plt.rcParams.update({'font.size': 20})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "class LinearNetwork(nn.Module):\n",
    "    def __init__(self, hidden, weight_scale=1.) -> None:\n",
    "        modules = []\n",
    "        for i in range(len(hidden)-1):\n",
    "            modules.append(nn.Linear(hidden[i], hidden[i+1], bias=False))\n",
    "            modules[-1].weight = nn.Parameter(modules[-1].weight * weight_scale)\n",
    "        \n",
    "        super().__init__()\n",
    "        self.model = nn.Sequential(*modules)\n",
    "\n",
    "    def forward(self, x):\n",
    "        return self.model(x)\n",
    "    \n",
    "    @property\n",
    "    def param(self):\n",
    "        for name, weight in self.model.named_parameters():\n",
    "            try:\n",
    "                p\n",
    "            except NameError:\n",
    "                p = weight\n",
    "            else:\n",
    "                p = weight@p\n",
    "        return p.T.squeeze(dim=1).clone().detach()\n",
    "    \n",
    "class LogisticLoss(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "    \n",
    "    def forward(self, pred, label):\n",
    "        # $`label` \\in \\{ \\pm 1 \\}$\n",
    "        loss = torch.logaddexp(torch.zeros_like(pred), -label * pred).sum()\n",
    "        return loss \n",
    "\n",
    "class ExpLoss(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "    \n",
    "    def forward(self, pred, label):\n",
    "        # $`label` \\in \\{ \\pm 1 \\}$\n",
    "        loss = torch.exp(-label * pred).sum()\n",
    "        return loss \n",
    "\n",
    "@torch.no_grad()\n",
    "def normalized_margin(pred, label, model):\n",
    "    normalized_margin_mapping = label*pred / torch.norm(model.param)\n",
    "    return torch.min(normalized_margin_mapping).item()\n",
    "\n",
    "@torch.no_grad()\n",
    "def unit_vector_distance(model, pivot=torch.tensor([0.,1.])):\n",
    "    unit_param = model.param.clone().detach()\n",
    "    unit_param /= torch.norm(unit_param, p=2)\n",
    "    unit_pivot = pivot / torch.norm(pivot, p=2)\n",
    "    return torch.norm(unit_param - unit_pivot).item()\n",
    "\n",
    "def get_random_data(dim, n_data, mu_p, mu_m, sigma_p, sigma_m, ratio_p=0.5, device='cpu'):\n",
    "    n_data_p = int(n_data * ratio_p)\n",
    "    n_data_m = n_data - n_data_p\n",
    "\n",
    "    X_p = torch.randn((n_data_p, dim)) * sigma_p + torch.tensor(mu_p).view(1,dim)\n",
    "    X_m = torch.randn((n_data_m, dim)) * sigma_m + torch.tensor(mu_m).view(1,dim)\n",
    "    X = torch.cat([X_p, X_m]).to(device)\n",
    "    y = torch.cat([torch.ones(n_data_p), -torch.ones(n_data_m)]).view(-1,1).to(device)\n",
    "    return X, y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "losses_N_ :  [[], []]\n",
      "0.0 0.0\n"
     ]
    }
   ],
   "source": [
    "\n",
    "n_cycle = 100\n",
    "n_task = 2\n",
    "n_stage = n_cycle*n_task\n",
    "max_iter = 10\n",
    "device ='cpu'\n",
    "criterion = 'iter'  #iter or risk\n",
    "step_size=1e-3\n",
    "\n",
    "\n",
    "task_N_ = {}\n",
    "torch.manual_seed(42)\n",
    "X1_N_, y1_N_ = torch.tensor([[1.,2], [1.1, 1.8], [1.2, 1.9]]), torch.tensor([[1], [1], [1]])\n",
    "# Artificially adding data to make max margin direction to x-axis'\n",
    "task_N_[0] = [X1_N_, y1_N_]\n",
    "X_total_N_ = X1_N_\n",
    "y_total_N_ = y1_N_\n",
    "\n",
    "torch.manual_seed(42)\n",
    "X2_N_, y2_N_ = torch.tensor([[1., -2], [1.1, -1.8], [1.2, -1.9]]), torch.tensor([[1], [1], [1]])\n",
    "task_N_[1] = [X2_N_, y2_N_]\n",
    "X_total_N_ = torch.cat([X_total_N_, X2_N_])\n",
    "y_total_N_ = torch.cat([y_total_N_, y2_N_])\n",
    "\n",
    "# risk\n",
    "empirical_risk = LogisticLoss()\n",
    "xs_N_ = []\n",
    "ys_N_ = []\n",
    "#losses = [[],[], [], []]\n",
    "losses_N_ = []\n",
    "for i in range(n_task):\n",
    "    losses_N_.append([])\n",
    "print(\"losses_N_ : \", losses_N_)\n",
    "\n",
    "x0, y0 = 0., 0.\n",
    "print(x0, y0)\n",
    "# initialization\n",
    "xs_N_.append(x0)\n",
    "ys_N_.append(y0)\n",
    "\n",
    "# model 1: Continual Learning\n",
    "net = LinearNetwork([2, 1])\n",
    "net.model[-1].weight = nn.Parameter(torch.Tensor([[x0, y0]]))\n",
    "net.to(device)\n",
    "    \n",
    "# optimizer    \n",
    "optimizer = torch.optim.SGD(net.parameters(), lr=step_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3323.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4601.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5313.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4091.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3472.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4347.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4347.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4246.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4277.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2970.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4310.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4545.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3668.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3714.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4460.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4295.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4454.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4514.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4083.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3974.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4424.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 373.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1736.12it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4168.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4484.45it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4089.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4420.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3837.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4128.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4457.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4478.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4535.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4613.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4184.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4721.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3889.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4127.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4199.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4633.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4370.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3372.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3973.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4505.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4092.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3599.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3657.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 345.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1213.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3329.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4456.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4009.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3999.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4422.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4144.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4205.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3176.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4040.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3846.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4730.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4768.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3306.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4444.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4470.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3864.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4159.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3706.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3494.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4251.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4532.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 357.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1369.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 10/10 [00:00<00:00, 3707.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4166.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4083.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4582.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4112.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3898.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4384.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4300.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4074.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4205.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4120.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3809.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3949.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4359.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1840.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4135.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3832.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4506.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4233.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3766.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3855.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4541.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4189.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 368.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1265.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3769.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4235.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4295.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3966.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3428.12it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4154.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3894.07it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4019.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4328.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3644.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3865.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4262.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3980.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4043.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4355.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4272.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5144.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3496.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4551.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4319.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 356.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1682.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4518.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3992.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4164.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3656.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3454.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3935.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3720.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4063.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3120.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3779.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4786.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4026.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3846.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3659.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3958.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3894.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4168.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4125.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4707.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3812.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3243.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4833.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3831.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3892.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4856.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3877.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5100.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4823.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4215.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3750.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4022.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3952.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3790.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3506.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4547.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3971.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4928.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4133.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3572.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5248.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3191.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3938.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4142.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4180.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3874.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4928.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4279.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3626.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2602.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4032.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4350.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3979.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4476.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3345.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4582.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3940.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5110.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3974.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4549.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5094.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5251.41it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3587.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 5135.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3841.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4196.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4918.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4071.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4279.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4771.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3312.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4732.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4574.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4494.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4393.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3793.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3826.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4582.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3757.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3322.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3753.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4470.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3889.38it/s]\n"
     ]
    }
   ],
   "source": [
    "prev_loss = [0 for i in range(n_task)]\n",
    "    \n",
    "avr_forget_N_ = []\n",
    "\n",
    "for k in range(n_stage):\n",
    "    k_ = k%n_task\n",
    "    print(\"task n: \", k_)\n",
    "    # Run GD for task 1\n",
    "    pbar = trange(max_iter)\n",
    "    for i in pbar:\n",
    "        pred = net(task_N_[k_][0])\n",
    "        loss = empirical_risk(pred, task_N_[k_][1])\n",
    "\n",
    "        for j in range(n_task):\n",
    "            pred_j = net(task_N_[j][0])\n",
    "            loss_j = empirical_risk(pred_j, task_N_[j][1])\n",
    "            losses_N_[j].append(loss_j.clone().detach().item())\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "    prev_loss[k_] = loss.clone().detach().item()\n",
    "        \n",
    "    #if k>n_task and k_ == n_task - 1:\n",
    "    if k_ == n_task - 1:\n",
    "        forget = 0\n",
    "        for j in range(n_task-1):\n",
    "            pred_j = net(task_N_[j][0])\n",
    "            loss_j = empirical_risk(pred_j, task_N_[j][1])\n",
    "            forget += loss_j.clone().detach().item() - prev_loss[j]\n",
    "        avr_forget_N_.append(forget/n_task)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "losses_N :  [[], []]\n",
      "0.0 0.0\n"
     ]
    }
   ],
   "source": [
    "task_N = {}\n",
    "\n",
    "torch.manual_seed(42)\n",
    "X1_N, y1_N = torch.tensor([[1.,2], [1.1, 1.8], [1.2, -1.9]]), torch.tensor([[1], [1], [1]])\n",
    "task_N[0] = [X1_N, y1_N]\n",
    "X_total_N = X1_N\n",
    "y_total_N = y1_N\n",
    "\n",
    "torch.manual_seed(42)\n",
    "X2_N, y2_N = torch.tensor([[1., -2], [1.1, -1.8], [1.2, 1.9]]), torch.tensor([[1], [1], [1]])\n",
    "task_N[1] = [X2_N, y2_N]\n",
    "X_total_N = torch.cat([X_total_N, X2_N])\n",
    "y_total_N = torch.cat([y_total_N, y2_N])\n",
    "\n",
    "# risk\n",
    "empirical_risk = LogisticLoss()\n",
    "xs_N = []\n",
    "ys_N = []\n",
    "\n",
    "#losses = [[],[], [], []]\n",
    "losses_N = []\n",
    "for i in range(n_task):\n",
    "    losses_N.append([])\n",
    "print(\"losses_N : \", losses_N)\n",
    "\n",
    "x0, y0 = 0., 0.,\n",
    "print(x0, y0)\n",
    "# initialization\n",
    "xs_N.append(x0)\n",
    "ys_N.append(y0)\n",
    "\n",
    "# model 1: Continual Learning\n",
    "net = LinearNetwork([2, 1])\n",
    "net.model[-1].weight = nn.Parameter(torch.Tensor([[x0, y0]]))\n",
    "net.to(device)\n",
    "    \n",
    "# optimizer    \n",
    "optimizer = torch.optim.SGD(net.parameters(), lr=step_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3224.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4480.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1067.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2795.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3498.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3770.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4002.96it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3144.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2176.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3977.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2046.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3805.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 316.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1301.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2712.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4217.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3500.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2206.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3314.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2159.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3979.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2368.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3112.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3785.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3288.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2579.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4565.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3310.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3202.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 318.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2514.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2396.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3059.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2105.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4390.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3517.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2860.47it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3985.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4316.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2667.45it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2859.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2107.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4457.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3561.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1852.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3580.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 306.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1116.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2338.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3580.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3172.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 520.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2618.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3861.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3246.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2160.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3983.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3903.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2611.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3636.47it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2391.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3065.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1541.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3734.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3118.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 303.55it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2745.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2540.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4113.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3249.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4210.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3257.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1794.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3738.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2696.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2572.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3432.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4214.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4460.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2058.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3918.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2829.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3853.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 243.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 916.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1862.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2699.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1420.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2819.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1811.32it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3385.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2621.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2849.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1332.41it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1903.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3264.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2958.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1706.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 521.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2327.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4221.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2099.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3073.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1908.32it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3283.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2384.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4104.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4076.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1561.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2644.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2744.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3561.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4198.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2842.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3683.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2869.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2271.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3463.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2902.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3364.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2374.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3741.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2442.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2866.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2518.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2613.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3214.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2727.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3366.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3270.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 283.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1092.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3581.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1534.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3570.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4114.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3426.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3275.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3799.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3161.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3172.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2101.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2489.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3641.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2856.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3834.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3253.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2371.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1977.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3485.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4079.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2647.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3325.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2497.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4350.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2783.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2429.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3204.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2966.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2808.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 300.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 740.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4108.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3270.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2686.07it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1426.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2192.07it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 469.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2780.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 10/10 [00:00<00:00, 3632.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3237.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1826.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1847.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2672.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3374.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3843.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1954.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1928.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3057.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2772.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4344.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 249.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 4077.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3138.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3900.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1836.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2882.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2038.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3669.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2392.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1867.04it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1010.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2081.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1248.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1918.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1052.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 3599.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 237.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1109.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "task n:  1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2198.73it/s]\n"
     ]
    }
   ],
   "source": [
    "prev_loss = [0 for i in range(n_task)]\n",
    "    \n",
    "avr_forget_N = []\n",
    "\n",
    "for k in range(n_stage):\n",
    "    k_ = k%n_task\n",
    "    print(\"task n: \", k_)\n",
    "    # Run GD for task 1\n",
    "    pbar = trange(max_iter)\n",
    "    for i in pbar:\n",
    "        pred = net(task_N[k_][0])\n",
    "        loss = empirical_risk(pred, task_N[k_][1])\n",
    "\n",
    "        for j in range(n_task):\n",
    "            pred_j = net(task_N[j][0])\n",
    "            loss_j = empirical_risk(pred_j, task_N[j][1])\n",
    "            losses_N[j].append(loss_j.clone().detach().item())\n",
    "\n",
    "        if i == max_iter-1:\n",
    "            xs_N.append(net.param[0])\n",
    "            ys_N.append(net.param[1])\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "    prev_loss[k_] = loss.clone().detach().item()\n",
    "        \n",
    "    #if k>n_task and k_ == n_task - 1:\n",
    "    if k_ == n_task - 1:\n",
    "        forget = 0\n",
    "        for j in range(n_task-1):\n",
    "            pred_j = net(task_N[j][0])\n",
    "            loss_j = empirical_risk(pred_j, task_N[j][1])\n",
    "            forget += loss_j.clone().detach().item() - prev_loss[j]\n",
    "        avr_forget_N.append(forget/n_task)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = f\"section4_forgetting/\"\n",
    "os.makedirs(path, exist_ok=True)\n",
    "risk = 0"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams[\"text.usetex\"] = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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SPXo0UOvvvpqpvP27dunr7/+Wt99952+++47rVq1SpMmTUo//uyzz+rDDz/Ue++9p507d2r06NG67777tGrVKknSkSNHdMstt6hv376KjIzUww8/rKeffrrg/iEUAY8IeTNnzlRYWJj8/f3VunVrrV69OsfzV61apdatW8vf31/h4eGaNWuWy/E5c+aoc+fOKl++vMqXL6/u3btrw4YNl31ft+ZwSB98IJUpY9bNmznT7ooAAAAgybKkf/6xp1lW3mq99dZbdcstt6h+/fq68sorNXfuXG3fvl27du265Gffeecd9enTR2PHjlWDBg302GOPqU+fPpnOS0tL00cffaSmTZuqc+fOGjBggFasWCHJhMypU6dq3rx56tWrl8LDw3X//ffrvvvu0+zZsyVJ7733nsLDwzVt2jQ1bNhQ9957r+6///68fVGbuX3IW7hwoUaNGqXx48dr69at6ty5s/r06aPDhw9nef6BAwfUt29fde7cWVu3btUzzzyjESNGaNGiRenn/Pzzz7r77rv1008/KSIiQrVq1VLPnj119OjRfN/XI4SFSZMnm+2nn5YOHLC3HgAAACghQSpb1p6WkJC3Wvft26d77rlH4eHhCgoKUlhYmCTl6u/Qu3fvVtu2bV32XfxekurUqaPAwMD091WrVlVsbKwkadeuXTp//rx69OihsmXLprf58+enDxuNiopS+/btXZ4F7NChQ96+qM1K2V3A5Zo6daoeeughPfzww5Kkt956Sz/88IPee+89TZw4MdP5s2bNUq1atfTWW29Jkho3bqxNmzbpjTfe0K233ipJ+vTTT10+M2fOHH355ZdasWKFBg4cmK/7eoxHH5X+8x9p1Srp4YelH380vXwAAADAJdxwww2qWbOm5syZo2rVqiktLU1NmzZVUlLSJT9rWVamSVisLLoSfXx8XN47HI704aDO1++//17Vq1d3Oc/Pzy/ba7obtw55SUlJ2rx5c6Yxsj179tTatWuz/ExERIR69uzpsq9Xr16aO3eukpOTM/0oJCkhIUHJycmqUKFCvu8rSYmJiUpMTEx/Hx8fn/MXLI68vMywzebNpZUrpfffl4YMsbsqAACAEqt0aensWfvunVsnTpxQVFSUZs+erc6dO0uS1qxZk+vPN2rUKNMjVJs2bcp9AZKaNGkiPz8/HT58WNdcc02253z99dcu+9at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zpWvr68efvjhAinSU8XHxys4OFhxcXEKCgqyuxwgs7VrpTvukI4eNc/rzZolDRxod1UAAAAlUm7zQ65DHgoeIQ9u4e+/pfvuk5YtM+8feEB65x2pTBl76wIAAChhcpsf8vRM3tChQzV79mxt3LhRiYmJl10kADdQqZK0ZIn04ouSwyF9+KHUpo20bZvdlQEAACALeerJa9eunXbs2KFz586pVKlSatSokVq1aqVWrVqpZcuWatmypcqWLVuY9XoUevLgdn7+2czCeeyY5Ocnvfmm9NhjJvwBAACgUBXacM20tDT9/vvv2rp1a3qLjIzUqVOn5OXlpXr16ql79+4aPny4GjZseNlfxJMR8uCWjh83Qza/+868v+kmae5cqUIFW8sCAADwdEX+TN6hQ4e0detWbd68WUuXLtXOnTu1bNkyderUqSAu75EIeXBbliVNny49+aSUlCTVrCl99pnE/94BAAAKje0Tr7z88staunSpfv3118K4vEcg5MHtbdki3XWXtGeP5OUlPf+8NH68WXoBAAAABarAJ145fPhwngro1q2btjExA+DZWrUyi6cPGCClpUkTJkidO0v79tldGQAAQImV65B31VVXafDgwdqwYUO258TFxWnOnDlq2rSptm7dqoiIiAIpEkAxFhgozZ8vffqpWUh93TqpRQvznB4rtAAAABS5XA/XPHnypF577TXNmzdPPj4+atOmjapVqyZ/f3+dOnVKu3bt0s6dO9WmTRs9++yz6tOnT2HX7vYYrgmPc+iQNGiQtGqVeX/TTdKcOVJIiK1lAQAAeIJCeybv/PnzWrJkiVavXq2DBw/q3LlzCgkJUcuWLdWrVy81bdr0sosvKQh58EipqWZphWeflZKTpdBQs7Ze7952VwYAAODWCmUxdEny9/fXLbfcomnTpmnx4sVaunSpPvnkEz3xxBO2BbyZM2cqLCxM/v7+at26tVavXp3j+atWrVLr1q3l7++v8PBwzZo1y+X4zp07deutt6pOnTpyOBx66623CuS+QIng7W1m3Vy/XmrcWIqJkfr0kR5/XPrnH7urAwAA8Hh5DnlZiY6OVlpaWkFcKs8WLlyoUaNGafz48dq6das6d+6sPn36ZDtRzIEDB9S3b1917txZW7du1TPPPKMRI0Zo0aJF6eckJCQoPDxckyZNUmhoaIHcFyhxWrY0k7IMH27e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Xbt26eTJkypfvnz6DJsAAAAAgKKX55Dn4+OjHTt2ZApzFSpUKLCiAAAAAAD5k69l5QcOHKi5c+cWdC0AAAAAgMuUr2fykpKS9MEHH2j58uVq06aNypQp43J86tSpBVIcAAAAACBv8hXyduzYoVatWkmS/vjjD5djPJMHAAAAAPbJV8j76aefCroOAAAAAEAByNczeQAAAACA4infIW/16tW677771KFDBx09elSStGDBAq1Zs6bAigMAAAAA5E2+Qt6iRYvUq1cvBQQEaOvWrUpMTJQknTlzRq+99lqBFggAAAAAyL18hbxXXnlFs2bN0pw5c+Tj45O+v2PHjtqyZUuBFQcAAAAAyJt8hbzdu3erS5cumfYHBQXp9OnTl1sTAAAAACCf8hXyqlatqr1792bav2bNGoWHh192UQAAAACA/MlXyBsyZIhGjhyp9evXy+Fw6NixY/r00081duxYPfbYYwVdIwAAAAAgl/K1Tt6TTz6puLg4devWTefPn1eXLl3k5+ensWPHatiwYQVdIwAAAAAglxyWZVn5/XBCQoJ27dqltLQ0NWnSRGXLli3I2jxefHy8goODFRcXp6CgILvLAQAAAFCM5TY/5Gu45gMPPKAVK1YoICBAbdq0Udu2bQl4AAAAAFAM5CvknThxQtdff71q1KihJ554QpGRkQVcVt7MnDlTYWFh8vf3V+vWrbV69eocz1+1apVat24tf39/hYeHa9asWZnOWbRokZo0aSI/Pz81adJEixcvvuz7AgAAAEBhy1fI++abbxQTE6MXXnhBmzdvVuvWrdWkSRO99tprOnjwYAGXmLOFCxdq1KhRGj9+vLZu3arOnTurT58+Onz4cJbnHzhwQH379lXnzp21detWPfPMMxoxYoQWLVqUfk5ERITuvPNODRgwQNu2bdOAAQN0xx13aP369fm+LwAAAAAUhct6Js/pzz//1Oeff6558+Zpz549SklJKYjacqVdu3Zq1aqV3nvvvfR9jRs31k033aSJEydmOv+pp57SN998o6ioqPR9Q4cO1bZt2xQRESFJuvPOOxUfH6///e9/6ef07t1b5cuX1+eff56v+2aFZ/IAAAAA5FahPpN3oeTkZG3atEnr16/XwYMHVaVKlcu9ZK4lJSVp8+bN6tmzp8v+nj17au3atVl+JiIiItP5vXr10qZNm5ScnJzjOc5r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X6NGjaynn37aporgLmJjYy1J1qpVqyzLsqy0tDQrNDTUmjRpUvo558+ft4KDg61Zs2bZVSaKkTNnzlj169e3li9fbl1zzTXWyJEjLcvit4NLe+qpp6xOnTple5zfEHJy/fXXWw8++KDLvltuucW67777LMvi94PsSbIWL16c/j43v5XTp09bPj4+1hdffJF+ztGjRy0vLy9r6dKlRVI3PXklXFJSkjZv3qyePXu67O/Zs6fWrl1rU1VwF3FxcZKkChUqSJIOHDigmJgYl9+Tn5+frrnmGn5PkCQ9/vjjuv7669W9e3eX/fx2cCnffPON2rRpo9tvv12VK1dWy5YtNWfOnPTj/IaQk06dOmnFihX6448/JEnbtm3TmjVr1LdvX0n8fpB7ufmtbN68WcnJyS7nVKtWTU2bNi2y31OpIrkLiq3jx48rNTVVVapUcdlfpUoVxcTE2FQV3IFlWRozZow6deqkpk2bSlL6byar39OhQ4eKvEYUL1988YW2bNmijRs3ZjrGbweXsn//fr333nsaM2aMnnnmGW3YsEEjRoyQn5+fBg4cyG8IOXrqqacUFxenRo0aydvbW6mpqXr11Vd19913S+LPIORebn4rMTEx8vX1Vfny5TOdU1R/vybkQZLkcDhc3luWlWkfcKFhw4bpt99+05o1azId4/eEix05ckQjR47UsmXL5O/vn+15/HaQnbS0NLVp00avvfaaJKlly5bauXOn3nvvPQ0cODD9PH5DyMrChQv1ySef6LPPPtMVV1yhyMhIjRo1StWqVdOgQYPSz+P3g9zKz2+lKH9PDNcs4UJCQuTt7Z3pvyrExsZm+i8UgNPw4cP1zTff6KefflKNGjXS94eGhkoSvydksnnzZsXGxqp169YqVaqUSpUqpVWrVmn69OkqVapU+u+D3w6yU7VqVTVp0sRlX+PGjdMnCePPH+TkX//6l55++mndddddatasmQYMGKDRo0dr4sSJkvj9IPdy81sJDQ1VUlKSTp06le05hY2QV8L5+vqqdevWWr58ucv+5cuXq2PHjjZVheLKsiwNGzZMX331lVauXKmwsDCX42FhYQoNDXX5PSUlJWnVqlX8nkq46667Ttu3b1dkZGR6a9Omje69915FRkYqPDyc3w5ydPXVV2dasuWPP/5Q7dq1JfHnD3KWkJAgLy/Xv/Z6e3unL6HA7we5lZvfSuvWreXj4+NyTnR0tHbs2FF0v6cimd4FxdoXX3xh+fj4WHPnzrV27dpljRo1yipTpox18OBBu0tDMfPoo49awcHB1s8//2xFR0ent4SEhPRzJk2aZAUHB1tfffWVtX37duvuu++2qlatasXHx9tYOYqjC2fXtCx+O8jZhg0brFKlSlmvvvqqtWfPHuvTTz+1SpcubX3yySfp5/AbQnYGDRpkVa9e3fruu++sAwcOWF999ZUVEhJiPfnkk+nn8PuB05kzZ6ytW7daW7dutSRZU6dOtbZu3WodOnTIsqzc/VaGDh1q1ahRw/rxxx+tLVu2WNdee63VokULKyUlpUi+AyEPlmVZ1rvvvmvVrl3b8vX1tVq1apU+JT5wIUlZtg8//DD9nLS0NOuFF16wQkNDLT8/P6tLly7W9u3b7SsaxdbFIY/fDi7l22+/tZo2bWr5+flZjRo1st5//32X4/yGkJ34+Hhr5MiRVq1atSx/f38rPDzcGj9+vJWYmJh+Dr8fOP30009Z/n1n0KBBlmXl7rdy7tw5a9iwYVaFChWsgIAAq1+/ftbhw4eL7Ds4LMuyiqbPEAAAAABQ2HgmDwAAAAA8CCEPAAAAADwIIQ8AAAAAPAghDwAAAAA8CCEPAAAAADwIIQ8AAAAAPAghDwAAAAA8CCEPAAAAADwIIQ8AAAAAPAghDwAAAAA8CCEPAIBc6Nq1q0aNGmV3Geksy9IjjzyiChUqyOFwKDIysshrKG7/TAAABiEPAOAW7r//fjkcDk2aNMll/9dffy2Hw2FTVfZZunSpPvroI3333XeKjo5W06ZN7S4p39q1a6dHHnnE7jIAwGMQ8gAAbsPf31+TJ0/WqVOn7C6lwCQlJeXrc/v27VPVqlXVsWNHhYaGqlSpUgVcWdFITU3V9u3b1bJlS7tLAQCPQcgDALiN7t27KzQ0VBMnTsz2nDp16uitt95y2XfllVdqwoQJ6e+7du2q4cOHa9SoUSpfvryqVKmi999/X//8848eeOABBQYGqm7duvrf//7ncp2UlBQNGzZM5cqVU8WKFfXss8/Ksqz045ZlacqUKQoPD1dAQIBatGihL7/80uUaXbt21bBhwzRmzBiFhISoR48eWX6PxMREjRgxQpUrV5a/v786deqkjRs3SjK9msOHD9fhw4flcDhUp06dbP95pKWlafLkyapXr578/PxUq1Ytvfrqq5o/f74qVqyoxMREl/NvvfVWDRw4MMfPZic33/9iv//+u86dO6dWrVrleB4AIPcIeQAAt+Ht7a3XXntN77zzjv7888/LutbHH3+skJAQbdiwQcOHD9ejjz6q22+/XR07dtSWLVvUq1cvDRgwQAkJCS6fKVWqlNavX6/p06dr2rRp+uCDD9KPP/vss/rwww/13nvvaefOnRo9erTuu+8+rVq1KtO9S5UqpV9//VWzZ8/Osr4nn3xSixYt0scff6wtW7aoXr166tWrl06ePKm3335bL730kmrUqKHo6Oj08JeVcePGafLkyXruuee0a9cuffbZZ6pSpYpuv/12paam6ptvvkk/9/jx4/ruu+/0wAMP5PjZ7OT2+19o69at8vb2VvPmzbM9BwCQRxYAAG5g0KBBVv/+/S3Lsqz27dtbDz74oGVZlrV48WLrwv87q127tjVt2jSXz7Zo0cJ64YUX0t9fc801VqdOndLfp6SkWGXKlLEGDBiQvi86OtqSZEVERKR/pnHjxlZaWlr6OU899ZTVuHFjy7Is6+zZs5a/v7+1du1al3s/9NBD1t133+1y7yuvvDLH73r27FnLx8fH+vTTT9P3JSUlWdWqVbOmTJliWZZlTZs2zapdu3aO14mPj7f8/PysOXPmZHn80Ucftfr06ZP+/q233rLCw8OttLS0S37W+V1GjhyZXnNuvv/FxowZY11xxRU5fg8AQN645wB+AECJNnnyZF177bV64okn8n2NC3uOvL29VbFiRTVr1ix9n7PHKjY2Nn1f+/btXSZ56dChg958802lpqZq165dOn/+fKbhl0lJSZmeN2vTpk2Ote3bt0/Jycm6+uqr0/f5+Piobdu2ioqKyvV3jIqKUmJioq677rosjw8ePFhXXXWVjh49qurVq+vDDz9Mn+DmUp+9WF6+/4W2bt3KUE0AKGCEPACA2+nSpYt69eqlZ555Rvfff7/LMS8vL5fn5CQpOTk50zV8fHxc3jscDpd9zjCXlpaWq5qc533//feqXr26yzE/Pz+X92XKlMnxWs76L5411LKsPM0kGhAQkOPxli1bqkWLFpo/f7569eql7du369tvv83VZy+Wl+9/ocjISN144415uhcAIGc8kwcAcEuTJk3St99+q7Vr17rsr1SpkqKjo9Pfx8fH68CBAwVyz3Xr1mV6X79+fXl7e6tJkyby8/PT4cOHVa9ePZdWs2bNPN2nXr168vX11Zo1a9L3JScna9OmTWrcuHGur1O/fn0FBARoxYoV2Z7z8MMP68MPP9S8efPUvXv39Fpz89kL5ef7Hzx4UKdOnWJmTQAoYPTkAQDcUrNmzXTvvffqnXfecdl/7bXX6qOPPtINN9yg8uXL67nnnpO3t3eB3PPIkSMaM2aMhgwZoi1btuidd97Rm2++KUkKDAzU2LFjNXr0aKWlpalTp06Kj4/X2rVrVbZsWQ0aNCjX9ylTpoweffRR/etf/1KFChVUq1YtTZkyRQkJCXrooYdyfR1/f3899dRTevLJJ+Xr66urr75af//9t3bu3Jl+nXvvvVdjx47VnDlzNH/+/Dx99kL5+f5bt26Vw+Eg5AFAASPkAQDc1ssvv6x///vfLvvGjRun/fv3q1+/fgoODtbLL79cYD15AwcO1Llz59S2bVt5e3tr+PDhLot4v/zyy6pcubImTpyo/fv3q1y5cmrVqpWeeeaZPN9r0qRJSktL04ABA3TmzBm1adNGP/zwg8qXL5+n6zz33HMqVaqUnn/+eR07dkxVq1bV0KFD048HBQXp1ltv1ffff6+bbropT5+9WF6//+bNm1WvXj0FBQXl6TsBAHLmsC5+cAEAAJQoPXr0UOPGjTV9+vQivW+bNm3Utm1bzZw5s0jvCwCejp48AABKqJMnT2rZsmVauXKlZsyYUST3tCxLhw4d0oIFC7Rjxw4tWLCgSO4LACUJIQ8AgBKqVatWOnXqlCZPnqyGDRsWyT23b9+uDh06qHnz5vrhhx/yNJEMACB3GK4JAAAAAB6EJRQAAAAAwIMQ8gAAAADAgxDyAAAAAMCDEPIAAAAAwIMQ8gAAAADAgxDyAAAAAMCDEPIAAAAAwIMQ8gAAAADAgxDyAAAAAMCDEPIAAAAAwIMQ8gAAAADAg/wfNW0NR1B1SMUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 900x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "fig, axes = plt.subplots(1,1,figsize=(9,6))\n",
    "ax = axes\n",
    "ax.plot(avr_forget_N_, c='red', label = \"contradict\")\n",
    "ax.plot(avr_forget_N, c='blue', label = \"aligned\")\n",
    "plt.xlabel(r'Number of cycle $%s$'  % \"J\")\n",
    "plt.ylabel(r'Average Forgetting $%s$'  % \"\\\\mathcal{F}_{cyc}( J )\")\n",
    "#ax.plot(l_t, c=\"orange\", label = \"vanilla loss\")\n",
    "#ax.set_yscale('log')\n",
    "ax.legend()\n",
    "plt.tight_layout()\n",
    "fig.savefig(os.path.join(path, f\"{max_iter}iter_avr_forget.pdf\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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1Wg+BYBEKAJAovmUXLt27YqBgYGoq6sbdZ+3AFOVUCTXrl27KkNHCUVgutN8CgCJUASARCgCQCIUASARigCQCEUASIQiACRCEQASF++Ta9asWZWL9wGmO5905Oro6Ci7BICq0XwKAIlQBIBEKAJA4pgiubZs2VI50cbxRWC6E4rkOnTokLNPgZOG5lMASIQiACRCEQASoQgAiVAEgEQoAkAiFAEgmdQXn2VZFhERPT09JVdy8jpw4EDlOkXbASjLkc+fI7lQlEkdirt3746IiPb29pIrAWAy2L17dzQ1NRX2/JM6FFtaWiIiYuvWrYW+CUXq6emJ9vb22LZtW8ydO7fscsZsqtcfMfXXQf3lm+rrMNXrj4jYt29fnHnmmZVcKMqkDsXa2qFDnk1NTVN2Qx4xd+7cKb0OU73+iKm/Duov31Rfh6lef8SvcqGw5y/02QFgChGKAJBM6lBsbGyMj33sY9HY2Fh2KeM21ddhqtcfMfXXQf3lm+rrMNXrj6jeOtRkRZ/fCgBTxKT+pQgA1SQUASARigCQCEUASIQiACSlhuIvf/nLuPbaa6OpqSmampri2muvjb179+Yuc/3110dNTc2w24UXXjhsnt7e3vjwhz8cra2tMXv27HjPe94Tzz///KRYh76+vvjrv/7reMMb3hCzZ8+O+fPnxx/+4R/G9u3bh8138cUXH7We11xzzQnX+7nPfS46Oztj5syZsXz58vj+97+fO//jjz8ey5cvj5kzZ8brXve6+Od//uej5nnggQfi3HPPjcbGxjj33HPjoYceOuE684xlHR588MH4rd/6rTjttNNi7ty5sWLFiviv//qvYfPcc889R73XNTU18fLLL5de/2OPPTZibevXrx8232TeBiPtszU1NfH617++Mk81t8H3vve9ePe73x3z58+Pmpqa+PrXv37cZSbTfjDW+ifjPjDWdajqfpCV6PLLL8+WLl2arV69Olu9enW2dOnS7Morr8xd5rrrrssuv/zy7MUXX6zcdu/ePWyeG2+8MVuwYEH28MMPZ2vXrs0uueSS7I1vfGPW399f+jrs3bs3u/TSS7P7778/W79+fbZmzZrsggsuyJYvXz5svosuuii74YYbhq3n3r17T6jWr371q1lDQ0P2hS98IXv22Wezm266KZs9e3a2ZcuWEef/6U9/mr3mNa/JbrrppuzZZ5/NvvCFL2QNDQ3Zv//7v1fmWb16dVZXV5d94hOfyH7yk59kn/jEJ7L6+vrsBz/4wQnVOlHrcNNNN2Wf+tSnsieeeCLbsGFDduutt2YNDQ3Z2rVrK/Pcfffd2dy5c4e91y+++OKkqP/RRx/NIiJ77rnnhtX2yr/lyb4N9u7dO6z2bdu2ZS0tLdnHPvaxyjzV3Abf+ta3so9+9KPZAw88kEVE9tBDD+XOP9n2g7HWP9n2gfGsQzX3g9JC8dlnn80iYljBa9asySIiW79+/TGXu+6667Lf+Z3fOebje/fuzRoaGrKvfvWrlWkvvPBCVltbm33729+ekNqPGO86vNoTTzyRRcSwD5WLLroou+mmmyay3Ow3fuM3shtvvHHYtK6uruyWW24Zcf6/+qu/yrq6uoZN++AHP5hdeOGFlftXX311dvnllw+b513veld2zTXXTFDVw411HUZy7rnnZrfffnvl/t133501NTVNVIm5xlr/kQ+DX/7yl8d8zqm2DR566KGspqYm+9nPflaZVs1t8Eqj+UCejPvBEaOpfyRl7gOvNpZQrMZ+UFrz6Zo1a6KpqSkuuOCCyrQLL7wwmpqaYvXq1bnLPvbYY9HW1hZLliyJG264IXbu3Fl57Omnn46+vr647LLLKtPmz58fS5cuPe7zVnMdXmnfvn1RU1MTzc3Nw6Z/5StfidbW1nj9618ff/mXfxn79+8fd62HDx+Op59+etj7EhFx2WWXHbPWNWvWHDX/u971rnjqqaeir68vd56Jfq8jxrcOrzY4OBj79+8/qqf9AwcOREdHRyxcuDCuvPLKWLdu3YTVfcSJ1H/eeefFGWecEe985zvj0UcfHfbYVNsGd911V1x66aXR0dExbHo1tsF4TLb94ESVuQ+cqGrsB6WF4o4dO6Ktre2o6W1tbbFjx45jLnfFFVfEV77ylXjkkUfi05/+dDz55JPxjne8I3p7eyvPO2PGjHjta187bLnTTz8993mruQ6v9PLLL8ctt9wSf/AHfzCs9/r3ve99cd9998Vjjz0Wf/M3fxMPPPBA/N7v/d64a921a1cMDAzE6aefPmx63vuyY8eOEefv7++PXbt25c4z0e91xPjW4dU+/elPx8GDB+Pqq6+uTOvq6op77rknvvGNb8R9990XM2fOjLe+9a2xcePG0us/44wz4s4774wHHnggHnzwwTjnnHPine98Z3zve9+rzDOVtsGLL74Y//mf/xl/8id/Mmx6tbbBeEy2/eBElbkPjFc194MJHzrqtttui9tvvz13nieffDIiImpqao56LMuyEacf8d73vrfy/6VLl8b5558fHR0d8c1vfjM3NI73vK9U9Doc0dfXF9dcc00MDg7G5z73uWGP3XDDDZX/L126NM4+++w4//zzY+3atbFs2bLRrMaIXl3X8Wodaf5XTx/rc56o8b7efffdF7fddlv8x3/8x7AvMxdeeOGwk7Xe+ta3xrJly+Izn/lM/OM//uPEFZ6Mpf5zzjknzjnnnMr9FStWxLZt2+KOO+6It7/97eN6zokw3te75557orm5Oa666qph06u9DcZqMu4H4zFZ9oGxquZ+MOGhuHLlyuOeJXnWWWfFj370o/j5z39+1GO/+MUvjkr7PGeccUZ0dHRUvtHMmzcvDh8+HL/85S+H/VrcuXNnvOUtb5k069DX1xdXX311dHd3xyOPPHLcMc6WLVsWDQ0NsXHjxnGFYmtra9TV1R31rWnnzp3HrHXevHkjzl9fXx+nnnpq7jxj2YajNZ51OOL++++PD3zgA/G1r30tLr300tx5a2tr481vfvOEf0s+kfpf6cILL4wvf/nLlftTZRtkWRZf/OIX49prr40ZM2bkzlvUNhiPybYfjNdk2AcmUlH7wYQ3n7a2tkZXV1fubebMmbFixYrYt29fPPHEE5Vlf/jDH8a+fftGHV4REbt3745t27bFGWecERERy5cvj4aGhnj44Ycr87z44ovx4x//eNTPW/Q6HAnEjRs3xne/+93KjpXn//7v/6Kvr6+ynmM1Y8aMWL58+bD3JSLi4YcfPmatK1asOGr+73znO3H++edHQ0ND7jxj2YajNZ51iBj6dnz99dfHvffeG7/927993NfJsiyeeeaZcb/XxzLe+l9t3bp1w2qbCtsgYuiyhk2bNsUHPvCB475OUdtgPCbbfjAek2UfmEiF7QdjOi1ngl1++eXZr//6r2dr1qzJ1qxZk73hDW846nKGc845J3vwwQezLMuy/fv3Z3/xF3+RrV69Ouvu7s4effTRbMWKFdmCBQuynp6eyjI33nhjtnDhwuy73/1utnbt2uwd73hHoZdkjGUd+vr6sve85z3ZwoULs2eeeWbY6cW9vb1ZlmXZpk2bsttvvz178skns+7u7uyb3/xm1tXVlZ133nkntA5HTqW/6667smeffTb7yEc+ks2ePbtyFuAtt9ySXXvttZX5j5yK/ud//ufZs88+m911111HnYr+P//zP1ldXV32yU9+MvvJT36SffKTn6zK5QCjXYd77703q6+vzz772c8e8/KW2267Lfv2t7+dbd68OVu3bl32R3/0R1l9fX32wx/+sPT6/+Ef/iF76KGHsg0bNmQ//vGPs1tuuSWLiOyBBx6ozDPZt8ER73//+7MLLrhgxOes5jbYv39/tm7dumzdunVZRGR///d/n61bt65y9vdk3w/GWv9k2wfGsw7V3A9KDcXdu3dn73vf+7I5c+Zkc+bMyd73vvcddcptRGR33313lmVZ9tJLL2WXXXZZdtppp2UNDQ3ZmWeemV133XXZ1q1bhy1z6NChbOXKlVlLS0s2a9as7MorrzxqnrLWobu7O4uIEW+PPvpolmVZtnXr1uztb3971tLSks2YMSNbtGhR9md/9mdHXY85Hp/97Gezjo6ObMaMGdmyZcuyxx9/vPLYddddl1100UXD5n/sscey8847L5sxY0Z21llnZZ///OePes6vfe1r2TnnnJM1NDRkXV1dw/5QizCWdbjoootGfK+vu+66yjwf+chHsjPPPDObMWNGdtppp2WXXXZZtnr16klR/6c+9als0aJF2cyZM7PXvva12dve9rbsm9/85lHPOZm3QZYNXSo1a9as7M477xzx+aq5DY6c3n+sv4nJvh+Mtf7JuA+MdR2quR8YTxEAEn2fAkAiFAEgEYoAkAhFAEiEIgAkQhEAEqEIAIlQBIBEKAJAIhQBIBGKAJD8f4bi/bRVQeziAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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UTKee64UjC9/uVEyTpdQBJhmGhsjVqwo3YynOLkqdkzxF7/4Rbzzne+Mrq6umD17dixZsiQ+8IEPxHG9004rCxcujI6Ojli4cGHRpQCjmDUrYu5cgThZKranuHHjxhgaGop//dd/jaVLl8bPfvazuPHGG+PIkSPx0Y9+tFIvyySbN29e0SUAVE3FQvHqq6+Oq6++unz/wgsvjCeffDI+9alPCUVgShqtx5jnd5F2su7Sijz5hslV1U158ODBaG1tPenjfX190dfXV77f29tbjbIAIuLXZ5mezOc+N/r0d71r8muhGFW7TnHLli3x8Y9/PG666aaTzrN27dpobm4u3zo6OqpVHidx9OjReO655+Lo0aNFlwJQcTVZlmXjWeCOO+6IO++8M3eeRx99NC655JLy/Z07d8bll18el19+efzbv/3bSZcbbU+xo6MjDh486NhWQTZu3FgeOqq7u7vocqCiTtZ8OryHuGbN6J1raz6tvN7e3mhubq54Hox7U958881x7bXX5s5zwQUXlP/euXNnXHnllbF69eq46667cpdramqKpqam8ZYEMClOFW7Do1Uwc41787a1tUVbW9uY5n3mmWfiyiuvjFWrVsXdd98dtbV6lQNg6qrYb56dO3fGFVdcEeeff3589KMfjV/+8pflxxYsWFCplwWACatYKH7rW9+KzZs3x+bNm2PxCzrgG+dhTACoioq1Z15//fWRZdmoNwCYihwyBshRX+86xDOJM18AIBGKAJAIRQBIHFMk10UXXVR0CQBVIxTJVVdXV3QJAFWj+RQAEqEIAInmU3Lt3bs3BgcHo66ubsx93gJMV0KRXHv37i0PHSUUgZlO8ykAJEIRABKhCACJUASARCgCQCIUASARigCQCEUASFy8T67Zs2eXL94HmOl805Grs7Oz6BIAqkbzKQAkQhEAEqEIAIljiuTaunVr+UQbxxeBmU4okuvo0aPOPgXOGJpPASARigCQCEUASIQiACRCEQASoQgAiVAEgGRKX3yWZVlERPT29hZcyZnr8OHD5esUbQegKMPfP8O5UClTOhT37dsXEREdHR0FVwLAVLBv375obm6u2PNP6VBsbW2NiIht27ZV9E2opN7e3ujo6Ijt27fHvHnzii5n3KZ7/RHTfx3UX7zpvg7Tvf6IiIMHD8b5559fzoVKmdKhWFtbOuTZ3Nw8bTfksHnz5k3rdZju9UdM/3VQf/Gm+zpM9/ojfp0LFXv+ij47AEwjQhEAkikdik1NTfGBD3wgmpqaii5lwqb7Okz3+iOm/zqov3jTfR2me/0R1VuHmqzS57cCwDQxpfcUAaCahCIAJEIRABKhCACJUASApNBQ/NWvfhVr1qyJ5ubmaG5ujjVr1sSBAwdyl7n++uujpqZmxO2yyy4bMU9fX1+8973vjba2tpgzZ068+c1vjh07dkyJdejv74+/+Zu/iZe+9KUxZ86cWLhwYfzxH/9x7Ny5c8R8V1xxxQnree211552vZ/85Cejq6srZs2aFatWrYrvf//7ufN/97vfjVWrVsWsWbPiwgsvjH/5l385YZ777rsvXvziF0dTU1O8+MUvjgceeOC068wznnW4//7743d+53fi3HPPjXnz5sXq1avjv//7v0fMc88995zwXtfU1MSxY8cKr//hhx8etbaNGzeOmG8qb4PRPrM1NTXxkpe8pDxPNbfB9773vXjTm94UCxcujJqamvjqV796ymWm0udgvPVPxc/AeNehqp+DrEBXX311tmLFimzdunXZunXrshUrVmRvfOMbc5e57rrrsquvvjp79tlny7d9+/aNmOemm27KFi1alD344IPZ+vXrsyuvvDJ72ctelg0MDBS+DgcOHMhe//rXZ1/+8pezjRs3Zo888kh26aWXZqtWrRox3+WXX57deOONI9bzwIEDp1Xrl770payhoSH79Kc/nT3xxBPZLbfcks2ZMyfbunXrqPM//fTT2VlnnZXdcsst2RNPPJF9+tOfzhoaGrL/+I//KM+zbt26rK6uLvvQhz6U/fznP88+9KEPZfX19dkPfvCD06p1stbhlltuyT7ykY9kP/rRj7JNmzZlt99+e9bQ0JCtX7++PM/dd9+dzZs3b8R7/eyzz06J+h966KEsIrInn3xyRG3P/7881bfBgQMHRtS+ffv2rLW1NfvABz5Qnqea2+Ab3/hG9v73vz+77777sojIHnjggdz5p9rnYLz1T7XPwETWoZqfg8JC8YknnsgiYkTBjzzySBYR2caNG0+63HXXXZf93u/93kkfP3DgQNbQ0JB96UtfKk975plnstra2uyb3/zmpNQ+bKLr8EI/+tGPsogY8aVy+eWXZ7fccstklpv91m/9VnbTTTeNmNbd3Z3ddttto87/13/911l3d/eIae9+97uzyy67rHz/rW99a3b11VePmOcNb3hDdu21105S1SONdx1G8+IXvzi78847y/fvvvvurLm5ebJKzDXe+oe/DH71q1+d9Dmn2zZ44IEHspqamuwXv/hFeVo1t8HzjeULeSp+DoaNpf7RFPkZeKHxhGI1PgeFNZ8+8sgj0dzcHJdeeml52mWXXRbNzc2xbt263GUffvjhaG9vj2XLlsWNN94Ye/bsKT/22GOPRX9/f1x11VXlaQsXLowVK1ac8nmruQ7Pd/DgwaipqYmWlpYR0z//+c9HW1tbvOQlL4m/+qu/ikOHDk241uPHj8djjz024n2JiLjqqqtOWusjjzxywvxveMMb4sc//nH09/fnzjPZ73XExNbhhYaGhuLQoUMn9LR/+PDh6OzsjMWLF8cb3/jG2LBhw6TVPex06r/44ovjvPPOi9e97nXx0EMPjXhsum2Dz3zmM/H6178+Ojs7R0yvxjaYiKn2OThdRX4GTlc1PgeFheKuXbuivb39hOnt7e2xa9euky53zTXXxOc///n4zne+Ex/72Mfi0Ucfjde+9rXR19dXft7GxsZ40YteNGK5+fPn5z5vNdfh+Y4dOxa33XZb/NEf/dGI3uvf/va3xxe/+MV4+OGH42//9m/jvvvuiz/4gz+YcK179+6NwcHBmD9//ojpee/Lrl27Rp1/YGAg9u7dmzvPZL/XERNbhxf62Mc+FkeOHIm3vvWt5Wnd3d1xzz33xNe+9rX44he/GLNmzYpXvepV8dRTTxVe/3nnnRd33XVX3HfffXH//ffH8uXL43Wve11873vfK88znbbBs88+G//1X/8Vf/qnfzpierW2wURMtc/B6SryMzBR1fwcTPrQUXfccUfceeedufM8+uijERFRU1NzwmNZlo06fdjb3va28t8rVqyISy65JDo7O+PrX/96bmic6nmfr9LrMKy/vz+uvfbaGBoaik9+8pMjHrvxxhvLf69YsSIuuuiiuOSSS2L9+vWxcuXKsazGqF5Y16lqHW3+F04f73Oerom+3he/+MW444474j//8z9H/Ji57LLLRpys9apXvSpWrlwZH//4x+Of/umfJq/wZDz1L1++PJYvX16+v3r16ti+fXt89KMfjde85jUTes7JMNHXu+eee6KlpSXe8pa3jJhe7W0wXlPxczARU+UzMF7V/BxMeijefPPNpzxL8oILLoif/vSnsXv37hMe++Uvf3lC2uc577zzorOzs/yLZsGCBXH8+PH41a9+NWJvcc+ePfHKV75yyqxDf39/vPWtb42enp74zne+c8oxzlauXBkNDQ3x1FNPTSgU29raoq6u7oRfTXv27DlprQsWLBh1/vr6+jjnnHNy5xnPNhyriazDsC9/+cvxzne+M77yla/E61//+tx5a2tr4xWveMWk/0o+nfqf77LLLot77723fH+6bIMsy+Kzn/1srFmzJhobG3PnrdQ2mIip9jmYqKnwGZhMlfocTHrzaVtbW3R3d+feZs2aFatXr46DBw/Gj370o/KyP/zhD+PgwYNjDq+IiH379sX27dvjvPPOi4iIVatWRUNDQzz44IPleZ599tn42c9+NubnrfQ6DAfiU089Fd/+9rfLH6w8//d//xf9/f3l9RyvxsbGWLVq1Yj3JSLiwQcfPGmtq1evPmH+b33rW3HJJZdEQ0ND7jzj2YZjNZF1iCj9Or7++uvjC1/4Qvzu7/7uKV8ny7J4/PHHJ/xen8xE63+hDRs2jKhtOmyDiNJlDZs3b453vvOdp3ydSm2DiZhqn4OJmCqfgclUsc/BuE7LmWRXX3119pu/+ZvZI488kj3yyCPZS1/60hMuZ1i+fHl2//33Z1mWZYcOHcr+8i//Mlu3bl3W09OTPfTQQ9nq1auzRYsWZb29veVlbrrppmzx4sXZt7/97Wz9+vXZa1/72opekjGedejv78/e/OY3Z4sXL84ef/zxEacX9/X1ZVmWZZs3b87uvPPO7NFHH816enqyr3/961l3d3d28cUXn9Y6DJ9K/5nPfCZ74oknsve9733ZnDlzymcB3nbbbdmaNWvK8w+fiv4Xf/EX2RNPPJF95jOfOeFU9P/93//N6urqsg9/+MPZz3/+8+zDH/5wVS4HGOs6fOELX8jq6+uzT3ziEye9vOWOO+7IvvnNb2ZbtmzJNmzYkP3Jn/xJVl9fn/3whz8svP5//Md/zB544IFs06ZN2c9+9rPstttuyyIiu++++8rzTPVtMOwd73hHdumll476nNXcBocOHco2bNiQbdiwIYuI7B/+4R+yDRs2lM/+nuqfg/HWP9U+AxNZh2p+DgoNxX379mVvf/vbs7lz52Zz587N3v72t59wym1EZHfffXeWZVn23HPPZVdddVV27rnnZg0NDdn555+fXXfdddm2bdtGLHP06NHs5ptvzlpbW7PZs2dnb3zjG0+Yp6h16OnpySJi1NtDDz2UZVmWbdu2LXvNa16Ttba2Zo2NjdmSJUuyP//zPz/hesyJ+MQnPpF1dnZmjY2N2cqVK7Pvfve75ceuu+667PLLLx8x/8MPP5xdfPHFWWNjY3bBBRdkn/rUp054zq985SvZ8uXLs4aGhqy7u3vEf9RKGM86XH755aO+19ddd115nve9733Z+eefnzU2NmbnnntudtVVV2Xr1q2bEvV/5CMfyZYsWZLNmjUre9GLXpS9+tWvzr7+9a+f8JxTeRtkWelSqdmzZ2d33XXXqM9XzW0wfHr/yf5PTPXPwXjrn4qfgfGuQzU/B8ZTBIBE36cAkAhFAEiEIgAkQhEAEqEIAIlQBIBEKAJAIhQBIBGKAJAIRQBIhCIAJP8PI3H6nLA6JXkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 500x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1,1,figsize=(5,8))\n",
    "ax = axes\n",
    "ax.scatter(*X1_N_.cpu()[y1_N_.cpu().squeeze()==1].T, marker='o', s=100, alpha=0.4, c='r')\n",
    "ax.scatter(*X2_N_.cpu()[y2_N_.cpu().squeeze()==1].T, marker='+', s=100, alpha=0.4, c='r')\n",
    "plt.axhline(0, 0, 1, color='lightgray', linestyle='--', linewidth=2)\n",
    "plt.axvline(0, 0, 1, color='lightgray', linestyle='--', linewidth=2)\n",
    "plt.xlim([-0.5, 1.5])\n",
    "plt.ylim([-2.3, 2.3])\n",
    "fig.savefig(os.path.join(path, f\"{max_iter}iter_data1.pdf\"))\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(1,1,figsize=(5,8))\n",
    "ax = axes\n",
    "ax.scatter(*X1_N.cpu()[y1_N.cpu().squeeze()==1].T, marker='o', s=100, alpha=0.4, c='b')\n",
    "ax.scatter(*X2_N.cpu()[y2_N.cpu().squeeze()==1].T, marker='+', s=100, alpha=0.4, c='b')\n",
    "plt.axhline(0, 0, 1, color='lightgray', linestyle='--', linewidth=2)\n",
    "plt.axvline(0, 0, 1, color='lightgray', linestyle='--', linewidth=2)\n",
    "plt.xlim([-0.5, 1.5])\n",
    "plt.ylim([-2.3, 2.3])\n",
    "fig.savefig(os.path.join(path, f\"{max_iter}iter_data2.pdf\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "CL",
   "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
