{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f611aeec",
   "metadata": {},
   "source": [
    "# LAVA Data Value\n",
    "## For Mislabeled Data Detection (CIFAR-10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "dcf3bcff",
   "metadata": {},
   "outputs": [],
   "source": [
    "import lava"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4e34f958",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torchvision\n",
    "# print(torch.__version__)\n",
    "# print(torchvision.__version__)\n",
    "# print(torch.version.cuda)\n",
    "# print(torch.cuda.is_available())\n",
    "\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "import torchvision.models as models\n",
    "from torch.autograd import Variable\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from torch import tensor\n",
    "from torchvision import datasets, transforms\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from copy import deepcopy as dpcp\n",
    "\n",
    "from torch.utils.data import Dataset, TensorDataset, DataLoader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4b3bded",
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "! nvidia-smi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a54003f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "cuda_num = 0\n",
    "import torchvision\n",
    "print(torchvision.__version__)\n",
    "import torch\n",
    "print(torch.__version__)\n",
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=str(cuda_num)\n",
    "print(os.environ[\"CUDA_VISIBLE_DEVICES\"])\n",
    "torch.cuda.set_device(cuda_num)\n",
    "print(\"Cuda device: \", torch.cuda.current_device())\n",
    "print(\"cude devices: \", torch.cuda.device_count())\n",
    "device = torch.device('cuda:' + str(cuda_num) if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "defdeae8",
   "metadata": {},
   "source": [
    "### Set Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "23633651",
   "metadata": {},
   "outputs": [],
   "source": [
    "training_size = 40000\n",
    "valid_size = 10000\n",
    "resize = 32\n",
    "portion = 0.25"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7e0b7fb1",
   "metadata": {},
   "source": [
    "### Loading Corrupted Data into DataLoaders\n",
    "### Train and Test Loaders with Indices of Corrupted Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f7319d3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "loaders, shuffle_ind = lava.load_data_corrupted(corrupt_type='shuffle', dataname='CIFAR10', resize=resize,\n",
    "                                        training_size=training_size, test_size=valid_size, currupt_por=portion)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f59b1c38",
   "metadata": {},
   "source": [
    "### Load Feature Extractor for a Given Dataset\n",
    "### Checkpoints provided and training files provided"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "58be73c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "feature_extractor = lava.load_pretrained_feature_extractor('cifar10_embedder_preact_resnet18.pth', device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d345bcac",
   "metadata": {},
   "source": [
    "### Compute Dual Solution of Optimal Transport Problem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5abb7145",
   "metadata": {},
   "outputs": [],
   "source": [
    "dual_sol, trained_with_flag = lava.compute_dual(feature_extractor, loaders['train'], loaders['test'], \n",
    "                                                training_size, shuffle_ind, resize=resize)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3598f5b7",
   "metadata": {},
   "source": [
    "### Compute the Data Values from Calibrated Gradient\n",
    "### Visualize Detection Rate Based on LAVA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b8f745db",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inspected: 10, found: 10 detection rate: 0.00 baseline: 1.8\n",
      "inspected: 20, found: 20 detection rate: 0.00 baseline: 3.6\n",
      "inspected: 30, found: 30 detection rate: 0.00 baseline: 5.4\n",
      "inspected: 40, found: 40 detection rate: 0.00 baseline: 7.2\n",
      "inspected: 50, found: 50 detection rate: 0.01 baseline: 9.0\n",
      "inspected: 60, found: 60 detection rate: 0.01 baseline: 10.8\n",
      "inspected: 70, found: 70 detection rate: 0.01 baseline: 12.6\n",
      "inspected: 80, found: 80 detection rate: 0.01 baseline: 14.4\n",
      "inspected: 90, found: 90 detection rate: 0.01 baseline: 16.2\n",
      "inspected: 100, found: 100 detection rate: 0.01 baseline: 18.0\n",
      "inspected: 110, found: 110 detection rate: 0.01 baseline: 19.8\n",
      "inspected: 120, found: 120 detection rate: 0.01 baseline: 21.6\n",
      "inspected: 130, found: 130 detection rate: 0.01 baseline: 23.400000000000002\n",
      "inspected: 140, found: 140 detection rate: 0.01 baseline: 25.2\n",
      "inspected: 150, found: 150 detection rate: 0.01 baseline: 27.0\n",
      "inspected: 160, found: 160 detection rate: 0.02 baseline: 28.8\n",
      "inspected: 170, found: 170 detection rate: 0.02 baseline: 30.6\n",
      "inspected: 180, found: 180 detection rate: 0.02 baseline: 32.4\n",
      "inspected: 190, found: 190 detection rate: 0.02 baseline: 34.2\n",
      "inspected: 200, found: 200 detection rate: 0.02 baseline: 36.0\n",
      "inspected: 210, found: 210 detection rate: 0.02 baseline: 37.800000000000004\n",
      "inspected: 220, found: 220 detection rate: 0.02 baseline: 39.6\n",
      "inspected: 230, found: 230 detection rate: 0.02 baseline: 41.4\n",
      "inspected: 240, found: 240 detection rate: 0.02 baseline: 43.2\n",
      "inspected: 250, found: 250 detection rate: 0.03 baseline: 45.0\n",
      "inspected: 260, found: 260 detection rate: 0.03 baseline: 46.800000000000004\n",
      "inspected: 270, found: 270 detection rate: 0.03 baseline: 48.6\n",
      "inspected: 280, found: 280 detection rate: 0.03 baseline: 50.4\n",
      "inspected: 290, found: 290 detection rate: 0.03 baseline: 52.2\n",
      "inspected: 300, found: 300 detection rate: 0.03 baseline: 54.0\n",
      "inspected: 310, found: 310 detection rate: 0.03 baseline: 55.800000000000004\n",
      "inspected: 320, found: 320 detection rate: 0.03 baseline: 57.6\n",
      "inspected: 330, found: 330 detection rate: 0.03 baseline: 59.4\n",
      "inspected: 340, found: 340 detection rate: 0.03 baseline: 61.2\n",
      "inspected: 350, found: 350 detection rate: 0.04 baseline: 63.0\n",
      "inspected: 360, found: 360 detection rate: 0.04 baseline: 64.8\n",
      "inspected: 370, found: 370 detection rate: 0.04 baseline: 66.60000000000001\n",
      "inspected: 380, found: 380 detection rate: 0.04 baseline: 68.4\n",
      "inspected: 390, found: 390 detection rate: 0.04 baseline: 70.2\n",
      "inspected: 400, found: 400 detection rate: 0.04 baseline: 72.0\n",
      "inspected: 410, found: 410 detection rate: 0.04 baseline: 73.8\n",
      "inspected: 420, found: 420 detection rate: 0.04 baseline: 75.60000000000001\n",
      "inspected: 430, found: 430 detection rate: 0.04 baseline: 77.4\n",
      "inspected: 440, found: 440 detection rate: 0.04 baseline: 79.2\n",
      "inspected: 450, found: 450 detection rate: 0.04 baseline: 81.0\n",
      "inspected: 460, found: 460 detection rate: 0.05 baseline: 82.8\n",
      "inspected: 470, found: 470 detection rate: 0.05 baseline: 84.60000000000001\n",
      "inspected: 480, found: 480 detection rate: 0.05 baseline: 86.4\n",
      "inspected: 490, found: 490 detection rate: 0.05 baseline: 88.2\n",
      "inspected: 500, found: 500 detection rate: 0.05 baseline: 90.0\n",
      "inspected: 510, found: 510 detection rate: 0.05 baseline: 91.8\n",
      "inspected: 520, found: 520 detection rate: 0.05 baseline: 93.60000000000001\n",
      "inspected: 530, found: 530 detection rate: 0.05 baseline: 95.4\n",
      "inspected: 540, found: 540 detection rate: 0.05 baseline: 97.2\n",
      "inspected: 550, found: 550 detection rate: 0.06 baseline: 99.0\n",
      "inspected: 560, found: 560 detection rate: 0.06 baseline: 100.8\n",
      "inspected: 570, found: 570 detection rate: 0.06 baseline: 102.60000000000001\n",
      "inspected: 580, found: 580 detection rate: 0.06 baseline: 104.4\n",
      "inspected: 590, found: 590 detection rate: 0.06 baseline: 106.2\n",
      "inspected: 600, found: 600 detection rate: 0.06 baseline: 108.0\n",
      "inspected: 610, found: 610 detection rate: 0.06 baseline: 109.8\n",
      "inspected: 620, found: 620 detection rate: 0.06 baseline: 111.60000000000001\n",
      "inspected: 630, found: 630 detection rate: 0.06 baseline: 113.4\n",
      "inspected: 640, found: 640 detection rate: 0.06 baseline: 115.2\n",
      "inspected: 650, found: 650 detection rate: 0.07 baseline: 117.0\n",
      "inspected: 660, found: 660 detection rate: 0.07 baseline: 118.8\n",
      "inspected: 670, found: 670 detection rate: 0.07 baseline: 120.60000000000001\n",
      "inspected: 680, found: 680 detection rate: 0.07 baseline: 122.4\n",
      "inspected: 690, found: 690 detection rate: 0.07 baseline: 124.2\n",
      "inspected: 700, found: 700 detection rate: 0.07 baseline: 126.0\n",
      "inspected: 710, found: 710 detection rate: 0.07 baseline: 127.8\n",
      "inspected: 720, found: 720 detection rate: 0.07 baseline: 129.6\n",
      "inspected: 730, found: 730 detection rate: 0.07 baseline: 131.4\n",
      "inspected: 740, found: 740 detection rate: 0.07 baseline: 133.20000000000002\n",
      "inspected: 750, found: 750 detection rate: 0.07 baseline: 135.0\n",
      "inspected: 760, found: 760 detection rate: 0.08 baseline: 136.8\n",
      "inspected: 770, found: 770 detection rate: 0.08 baseline: 138.6\n",
      "inspected: 780, found: 780 detection rate: 0.08 baseline: 140.4\n",
      "inspected: 790, found: 790 detection rate: 0.08 baseline: 142.20000000000002\n",
      "inspected: 800, found: 800 detection rate: 0.08 baseline: 144.0\n",
      "inspected: 810, found: 810 detection rate: 0.08 baseline: 145.8\n",
      "inspected: 820, found: 820 detection rate: 0.08 baseline: 147.6\n",
      "inspected: 830, found: 830 detection rate: 0.08 baseline: 149.4\n",
      "inspected: 840, found: 840 detection rate: 0.08 baseline: 151.20000000000002\n",
      "inspected: 850, found: 850 detection rate: 0.09 baseline: 153.0\n",
      "inspected: 860, found: 860 detection rate: 0.09 baseline: 154.8\n",
      "inspected: 870, found: 870 detection rate: 0.09 baseline: 156.6\n",
      "inspected: 880, found: 880 detection rate: 0.09 baseline: 158.4\n",
      "inspected: 890, found: 890 detection rate: 0.09 baseline: 160.20000000000002\n",
      "inspected: 900, found: 900 detection rate: 0.09 baseline: 162.0\n",
      "inspected: 910, found: 910 detection rate: 0.09 baseline: 163.8\n",
      "inspected: 920, found: 920 detection rate: 0.09 baseline: 165.6\n",
      "inspected: 930, found: 930 detection rate: 0.09 baseline: 167.4\n",
      "inspected: 940, found: 940 detection rate: 0.09 baseline: 169.20000000000002\n",
      "inspected: 950, found: 950 detection rate: 0.10 baseline: 171.0\n",
      "inspected: 960, found: 960 detection rate: 0.10 baseline: 172.8\n",
      "inspected: 970, found: 970 detection rate: 0.10 baseline: 174.6\n",
      "inspected: 980, found: 980 detection rate: 0.10 baseline: 176.4\n",
      "inspected: 990, found: 990 detection rate: 0.10 baseline: 178.20000000000002\n",
      "inspected: 1000, found: 1000 detection rate: 0.10 baseline: 180.0\n",
      "inspected: 1010, found: 1010 detection rate: 0.10 baseline: 181.8\n",
      "inspected: 1020, found: 1020 detection rate: 0.10 baseline: 183.6\n",
      "inspected: 1030, found: 1030 detection rate: 0.10 baseline: 185.4\n",
      "inspected: 1040, found: 1040 detection rate: 0.10 baseline: 187.20000000000002\n",
      "inspected: 1050, found: 1050 detection rate: 0.10 baseline: 189.0\n",
      "inspected: 1060, found: 1060 detection rate: 0.11 baseline: 190.8\n",
      "inspected: 1070, found: 1070 detection rate: 0.11 baseline: 192.6\n",
      "inspected: 1080, found: 1080 detection rate: 0.11 baseline: 194.4\n",
      "inspected: 1090, found: 1090 detection rate: 0.11 baseline: 196.20000000000002\n",
      "inspected: 1100, found: 1100 detection rate: 0.11 baseline: 198.0\n",
      "inspected: 1110, found: 1110 detection rate: 0.11 baseline: 199.8\n",
      "inspected: 1120, found: 1120 detection rate: 0.11 baseline: 201.6\n",
      "inspected: 1130, found: 1130 detection rate: 0.11 baseline: 203.4\n",
      "inspected: 1140, found: 1140 detection rate: 0.11 baseline: 205.20000000000002\n",
      "inspected: 1150, found: 1150 detection rate: 0.12 baseline: 207.0\n",
      "inspected: 1160, found: 1160 detection rate: 0.12 baseline: 208.8\n",
      "inspected: 1170, found: 1170 detection rate: 0.12 baseline: 210.6\n",
      "inspected: 1180, found: 1180 detection rate: 0.12 baseline: 212.4\n",
      "inspected: 1190, found: 1190 detection rate: 0.12 baseline: 214.20000000000002\n",
      "inspected: 1200, found: 1200 detection rate: 0.12 baseline: 216.0\n",
      "inspected: 1210, found: 1210 detection rate: 0.12 baseline: 217.8\n",
      "inspected: 1220, found: 1220 detection rate: 0.12 baseline: 219.6\n",
      "inspected: 1230, found: 1230 detection rate: 0.12 baseline: 221.4\n",
      "inspected: 1240, found: 1240 detection rate: 0.12 baseline: 223.20000000000002\n",
      "inspected: 1250, found: 1250 detection rate: 0.12 baseline: 225.0\n",
      "inspected: 1260, found: 1260 detection rate: 0.13 baseline: 226.8\n",
      "inspected: 1270, found: 1270 detection rate: 0.13 baseline: 228.6\n",
      "inspected: 1280, found: 1280 detection rate: 0.13 baseline: 230.4\n",
      "inspected: 1290, found: 1290 detection rate: 0.13 baseline: 232.20000000000002\n",
      "inspected: 1300, found: 1300 detection rate: 0.13 baseline: 234.0\n",
      "inspected: 1310, found: 1310 detection rate: 0.13 baseline: 235.8\n",
      "inspected: 1320, found: 1320 detection rate: 0.13 baseline: 237.6\n",
      "inspected: 1330, found: 1330 detection rate: 0.13 baseline: 239.4\n",
      "inspected: 1340, found: 1340 detection rate: 0.13 baseline: 241.20000000000002\n",
      "inspected: 1350, found: 1350 detection rate: 0.14 baseline: 243.0\n",
      "inspected: 1360, found: 1360 detection rate: 0.14 baseline: 244.8\n",
      "inspected: 1370, found: 1370 detection rate: 0.14 baseline: 246.6\n",
      "inspected: 1380, found: 1380 detection rate: 0.14 baseline: 248.4\n",
      "inspected: 1390, found: 1390 detection rate: 0.14 baseline: 250.20000000000002\n",
      "inspected: 1400, found: 1400 detection rate: 0.14 baseline: 252.0\n",
      "inspected: 1410, found: 1410 detection rate: 0.14 baseline: 253.8\n",
      "inspected: 1420, found: 1420 detection rate: 0.14 baseline: 255.6\n",
      "inspected: 1430, found: 1430 detection rate: 0.14 baseline: 257.40000000000003\n",
      "inspected: 1440, found: 1440 detection rate: 0.14 baseline: 259.2\n",
      "inspected: 1450, found: 1450 detection rate: 0.14 baseline: 261.0\n",
      "inspected: 1460, found: 1460 detection rate: 0.15 baseline: 262.8\n",
      "inspected: 1470, found: 1470 detection rate: 0.15 baseline: 264.6\n",
      "inspected: 1480, found: 1480 detection rate: 0.15 baseline: 266.40000000000003\n",
      "inspected: 1490, found: 1490 detection rate: 0.15 baseline: 268.2\n",
      "inspected: 1500, found: 1500 detection rate: 0.15 baseline: 270.0\n",
      "inspected: 1510, found: 1510 detection rate: 0.15 baseline: 271.8\n",
      "inspected: 1520, found: 1520 detection rate: 0.15 baseline: 273.6\n",
      "inspected: 1530, found: 1530 detection rate: 0.15 baseline: 275.40000000000003\n",
      "inspected: 1540, found: 1540 detection rate: 0.15 baseline: 277.2\n",
      "inspected: 1550, found: 1550 detection rate: 0.15 baseline: 279.0\n",
      "inspected: 1560, found: 1560 detection rate: 0.16 baseline: 280.8\n",
      "inspected: 1570, found: 1570 detection rate: 0.16 baseline: 282.6\n",
      "inspected: 1580, found: 1580 detection rate: 0.16 baseline: 284.40000000000003\n",
      "inspected: 1590, found: 1590 detection rate: 0.16 baseline: 286.2\n",
      "inspected: 1600, found: 1600 detection rate: 0.16 baseline: 288.0\n",
      "inspected: 1610, found: 1610 detection rate: 0.16 baseline: 289.8\n",
      "inspected: 1620, found: 1620 detection rate: 0.16 baseline: 291.6\n",
      "inspected: 1630, found: 1630 detection rate: 0.16 baseline: 293.40000000000003\n",
      "inspected: 1640, found: 1640 detection rate: 0.16 baseline: 295.2\n",
      "inspected: 1650, found: 1650 detection rate: 0.17 baseline: 297.0\n",
      "inspected: 1660, found: 1660 detection rate: 0.17 baseline: 298.8\n",
      "inspected: 1670, found: 1670 detection rate: 0.17 baseline: 300.6\n",
      "inspected: 1680, found: 1680 detection rate: 0.17 baseline: 302.40000000000003\n",
      "inspected: 1690, found: 1690 detection rate: 0.17 baseline: 304.2\n",
      "inspected: 1700, found: 1700 detection rate: 0.17 baseline: 306.0\n",
      "inspected: 1710, found: 1710 detection rate: 0.17 baseline: 307.8\n",
      "inspected: 1720, found: 1720 detection rate: 0.17 baseline: 309.6\n",
      "inspected: 1730, found: 1730 detection rate: 0.17 baseline: 311.40000000000003\n",
      "inspected: 1740, found: 1740 detection rate: 0.17 baseline: 313.2\n",
      "inspected: 1750, found: 1750 detection rate: 0.17 baseline: 315.0\n",
      "inspected: 1760, found: 1760 detection rate: 0.18 baseline: 316.8\n",
      "inspected: 1770, found: 1770 detection rate: 0.18 baseline: 318.6\n",
      "inspected: 1780, found: 1780 detection rate: 0.18 baseline: 320.40000000000003\n",
      "inspected: 1790, found: 1790 detection rate: 0.18 baseline: 322.2\n",
      "inspected: 1800, found: 1800 detection rate: 0.18 baseline: 324.0\n",
      "inspected: 1810, found: 1810 detection rate: 0.18 baseline: 325.8\n",
      "inspected: 1820, found: 1820 detection rate: 0.18 baseline: 327.6\n",
      "inspected: 1830, found: 1830 detection rate: 0.18 baseline: 329.40000000000003\n",
      "inspected: 1840, found: 1840 detection rate: 0.18 baseline: 331.2\n",
      "inspected: 1850, found: 1850 detection rate: 0.18 baseline: 333.0\n",
      "inspected: 1860, found: 1860 detection rate: 0.19 baseline: 334.8\n",
      "inspected: 1870, found: 1870 detection rate: 0.19 baseline: 336.6\n",
      "inspected: 1880, found: 1880 detection rate: 0.19 baseline: 338.40000000000003\n",
      "inspected: 1890, found: 1890 detection rate: 0.19 baseline: 340.2\n",
      "inspected: 1900, found: 1900 detection rate: 0.19 baseline: 342.0\n",
      "inspected: 1910, found: 1910 detection rate: 0.19 baseline: 343.8\n",
      "inspected: 1920, found: 1920 detection rate: 0.19 baseline: 345.6\n",
      "inspected: 1930, found: 1930 detection rate: 0.19 baseline: 347.40000000000003\n",
      "inspected: 1940, found: 1940 detection rate: 0.19 baseline: 349.2\n",
      "inspected: 1950, found: 1950 detection rate: 0.20 baseline: 351.0\n",
      "inspected: 1960, found: 1960 detection rate: 0.20 baseline: 352.8\n",
      "inspected: 1970, found: 1970 detection rate: 0.20 baseline: 354.6\n",
      "inspected: 1980, found: 1980 detection rate: 0.20 baseline: 356.40000000000003\n",
      "inspected: 1990, found: 1990 detection rate: 0.20 baseline: 358.2\n",
      "inspected: 2000, found: 2000 detection rate: 0.20 baseline: 360.0\n",
      "inspected: 2010, found: 2010 detection rate: 0.20 baseline: 361.8\n",
      "inspected: 2020, found: 2020 detection rate: 0.20 baseline: 363.6\n",
      "inspected: 2030, found: 2030 detection rate: 0.20 baseline: 365.40000000000003\n",
      "inspected: 2040, found: 2040 detection rate: 0.20 baseline: 367.2\n",
      "inspected: 2050, found: 2050 detection rate: 0.20 baseline: 369.0\n",
      "inspected: 2060, found: 2060 detection rate: 0.21 baseline: 370.8\n",
      "inspected: 2070, found: 2070 detection rate: 0.21 baseline: 372.6\n",
      "inspected: 2080, found: 2080 detection rate: 0.21 baseline: 374.40000000000003\n",
      "inspected: 2090, found: 2090 detection rate: 0.21 baseline: 376.2\n",
      "inspected: 2100, found: 2100 detection rate: 0.21 baseline: 378.0\n",
      "inspected: 2110, found: 2110 detection rate: 0.21 baseline: 379.8\n",
      "inspected: 2120, found: 2120 detection rate: 0.21 baseline: 381.6\n",
      "inspected: 2130, found: 2130 detection rate: 0.21 baseline: 383.40000000000003\n",
      "inspected: 2140, found: 2140 detection rate: 0.21 baseline: 385.2\n",
      "inspected: 2150, found: 2150 detection rate: 0.21 baseline: 387.0\n",
      "inspected: 2160, found: 2160 detection rate: 0.22 baseline: 388.8\n",
      "inspected: 2170, found: 2170 detection rate: 0.22 baseline: 390.6\n",
      "inspected: 2180, found: 2180 detection rate: 0.22 baseline: 392.40000000000003\n",
      "inspected: 2190, found: 2190 detection rate: 0.22 baseline: 394.2\n",
      "inspected: 2200, found: 2200 detection rate: 0.22 baseline: 396.0\n",
      "inspected: 2210, found: 2210 detection rate: 0.22 baseline: 397.8\n",
      "inspected: 2220, found: 2220 detection rate: 0.22 baseline: 399.6\n",
      "inspected: 2230, found: 2230 detection rate: 0.22 baseline: 401.40000000000003\n",
      "inspected: 2240, found: 2240 detection rate: 0.22 baseline: 403.2\n",
      "inspected: 2250, found: 2250 detection rate: 0.23 baseline: 405.0\n",
      "inspected: 2260, found: 2260 detection rate: 0.23 baseline: 406.8\n",
      "inspected: 2270, found: 2270 detection rate: 0.23 baseline: 408.6\n",
      "inspected: 2280, found: 2280 detection rate: 0.23 baseline: 410.40000000000003\n",
      "inspected: 2290, found: 2290 detection rate: 0.23 baseline: 412.2\n",
      "inspected: 2300, found: 2300 detection rate: 0.23 baseline: 414.0\n",
      "inspected: 2310, found: 2310 detection rate: 0.23 baseline: 415.8\n",
      "inspected: 2320, found: 2320 detection rate: 0.23 baseline: 417.6\n",
      "inspected: 2330, found: 2330 detection rate: 0.23 baseline: 419.40000000000003\n",
      "inspected: 2340, found: 2340 detection rate: 0.23 baseline: 421.2\n",
      "inspected: 2350, found: 2350 detection rate: 0.23 baseline: 423.0\n",
      "inspected: 2360, found: 2360 detection rate: 0.24 baseline: 424.8\n",
      "inspected: 2370, found: 2370 detection rate: 0.24 baseline: 426.6\n",
      "inspected: 2380, found: 2380 detection rate: 0.24 baseline: 428.40000000000003\n",
      "inspected: 2390, found: 2390 detection rate: 0.24 baseline: 430.2\n",
      "inspected: 2400, found: 2400 detection rate: 0.24 baseline: 432.0\n",
      "inspected: 2410, found: 2410 detection rate: 0.24 baseline: 433.8\n",
      "inspected: 2420, found: 2420 detection rate: 0.24 baseline: 435.6\n",
      "inspected: 2430, found: 2430 detection rate: 0.24 baseline: 437.40000000000003\n",
      "inspected: 2440, found: 2440 detection rate: 0.24 baseline: 439.2\n",
      "inspected: 2450, found: 2450 detection rate: 0.24 baseline: 441.0\n",
      "inspected: 2460, found: 2460 detection rate: 0.25 baseline: 442.8\n",
      "inspected: 2470, found: 2470 detection rate: 0.25 baseline: 444.6\n",
      "inspected: 2480, found: 2480 detection rate: 0.25 baseline: 446.40000000000003\n",
      "inspected: 2490, found: 2490 detection rate: 0.25 baseline: 448.2\n",
      "inspected: 2500, found: 2500 detection rate: 0.25 baseline: 450.0\n",
      "inspected: 2510, found: 2510 detection rate: 0.25 baseline: 451.8\n",
      "inspected: 2520, found: 2520 detection rate: 0.25 baseline: 453.6\n",
      "inspected: 2530, found: 2530 detection rate: 0.25 baseline: 455.40000000000003\n",
      "inspected: 2540, found: 2540 detection rate: 0.25 baseline: 457.2\n",
      "inspected: 2550, found: 2550 detection rate: 0.26 baseline: 459.0\n",
      "inspected: 2560, found: 2560 detection rate: 0.26 baseline: 460.8\n",
      "inspected: 2570, found: 2570 detection rate: 0.26 baseline: 462.6\n",
      "inspected: 2580, found: 2580 detection rate: 0.26 baseline: 464.40000000000003\n",
      "inspected: 2590, found: 2590 detection rate: 0.26 baseline: 466.2\n",
      "inspected: 2600, found: 2600 detection rate: 0.26 baseline: 468.0\n",
      "inspected: 2610, found: 2610 detection rate: 0.26 baseline: 469.8\n",
      "inspected: 2620, found: 2620 detection rate: 0.26 baseline: 471.6\n",
      "inspected: 2630, found: 2630 detection rate: 0.26 baseline: 473.40000000000003\n",
      "inspected: 2640, found: 2640 detection rate: 0.26 baseline: 475.2\n",
      "inspected: 2650, found: 2650 detection rate: 0.27 baseline: 477.0\n",
      "inspected: 2660, found: 2660 detection rate: 0.27 baseline: 478.8\n",
      "inspected: 2670, found: 2670 detection rate: 0.27 baseline: 480.6\n",
      "inspected: 2680, found: 2680 detection rate: 0.27 baseline: 482.40000000000003\n",
      "inspected: 2690, found: 2690 detection rate: 0.27 baseline: 484.2\n",
      "inspected: 2700, found: 2700 detection rate: 0.27 baseline: 486.0\n",
      "inspected: 2710, found: 2710 detection rate: 0.27 baseline: 487.8\n",
      "inspected: 2720, found: 2720 detection rate: 0.27 baseline: 489.6\n",
      "inspected: 2730, found: 2730 detection rate: 0.27 baseline: 491.40000000000003\n",
      "inspected: 2740, found: 2740 detection rate: 0.27 baseline: 493.2\n",
      "inspected: 2750, found: 2750 detection rate: 0.28 baseline: 495.0\n",
      "inspected: 2760, found: 2760 detection rate: 0.28 baseline: 496.8\n",
      "inspected: 2770, found: 2770 detection rate: 0.28 baseline: 498.6\n",
      "inspected: 2780, found: 2780 detection rate: 0.28 baseline: 500.40000000000003\n",
      "inspected: 2790, found: 2790 detection rate: 0.28 baseline: 502.2\n",
      "inspected: 2800, found: 2800 detection rate: 0.28 baseline: 504.0\n",
      "inspected: 2810, found: 2810 detection rate: 0.28 baseline: 505.8\n",
      "inspected: 2820, found: 2820 detection rate: 0.28 baseline: 507.6\n",
      "inspected: 2830, found: 2830 detection rate: 0.28 baseline: 509.40000000000003\n",
      "inspected: 2840, found: 2840 detection rate: 0.28 baseline: 511.2\n",
      "inspected: 2850, found: 2850 detection rate: 0.28 baseline: 513.0\n",
      "inspected: 2860, found: 2860 detection rate: 0.29 baseline: 514.8000000000001\n",
      "inspected: 2870, found: 2870 detection rate: 0.29 baseline: 516.6\n",
      "inspected: 2880, found: 2880 detection rate: 0.29 baseline: 518.4\n",
      "inspected: 2890, found: 2890 detection rate: 0.29 baseline: 520.2\n",
      "inspected: 2900, found: 2900 detection rate: 0.29 baseline: 522.0\n",
      "inspected: 2910, found: 2910 detection rate: 0.29 baseline: 523.8000000000001\n",
      "inspected: 2920, found: 2920 detection rate: 0.29 baseline: 525.6\n",
      "inspected: 2930, found: 2930 detection rate: 0.29 baseline: 527.4\n",
      "inspected: 2940, found: 2940 detection rate: 0.29 baseline: 529.2\n",
      "inspected: 2950, found: 2950 detection rate: 0.29 baseline: 531.0\n",
      "inspected: 2960, found: 2960 detection rate: 0.30 baseline: 532.8000000000001\n",
      "inspected: 2970, found: 2970 detection rate: 0.30 baseline: 534.6\n",
      "inspected: 2980, found: 2980 detection rate: 0.30 baseline: 536.4\n",
      "inspected: 2990, found: 2990 detection rate: 0.30 baseline: 538.2\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of poisoned images:  10000  out of 10000.\n",
      "last index of poison 35275\n"
     ]
    },
    {
     "data": {
      "image/png": "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RCxI+7iQbDrijcAP87kleHW6jJ6wtbvYzIKrj6w2z7Jlyzj33HOZPHkybdq0oUOHDlx33XVsu+22HHXUUcyaNatWy5RrzJgxtGrVivPPP79gxzAzq4m6aAGdA7yS8/wa4NcR8WWyyZjOSOlnAO+m9F+nfEjai2yiqR5kE3L9VjWf/7zoIoJjjz2WwYMHM3/+fKZOncpVV13FP2bO45Wl7xW7eGZmda6gAShNjXwk8Lv0XMAhZFM1A9wBHJOWh6fnpPWHpvzDgXsiYkNEvEk2Y2OhpgUumIkTJ9KiRQu+973vbUrbe++96TvgK5vl27hxIxdccAH9+vWjd+/e3HLLLQCsXbuWQw89lL59+9KrVy/+/OfsTvQLFixgzz33ZOTIkfTo0YMhQ4awbt26KssyePBgzjvvPEpKSthzzz2ZPHkyxx13HN26dePiiy/elO+YY45h3333pUePHowdO3ZT+m233cbuu+9O//79GTlyJGeffTYAK1as4Otf/zr9+vWjX79+vPDCCwA8++yz9OnThz59+rDPPvuwZs2arahJM2ssCt0Fdx3ZFNut0/OdgFURUZqeLwY6puWOZNNgExGlklan/B3ZfHre3G02SbP7jQLYdddda/UkasOsWbPYd999q8132223seOOOzJ58mQ2bNjAoEGDGDJkCJ07d+ahhx7is5/9LG+//TYDBw7k6KOPBmDu3Lncfffd3HrrrZxwwgk88MADnHLKKVUeZ9ttt2XKlClcf/31DB8+nKlTp9KuXTu+9KUvcd5557HTTjtx++23065dO9atW0e/fv34+te/zoYNG7j88suZNm0arVu35pBDDmHvvfcG4JxzzuG8885j//3359///jdDhw7llVde4dprr+XGG29k0KBBrF27lpYtW259hZpZg1ewACTpKOCtiJgqaXChjlMmIsaSzWNOSUlJg5jkaMbiVZ9Ke/zxx5kxYwb33581ElevXs3cuXPp1KkTF110Ec899xzNmjVjyZIlLF++HICuXbvSp08fAPbdd18WLFhQ7bHLglevXr3o0aMHu+yyCwBf/OIXWbRoETvttBM33HADDz30EACLFi1i7ty5LFu2jIMOOoh27doBcPzxx/P6668D8OSTTzJnzpxNx3jvvfdYu3YtgwYN4kc/+hEnn3wyxx13HJ06dap5ZZlZo1PIFtAg4GhJRwAtgc8C1wNtJG2TWkGdgCUp/xKgM7BY0jbAjmSDEcrSy+Ru02D06NFjU1CpSkTwm9/8hqFDh26WPm7cOFasWMHUqVNp0aIFXbp02fS7l+22225TvubNm1fbBZe7TbNmzTbbvlmzZpSWlvLMM8/w5JNP8s9//pMddtiBwYMHV/s7m48//phJkyZ9qoUzevRojjzySB599FEGDRrEY489Rvfu3asto5k1bgW7BhQRF0ZEp4joQjaI4OmIOBmYCHwjZRvBJ9Pqjk/PSeufjmy61vHASZK2SyPougEvFarchXLIIYewYcOGza6lvP7KLKa9+I/N8g0dOpSbbrqJjz76KMvz+uu8//77rF69ms997nO0aNGCiRMnsnBhYe+avnr1atq2bcsOO+zAq6++yqRJWS9ov379ePbZZ3n33XcpLS3lgQce2LTNkCFD+M1vfrPp+fTp0wGYP38+vXr14qc//Sn9+vXj1VdfLWjZzaxhKMateH4K3CPpCuBfwG0p/TbgD5LmAe+QBS0iYrak+4A5QClwVkRs3NpC5DNsujZJ4qGHHuLcc8/lmmuuoWXLluz0+Y5cMOaqzfKdeeaZLFiwgL59+xIRtG/fnocffpiTTz6Zr33ta/Tq1YuSkpKCtyCGDRvGzTffzJ577skee+zBwIEDAejYsSMXXXQR/fv3p127dnTv3p0dd9wRgBtuuIGzzjqL3r17U1payoEHHsjNN9/Mddddx8SJE2nWrBk9evTg8MMPL2jZzaxhUNbIaFxKSkqi/IR0r7zyCnvuuWeRSlSx3GtAvTu1KVo5amrt2rW0atWK0tJSjj32WL7zne9w7LHHFrtY9fI1NmtIJE2NiJK6Op7vhGA1NmbMGPr06UPPnj3p2rUrxxxzTLGLZGYNUJO5G7bVnmuvvbbYRTCzRsAtIDMzKwoHIDMzKwoHIDMzKwoHIDMzK4qmOwhh4lXV56mJgy+sNkvz5s3p1asXpaWl7Lnnnpz/8+vZfvsdKsw7fvx45syZw+jRo2u3nNV45plnuPbaa3nkkUfySjcz21JuAdWh7bffnunTp3PX357ng1L40x9+X2neo48+us6Dj5lZXXIAKpJ9+u/HogVvsPrddzn3jJPp3bs3AwcOZMaMGUB277eyaQ7+9Kc/0bNnT/bee28OPPBAANavX8/pp59Or1692GeffZg4ceKm7Y477jiGDRtGt27d+MlPfrLpmI8//jj77bcfffv25fjjj2ft2rUA/O1vf6N79+707duXBx98sNqyjxkzhhEjRnDAAQew22678eCDD/KTn/yEXr16MWzYsE23Ebrsssvo168fPXv2ZNSoUZT96Hny5Mn07t2bPn36cMEFF9CzZ0+g8qkoli5dyoEHHrjpt0d///vft7r+zaz4HICKoLS0lBcmPkm37nvx219dRfeevZkxYwY///nPOfXUUz+V/7LLLuOxxx7j5ZdfZvz48QDceOONSGLmzJncfffdjBgxYtPNQqdPn869997LzJkzuffee1m0aBFvv/02V1xxBU8++STTpk2jpKSEX/3qV6xfv56RI0fyl7/8halTp7Js2bK8zmH+/Pk8/fTTjB8/nlNOOYWDDz6YmTNnsv322zNhQjbb7Nlnn83kyZOZNWsW69at29R9d/rpp3PLLbcwffp0mjf/ZG7B3KkoJk+ezK233sqbb77JXXfdxdChQ5k+fTovv/zypjt/m1nD5gBUh9atW0efPn341pEH8/mOnTj2pG/zr8mTOOq4E4HshqUrV67kvfc2nyF10KBBnHbaadx6661s3JjdBu/555/fNOdP9+7d2W233TZNi3DooYey44470rJlS/baay8WLlzIpEmTmDNnDoMGDaJPnz7ccccdLFy4kFdffZWuXbvSrVs3JFU7j1CZww8/nBYtWtCrVy82btzIsGHDgGx6h7LpICZOnMiAAQPo1asXTz/9NLNnz2bVqlWsWbOG/fbbD4Bvfetbm/b5+OOPc+edd9KnTx8GDBjAypUrmTt3Lv369eP3v/89Y8aMYebMmbRu3fpT5TGzhqfpDkIogrJrQBXNA1SVm2++mRdffJEJEyaw7777MnXq1Crzl5+eobS0lIjgsMMO4+67794sb9kdq2sqdzqHFi1akE1e+8l0DuvXr+cHP/gBU6ZMoXPnzowZM6ba6Rwqm4oC4LnnnmPChAmcdtpp/OhHP6qwpWhmDYtbQEXWt/9+THjoT0A20mznnXfms5/97GZ55s+fz4ABA7jsssto3749ixYt4oADDuCPf/wjkE3Z8O9//5s99tij0uMMHDiQF154gXnz5gHw/vvv8/rrr9O9e3cWLFjA/PnzAT4VoLZUWbDZeeedWbt27aa5kNq0aUPr1q158cUXAbjnnns2bVPZVBQLFy6kQ4cOjBw5kjPP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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "%matplotlib inline\n",
    "calibrated_gradient = lava.compute_values_and_visualize(dual_sol, trained_with_flag, training_size, portion)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a72963e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1760.8445,\n",
       " 1711.2532,\n",
       " 1695.4175,\n",
       " 1610.2479,\n",
       " 1607.1549,\n",
       " 1595.6134,\n",
       " 1565.5303,\n",
       " 1541.2612,\n",
       " 1536.2543,\n",
       " 1532.9617,\n",
       " 1531.9221,\n",
       " 1531.4606,\n",
       " 1531.1067,\n",
       " 1520.5334,\n",
       " 1519.1776,\n",
       " 1514.936,\n",
       " 1510.6559,\n",
       " 1508.984,\n",
       " 1508.4443,\n",
       " 1508.3225,\n",
       " 1507.6145,\n",
       " 1507.4087,\n",
       " 1506.1387,\n",
       " 1506.0825,\n",
       " 1505.9579,\n",
       " 1505.8258,\n",
       " 1505.611,\n",
       " 1505.4696,\n",
       " 1503.0316,\n",
       " 1502.037,\n",
       " 1501.7511,\n",
       " 1499.8995,\n",
       " 1499.0443,\n",
       " 1498.6959,\n",
       " 1495.9205,\n",
       " 1494.7053,\n",
       " 1494.0863,\n",
       " 1493.4296,\n",
       " 1492.1981,\n",
       " 1492.1196,\n",
       " 1491.4706,\n",
       " 1491.26,\n",
       " 1490.7554,\n",
       " 1490.0614,\n",
       " 1489.7915,\n",
       " 1489.5223,\n",
       " 1487.3123,\n",
       " 1485.79,\n",
       " 1485.4828,\n",
       " 1485.435,\n",
       " 1485.0864,\n",
       " 1485.0663,\n",
       " 1481.5033,\n",
       " 1479.6412,\n",
       " 1478.488,\n",
       " 1478.3394,\n",
       " 1475.9414,\n",
       " 1475.2765,\n",
       " 1474.0159,\n",
       " 1473.5983,\n",
       " 1472.7838,\n",
       " 1471.9462,\n",
       " 1471.6104,\n",
       " 1469.1716,\n",
       " 1468.8197,\n",
       " 1468.5944,\n",
       " 1467.2744,\n",
       " 1465.4305,\n",
       " 1465.1786,\n",
       " 1463.7997,\n",
       " 1463.4319,\n",
       " 1462.9943,\n",
       " 1462.304,\n",
       " 1461.2032,\n",
       " 1460.7394,\n",
       " 1458.55,\n",
       " 1457.2844,\n",
       " 1454.6569,\n",
       " 1454.6523,\n",
       " 1446.8884,\n",
       " 1445.7305,\n",
       " 1437.895,\n",
       " 1431.1599,\n",
       " 1426.7028,\n",
       " 1424.7797,\n",
       " 1423.372,\n",
       " 1412.589,\n",
       " 1412.2356,\n",
       " 1403.454,\n",
       " 1393.3331,\n",
       " 1392.4473,\n",
       " 1391.7267,\n",
       " 1391.3994,\n",
       " 1390.347,\n",
       " 1389.1355,\n",
       " 1386.8306,\n",
       " 1384.1904,\n",
       " 1382.9755,\n",
       " 1382.9563,\n",
       " 1382.5654,\n",
       " 1380.9205,\n",
       " 1379.645,\n",
       " 1377.9182,\n",
       " 1373.563,\n",
       " 1373.199,\n",
       " 1371.0166,\n",
       " 1370.4149,\n",
       " 1370.053,\n",
       " 1369.46,\n",
       " 1368.0793,\n",
       " 1366.911,\n",
       " 1362.5085,\n",
       " 1362.4745,\n",
       " 1359.8406,\n",
       " 1359.2764,\n",
       " 1357.7911,\n",
       " 1356.5426,\n",
       " 1354.5773,\n",
       " 1354.0416,\n",
       " 1351.7192,\n",
       " 1350.4374,\n",
       " 1348.8481,\n",
       " 1348.2903,\n",
       " 1346.9808,\n",
       " 1346.2333,\n",
       " 1344.5209,\n",
       " 1343.1742,\n",
       " 1342.5999,\n",
       " 1340.3268,\n",
       " 1334.9166,\n",
       " 1333.1522,\n",
       " 1332.0591,\n",
       " 1330.4183,\n",
       " 1329.6738,\n",
       " 1327.8627,\n",
       " 1327.2992,\n",
       " 1325.494,\n",
       " 1324.9698,\n",
       " 1324.3147,\n",
       " 1321.3362,\n",
       " 1321.2097,\n",
       " 1321.0135,\n",
       " 1320.6741,\n",
       " 1320.5852,\n",
       " 1320.2642,\n",
       " 1318.9143,\n",
       " 1318.8641,\n",
       " 1317.4844,\n",
       " 1317.2318,\n",
       " 1315.7521,\n",
       " 1315.2609,\n",
       " 1314.5427,\n",
       " 1314.0515,\n",
       " 1314.0349,\n",
       " 1313.773,\n",
       " 1310.8496,\n",
       " 1310.6881,\n",
       " 1309.6802,\n",
       " 1308.7212,\n",
       " 1307.2816,\n",
       " 1306.9364,\n",
       " 1305.6376,\n",
       " 1304.868,\n",
       " 1303.6934,\n",
       " 1303.0616,\n",
       " 1302.4651,\n",
       " 1301.6028,\n",
       " 1299.3964,\n",
       " 1298.0012,\n",
       " 1297.788,\n",
       " 1296.2802,\n",
       " 1294.1606,\n",
       " 1293.4746,\n",
       " 1292.2644,\n",
       " 1290.442,\n",
       " 1290.2888,\n",
       " 1289.8126,\n",
       " 1289.5447,\n",
       " 1287.5594,\n",
       " 1284.4233,\n",
       " 1284.1753,\n",
       " 1284.1562,\n",
       " 1281.7194,\n",
       " 1281.5446,\n",
       " 1275.4917,\n",
       " 1275.3859,\n",
       " 1273.8507,\n",
       " 1273.7413,\n",
       " 1267.2094,\n",
       " 1266.8099,\n",
       " 1266.056,\n",
       " 1263.9629,\n",
       " 1262.9569,\n",
       " 1260.656,\n",
       " 1257.6769,\n",
       " 1257.2169,\n",
       " 1255.8804,\n",
       " 1254.3992,\n",
       " 1252.8647,\n",
       " 1252.7285,\n",
       " 1250.0844,\n",
       " 1249.5171,\n",
       " 1249.163,\n",
       " 1248.8297,\n",
       " 1248.431,\n",
       " 1247.3322,\n",
       " 1245.7653,\n",
       " 1245.6204,\n",
       " 1245.546,\n",
       " 1244.9963,\n",
       " 1244.7428,\n",
       " 1244.4866,\n",
       " 1244.2894,\n",
       " 1244.0281,\n",
       " 1243.362,\n",
       " 1243.1753,\n",
       " 1239.4248,\n",
       " 1239.2749,\n",
       " 1238.2393,\n",
       " 1236.2916,\n",
       " 1235.7091,\n",
       " 1234.3413,\n",
       " 1233.1034,\n",
       " 1232.7295,\n",
       " 1232.3137,\n",
       " 1231.2617,\n",
       " 1231.0308,\n",
       " 1230.128,\n",
       " 1229.9601,\n",
       " 1229.3811,\n",
       " 1228.9193,\n",
       " 1228.0619,\n",
       " 1227.8839,\n",
       " 1227.393,\n",
       " 1227.2826,\n",
       " 1226.2241,\n",
       " 1225.208,\n",
       " 1225.0114,\n",
       " 1224.5386,\n",
       " 1224.4227,\n",
       " 1224.1658,\n",
       " 1223.8551,\n",
       " 1222.6702,\n",
       " 1222.5378,\n",
       " 1221.1571,\n",
       " 1221.0476,\n",
       " 1220.9639,\n",
       " 1220.1698,\n",
       " 1220.1649,\n",
       " 1220.0221,\n",
       " 1219.5326,\n",
       " 1219.4877,\n",
       " 1219.1534,\n",
       " 1218.1182,\n",
       " 1217.9996,\n",
       " 1217.9365,\n",
       " 1217.4171,\n",
       " 1217.4147,\n",
       " 1216.5724,\n",
       " 1215.9502,\n",
       " 1215.5973,\n",
       " 1215.4695,\n",
       " 1215.3931,\n",
       " 1215.3828,\n",
       " 1214.8171,\n",
       " 1213.5503,\n",
       " 1213.4128,\n",
       " 1211.7338,\n",
       " 1211.6875,\n",
       " 1211.3636,\n",
       " 1210.9916,\n",
       " 1210.9729,\n",
       " 1210.6774,\n",
       " 1209.1299,\n",
       " 1208.2428,\n",
       " 1207.4939,\n",
       " 1207.1715,\n",
       " 1206.9385,\n",
       " 1206.4725,\n",
       " 1206.4207,\n",
       " 1204.0454,\n",
       " 1203.211,\n",
       " 1203.1794,\n",
       " 1202.954,\n",
       " 1202.3176,\n",
       " 1201.5875,\n",
       " 1201.5593,\n",
       " 1201.2578,\n",
       " 1200.3234,\n",
       " 1199.9675,\n",
       " 1199.5065,\n",
       " 1199.1682,\n",
       " 1198.9291,\n",
       " 1198.8976,\n",
       " 1198.1394,\n",
       " 1196.082,\n",
       " 1195.3162,\n",
       " 1194.6034,\n",
       " 1194.4673,\n",
       " 1193.2823,\n",
       " 1192.6598,\n",
       " 1191.0797,\n",
       " 1191.0496,\n",
       " 1189.632,\n",
       " 1189.4198,\n",
       " 1188.9331,\n",
       " 1188.0421,\n",
       " 1187.7898,\n",
       " 1187.5322,\n",
       " 1187.2406,\n",
       " 1187.2223,\n",
       " 1187.2135,\n",
       " 1187.1873,\n",
       " 1187.1082,\n",
       " 1186.7723,\n",
       " 1186.5466,\n",
       " 1186.3635,\n",
       " 1186.3171,\n",
       " 1186.2595,\n",
       " 1185.9254,\n",
       " 1185.8512,\n",
       " 1183.6794,\n",
       " 1183.1829,\n",
       " 1181.6472,\n",
       " 1181.5914,\n",
       " 1180.9648,\n",
       " 1180.2053,\n",
       " 1179.7528,\n",
       " 1179.0941,\n",
       " 1178.8395,\n",
       " 1178.0676,\n",
       " 1177.5944,\n",
       " 1175.5884,\n",
       " 1175.3259,\n",
       " 1173.4279,\n",
       " 1168.5023,\n",
       " 1167.4427,\n",
       " 1165.7338,\n",
       " 1165.5447,\n",
       " 1163.1805,\n",
       " 1162.0865,\n",
       " 1161.8676,\n",
       " 1161.3528,\n",
       " 1161.1046,\n",
       " 1160.6703,\n",
       " 1159.4943,\n",
       " 1159.4323,\n",
       " 1158.4468,\n",
       " 1153.4207,\n",
       " 1150.1104,\n",
       " 1149.8402,\n",
       " 1149.5009,\n",
       " 1149.2783,\n",
       " 1148.9418,\n",
       " 1148.6943,\n",
       " 1148.182,\n",
       " 1146.3729,\n",
       " 1144.3756,\n",
       " 1140.4935,\n",
       " 1139.0465,\n",
       " 1138.8009,\n",
       " 1138.2628,\n",
       " 1136.0354,\n",
       " 1135.9558,\n",
       " 1134.1451,\n",
       " 1134.1396,\n",
       " 1132.496,\n",
       " 1131.2683,\n",
       " 1130.7346,\n",
       " 1130.6437,\n",
       " 1130.149,\n",
       " 1127.2755,\n",
       " 1126.4225,\n",
       " 1124.8824,\n",
       " 1121.86,\n",
       " 1120.6965,\n",
       " 1120.1074,\n",
       " 1119.0048,\n",
       " 1118.9749,\n",
       " 1118.5295,\n",
       " 1117.0337,\n",
       " 1116.4237,\n",
       " 1114.9468,\n",
       " 1114.1134,\n",
       " 1112.2299,\n",
       " 1110.0721,\n",
       " 1108.8278,\n",
       " 1107.1154,\n",
       " 1106.7559,\n",
       " 1106.2065,\n",
       " 1105.2804,\n",
       " 1105.1111,\n",
       " 1103.4781,\n",
       " 1102.869,\n",
       " 1102.4469,\n",
       " 1100.9274,\n",
       " 1099.3318,\n",
       " 1098.1367,\n",
       " 1097.327,\n",
       " 1096.637,\n",
       " 1096.3953,\n",
       " 1095.9491,\n",
       " 1095.3911,\n",
       " 1095.1559,\n",
       " 1094.6774,\n",
       " 1090.2834,\n",
       " 1088.7463,\n",
       " 1087.0671,\n",
       " 1086.8041,\n",
       " 1085.9836,\n",
       " 1085.1848,\n",
       " 1084.8868,\n",
       " 1084.6702,\n",
       " 1084.5493,\n",
       " 1084.2595,\n",
       " 1084.2452,\n",
       " 1080.6738,\n",
       " 1080.0387,\n",
       " 1079.2395,\n",
       " 1079.1113,\n",
       " 1077.9537,\n",
       " 1077.3486,\n",
       " 1077.1392,\n",
       " 1077.0541,\n",
       " 1076.8788,\n",
       " 1076.8414,\n",
       " 1076.7739,\n",
       " 1075.8099,\n",
       " 1075.6455,\n",
       " 1073.8196,\n",
       " 1073.6339,\n",
       " 1072.5565,\n",
       " 1072.5518,\n",
       " 1072.5385,\n",
       " 1070.9397,\n",
       " 1070.0448,\n",
       " 1069.9276,\n",
       " 1069.5828,\n",
       " 1069.5555,\n",
       " 1069.2161,\n",
       " 1069.2092,\n",
       " 1069.1697,\n",
       " 1067.8499,\n",
       " 1067.821,\n",
       " 1066.9563,\n",
       " 1066.2363,\n",
       " 1065.6688,\n",
       " 1065.4424,\n",
       " 1065.3417,\n",
       " 1065.0072,\n",
       " 1064.8577,\n",
       " 1064.8225,\n",
       " 1064.6082,\n",
       " 1064.4636,\n",
       " 1063.9198,\n",
       " 1063.883,\n",
       " 1063.8097,\n",
       " 1063.2804,\n",
       " 1062.8121,\n",
       " 1062.423,\n",
       " 1062.0514,\n",
       " 1062.042,\n",
       " 1061.4572,\n",
       " 1061.3342,\n",
       " 1060.6226,\n",
       " 1060.4476,\n",
       " 1059.92,\n",
       " 1059.124,\n",
       " 1058.9048,\n",
       " 1058.9001,\n",
       " 1058.7611,\n",
       " 1058.5083,\n",
       " 1058.2548,\n",
       " 1057.9067,\n",
       " 1057.3488,\n",
       " 1057.2627,\n",
       " 1057.1381,\n",
       " 1056.9414,\n",
       " 1056.6515,\n",
       " 1056.3081,\n",
       " 1055.6514,\n",
       " 1055.1058,\n",
       " 1054.9171,\n",
       " 1054.7823,\n",
       " 1054.6263,\n",
       " 1054.2853,\n",
       " 1053.8158,\n",
       " 1053.6254,\n",
       " 1053.3461,\n",
       " 1051.8624,\n",
       " 1049.9379,\n",
       " 1049.7954,\n",
       " 1049.5671,\n",
       " 1047.9376,\n",
       " 1047.8225,\n",
       " 1047.5457,\n",
       " 1047.1718,\n",
       " 1046.9548,\n",
       " 1045.9799,\n",
       " 1045.8822,\n",
       " 1045.7878,\n",
       " 1043.4834,\n",
       " 1042.9807,\n",
       " 1041.8234,\n",
       " 1040.9896,\n",
       " 1040.6592,\n",
       " 1040.1384,\n",
       " 1039.56,\n",
       " 1038.9752,\n",
       " 1038.3817,\n",
       " 1038.3807,\n",
       " 1037.7909,\n",
       " 1037.0796,\n",
       " 1037.0629,\n",
       " 1036.8134,\n",
       " 1036.4902,\n",
       " 1036.2313,\n",
       " 1036.068,\n",
       " 1036.0115,\n",
       " 1035.7158,\n",
       " 1034.6592,\n",
       " 1034.285,\n",
       " 1033.2847,\n",
       " 1032.756,\n",
       " 1031.9706,\n",
       " 1031.8102,\n",
       " 1031.2808,\n",
       " 1031.0052,\n",
       " 1030.036,\n",
       " 1030.0343,\n",
       " 1029.8961,\n",
       " 1029.8152,\n",
       " 1029.6628,\n",
       " 1029.5979,\n",
       " 1029.5923,\n",
       " 1028.3662,\n",
       " 1027.4962,\n",
       " 1027.4836,\n",
       " 1026.05,\n",
       " 1025.6686,\n",
       " 1025.4806,\n",
       " 1025.393,\n",
       " 1024.9943,\n",
       " 1024.2572,\n",
       " 1023.8718,\n",
       " 1023.4457,\n",
       " 1022.8729,\n",
       " 1022.1234,\n",
       " 1022.0388,\n",
       " 1021.631,\n",
       " 1021.28784,\n",
       " 1020.322,\n",
       " 1020.28076,\n",
       " 1019.57666,\n",
       " 1019.38904,\n",
       " 1019.14307,\n",
       " 1019.12634,\n",
       " 1019.05676,\n",
       " 1018.78076,\n",
       " 1018.66797,\n",
       " 1018.5864,\n",
       " 1017.19446,\n",
       " 1016.98926,\n",
       " 1016.75696,\n",
       " 1016.2377,\n",
       " 1016.1168,\n",
       " 1015.8572,\n",
       " 1015.2894,\n",
       " 1015.2217,\n",
       " 1014.781,\n",
       " 1014.56396,\n",
       " 1014.5521,\n",
       " 1014.0719,\n",
       " 1013.0646,\n",
       " 1012.74915,\n",
       " 1012.5725,\n",
       " 1011.93176,\n",
       " 1011.775,\n",
       " 1011.0593,\n",
       " 1011.05786,\n",
       " 1010.92456,\n",
       " 1010.44055,\n",
       " 1010.1428,\n",
       " 1009.8827,\n",
       " 1009.7506,\n",
       " 1009.70264,\n",
       " 1009.5886,\n",
       " 1008.46387,\n",
       " 1008.4346,\n",
       " 1007.6139,\n",
       " 1007.46106,\n",
       " 1007.20825,\n",
       " 1006.8148,\n",
       " 1005.6936,\n",
       " 1004.5465,\n",
       " 1004.49585,\n",
       " 1004.1398,\n",
       " 1004.0654,\n",
       " 1004.01855,\n",
       " 1003.7909,\n",
       " 1003.77136,\n",
       " 1003.6737,\n",
       " 1003.26306,\n",
       " 1002.921,\n",
       " 1002.91943,\n",
       " 1002.51,\n",
       " 1002.2738,\n",
       " 1002.1576,\n",
       " 1002.1167,\n",
       " 1001.4979,\n",
       " 1001.3617,\n",
       " 1001.1411,\n",
       " 1000.1603,\n",
       " 999.7383,\n",
       " 999.5785,\n",
       " 999.4536,\n",
       " 999.1847,\n",
       " 998.8313,\n",
       " 998.6,\n",
       " 998.34814,\n",
       " 998.1256,\n",
       " 997.97644,\n",
       " 997.7307,\n",
       " 997.3983,\n",
       " 997.18774,\n",
       " 997.0226,\n",
       " 996.02673,\n",
       " 995.5397,\n",
       " 995.2377,\n",
       " 994.96936,\n",
       " 994.95984,\n",
       " 994.875,\n",
       " 994.64404,\n",
       " 994.3135,\n",
       " 994.10876,\n",
       " 993.9048,\n",
       " 993.8534,\n",
       " 993.2894,\n",
       " 993.2822,\n",
       " 991.9829,\n",
       " 991.56323,\n",
       " 991.2986,\n",
       " 990.8733,\n",
       " 990.83496,\n",
       " 990.64136,\n",
       " 988.8063,\n",
       " 988.35925,\n",
       " 987.63513,\n",
       " 987.57166,\n",
       " 987.2317,\n",
       " 986.71277,\n",
       " 986.6493,\n",
       " 986.6279,\n",
       " 985.4407,\n",
       " 984.93555,\n",
       " 984.49023,\n",
       " 983.5404,\n",
       " 983.3036,\n",
       " 981.5337,\n",
       " 981.51025,\n",
       " 980.8513,\n",
       " 979.96875,\n",
       " 978.8074,\n",
       " 978.79114,\n",
       " 978.43616,\n",
       " 977.47546,\n",
       " 976.4656,\n",
       " 976.45154,\n",
       " 976.34326,\n",
       " 976.33923,\n",
       " 975.876,\n",
       " 975.6924,\n",
       " 975.3573,\n",
       " 975.2864,\n",
       " 974.45264,\n",
       " 973.2799,\n",
       " 972.9977,\n",
       " 971.96106,\n",
       " 971.2322,\n",
       " 971.21545,\n",
       " 969.308,\n",
       " 967.8679,\n",
       " 967.1393,\n",
       " 966.9116,\n",
       " 966.631,\n",
       " 966.3717,\n",
       " 965.99976,\n",
       " 965.7838,\n",
       " 963.6311,\n",
       " 963.5781,\n",
       " 962.23413,\n",
       " 962.2267,\n",
       " 961.8673,\n",
       " 961.76514,\n",
       " 961.43835,\n",
       " 961.35547,\n",
       " 959.63684,\n",
       " 959.547,\n",
       " 958.41394,\n",
       " 957.1017,\n",
       " 956.96204,\n",
       " 956.6697,\n",
       " 956.2462,\n",
       " 955.3904,\n",
       " 954.90283,\n",
       " 954.86816,\n",
       " 952.93945,\n",
       " 952.7289,\n",
       " 952.5193,\n",
       " 950.80994,\n",
       " 950.3148,\n",
       " 949.34204,\n",
       " 949.1394,\n",
       " 948.5134,\n",
       " 948.46814,\n",
       " 948.1178,\n",
       " 947.57495,\n",
       " 947.3009,\n",
       " 946.9452,\n",
       " 946.67346,\n",
       " 946.3948,\n",
       " 945.5294,\n",
       " 945.5082,\n",
       " 944.8301,\n",
       " 944.28394,\n",
       " 943.6261,\n",
       " 943.57043,\n",
       " 942.78516,\n",
       " 942.60986,\n",
       " 941.5718,\n",
       " 941.56885,\n",
       " 941.40515,\n",
       " 941.08606,\n",
       " 940.6366,\n",
       " 940.6289,\n",
       " 940.37366,\n",
       " 940.0928,\n",
       " 940.0913,\n",
       " 939.60034,\n",
       " 938.7152,\n",
       " 938.6221,\n",
       " 938.40234,\n",
       " 938.0869,\n",
       " 937.1035,\n",
       " 936.7361,\n",
       " 936.6636,\n",
       " 936.1321,\n",
       " 936.0027,\n",
       " 935.9772,\n",
       " 935.3539,\n",
       " 935.0918,\n",
       " 933.871,\n",
       " 933.40466,\n",
       " 930.84546,\n",
       " 929.1493,\n",
       " 929.1433,\n",
       " 928.7252,\n",
       " 927.4989,\n",
       " 927.30664,\n",
       " 926.1654,\n",
       " 925.89905,\n",
       " 925.4342,\n",
       " 924.7648,\n",
       " 924.39417,\n",
       " 923.9154,\n",
       " 923.51086,\n",
       " 922.97437,\n",
       " 922.72595,\n",
       " 922.3596,\n",
       " 921.90674,\n",
       " 921.8424,\n",
       " 921.2698,\n",
       " 920.9435,\n",
       " 920.8236,\n",
       " 920.4707,\n",
       " 920.306,\n",
       " 920.05334,\n",
       " 919.79553,\n",
       " 919.7489,\n",
       " 919.619,\n",
       " 918.91003,\n",
       " 918.1732,\n",
       " 917.94055,\n",
       " 917.90955,\n",
       " 917.8739,\n",
       " 917.24084,\n",
       " 917.15576,\n",
       " 916.93823,\n",
       " 916.84595,\n",
       " 916.4907,\n",
       " 916.3153,\n",
       " 916.0471,\n",
       " 915.72034,\n",
       " 915.49207,\n",
       " 915.1001,\n",
       " 914.931,\n",
       " 914.8104,\n",
       " 914.72864,\n",
       " 914.1614,\n",
       " 913.646,\n",
       " 913.13574,\n",
       " 913.11426,\n",
       " 912.80835,\n",
       " 912.6373,\n",
       " 912.60376,\n",
       " 912.5182,\n",
       " 911.974,\n",
       " 911.6387,\n",
       " 911.4949,\n",
       " 911.0718,\n",
       " 911.04297,\n",
       " 910.5126,\n",
       " 910.4879,\n",
       " 910.16846,\n",
       " 910.15466,\n",
       " 909.428,\n",
       " 909.3656,\n",
       " 908.80493,\n",
       " 907.8992,\n",
       " 907.6079,\n",
       " 907.60535,\n",
       " 907.36914,\n",
       " 907.0448,\n",
       " 906.97266,\n",
       " 906.8522,\n",
       " 906.8491,\n",
       " 905.9315,\n",
       " 905.7882,\n",
       " 905.7461,\n",
       " 905.1959,\n",
       " 905.1456,\n",
       " 904.88306,\n",
       " 903.5796,\n",
       " 902.95715,\n",
       " 902.9247,\n",
       " 902.8878,\n",
       " 901.9884,\n",
       " 901.8817,\n",
       " 901.87146,\n",
       " 901.79504,\n",
       " 901.41956,\n",
       " 901.19824,\n",
       " 901.1748,\n",
       " 900.9321,\n",
       " 900.81213,\n",
       " 899.9817,\n",
       " 898.6887,\n",
       " 898.6416,\n",
       " 898.303,\n",
       " 897.3905,\n",
       " 897.34265,\n",
       " 897.18225,\n",
       " 896.9918,\n",
       " 896.8174,\n",
       " 896.54297,\n",
       " 896.03284,\n",
       " 895.7251,\n",
       " 895.14453,\n",
       " 894.73083,\n",
       " 894.3583,\n",
       " 894.1654,\n",
       " 894.08777,\n",
       " 893.91724,\n",
       " 893.8054,\n",
       " 893.32214,\n",
       " 893.0753,\n",
       " 891.93335,\n",
       " 891.8031,\n",
       " 891.68933,\n",
       " 891.29346,\n",
       " 890.8948,\n",
       " 890.85767,\n",
       " 890.79675,\n",
       " 890.71106,\n",
       " 890.4015,\n",
       " 889.7517,\n",
       " 889.5714,\n",
       " 889.072,\n",
       " 888.8617,\n",
       " 888.8097,\n",
       " 888.30945,\n",
       " 887.4581,\n",
       " 887.35767,\n",
       " 887.32263,\n",
       " 887.1466,\n",
       " 886.68445,\n",
       " 886.6306,\n",
       " 886.08093,\n",
       " 885.87524,\n",
       " 885.765,\n",
       " 885.2023,\n",
       " 885.0519,\n",
       " 884.96985,\n",
       " 884.3662,\n",
       " 883.9321,\n",
       " 883.81116,\n",
       " 883.2936,\n",
       " 883.2543,\n",
       " 883.21985,\n",
       " 883.17175,\n",
       " 882.6792,\n",
       " 882.6538,\n",
       " 882.5952,\n",
       " 882.0171,\n",
       " 881.6958,\n",
       " 881.67456,\n",
       " 881.53296,\n",
       " 880.7295,\n",
       " 880.6902,\n",
       " 880.3246,\n",
       " 880.2035,\n",
       " 880.00183,\n",
       " 879.864,\n",
       " 879.7783,\n",
       " 879.5215,\n",
       " 879.4203,\n",
       " 879.40894,\n",
       " 879.31165,\n",
       " 879.20483,\n",
       " 878.8849,\n",
       " 878.74695,\n",
       " 878.61865,\n",
       " 878.49243,\n",
       " 878.32556,\n",
       " 878.3031,\n",
       " 877.67834,\n",
       " 877.5043,\n",
       " 876.83826,\n",
       " 876.7992,\n",
       " 876.76855,\n",
       " 876.6749,\n",
       " 876.4895,\n",
       " 876.47144,\n",
       " 876.43896,\n",
       " 876.4343,\n",
       " 876.3158,\n",
       " 876.2479,\n",
       " 876.1553,\n",
       " 875.83484,\n",
       " 875.8257,\n",
       " 875.64026,\n",
       " 875.5182,\n",
       " 875.48315,\n",
       " 875.4739,\n",
       " 875.4617,\n",
       " 875.0831,\n",
       " 875.0514,\n",
       " 874.9457,\n",
       " 874.7612,\n",
       " 874.7411,\n",
       " 874.66675,\n",
       " 874.5541,\n",
       " 874.22266,\n",
       " 874.1554,\n",
       " 874.0425,\n",
       " 873.7815,\n",
       " 873.69055,\n",
       " 873.5974,\n",
       " 873.5901,\n",
       " 873.5559,\n",
       " 873.36707,\n",
       " 873.12036,\n",
       " 872.754,\n",
       " 872.63794,\n",
       " 872.55066,\n",
       " 872.3186,\n",
       " 872.0915,\n",
       " 871.6607,\n",
       " 871.64825,\n",
       " 871.48584,\n",
       " 871.416,\n",
       " 871.1844,\n",
       " 871.10065,\n",
       " 871.08014,\n",
       " 870.65063,\n",
       " 870.53253,\n",
       " 870.5034,\n",
       " 870.46466,\n",
       " 870.31213,\n",
       " 870.2474,\n",
       " 870.1603,\n",
       " 870.0125,\n",
       " 869.89136,\n",
       " 869.73236,\n",
       " 869.7134,\n",
       " 869.6139,\n",
       " 869.5688,\n",
       " 869.47064,\n",
       " 869.40186,\n",
       " 869.2794,\n",
       " 868.90405,\n",
       " 868.879,\n",
       " 868.855,\n",
       " 868.8136,\n",
       " 868.73987,\n",
       " 868.41345,\n",
       " 868.3409,\n",
       " 868.25604,\n",
       " 868.1737,\n",
       " 868.09576,\n",
       " ...]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "calibrated_gradient"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecd27488",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "otdd",
   "language": "python",
   "name": "otdd"
  },
  "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.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
