{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Make all actions relative to module main directory.\n",
    "import sys\n",
    "sys.path.append(\"..\")\n",
    "import os\n",
    "os.chdir(\"..\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ML_Models.data_loader import return_loaders\n",
    "from ML_Models.KernelRidgeRegression.model import KernelRidgeRegression, squared_exp_kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_load, test_load = return_loaders(\"twomoons\", True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = torch.tensor(train_load.dataset.X.to_numpy(), dtype=torch.float32)\n",
    "labels = torch.tensor(train_load.dataset.targets.to_numpy(), dtype=torch.float32)\n",
    "\n",
    "# Sort the data by x value.\n",
    "ind = torch.argsort(data[:,0])\n",
    "data = data[ind]\n",
    "labels = labels[ind]\n",
    "\n",
    "data_test = torch.tensor(test_load.dataset.X.to_numpy(), dtype=torch.float32)\n",
    "labels_test = torch.tensor(test_load.dataset.targets.to_numpy(), dtype=torch.float32)\n",
    "ind_test = torch.argsort(data_test[:,0])\n",
    "data_test = data_test[ind_test]\n",
    "labels_test = labels_test[ind_test]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x19f48a9bc18>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(data[labels==0,0], data[labels==0,1], label=\"y=0\")\n",
    "plt.scatter(data[labels==1,0], data[labels==1,1], label=\"y=1\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "kr = KernelRidgeRegression(squared_exp_kernel, lambd=0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([100])\n"
     ]
    }
   ],
   "source": [
    "kr.fit(data, labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "yhat = kr.predict_with_logits(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x19f48d05eb8>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(data[yhat<0.5,0], data[yhat<0.5,1], label=\"y=0\")\n",
    "plt.scatter(data[yhat>0.5,0], data[yhat>0.5,1], label=\"y=1\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3000, 2])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\fred0\\Anaconda3\\envs\\env_robustnes\\lib\\site-packages\\torch\\functional.py:445: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at  ..\\aten\\src\\ATen\\native\\TensorShape.cpp:2157.)\n",
      "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n"
     ]
    }
   ],
   "source": [
    "v1 = torch.linspace(-1.5,2.5,50)\n",
    "v2 = torch.linspace(-1,1.5,60)\n",
    "x1, x2 = torch.meshgrid(v1,v2)\n",
    "inp = torch.stack((x1.flatten(), x2.flatten())).t()\n",
    "print(inp.shape)\n",
    "yhatbg = kr.predict_with_logits(inp)\n",
    "yhatbg = yhatbg.reshape(len(v1), len(v2)).t()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x19f498bdc18>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.pcolor(v1, v2, yhatbg, shading=\"auto\")\n",
    "plt.scatter(data[yhat<0.5,0], data[yhat<0.5,1], label=\"y=0\")\n",
    "plt.scatter(data[yhat>0.5,0], data[yhat>0.5,1], label=\"y=1\")\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test the recourse objective"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Tools import jackknife"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "objective = jackknife.counterfactual_recourse_objective(kr, data_test, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([400, 2])\n",
      "tensor([[ 22.3022,  36.0449],\n",
      "        [ 25.7355,  41.7221],\n",
      "        [ 25.9796,  44.0224],\n",
      "        [ 29.9599,  43.9932],\n",
      "        [ 32.4200,  50.3234],\n",
      "        [ 34.9878,  42.3204],\n",
      "        [ 35.5803,  38.9960],\n",
      "        [ 37.4709,  34.1159],\n",
      "        [ 37.8950,  47.8376],\n",
      "        [ 40.1738,  31.6998],\n",
      "        [ 41.9571,  44.6574],\n",
      "        [ 43.6299,  30.3312],\n",
      "        [ 47.2880,  39.4621],\n",
      "        [ 48.2055,  44.5481],\n",
      "        [ 50.5172,  35.6854],\n",
      "        [ 53.3723,  30.0344],\n",
      "        [ 54.1374,  30.2495],\n",
      "        [ 61.3341,  37.3089],\n",
      "        [ 63.1804,  36.0125],\n",
      "        [ 64.0402,  42.0145],\n",
      "        [ 25.1427,  13.9984],\n",
      "        [ 21.7517,  10.8576],\n",
      "        [ 21.5291,   9.7603],\n",
      "        [ 18.1937,   9.7736],\n",
      "        [ 16.3797,   7.1913],\n",
      "        [ 14.6596,  10.5633],\n",
      "        [ 14.2858,  12.2840],\n",
      "        [ 13.1466,  15.2251],\n",
      "        [ 12.9019,   8.1334],\n",
      "        [ 11.6502,  16.8931],\n",
      "        [ 10.7412,   9.4734],\n",
      "        [  9.9410,  17.9087],\n",
      "        [  8.3538,  12.0299],\n",
      "        [  7.9884,   9.5222],\n",
      "        [  7.1215,  14.2204],\n",
      "        [  6.1510,  18.1362],\n",
      "        [  5.9086,  17.9710],\n",
      "        [  3.9613,  13.2412],\n",
      "        [  3.5507,  14.0183],\n",
      "        [  3.3708,  10.7129],\n",
      "        [  5.7167,   1.5920],\n",
      "        [  4.2506,   0.9384],\n",
      "        [  4.1596,   0.7994],\n",
      "        [  2.8876,   0.8008],\n",
      "        [  2.2792,   0.7323],\n",
      "        [  1.7686,   0.8958],\n",
      "        [  1.6673,   1.1935],\n",
      "        [  1.3827,   1.9286],\n",
      "        [  1.3266,   0.7075],\n",
      "        [  1.0707,   2.4446],\n",
      "        [  0.9211,   0.7725],\n",
      "        [  0.8185,   2.7878],\n",
      "        [  0.7107,   1.1426],\n",
      "        [  0.7072,   0.7768],\n",
      "        [  0.7368,   1.6500],\n",
      "        [  0.8454,   2.8674],\n",
      "        [  0.8872,   2.8095],\n",
      "        [  1.5191,   1.4049],\n",
      "        [  1.7450,   1.5972],\n",
      "        [  1.8583,   0.9170],\n",
      "        [ 66.6280,  47.2422],\n",
      "        [ 60.9771,  41.1811],\n",
      "        [ 60.5999,  38.9587],\n",
      "        [ 54.8418,  38.9861],\n",
      "        [ 51.6124,  33.4522],\n",
      "        [ 48.4724,  40.5912],\n",
      "        [ 47.7785,  43.9827],\n",
      "        [ 45.6361,  49.5139],\n",
      "        [ 45.1698,  35.5296],\n",
      "        [ 42.7489,  52.5343],\n",
      "        [ 40.9484,  38.3664],\n",
      "        [ 39.3293,  54.3395],\n",
      "        [ 36.0050,  43.4900],\n",
      "        [ 35.2147,  38.4677],\n",
      "        [ 33.2951,  47.6567],\n",
      "        [ 31.0577,  54.7406],\n",
      "        [ 30.4818,  54.4496],\n",
      "        [ 25.5063,  45.8155],\n",
      "        [ 24.3483,  47.2794],\n",
      "        [ 23.8241,  40.8917],\n",
      "        [  1.6736,   0.8060],\n",
      "        [  1.1006,   1.3064],\n",
      "        [  1.0707,   1.6121],\n",
      "        [  0.7562,   1.6078],\n",
      "        [  0.7071,   2.7058],\n",
      "        [  0.7577,   1.3806],\n",
      "        [  0.7828,   1.0181],\n",
      "        [  0.8947,   0.7296],\n",
      "        [  0.9262,   2.2324],\n",
      "        [  1.1324,   0.7111],\n",
      "        [  1.3351,   1.7058],\n",
      "        [  1.5561,   0.7422],\n",
      "        [  2.1348,   1.0614],\n",
      "        [  2.2992,   1.6894],\n",
      "        [  2.7448,   0.7878],\n",
      "        [  3.3540,   0.7532],\n",
      "        [  3.5277,   0.7451],\n",
      "        [  5.3563,   0.8833],\n",
      "        [  5.8775,   0.8043],\n",
      "        [  6.1270,   1.3422],\n",
      "        [ 31.9338,  19.1162],\n",
      "        [ 28.0840,  15.3824],\n",
      "        [ 27.8300,  14.0567],\n",
      "        [ 24.0027,  14.0729],\n",
      "        [ 21.9013,  10.8912],\n",
      "        [ 19.8929,  15.0281],\n",
      "        [ 19.4541,  17.0880],\n",
      "        [ 18.1112,  20.5551],\n",
      "        [ 17.8215,  12.0638],\n",
      "        [ 16.3324,  22.4976],\n",
      "        [ 15.2424,  13.7077],\n",
      "        [ 14.2759,  23.6736],\n",
      "        [ 12.3360,  16.7855],\n",
      "        [ 11.8843,  13.7672],\n",
      "        [ 10.8037,  19.3772],\n",
      "        [  9.5759,  23.9363],\n",
      "        [  9.2659,  23.7456],\n",
      "        [  6.7037,  18.2230],\n",
      "        [  6.1413,  19.1396],\n",
      "        [  5.8915,  15.2084],\n",
      "        [ 16.3702,  28.3240],\n",
      "        [ 19.3130,  33.3674],\n",
      "        [ 19.5236,  35.4233],\n",
      "        [ 22.9780,  35.3972],\n",
      "        [ 25.1308,  41.0867],\n",
      "        [ 27.3904,  33.9014],\n",
      "        [ 27.9135,  30.9397],\n",
      "        [ 29.5862,  26.6218],\n",
      "        [ 29.9622,  38.8473],\n",
      "        [ 31.9873,  24.4993],\n",
      "        [ 33.5770,  35.9921],\n",
      "        [ 35.0721,  23.3021],\n",
      "        [ 38.3531,  31.3541],\n",
      "        [ 39.1784,  35.8942],\n",
      "        [ 41.2616,  28.0062],\n",
      "        [ 43.8417,  23.0430],\n",
      "        [ 44.5344,  23.2308],\n",
      "        [ 51.0738,  29.4426],\n",
      "        [ 52.7578,  28.2953],\n",
      "        [ 53.5429,  33.6283],\n",
      "        [204.7618, 169.3761],\n",
      "        [194.7235, 157.6459],\n",
      "        [194.0462, 153.2392],\n",
      "        [183.5849, 153.2939],\n",
      "        [177.6077, 142.0302],\n",
      "        [171.7110, 156.4821],\n",
      "        [170.3959, 163.1171],\n",
      "        [166.3056, 173.6766],\n",
      "        [165.4093, 146.3113],\n",
      "        [160.7187, 179.3227],\n",
      "        [157.1873, 152.0542],\n",
      "        [153.9783, 182.6607],\n",
      "        [147.2818, 162.1614],\n",
      "        [145.6666, 152.2571],\n",
      "        [141.7035, 170.1644],\n",
      "        [137.0067, 183.3988],\n",
      "        [135.7830, 182.8633],\n",
      "        [124.9289, 166.6500],\n",
      "        [122.3198, 169.4469],\n",
      "        [121.1272, 157.0755],\n",
      "        [ 10.1993,   3.8877],\n",
      "        [  8.1335,   2.4593],\n",
      "        [  8.0015,   2.0217],\n",
      "        [  6.0867,   2.0268],\n",
      "        [  5.1027,   1.1751],\n",
      "        [  4.2153,   2.3382],\n",
      "        [  4.0291,   3.0793],\n",
      "        [  3.4783,   4.5016],\n",
      "        [  3.3634,   1.4516],\n",
      "        [  2.7973,   5.3765],\n",
      "        [  2.4111,   1.9138],\n",
      "        [  2.0911,   5.9292],\n",
      "        [  1.5225,   2.9650],\n",
      "        [  1.4061,   1.9320],\n",
      "        [  1.1565,   3.9968],\n",
      "        [  0.9289,   6.0548],\n",
      "        [  0.8822,   5.9636],\n",
      "        [  0.7105,   3.5230],\n",
      "        [  0.7381,   3.8975],\n",
      "        [  0.7601,   2.3995],\n",
      "        [  1.7057,   0.7960],\n",
      "        [  1.1212,   1.2816],\n",
      "        [  1.0905,   1.5815],\n",
      "        [  0.7636,   1.5773],\n",
      "        [  0.7073,   2.6602],\n",
      "        [  0.7506,   1.3543],\n",
      "        [  0.7742,   1.0003],\n",
      "        [  0.8810,   0.7250],\n",
      "        [  0.9112,   2.1926],\n",
      "        [  1.1115,   0.7134],\n",
      "        [  1.3097,   1.6737],\n",
      "        [  1.5265,   0.7485],\n",
      "        [  2.0963,   1.0423],\n",
      "        [  2.2585,   1.6575],\n",
      "        [  2.6988,   0.7789],\n",
      "        [  3.3015,   0.7604],\n",
      "        [  3.4735,   0.7517],\n",
      "        [  5.2866,   0.8700],\n",
      "        [  5.8040,   0.7944],\n",
      "        [  6.0517,   1.3166],\n",
      "        [ 37.1870,  23.1970],\n",
      "        [ 33.0157,  19.0479],\n",
      "        [ 32.7397,  17.5620],\n",
      "        [ 28.5678,  17.5802],\n",
      "        [ 26.2651,  13.9788],\n",
      "        [ 24.0547,  18.6514],\n",
      "        [ 23.5703,  20.9491],\n",
      "        [ 22.0847,  24.7845],\n",
      "        [ 21.7635,  15.3128],\n",
      "        [ 20.1081,  26.9195],\n",
      "        [ 18.8913,  17.1697],\n",
      "        [ 17.8083,  28.2077],\n",
      "        [ 15.6213,  20.6126],\n",
      "        [ 15.1092,  17.2366],\n",
      "        [ 13.8788,  23.4855],\n",
      "        [ 12.4708,  28.4952],\n",
      "        [ 12.1133,  28.2866],\n",
      "        [  9.1204,  22.2086],\n",
      "        [  8.4517,  23.2229],\n",
      "        [  8.1529,  18.8532],\n",
      "        [  5.9191,   1.6783],\n",
      "        [  4.4211,   0.9835],\n",
      "        [  4.3279,   0.8286],\n",
      "        [  3.0219,   0.8302],\n",
      "        [  2.3935,   0.7201],\n",
      "        [  1.8628,   0.9367],\n",
      "        [  1.7571,   1.2580],\n",
      "        [  1.4583,   2.0296],\n",
      "        [  1.3991,   0.7113],\n",
      "        [  1.1267,   2.5647],\n",
      "        [  0.9646,   0.7974],\n",
      "        [  0.8504,   2.9189],\n",
      "        [  0.7181,   1.2037],\n",
      "        [  0.7086,   0.8024],\n",
      "        [  0.7234,   1.7389],\n",
      "        [  0.8141,   3.0010],\n",
      "        [  0.8512,   2.9413],\n",
      "        [  1.4404,   1.4817],\n",
      "        [  1.6557,   1.6836],\n",
      "        [  1.7643,   0.9601],\n",
      "        [ 12.8226,  23.5387],\n",
      "        [ 15.4261,  28.1436],\n",
      "        [ 15.6134,  30.0306],\n",
      "        [ 18.7040,  30.0067],\n",
      "        [ 20.6443,  35.2529],\n",
      "        [ 22.6907,  28.6333],\n",
      "        [ 23.1657,  25.9225],\n",
      "        [ 24.6877,  21.9935],\n",
      "        [ 25.0305,  33.1840],\n",
      "        [ 26.8800,  20.0741],\n",
      "        [ 28.3358,  30.5535],\n",
      "        [ 29.7079,  18.9955],\n",
      "        [ 32.7281,  26.3010],\n",
      "        [ 33.4895,  30.4635],\n",
      "        [ 35.4147,  23.2500],\n",
      "        [ 37.8045,  18.7625],\n",
      "        [ 38.4472,  18.9313],\n",
      "        [ 44.5318,  24.5569],\n",
      "        [ 46.1036,  23.5127],\n",
      "        [ 46.8370,  28.3828],\n",
      "        [ 29.3453,  17.1417],\n",
      "        [ 25.6638,  13.6255],\n",
      "        [ 25.4213,  12.3836],\n",
      "        [ 21.7745,  12.3987],\n",
      "        [ 19.7786,   9.4370],\n",
      "        [ 17.8760,  13.2931],\n",
      "        [ 17.4610,  15.2286],\n",
      "        [ 16.1929,  18.5027],\n",
      "        [ 15.9197,  10.5250],\n",
      "        [ 14.5177,  20.3445],\n",
      "        [ 13.4942,  12.0574],\n",
      "        [ 12.5887,  21.4616],\n",
      "        [ 10.7782,  14.9439],\n",
      "        [ 10.3581,  12.1130],\n",
      "        [  9.3559,  17.3884],\n",
      "        [  8.2226,  21.7114],\n",
      "        [  7.9373,  21.5301],\n",
      "        [  5.6008,  16.2984],\n",
      "        [  5.0941,  17.1638],\n",
      "        [  4.8700,  13.4622],\n",
      "        [ 51.2907,  71.4305],\n",
      "        [ 56.4782,  79.3745],\n",
      "        [ 56.8423,  82.5480],\n",
      "        [ 62.7031,  82.5079],\n",
      "        [ 66.2618,  91.1290],\n",
      "        [ 69.9318,  80.2021],\n",
      "        [ 70.7727,  75.5809],\n",
      "        [ 73.4420,  68.6904],\n",
      "        [ 74.0380,  87.7621],\n",
      "        [ 77.2244,  65.2244],\n",
      "        [ 79.6997,  83.4200],\n",
      "        [ 82.0082,  63.2430],\n",
      "        [ 87.0146,  76.2322],\n",
      "        [ 88.2618,  83.2701],\n",
      "        [ 91.3907,  70.9215],\n",
      "        [ 95.2291,  62.8115],\n",
      "        [ 96.2532,  63.1243],\n",
      "        [105.8004,  73.2140],\n",
      "        [108.2267,  71.3847],\n",
      "        [109.3538,  79.7792],\n",
      "        [  4.0434,   0.9870],\n",
      "        [  2.8702,   0.7119],\n",
      "        [  2.7992,   0.7187],\n",
      "        [  1.8414,   0.7183],\n",
      "        [  1.4164,   1.0323],\n",
      "        [  1.0898,   0.7076],\n",
      "        [  1.0300,   0.7888],\n",
      "        [  0.8754,   1.1881],\n",
      "        [  0.8480,   0.8604],\n",
      "        [  0.7437,   1.5288],\n",
      "        [  0.7097,   0.7314],\n",
      "        [  0.7132,   1.7696],\n",
      "        [  0.8306,   0.7687],\n",
      "        [  0.8821,   0.7289],\n",
      "        [  1.0482,   1.0200],\n",
      "        [  1.3209,   1.8267],\n",
      "        [  1.4060,   1.7852],\n",
      "        [  2.4304,   0.8866],\n",
      "        [  2.7532,   0.9899],\n",
      "        [  2.9112,   0.7093],\n",
      "        [ 40.4160,  58.4520],\n",
      "        [ 45.0266,  65.6505],\n",
      "        [ 45.3512,  68.5368],\n",
      "        [ 50.5936,  68.5004],\n",
      "        [ 53.7910,  76.3680],\n",
      "        [ 57.0986,  66.4027],\n",
      "        [ 57.8578,  62.2080],\n",
      "        [ 60.2709,  55.9786],\n",
      "        [ 60.8104,  73.2909],\n",
      "        [ 63.6983,  52.8579],\n",
      "        [ 65.9460,  69.3309],\n",
      "        [ 68.0455,  51.0781],\n",
      "        [ 72.6084,  62.7984],\n",
      "        [ 73.7473,  69.1944],\n",
      "        [ 76.6074,  57.9922],\n",
      "        [ 80.1224,  50.6909],\n",
      "        [ 81.0613,  50.9716],\n",
      "        [ 89.8355,  60.0647],\n",
      "        [ 92.0711,  58.4106],\n",
      "        [ 93.1103,  66.0183],\n",
      "        [ 24.6214,  38.9952],\n",
      "        [ 28.2279,  44.8961],\n",
      "        [ 28.4838,  47.2824],\n",
      "        [ 32.6496,  47.2522],\n",
      "        [ 35.2180,  53.8084],\n",
      "        [ 37.8946,  45.5169],\n",
      "        [ 38.5116,  42.0646],\n",
      "        [ 40.4790,  36.9862],\n",
      "        [ 40.9200,  51.2356],\n",
      "        [ 43.2884,  34.4665],\n",
      "        [ 45.1399,  47.9408],\n",
      "        [ 46.8754,  33.0375],\n",
      "        [ 50.6665,  42.5490],\n",
      "        [ 51.6166,  47.8276],\n",
      "        [ 54.0089,  38.6209],\n",
      "        [ 56.9610,  32.7274],\n",
      "        [ 57.7516,  32.9522],\n",
      "        [ 65.1802,  40.3104],\n",
      "        [ 67.0837,  38.9615],\n",
      "        [ 67.9699,  45.1995],\n",
      "        [ 14.8071,   6.7463],\n",
      "        [ 12.2617,   4.6981],\n",
      "        [ 12.0968,   4.0217],\n",
      "        [  9.6679,   4.0298],\n",
      "        [  8.3835,   2.5517],\n",
      "        [  7.1947,   4.5143],\n",
      "        [  6.9406,   5.6100],\n",
      "        [  6.1768,   7.5821],\n",
      "        [  6.0149,   3.0691],\n",
      "        [  5.2006,   8.7440],\n",
      "        [  4.6253,   3.8490],\n",
      "        [  4.1314,   9.4642],\n",
      "        [  3.1941,   5.4451],\n",
      "        [  2.9876,   3.8783],\n",
      "        [  2.5146,   6.8963],\n",
      "        [  2.0181,   9.6267],\n",
      "        [  1.9005,   9.5087],\n",
      "        [  1.0862,   6.2395],\n",
      "        [  0.9552,   6.7598],\n",
      "        [  0.9041,   4.6076],\n",
      "        [ 12.1700,   5.0676],\n",
      "        [  9.8874,   3.3589],\n",
      "        [  9.7405,   2.8134],\n",
      "        [  7.5933,   2.8198],\n",
      "        [  6.4734,   1.6850],\n",
      "        [  5.4498,   3.2095],\n",
      "        [  5.2329,   4.1109],\n",
      "        [  4.5858,   5.7818],\n",
      "        [  4.4496,   2.0703],\n",
      "        [  3.7713,   6.7865],\n",
      "        [  3.2996,   2.6762],\n",
      "        [  2.9010,   7.4149],\n",
      "        [  2.1657,   3.9738],\n",
      "        [  2.0086,   2.6994],\n",
      "        [  1.6580,   5.1952],\n",
      "        [  1.3088,   7.5572],\n",
      "        [  1.2300,   7.4538],\n",
      "        [  0.7678,   4.6386],\n",
      "        [  0.7237,   5.0790],\n",
      "        [  0.7127,   3.2852]])\n"
     ]
    }
   ],
   "source": [
    "ovals = torch.cat([objective(torch.randn(len(kr.points)), data_test[i]+0.5, data_test[i]) for i in range(len(data_test))])\n",
    "print(ovals.shape)\n",
    "print(ovals)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test the jackknife"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "#jackknife.jackknife_make_differentiable(data_test+0.5, \n",
    "#                                        objective, \n",
    "#                                        kr.internal_weights.clone().requires_grad_(True), data_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Find counterfactuals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Recourse_Methods.gradient_methods import SCFE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "scfe = SCFE(kr, \n",
    "            setting=\"regression\", \n",
    "            lr=1e-3, \n",
    "            max_iter=1000, \n",
    "            target_thres= 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([-0.0387,  0.5572]) tensor(1.)\n"
     ]
    }
   ],
   "source": [
    "i = 5\n",
    "print(data_test[i], labels_test[i])\n",
    "org_point = data_test[i].reshape(1,-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\fred0\\Anaconda3\\envs\\env_robustnes\\lib\\site-packages\\torch\\nn\\modules\\loss.py:520: UserWarning: Using a target size (torch.Size([])) that is different to the input size (torch.Size([1, 1])). This will likely lead to incorrect results due to broadcasting. Please ensure they have the same size.\n",
      "  return F.mse_loss(input, target, reduction=self.reduction)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([[0.0358, 0.6211]])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scfe.generate_counterfactuals(org_point, \n",
    "                              target_class = 1-labels_test[i], \n",
    "                              _lambda = 0, \n",
    "                              step=0.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n"
     ]
    }
   ],
   "source": [
    "# Randomly sample some points and compute cfs\n",
    "mycfs = []\n",
    "for i in range(len(data_test)):\n",
    "    org_point = data_test[i].reshape(1,-1)\n",
    "    res = scfe.generate_counterfactuals(org_point, \n",
    "                                        target_class = 1-labels_test[i], \n",
    "                                        _lambda = 10, \n",
    "                                        step=0.0)\n",
    "    mycfs.append(res)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot the CFEs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.pcolor(v1, v2, yhatbg, shading=\"auto\")\n",
    "for i in range(len(data_test)):\n",
    "    plt.scatter(data_test[i][0], data_test[i][1], c=\"k\")\n",
    "    plt.annotate(\"\", \n",
    "                 xy=(mycfs[i][0][0], \n",
    "                         mycfs[i][0][1]), \n",
    "                 xytext=(data_test[i][0], \n",
    "                         data_test[i][1]), \n",
    "                 arrowprops=dict(arrowstyle=\"->\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "cf_vect = torch.cat(mycfs, dim=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Use the jackknife to calculate the change in the CFs under model change."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "objective = jackknife.counterfactual_recourse_objective(kr, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 2, 100])\n"
     ]
    }
   ],
   "source": [
    "jkx = jackknife.jackknife_compute_jacobians(cf_vect, \n",
    "                                            objective, \n",
    "                                            kr.internal_weights, \n",
    "                                            data_test)\n",
    "print(jkx.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "None\n"
     ]
    }
   ],
   "source": [
    "print(cf_vect.grad_fn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "cf_vect_diff = jackknife.jackknife_make_differentiable(cf_vect, \n",
    "                                                       objective, \n",
    "                                                       kr.internal_weights.clone().requires_grad_(),\n",
    "                                                       data_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AddBackward0 at 0x19f49b7b7f0>"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cf_vect_diff.grad_fn"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Sort them by their x value."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "norms_jq = torch.norm(jkx, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x19f49b52320>"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1152x230.4 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.matshow(norms_jq)\n",
    "plt.ylabel('CF index')\n",
    "plt.xlabel(r'$|x^{CF*}(w) / {d w}|$')\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.0631)\n"
     ]
    }
   ],
   "source": [
    "print(torch.max(norms_jq))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Use the removal equation to compute changes in internal_weights."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "chng = kr.compute_weights_under_removal(labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100, 100])"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "chng.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x19f49bd9320>"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# show that after applying the corresponding change, the weight is zero...\n",
    "plt.matshow(torch.abs(chng+kr.internal_weights.reshape(-1,1)))\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(4.7920)"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.max(chng)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([20, 2, 100])"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Now compute the matrix of the final changes of cfs\n",
    "chmat = torch.matmul(jkx, chng)\n",
    "chmat.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Maximal change:  tensor(0.0591)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1152x230.4 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "chnorms = torch.norm(chmat, dim=1)\n",
    "plt.matshow(chnorms)\n",
    "plt.xlabel(\"Training data index\")\n",
    "plt.ylabel(\"Counterfactual index\")\n",
    "print(\"Maximal change: \", torch.max(chnorms))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Verfication of the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Select 10 points for removal test.\n",
    "n_interv = 5\n",
    "ind = torch.argsort(-chnorms.sum(dim=0))[::n_interv]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([68, 17, 66,  8, 86, 37, 91, 95,  3, 87,  0, 60, 65, 51, 15, 69, 85, 78,\n",
      "        63, 49])\n"
     ]
    }
   ],
   "source": [
    "print(ind)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Recompute the CFs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Removing point 68\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "Removing point 17\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "Removing point 66\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4985]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5002]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "Removing point 8\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5002]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "Removing point 86\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "Removing point 37\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5013]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "Removing point 91\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "Removing point 95\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "Removing point 3\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "Removing point 87\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4985]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "Removing point 0\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "Removing point 60\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4983]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "Removing point 65\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5002]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "Removing point 51\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5002]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5013]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "Removing point 15\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "Removing point 69\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5015]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5015]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "Removing point 85\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5011]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "Removing point 78\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5002]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4985]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5012]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "Removing point 63\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "Removing point 49\n",
      "kernel weights shape: torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5007]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4995]])\n",
      "Counterfactual explanation found\n"
     ]
    }
   ],
   "source": [
    "real_change_norms = torch.zeros(len(data_test), len(ind))\n",
    "for k,i in enumerate(ind):\n",
    "    print(\"Removing point\", i.item())\n",
    "    all_but_i = ~(torch.arange(len(data)) == i)\n",
    "    kr = KernelRidgeRegression(squared_exp_kernel, lambd=0.1)\n",
    "    kr.fit(data[all_but_i], labels[all_but_i])\n",
    "    scfe = SCFE(kr, setting=\"regression\", lr=1e-3, max_iter=1000, target_thres= 0.5)\n",
    "    mycfs_new = []\n",
    "    for j in range(len(data_test)):\n",
    "        org_point = data_test[j].reshape(1,-1)\n",
    "        res = scfe.generate_counterfactuals(org_point, target_class = 1-labels_test[j], _lambda = 10, step=0.0)\n",
    "        mycfs_new.append(res)\n",
    "    cf_vect_new = torch.cat(mycfs_new, dim=0)\n",
    "    real_change_norms[:,k]=torch.norm(cf_vect_new-cf_vect, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [],
   "source": [
    "ana_change_norms = chnorms[:, ind]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 20])\n"
     ]
    }
   ],
   "source": [
    "print(ana_change_norms.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 20])\n"
     ]
    }
   ],
   "source": [
    "print(real_change_norms.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x19f49a600b8>"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.matshow(real_change_norms, vmax=0.05)\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x19f49ad7f98>"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.matshow(ana_change_norms)\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'actual change')"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZMAAAEKCAYAAADXdbjqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA2eklEQVR4nO3deZyNdfvA8c81Y8a+JYms/UgGCRNtWkilp3gqPaVHmxlkSSWVNg8lRR47MagQRQrjibJkS7axMyVL2UJjzzrb9fvj3KNjDA7nnDlnzlzv12tezrnP9z739TWc63zv731fX1FVjDHGGG+EBToAY4wxOZ8lE2OMMV6zZGKMMcZrlkyMMcZ4zZKJMcYYr1kyMcYY4zW/JhMRuV9ENonIFhHpmsXreUVkovP6MhGp6PbaDSKyREQ2ish6Ecnnz1iNMcZcPr8lExEJB4YCTYAooIWIRGVqFgMcUtXKQH+gt7NvHuBz4HlVrQ7cBaT4K1ZjjDHe8efIpB6wRVW3qWoy8CXQLFObZsAY5/FkoJGICHAvsE5V1wKo6gFVTfNjrMYYY7yQx4/vfQ2w0+35LqD++dqoaqqIHAFKANcBKiLfAyWBL1W1T+YDiEgboA1AwYIF615//fU+74QxxoQaVWXv3r3s2bMHVd2vqiW9fU9/JhNv5AFuB24CTgBzRWSlqs51b6SqcUAcQHR0tCYkJGR7oMYYk5OsXLmSVq1a8ccff/Cvf/2LSZMmbffF+/rzNNduoJzb87LOtizbOPMkRYEDuEYxC52MeQKYAdTxY6zGGBPSTp48yeuvv069evVISkpiypQpTJw40Wfv789ksgKoIiKVRCQSeAKIz9QmHnjGedwc+EFdlSe/B2qKSAEnydwJJPoxVmOMCVkLFy6kVq1a9OnTh1atWpGYmMg///lPnx7Db8lEVVOBjrgSw8/AJFXdKCLvikhTp9looISIbAE6A12dfQ8B/XAlpDXAKlX91l+xGmNMKDp69Cjt27fnzjvvJDU1lTlz5jBy5EiKFSvm82NJqJSgtzkTY4z524wZM2jbti27d+/mpZde4r333qNgwYLntHPmo6O9PZ7dAW+MMSFk//79tGzZkn/84x8UKVKEn376iX79+mWZSHzJkokxxoQAVWXixIlERUUxceJEunXrxqpVq7j55puz5fjBemmwMcYYD/3xxx+0a9eO+Ph4oqOjmTNnDjfccEO2xmAjE2OMyaFUlVGjRhEVFcWsWbP46KOPWLJkSbYnErCRiTHG5Ejbtm2jdevW/PDDD9x5552MGjWKypUrByweG5kYY0wOkpaWRv/+/alRowYrVqxgxIgR/PDDDwFNJGAjE2OMyTE2bNhATEwMy5cv5x//+AfDhw+nbNmygQ4LsJGJMcYEveTkZHr06EGdOnXYtm0bEyZMYPr06UGTSMBGJsYYE9RWrFhBq1at2LBhAy1atGDgwIGULOl1kV+fs5GJMcYEoRMnTtClSxduvvlmDh06RHx8PBMmTAjKRAI2MjHGmKAzf/58YmNj2bp1K23btqV3794ULVo00GFdkI1MjDEmSBw5coS2bdty9913A/DDDz8wfPjwoE8kYMnEGGOCwvTp04mKimLUqFF06dKFdevWnUkqOYElE2OMCaCkpCSefPJJmjZtyhVXXMGSJUv46KOPKFCgQKBDuySWTIwxJgBUlQkTJlCtWjUmT55Mjx49WLlyJfXq1Qt0aJfFJuCNMSab7dq1i3bt2vG///2P+vXrM3r0aKpXrx7osLxiIxNjjMkm6enpjBgxgqioKObOnUu/fv1YvHixR4lkduI+uk3bwOzEfdkQ6aWzkYkxxmSDLVu20Lp1a+bPn0/Dhg0ZOXIk1157rUf7zk7cR6cvVnMyJY2vEnYxqEVtGkeV8nPEl8ZGJsYY40epqan07duXmjVrsmrVKkaOHMmcOXM8TiQAizYncTIlDYCTKWks2pzkr3AvmyUTY4zxk3Xr1nHLLbfw6quvcu+995KYmEhsbCwicknv06BKSfJHhAOQPyKcBlWC7y54O81ljDE+dvr0aXr16kWvXr0oXrw4EydO5LHHHrvkJJKhcVQpBrWozaLNSTSoUjLoTnGBJRNjjPGppUuXEhMTQ2JiIi1btmTAgAGUKFHC6/dtHFUqKJNIBjvNZYwJedlxJdTx48fp3Lkzt956K0ePHuXbb79l3LhxPkkkOYGNTIwxIS07roSaO3curVu35rfffqNdu3Z8+OGHFClSxKfHCHY2MjHGhDR/Xgl1+PBhYmNjueeee8iTJw8LFixg2LBhuS6RgCUTY0yI89eVUNOmTSMqKopPP/2U1157jbVr13LHHXf45L1zIjvNZYwJab6+Emrfvn106tSJSZMmccMNNxAfH090dLSPos25/DoyEZH7RWSTiGwRka5ZvJ5XRCY6ry8TkYrO9ooiclJE1jg/w/0ZpzEmtDWOKsW7zWp4lUhUlc8//5yoqCimTp1Kz549SUhIsETi8NvIRETCgaFAY2AXsEJE4lU10a1ZDHBIVSuLyBNAb+Bx57Wtqnqjv+IzxhhP7dixg+eff56ZM2dyyy23MHr0aKpVqxbosIKKP0cm9YAtqrpNVZOBL4Fmmdo0A8Y4jycDjeRy7+oxxhgfS09PZ9iwYVSvXp0FCxYwcOBAFi1aZIkkC/5MJtcAO92e73K2ZdlGVVOBI0DGRdmVRGS1iCwQkQZ+jNMYY87x66+/ctddd9GhQwduvvlmNmzYQKdOnQgPDw90aEEpWK/m2gOUV9XaQGdggoicc62diLQRkQQRSUhKClzhs2AvDW2M8Vxqaiq9e/fmhhtuYP369XzyySfMmjWLSpUq+fW4Of1zxJ/JZDdQzu15WWdblm1EJA9QFDigqqdV9QCAqq4EtgLXZT6AqsaparSqRpcsGZjCZxk3RI1dsp1OX6zOsf8QjDGwdu1a6tevT9euXXnggQdITEzkueeeu+yaWp7y9HMkmBOOP5PJCqCKiFQSkUjgCSA+U5t44BnncXPgB1VVESnpTOAjItcCVYBtfoz1suWE0tDGmAs7deoUb7/9NtHR0ezevZvJkyfzzTffULp06Ww5viefI8H+xdVvycSZA+kIfA/8DExS1Y0i8q6INHWajQZKiMgWXKezMi4fvgNYJyJrcE3MP6+qB/0VqzdyQmloY8z5/fTTT9SuXZv333+ff//73yQmJvLoo49mawyefI4E+xdXUdVAx+AT0dHRmpCQEJBjz07cF9SloY0x5zp27BhvvfUWgwcPply5csTFxXHfffcFLJ6LfY641xjLHxHusxpjIrJSVb2+WcaSiTEm15k1axZt2rRh+/btdOzYkV69elG4cOFAh3VR/vji6qtkYuVUjDG5xqFDh+jcuTOfffYZVatWZdGiRdx+++2BDstjwbymSbBeGmyMMT71zTffEBUVxbhx43jjjTdYs2ZNjkokwc5GJsaYkLZ37146duzI119/zY033siMGTOoXbt2oMMKOTYyMcaEJFVlzJgxREVF8b///Y9evXqxfPlySyR+YiMTY0zI+f3332nbti2zZs3itttuY9SoUVx//fWBDiuk2cjEGBMy0tPTGTx4MDVq1GDx4sUMHjyYhQsXWiLJBjYyMcaEhF9++YXY2FgWL17Mfffdx4gRI6hQoUKgw8o1bGRicq1grnNkPJeSkkKvXr2oVasWiYmJjBkzhpkzZ1oiyWY2MjG5kvvdxF8l7PLZ3cQme61evZpWrVqxZs0amjdvzpAhQyhVyn6PgWAjE5MrBXudI3Nhp06d4o033uCmm25i7969fP3113z11VeWSALIkonJlaxAZ871448/UqtWLT788EOefvppEhMTeeSRRwIdVq5np7lMrtQ4qhSDWtS2Ap05yF9//cUbb7zB0KFDqVixIrNmzaJx48aBDss4LJmYXCuY6xyZs3333Xe0bduWnTt38uKLL9KzZ08KFSoU6LCMGzvNZYwJWgcOHOCZZ56hSZMmFCxYkMWLFzNgwABLJEHIkokxJuioKpMnTyYqKooJEybw9ttvs3r1am655ZZAh2bOw05zGWOCyp49e+jQoQNTpkyhbt26zJo1i1q1agU6LHMRNjIxxgQFVeWTTz6hWrVqzJw5k969e7N06VJLJDmEjUyMMQH322+/0aZNG+bMmUODBg0YNWoU1113XaDDMpfARibGmIBJS0tj4MCB1KhRg2XLljFs2DDmz59viSQHspGJMSYgEhMTiY2NZcmSJTRp0oQRI0ZQrly5QIdlLpONTIwx2SolJYWePXtSu3Ztfv31Vz7//HO+/fZbSyQ5nI1MjDHZJiEhgZiYGNatW8fjjz/OoEGDuOqqqwIdlvEBG5kYY/zu5MmTvPbaa9SvX5+kpCSmTp3Kl19+aYkkhNjIxBjjVwsWLCA2NpYtW7YQGxvLRx99RLFixQIdlvExG5kYY/xi6vItRDd5nLvuuov09HTmzJnDyJEjLZGEKBuZGGN87v3h4+n+2kukHjtI8fqP0H/IRzSKvjbQYRk/spGJMcZn9u/fT8uWLXm7XUsksgBXt/yIIne1ImH3iUCHZvzMr8lERO4XkU0iskVEumbxel4Rmei8vkxEKmZ6vbyIHBORLv6M0xjjHVVl4sSJREVFMXHiRFq2f4VKrQeTt0xVW3wsl/DbaS4RCQeGAo2BXcAKEYlX1US3ZjHAIVWtLCJPAL2Bx91e7wfM9FeMxhjv7d69m/bt2xMfH090dDRz586lZs2azE7cZ4uP5SL+nDOpB2xR1W0AIvIl0AxwTybNgO7O48nAEBERVVUR+SfwG3DcjzEaYy6TqjJq1Ci6dOlCcnIyffv25cUXXyRPHtfHii0+lrv48zTXNcBOt+e7nG1ZtlHVVOAIUEJECgGvAz0udAARaSMiCSKSkJSU5LPAjTEXtnXrVho1akSbNm2oU6cO69ev55VXXjmTSEzuE6wT8N2B/qp67EKNVDVOVaNVNbpkSTsna4y/paWl0a9fP2rWrMnKlSsZMWIEc+fOpXLlyoEOzQSYR18jRKQCUEVV54hIfiCPqv51kd12A+7Fdso627Jqs0tE8gBFgQNAfaC5iPQBigHpInJKVYd4Eq8xxvc2bNhATEwMy5cv58EHH+Tjjz+mbNmygQ7LBImLjkxEpDWu+YwRzqaywFQP3nsFUEVEKolIJPAEEJ+pTTzwjPO4OfCDujRQ1YqqWhEYAPSyRGJMYCQnJ9OjRw/q1KnDtm3bmDBhAvHx8ZZIzFk8GZl0wDWZvgxAVTeLyEUL6qhqqoh0BL4HwoFPVHWjiLwLJKhqPDAaGCciW4CDuBKOMSZILF++nJiYGDZs2MCTTz7JgAEDsFPKJiueJJPTqposIgA4p6PUkzdX1RnAjEzburk9PgU8dpH36O7JsYwxvnPixAm6detG//79KV26NNOnT+fBBx8MdFgmiHmSTBaIyJtAfhFpDLQHpvs3LGOMr3l638e8efOIjY1l27ZttG3blt69e1O0aNFsjNTkRJ5czdUVSALWA21xjTTe9mdQxhjfmp24j05frGbsku10+mI1sxP3ndPmyJEjtG3bloYNGyIizJs3j+HDh1siMR656MhEVdOBkc6PMSYHWrQ5iZMpaQCcTElj0eaks0Yn06dP5/nnn2fv3r106dKFHj16UKBAgUCFa3IgT67mWi8i6zL9LBKR/iJSIjuCNMZ4p0GVkuSPCAc4q1ZWUlISTz75JE2bNqVEiRIsXbqUjz76yBKJuWSezJnMBNKACc7zJ4ACwF7gM+Ahv0RmjPGZxlGlGNSi9pk5k3uqXcWECRPo1KkTR48epUePHnTt2pXIyMhAh2pyKE+SyT2qWsft+XoRWaWqdUSkpb8CM8b4VkatrJ07d/LQQw/x7bffUr9+fUaPHk316tUDHZ7J4TyZgA8XkXoZT0TkJlz3jQCk+iUqY4zPpaenM2LECKpXr868efPo378/ixcvtkRifMKTkUks8IlTfFGAo0CsiBQEPvBncMYY39i8eTOtW7dmwYIFNGrUiLi4OK691lY+NL7jydVcK4CaIlLUeX7E7eVJ/grMGOO91NRUBgwYwDvvvEPevHkZNWoUrVq1IuMmZGN85aLJRETyAo8CFYE8Gf8IVfVdv0ZmjPHKunXriImJISEhgWbNmjFs2DDKlCkT6LBMiPJkzmQarkWsUnEtVJXxY4wJQqdPn6Zbt27UrVuX7du3M3HiRKZMmWKJxPiVJ3MmZVX1fr9HYozx2tKlS4mJiSExMZGnnnqK/v37U6KE3Q5m/M+TkclPIlLT75EYYy7b8ePHefnll7n11lv566+/mDFjBmPHjrVEYrKNJyOT24FnReQ34DSuK7pUVW/wa2TGGI/MnTuX1q1b89tvv9G+fXs++OADihQpEuiwTC7jSTJp4vcojDGX7PDhw3Tp0oXRo0dTpUoVFixYwB133BHosEwuddHTXKq6XVW3AydxrWOS8WOMCZCpU6cSFRXFZ599xuuvv87atWstkZiA8qTQY1MR2Qz8BiwAfsdVr8sYk8327dvHv/71Lx5++GGuuuoqli1bxocffkj+/PkDHZrJ5TyZgH8PuBn4VVUrAY2ApX6NyhhzFlVl3LhxREVFMW3aNHr27MmKFSuoW7duoEMzBvBsziRFVQ+ISJiIhKnqPBEZ4O/AjDEuO3bsoHnL51ix6Aeiboxm8oSxVKtWLdBhGXMWT5LJYacu10JgvIj8id20aIzfpaenM3z4cLq8+hqnUtIofk9b0uo9xC69AkslJth4cpqrGa7J95eB74Ct2BomxvjVr7/+yl133UWHDh0oXeUGysQMpUjdhziV5lo10Zhg48nVXMdVNU1VU1V1jKoOUtUD2RGcMblNamoqvXv35oYbbmD9+vV8+umnfDz+Gwpf6SqF4r5KojHBxJNCj48AvYGrcN2wmHHTot0VZYwPrVmzhpiYGFatWsXDDz/M0KFDKV26NMBZqyS6r91uTLDwZM6kD/CQqv7s72CMyY1OnTrFe++9R+/evbnyyiuZPHkyjz766FltMlZJNCZYeZJM9lkiMcY/fvrpJ2JiYvjll1945pln6NevH1dccUWgwzLmkp03mTintwASRGQiMBVXbS4AVPUb/4ZmTOg6duwYb775JkOGDKFcuXJ899133HfffYEOy5jLdqGRifsVWyeAe92eK2DJxJjL8MHIifR+qzNH9++hQ4cO9OrVi8KFCwc6LGO8ct5koqrPefvmInI/MBAIB0ap6oeZXs8LjAXqAgeAx1X1dxGpB8RlNAO6q+oUb+Mx5mJmJ+7z20T3wYMHaRHTnllTJ5LnirKUe6oPTds9ZYnEhARPanONEZFibs+Li8gnHuwXDgzFVXU4CmghIlGZmsUAh1S1MtAf11VjABuAaFW9EbgfGCEinszvGHPZZifuo9MXqxm7ZDudvljN7MR9Pnvvr7/+mqioKGbHT6bILf+izHODkNLV7J4REzI8uWnxBlU9nPFEVQ8BtT3Yrx6wRVW3qWoy8CWuGyDdNQPGOI8nA41ERFT1hKqmOtvzYVWKTTZYtDmJkylpAJxMSfPJB/3evXtp3rw5zZs3p0yZMgyb9D1lGj2H5Im0e0ZMSPHk236YiBR3kggicoWH+10D7HR7vguof742qpoqIkeAEsB+EakPfAJUAJ5ySy5niEgboA1A+fLlPQjJmPNrUKUkXyXs4mRKmtcf9KrKmDFj6Ny5MydOnOCDDz7glVdeISIigv+r5r9TacYEiidJ4b/AEhH5ynn+GPC+/0JyUdVlQHURqQaMEZGZqnoqU5s4nLmV6OhoG70YrzSOKuWTmwN///132rZty6xZs7j99tsZNWoUVatWPes4lkRMqLloMlHVsSKSADR0Nj2iqokevPduoJzb87LOtqza7HLmRIrimoh3P/7PInIMqAEkeHBcYy6bNx/06enpDB06lDfeeAMRYciQIbRr146wME/OJhuTs3k0qe0kD08SiLsVQBURqYQraTwBPJmpTTzwDLAEaA78oKrq7LPTOfVVAbge16JcxgSlX375hdjYWBYvXsx9993HiBEjqFChQqDDMibb+O0rkzPH0RH4HvgZmKSqG0XkXRFp6jQbDZQQkS1AZ6Crs/12YK2IrAGmAO1Vdb+/YjXmcqWkpNCrVy9q1arFzz//zJgxY5g5c6YlEpPriGpoTDVER0drQoKdBTPZZ9WqVcTExLBmzRoee+wxBg8eTKlSNhdichYRWamq0d6+j53MNeYSnTx5kjfeeIN69eqxd+9evvnmGyZNmmSJxORqF6rN9RdZ399hJehNrjQ7cR/jp33P3Lh32fX7Vlq1akXfvn0pXrx4oEMzJuAuVE7FajwY45i2YivPtn+ZwwnTiShaig9HTeL1mMcCHZYxQcPjEiUichWuu9EBUNUdfonImCAzc+ZMnn66FUf376Nw3aYUu+Mpjl95faDDMiaoeFKbq6mIbAZ+AxbgukR3pp/jMibgDhw4wNNPP80DDzxAsSKFqfDsf7ninjYULFjIyqAYk4knI5P3gJuBOapaW0TuBlr6NyxjAkdVmTx5Mh07duTgwYO88847vPXWWyzcetjKoBhzHp4kkxRVPSAiYSISpqrzRGSAvwMzJhD27NlD+/btmTp1KnXr1mXWrFnUqlULuLy74/1Z0t6YYOJJMjksIoWAhcB4EfkTOO7fsIzJXqrKp59+SufOnTl9+jR9+vTh5ZdfJk+ey1/5IKOk/cmUNL5K2MWgFrUtoZiQ5cl9Js2Ak8DLwHfAVs5ehdGYHG3btm3ce++9xMTEUKtWLdauXcurr77qVSIB/5S0NyZYXTSZqOpxVU1T1VRVHaOqg1T1wMX2MybYpaWlMWDAAGrWrMmyZcv4+OOPmTdvHtddd51P3r9BlZLkjwgHsLVLTMi76FevTDcvRgIRwHG7adHkZImJicTExLB06VIq121A994D+HejOj49hq9K2huTE3hSgv7MzYsiIrhOe93sz6CM8Zfk5GR69+5Nz549yVegEKWbvUpy1TvoOf9Priq9z+cf+LZ2icktLqk2l7pMBe7zTzjG+E9CQgI33XQT3bp145FHHiF2wDdEXn8nImJzGsZ4yZPTXI+4PQ0DooFT52luTNA5efIk//nPf/jvf//L1VdfzbRp02jatCmzE/cxY8tqnyzTa0xu58nlKu5XbqXiugO+mV+iMcbHFixYQGxsLFu2bKF169b06dOHYsWKATanYYwveZJMRqnqYvcNInIb8Kd/QjK+lFtvmjt69Civv/46w4cP59prr2Xu3Lk0bNjwnHY2p2GMb3gyZzLYw20myGTcNDd2yXY6fbGa2Yn7Ah1Stvj222+pXr06cXFxdO7cmXXr1mWZSIwxvnOh9UxuAW4FSopIZ7eXigDh/g7MeC+rm+ZC+Vv4/v37eemllxg/fjzVq1dn8uTJ1K9fP9BhGZMrXOg0VyRQyGnjvrbJUaC5P4MyvtGgSkm+StgV8hPMqsrEiRN54YUXOHLkCP/5z3948803iYyMvKT3cT8lCOTK04PGXK6LrgEvIhVUdXs2xXPZbA34rIX6nMnu3btp37498fHx3HTTTYwePZqaNWue1caTvwP3OlqR4a6zv8lp6eSPCLeaWiakZeca8KNEpJjbgYuLyPfeHthkj8ZRpXi3WY2Q+zBUVUaOHElUVBSzZ8+mb9++LFmyJMtE4sm8kfspweS0dJLT0gGrqWWMpzxJJleq6uGMJ6p6CLjKbxEZcxFbt26lUaNGtGnThjp16rBu3TpeeeUVwsPPncrztNiiex2tyPCwM6OTUD49aIwveXJpcLqIlM9YpldEKvB3rS5jsk1aWhoDBw7k7bffJiIigri4OGJjY3FV+cmap/NGme85AZszMeZSeDJncj8Qh2vJXgEaAG1UNahOddmcSWjbsGEDMTExLF++nIceeoiPP/6Ya665xqN9Q33eyBhv+GrOxJNCj9+JSB3+Lu74kqru9/bAxngiOTmZDz74gPfff5+iRYvyxRdf8Pjjj19wNJKZ3ZhojP95uvpPGq473vMBUSKCqi70X1jGwPLly4mJiWHDhg08+eSTDBw4kCuvvDLQYRljsnDRCXgRicW1ZO/3QA/nz+7+DcvkZidOnOCVV17hlltu4dChQ0yfPp3x48dbIjEmiHlyNdeLwE3AdlW9G6gNHPbkzUXkfhHZJCJbRKRrFq/nFZGJzuvLRKSis72xiKwUkfXOn1YLI5eYN28eNWvWpF+/frRp04aNGzfy4IMPBjosY8xFeJJMTqnqKXB9+KvqL0DVi+0kIuHAUKAJEAW0EJGoTM1igEOqWhnoD/R2tu8HHlLVmsAzwDhPOmNyriNHjtCmTRsaNmxIWFgY8+fP5+OPP6Zo0aKBDs0Y4wFPksku56bFqcBsEZkGeHJHfD1gi6puU9Vk4EvOLV3fDBjjPJ4MNBIRUdXVqvqHs30jkF9E8npwTJMDTZ8+naioKEaPHs2rr77K2rVrufPOOwMdljHmEnhyNdfDzsPuIjIPKAp858F7XwPsdHu+C8hcde9MG1VNFZEjQAlcI5MMjwKrVPV05gOISBugDUD58uU9CMkEk6SkJDp16sSXX35JzZo1mTZtGtHRXl+haIwJgEtdtneBqsY7Iw2/E5HquE59tT1PPHGqGq2q0SVL2l3KOYWqMmHCBKpVq8bXX3/Nu+++S0JCgiUSY3KwS0oml2g3UM7teVlnW5ZtRCQPrlHPAed5WWAK8LSqbvVjnCYb7dy5k4ceeoh///vfVK5cmdWrV/POO+9ccoVfY0xw8WcyWQFUEZFKIhIJPAHEZ2oTj2uCHVxl7X9QVXXmaL4FumZe5dHkTOnp6QwfPpzq1aszb948+vfvz+LFi6levXqgQzPG+IDfkomqpgIdcd2X8jMwSVU3isi7ItLUaTYaKCEiW4DOQMblwx2BykA3EVnj/FhxyRxq8+bNNGzYkHbt2lGvXj3Wr1/PSy+9lGVhRmNMznTR2lw5hdXmCj6pqan079+fbt26kTdvXvr168dzzz13SaVQjDH+lW21uYy5HOvWrSMmJoaEhASaNWvGsGHDKFOmTKDDMsb4iT/nTEwudPr0abp160bdunXZsWMHkyZNYsqUKZZIjAlxNjIJIYEutb5kyRJiYmL4+eefeeqpp+jfvz8lSpTI9jiMMdnPRiYhwtPlaf3h+PHjvPTSS9x2220cO3aMGTNmMHbsWEskxuQilkxChKfL0/ranDlzqFGjBgMHDqR9+/Zs3LiRJk2aZMuxjTHBw5JJiHBfwzw71i0/fPgwMTExNG7cmIiICBYuXMiQIUMoXLiwX49rjAlONmcSIjKvYe7POZOpU6fSvn17/vzzT7p27Uq3bt3Inz+/345njAl+lkxCiL+Xp923bx8vvPACX331FbVq1WL69OnUrVsXCPzkvzEmsOw0l7koVWXcuHFERUUxbdo03n//fVasWHFWIgnU5L8xJjhYMjEXtGPHDh544AGefvpprr/+etasWcObb75JRETEmTaBmvw3xgQPSyYmS+np6QwdOpTq1auzaNEiBg0axKJFi6hWrdo5bbN78t8YE3xszsScY9OmTcTGxvLjjz/SuHFj4uLiqFix4nnbZ+fkvzEmOFkyMWekpqbSt29funfvTv78+fn000955plnPCrM6O/Jf2NMcLNkYgAY/vVcerz2Anu3/cwjjzzC0KFDufrqqwMdljEmh7A5k1zu1KlTPNn2Jdo9di9/7ttDmUff4vn3hlkiMcZcEhuZ5GKLFy8mJiaGTZs2UbDGPRRvGEN4/sIs2pxkp6yMMZfERia50LFjx+jUqRMNGjTg1KlT9Ir7knL/fIXw/IXtaixjzGWxkUkuM2vWLNq0acOOHTvo2LEjvXr1olChQkTbHezGGC9YMgkRFytncvDgQV555RU+++wzqlatyqJFi7jtttvOvG5XYxljvGHJJARklDM5mZLGVwm7GNSiNo2jSp1JMPy2jLgP32L//v20aPMiFe95ihPFywY6bGNMCLFkEgIylzPp+/0vrNl5mLiZK/lj5lBO/PoTlavVpPvQ8Qxck8JPK/cyZV3SmaRjjDHesgn4EOBezgTgl71/8dHg4Wwb3oYTW1dQ7M5nebznWP7IU8pqaBlj/MKSSQjIKGdStVQhUo/s489J3Uj6dgCRJStQ5rnBXN3gce68vjQNqpQkMtz1K48MD6Nwvgi6TdtgVX6NMV6z01whotH1JZk6fhSzR/cEEUrd34GXO3XgeHLamUl596SRrsrIhdtITks/a57FGGMuhyWTEPDzzz8TGxvLTz/9RPTtd3PL01156LZa5ySHRZuTSE5LByA1XQEF/j7lZcnEGHO5LJkEgctdpTAlJYW2r/6HsUP7UqBgIcaOHUvLli3PW5ixQZWSfJWwi5MpaWdOdyWnpduNisYYr+WaZBKsy8qe77LejNfOF/OqVat47Mmn2bZpIwWub0Cp+9txdd2GF6zwm7lUPBCUfyfGmJzHr8lERO4HBgLhwChV/TDT63mBsUBd4ADwuKr+LiIlgMnATcBnqtrRmzgu9IGduV12f7hmtUphxvxGRsxfLt/JbZVL8GT9CtxeqQg9evSgb9++5C9SnJIPv0WB624hxXmvi8Wd+eZESyLGGF/w29VcIhIODAWaAFFACxGJytQsBjikqpWB/kBvZ/sp4B2giy9i8WRZ2UCtY36+VQrdY05OS2fepiRie4/juqia9O7dm2effZYx3/5Iieq3n7OvMcZkN3+OTOoBW1R1G4CIfAk0AxLd2jQDujuPJwNDRERU9Tjwo4hU9kUg7nMF5/vQPd8Iwd/Ot0qhe8zpp09waMEYjq3+lkJXlmb27Nncc889ABQuWsxOVRljAs6fyeQaYKfb811A/fO1UdVUETkClAD2+zIQT5aV9STh+EtWdbEyYu4z8gvmf9KL1KP7KRzdjKvuegYtU/OC+xpjTHbL0RPwItIGaANQvnz5C7a92IdusKxjnjFvU6tkONOGf8CcceMoWroi+Zu+Rt5rqpGKZ3MjxhiTnfyZTHYD5dyel3W2ZdVml4jkAYrimoj3iKrGAXEA0dHR6lW0+Odb/qVM6s9O3McLE1ZxYP0CDs0ZDsnHeeedd6j/SCxdvk4MyKjJGGM84c9ksgKoIiKVcCWNJ4AnM7WJB54BlgDNgR9U1eukECw8uYrMPdnMWLaRHZPe5eTmpUReXZlnu47m3RcfBSAyMm/AR03GGHM+fksmzhxIR+B7XJcGf6KqG0XkXSBBVeOB0cA4EdkCHMSVcAAQkd+BIkCkiPwTuFdVE8lBLjapn5FsTiSnMnLkaA7PH83p06cpdtdzlLr1UZo3jj7T1uZGjDHBzK9zJqo6A5iRaVs3t8engMfOs29Ff8aWHS42qb9ocxJHk3Zz8LvBnNq+lvLV69Ljo8FsSy5sIxBjTI6Soyfgg92FJvXT0tJIWjKFPZ+8DxJGqSYdievzJvfVKB3AiI0x5vJYMvEz99NTGfMj5eUgoz94naVLl1Lvjkbc/FRXHry1po1EjDE5liUTH8vq6q3ZifuYsGw7P27aS9LiSRz5aSIFChVi/PjxtGjR4oL1tIwxJiewZOJDWV29BdDpi9Uc3vEzB2YOIiXpdwpUu4OS9z5PyRsvXJjRGGNyCksmPpAxGtl58MQ5V2+lnD7JH7NGcnTFVMILFqPkI+9QoIqrEIDdfGiMCRWWTLzkPhqJDA8jMjzszBohRQ9v5oM3X+boH9spVOs+it/dirC8BQEIDxO7+dAYEzIsmXgpc3Xfu6uW5Kp86SwcP5AuPb+kcMlruOqJ98lfodaZfcIFnr/z/2xUYowJGbkumfh6zZLM95L836lfGfjm6+zft5ciNz1MybueIiwiH8lp6YQB1a8pQqdG11kiMcaElJBPJhnJo3C+CBL/OMLiLQdITkv3qLyJJx/4GfeSfJewidWTBvJOz28oWb4yV7f8iLxlqpIK1Ly6EIl7/iItXdny53E/9dQYYwInpJOJ+3xGZhcqb5JxNVar2yvx16mUCyYWVeXAunmMfeUFjhw5Qvfu3bmpWSte+XrjmdHKlYXykpZ+9LzHNcaYnC6kk4n7fEZmkeFhWZY3cb8aa/iCraSl63lHMbt376Zdu3ZMnz6dqjVr8+g7cdx6z600jipFRGTkWWutL9120Kr+GmNCVkgnE/f5jMzSsyhO7N4+XCAt3dXmZEoaE5ZtP5Mc7ql2FaNGjaJLly6kpKTQ5tXuLIiI5rs/YMEXq88kHvfkEwxrpRhjjL9IqFR8v65GLX3i/fHnfFhnzIGs2nGYDbuPnLXP07dU4N1mNc7a5j7H8smPv5255BdcV2uF/7WPwgmfsHb5Yu6++25GjhzJmA0nGbtk+wXf1xhjgpGIrFTV6Iu3vLCQGZnsPOj6QM98SipjhDA7cR8dxq8iOS0dgDxhQuF8EXSbtuHMaaeMkUNGIrixXDF6/i+R3YdPkJKaxl8J0zi8aDyRkRHExcURGxuLiNDg9L6ALflrjDHBIGSSScZpq5MpafT9/heAc04nVb26EOt3Hz3TfuTCbSSnpfPlctdS9Zmv8pqyejfbD54gOel3DswcSPKezRSqUp+4EcNpcfeNZ943WJb8NcaYQAmZZBLmVuNq075jdPpi9ZmrsdxPWWVIV86MUjL+hLOvtpqfuJvDP37BkSVfEZavIFc2fY3mj/3rrESSwRavMsbkZiGTTMpdkZ9KpQqxad8x4OyrscKA9Cz2ydjuPieSPyKc/ceSuaHDULZM6kPK/h0UjLqL4o1aE16gKLMS9zE7cZ8lDmOMcRMyyaRIvgi63Hf9mXmRMP6+GiurRBIZHkbrO649cx/Jmp2HmZO4l3xhaXw+8D3+SognvNAVlGz+Hwr8301n9ktLV7tPxBhjMgmZZAKwZudhUp1TVmFhQh6Rs05hAZQsFMkVBSO5J+pqbixXjAnLttPzf4nsPHiCE9vXceC7QaQe3kuhG5tQ/K7nCMtb4Kz9bYLdGGPOFTLJ5OipFIYv2HpmFJKarhTKG0ZypltM9h9LJulYMr/u24KIa+4k/dQxDs3/lGNrvydP8dKUavEB+crXBKBQ3jzcVLE4UWWKXvRueGOMya1CJpkcO5VKZPrZ98wcO33uzYrq9qcqnNi8jIOzhpJ2/DBF6j9K0dueJCwiL+C6fLj/4zda8jDGmIsImWRSKF8ewiPCOZmShvB30nCXPyKMkymusUva8cMcnDOCE78sIqJkRUo+8g55S1c50zZPGHzcsq4lEmOM8UDIJJMi+SJ4/PZKTF29izxhwo6DJ89JKCdT0lFVjifO59DckaQnn6Bog5YUrf8oEh5xVtu2d1a2RGKMMR4KmWSy9+gphs3bkuWIJEPq0SQOzhrGya0riCxTlRJNXiTyyvLntKtboTiv3lfVf8EaY0yICZlkkvTXaUqf5zXVdI6t+Y5D8z8FTad4o9YUrvMgEhZOnjChWunCHD2ZQmq68s/aZS2RGGPMJQqZZHI+KQd3c+C7wZzeuYF8FW7kivs7ElHs6jOvt73z/yx5GGOMl0I2mWh6GkdXTOHIjxMgPIISTTpRsGZjxCm7UjAynGdvq2SJxBhjfCAkk0nyn9s4MHMQyXu3kL/KzVzRuB15Cpc4q82AJ85d7MoYY8zlCfPnm4vI/SKySUS2iEjXLF7PKyITndeXiUhFt9fecLZvEpH7PDmepqZweOE49ox5mdSj+7myWVdKPvzWOYmkw912pZYxxviS3xbHEpFw4FegMbALWAG0UNVEtzbtgRtU9XkReQJ4WFUfF5Eo4AugHlAGmANcp6pZr8ELRJQopyJCyoGdFKzRkOINYwnPX+ScdndXLcmnz9XzYU+NMSbn8tXiWP4cmdQDtqjqNlVNBr4EmmVq0wwY4zyeDDQS16RGM+BLVT2tqr8BW5z3O6/Ug7tITz7FVc27c+U/OmeZSPJHhPNk/Qre9coYY8w5/Dlncg2w0+35LqD++dqoaqqIHAFKONuXZtr3mswHEJE2QBsAwvMQXrAoh3/8nMM/fn5WO005fSw99fQJPX3i6L09jx3J/D45xJXA/kAH4UfWv5wtlPsXyn0D8MlVSDl6Al5V44A4ABFJOL1ns9dDtWAlIgm+GIoGK+tfzhbK/QvlvoGrf754H3+e5toNlHN7XtbZlmUbEckDFAUOeLivMcaYIOHPZLICqCIilUQkEngCiM/UJh54xnncHPhBXVcExANPOFd7VQKqAMv9GKsxxhgv+O00lzMH0hH4HggHPlHVjSLyLpCgqvHAaGCciGwBDuJKODjtJgGJQCrQ4UJXcjni/NWXIGH9y9msfzlXKPcNfNQ/v10abIwxJvfw602LxhhjcgdLJsYYY7yWI5JJdpdlyW6X2z8RKSEi80TkmIgMyfbAPeBF3xqLyEoRWe/82TDbg/eAF/2rJyJrnJ+1IvJwtgfvAW/+7zmvl3f+fXbJtqAvgRe/v4oictLtdzg824P3gJefnTeIyBIR2ej8P8x3wYOpalD/4Jq83wpcC0QCa4GoTG3aA8Odx08AE53HUU77vEAl533CA90nH/avIHA78DwwJNB98XHfagNlnMc1gN2B7o+P+1cAyOM8Lg38mfE8WH686Z/b65OBr4Auge6Pj39/FYENge6DH/uXB1gH1HKel7jYZ2dOGJlka1mWALjs/qnqcVX9ETiVfeFeEm/6tlpV/3C2bwTyi0jebInac97074Sqpjrb88EFFwkNFG/+7yEi/wR+w/X7C0Ze9S8H8KZ/9wLrVHUtgKoe0ItcUZsTkklWZVkyl1Y5qywL4F6W5WL7Bpo3/Qt2vurbo8AqVT3tpzgvl1f9E5H6IrIRWA8875ZcgsVl909ECgGvAz2yIc7L5e2/z0oislpEFohIA38Hexm86d91gIrI9yKySkReu9jBcnQ5FRP6RKQ60BvXN6WQoqrLgOoiUg0YIyIzVTVYR5mXqjvQX1WP5Zwv8pdkD1BeVQ+ISF1gqohUV9WjgQ7MR/LgOoV+E3ACmCuu6sJzz7dDThiZhHpZFm/6F+y86puIlAWmAE+r6la/R3vpfPK7U9WfgWO45oaCiTf9qw/0EZHfgZeAN8V1E3Mwuez+OafODwCo6kpccxPX+T3iS+PN728XsFBV96vqCWAGUOeCRwv0JJEHk0h5gG24JtAzJpGqZ2rTgbMnkSY5j6tz9gT8NoJvAv6y++f2+rME5wS8N7+7Yk77RwLdDz/1rxJ/T8BXAP4Argx0n3z9b9PZ3p3gnID35vdXMuOzBNcE927gikD3yYf9Kw6swrlQBNeaUv+44PEC3WEP/1IewLXQ1lbgLWfbu0BT53E+XFeMbMFVw+tat33fcvbbBDQJdF/80L/fcZWiOYbr20RUdsfvj74BbwPHgTVuP1cFuj8+7N9TuCam1zj/af8Z6L74+t+m23t0JwiTiZe/v0cz/f4eCnRffP37A1o6fdwA9LnYsaycijHGGK/lhDkTY4wxQc6SiTHGGK9ZMjHGGOM1SybGGGO8ZsnEGGOM1yyZmJAmIs9ebkVlEflMRJp78P5lLvF9K4rIhktoP19Eoi/lGMZkN0smxnjnWeCSkokxociSiclxRORpEVnnrAMyztn2kLMew2oRmSMipbLYr5SITHH2Wysit2YeJYhIFxHpnsW+3URkhYhsEJE4cWkORAPjnTUt8otIXafw30qnSF5pZ/+6GcfFddfx+fr2urN2xFoR+dDtpcdEZLmI/JpRVNCJfZFTiG+ViNzqbL/LGc1MFpFfRGS8WyXfB5xtK0VkkIj8z9leUEQ+cY6xWkQyV5c15oIsmZgcxSn8+DbQUFVrAS86L/0I3KyqtXGV2s6qyukgYIGzXx0urTT6EFW9SVVrAPmBB1V1MpAA/FtVbwRSgcFAc1WtC3wCvO/s/ynwgnPs8/WtCa6S4PWddn3cXs6jqvVw1bn6j7PtT6CxqtYBHnf6l6G20zYKV7mP28S1uNEIXJUg6uIqCZLhLeAH5xh3Ax+JSEFP/3KMsarBJqdpCHylqvsBVPWgs70sMNEZCUTiWkcjq32fdvZLA46ISHEPj3u3U4a7AHAFrkQ0PVObqriKNc52BgLhwB4RKQYUU9WFTrtxQJMsjnEP8Km6Cuu59w3gG+fPlbgWZgKIAIaIyI1AGmcXGlyuqrsARGSNs88xYJu61vYB+AJo4zy+F2gqf6+ImA8oD/yc1V+GMZlZMjGhYjDQT1XjReQuXPWgPJHK2SP0c5Ymdb7RDwOiVXWncxosqyVMBdioqrdk2r+Yh7FcSMZaLmn8/f/2ZWAfUAtXH05l0T7zPucjwKOqusn7UE1uZKe5TE7zA675g4wFpq5wthfl7/Laz5xn37lAO2e/cBEpiuvD+CoRKSGulRwfzGK/jMSxX1yLPrlf4fUXUNh5vAkoKSK3OMeIcNa4OAwcFpHbnXb/Pk98s4HnRKRApr6dT1Fgj6qm4yocGX6R9puAa+Xvdb4fd3vte+AFt7mV2hd5L2POYsnE5CiquhHXPMQCZzK7n/NSd+ArEVkJ7D/P7i/iOl21HtfpoihVTcFVRXU5rg/zX7I45mFgJK7qqd8DK9xe/gwY7pxKCseVaHo7sa0BbnXaPQcMddpluVqUqn4HxAMJTrsuWbVzMwx4xjnW9biqLJ+Xqp7Eteb3d87f01+4VtYDeA/XabN14lr98b2LHNuYs1jVYGNyEREppK7VDwUYCmxW1f6BjsvkfDYyMSZ3ae2MejbiOk02IrDhmFBhIxNjjDFes5GJMcYYr1kyMcYY4zVLJsYYY7xmycQYY4zXLJkYY4zx2v8DOqH2SW3ASUQAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(ana_change_norms.flatten(), real_change_norms.flatten(), 10)\n",
    "plt.xlim([0,0.06])\n",
    "plt.ylim([0,0.06])\n",
    "plt.plot([0,0.06],[0,0.06], \"k\")\n",
    "plt.xlabel(\"calculated change\")\n",
    "plt.ylabel(\"actual change\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1.         0.87712317]\n",
      " [0.87712317 1.        ]]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "print(np.corrcoef(torch.argsort(torch.argsort(ana_change_norms.flatten())), torch.argsort(torch.argsort(real_change_norms.flatten()))))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env_robustnes",
   "language": "python",
   "name": "env_robustnes"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
