{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b8a819e9",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2e0a16e2",
   "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,
   "id": "1312b8dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "10a22cc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "from ML_Models.data_loader import *\n",
    "from ML_Models.KernelRidgeRegression.model import KernelRidgeRegression, squared_exp_kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "515ea26e",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_load, test_load = return_loaders(\"twomoons\", True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "3da9083f",
   "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": 115,
   "id": "f755faab",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f79546bccd0>"
      ]
     },
     "execution_count": 115,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABEKElEQVR4nO2df5QdVZXvv7tvbshN4HUnIYzQCRA1DwRJaBIRH84MkZlEECQE7CjODI5gHqOOGmYyxDVOiHnOMsgaEJ76nCgsdBRNkNBGxAcamOXgW1ET8wOiYBxR6A5KSOiMJBf6dvd5f9St7rp1zzl1TtWpH/f2/qyVle7bdavOrVu1a5999v5uEkKAYRiGmVh05D0AhmEYJnvY+DMMw0xA2PgzDMNMQNj4MwzDTEDY+DMMw0xA2PgzDMNMQJwYfyK6m4heIKInFX+/iIiOENHu+r+1Lo7LMAzDxGOSo/3cA+BzAL6q2eY/hBCXOToewzAMkwAnnr8Q4ocADrvYF8MwDJM+rjx/E95CRHsAHADw90KIfbKNiGglgJUAMG3atIVnnnlmhkNkGIZpbXbu3PmiEGJW1HZZGf+fAThNCPEyEV0KoA/APNmGQoiNADYCwKJFi8SOHTsyGiLDMEzrQ0S/Ndkuk2wfIcR/CSFerv/8EIAyEZ2YxbEZhmGYZjIx/kT0GiKi+s/n1497KItjMwzDMM04CfsQ0TcAXATgRCLqB3AzgDIACCG+COBqAH9DRMMAqgDeLVhOlGEYJjecGH8hxHsi/v45eKmgDMMwmVGr1dDf349XXnkl76E4Z8qUKZg9ezbK5XKs92eZ7cMwDJMp/f39OOGEE3D66aejHnluC4QQOHToEPr7+zF37txY+2Djz1jRt2sAtz78NA4MVnFKVwWrl56BZT3deQ+rcPB5KgavvPJK2xl+ACAizJw5EwcPHoy9Dzb+jDF9uwbw8S1PoFobAQAMDFbx8S1PAEAqhq1VDWjW54nR026G3yfp52JhN8aYWx9+esyg+VRrI7j14aedH8s3oAODVQiMG9C+XQPOj+WaLM8Tw8SFjT9jzIHBqtXrSVAZ0HVbpYXhhSLL88S0J8888wze/OY3Y968eVixYgWGhoacH4ONP2PMKV0Vq9eToDKUg9Va4b3/LM8T057cdNNNWLVqFfbv34/p06fjrrvucn4MNv6MMauXnoFKudTwWqVcwuqlZzg/ls5QFj18kuV5YtzSt2sAF254FHPXfBcXbng0saPxT//0T7jjjjvGfv/Hf/xH3Hnnndr3CCHw6KOP4uqrrwYAXHvttejr60s0Dhm84MsY4y9WZrEIu3rpGfjYpt3Svw0MVtG3a6Cwi6dZnifGHWks1F933XVYvnw5PvrRj2J0dBTf/OY38eijj+Lcc8+Vbn/vvffipJNOQldXFyZN8szz7NmzMTDgfrbLxp+xYllPdyZGbFlPNz75nX146VhN+veiZ89kdZ4Yd+gW6uN+l6effjpmzpyJXbt24fe//z16enpw2mmnYffu3cr3yNI308hYYuNfYFo11dEVN19+doMnFiTpTckwYdJaqL/++utxzz334He/+x3e//734w9/+AP++I//WLrtvffeize84Q0YHBzE8PAwJk2ahP7+fpxyyimJxiCDjX9B4Vzx8c+pCv9w9gzjklO6KhiQXFNJF+qvvPJKrF27FrVaDffeey9KpZLW8weAxYsX41vf+hbe/e534ytf+QquuOKKRGOQwQu+BYVzxT2W9XSjm7NnmAxIa6F+8uTJWLx4MXp7e1EqlaLfAOCWW27Bbbfdhte//vU4dOgQrrvuukRjkMGef0HhXPFxVi89oyn8Y3JTTvSwGWNHWgv1o6Oj2L59O+677z7j97z2ta/FT37yk0THjYKNf0FJawraisS5KTlsxsTB9UL9z3/+c1x22WW48sorMW+etHlhbrDxLyhxvd12xfamTCNzg2FsOeuss/DrX/8672FIYeNfUDhX3AxVaIfDZgyjh41/geFccT19uwaw+r49qI16TeEGBqu4cdNufPI7+6BqE9cOYTNey2BcwMafaVnWbd03Zvh9RgFlYVg7hM14LYNxBRt/pnCYeraDVbmRl9HdJh4yr2UwruA8f6ZQpKHjTwB+tOZtbWEceS1jYvC5z30Or3/960FEePHFF1M5Bht/plDYFLdNn2rWuLod4vw+LBc9Mbjwwgvxgx/8AKeddlpqx2Dj32K4lpwtGjae7c2Xn41ySS941Q5x/iAsF50yezcDt78RWNfl/b93c6LdxZF0BoCenh6cfvrpiY4dBcf8W4iJsNhnU9wmS4ddfOYsPPbUwdwzYdLKyOEU4BTZuxn4zkeAWv36O/Kc9zsAzO+Ntcs4ks5nnXVWrGPZwsa/hZgIi322xW1FTIdN+yFdxM/cFmxbP274fWpV7/WYxj+OpHNWsPFvISbCYl+UZxv2qIvi6QeZCA/ptuRIv93rhthKOrPn34YkDQVMFL0flWcr86i/tv3Zsb8XJQw2ER7SbUnnbC/UI3s9AXEknbOAF3wzwkUK40Rf7JN51GGKIHvNGTktysVrgXLoOypXvNcTEEfS+c4778Ts2bPR39+P+fPn4/rrr080Bhls/DPChT7/sp5ufHr5OejuqoDgFS59evk5bR9K8DOcZLMeGXl72BP9Id2yzO8FLr8T6JwDgLz/L78zdrzfx5d0ttHk/8hHPoL+/n4MDw/jwIED+PKXv5xoDDI47JMRrkIBcRf7stSDcXmscKjHBJcedpzPwhk5Lcz83sTGPghLOjO5xes947kX1dro2GtpxsZdZ7qYhHqCuPSwk3wWzshhgGJLOnPYJyPyCAX4qpdBw++TVmzcdftJ3cyou6uCv7jg1NTCYNxKsz0QQqXx2tok/Vzs+WdEVqGAT/Q9gW/8+DmMGFwYacTGdeGtOCEU1YyJgNRDKZy10/pMmTIFhw4dwsyZM0GkrwZvJYQQOHToEKZMmRJ7H2z8MyTtUMAn+p5oSH2MorNSxoUbHrVqjRhlvFXGurNSjhVCWb30DKzatLtJn18A2rx5F+sOrkJ1/lgGBqsoEWFEiLZRGS06fsbMwYMH8x6Kc6ZMmYLZs+OnobLxbyO+8WNJjrKGo0PDY7LIUcbYNP6tqtAlQqzCp2U93fjYpt3Sv6k8cBfrDn27BnD01eGm121DdeGx+DOyotQktDvlchlz587NexiFxEnMn4juJqIXiOhJxd+JiO4kol8R0V4iOs/FcZlGTEI9PtMml1AbadxeF882jX8v6+nGVQu7UapPsUtEuGphNwYVDVZMQijdlnnzSWP1vsEO9wuYPrVsvaagW7Dm9QMmT1wt+N4D4O2av18CYF7930oA/8fRcZkAJYuY5tEhuUEaGKxKVUNN4999uwZw/86BsQfRiBC4f+cAuhTyyyYhFNliebmDcGxoWKpumjRWrzLYUydPsvbSo47J6wdMXjgJ+wghfkhEp2s2uQLAV4W3PL2diLqI6GQhxPMujp8nefdT7ds1gHVb92m7Wk0uEYZHBUYNJwZ+nDsYmjCNf6u87lckxtQ0hBJeLO+slHF0aHisXWM4hJI0Vu9qobdv1wA66jF+FVz1y+RFVqme3QCCAen++mtNENFKItpBRDuKvkiTRtcp2+Ovvm9PZDvDoRFzwx/GD02YpqqqDGT48LYhlGU93fjRmrfhmQ3vwLTjJmlDVknTal3IM/jXhs7wc9UvkydZLfjK4hHSu0IIsRHARgBYtGhRoRN081BvDM40orxKVwwMVsc+a1S2isrrDqMKoZjMpFQPGP+4cdNqg1k5hMYLNBhmMtlfVHEaZ/sweZOV8e8HMCfw+2wABzI6dmpknQeuyhxJQsngAUIYN6wjQox5rDLDpUrNDCM7R6ZZOrrc/75dA2MptTaGNXxsUd+fANAVEWYy/Xz+GJ/Z8A7jcTFMWmQV9tkK4K/qWT8XADjSDvH+rNUbbaUOoiiXzGYO4S10WSrLerojDT8gP0emWTqLz5ylHGfc7BnZsQU8Dz0qzCSDlT2ZouPE8yeibwC4CMCJRNQP4GYAZQAQQnwRwEMALgXwKwDHAPy1i+PmjW3XqaQkmVGUOwjlEuFYXeph+tQybr787LEwh4xw6MN0LN0RoR/VOTKZSfnZRCpMzpEstBRnFifLdAouSpdL1PDQ4Bg/UyRcZfu8J+LvAsCHXByrSGSt3mgaTy91EEYCK7wEYMX5c/CpZedIt5epZkY9HHQerOyh6D9IVLFuXWZM8FhRs58oz1oWWlp93x4QAbJJUGeljGnHTYo8B+H9DlZrKHcQpk8tY/BYzVkFNcO4git8E5KleqPMqJY7CCA0eJgjodQeAeBr25/FY08dbDIoJg8w29mN7UNRlxkTPpbOEzdZlJU9PGqaVKijQ8O4bMHJuH/ngPYcqPY7dfIk7Fq7RLl/n7T7/jJMGDb+LYTMqB4LLERGETQo4f2ojHPc2Y3NQ1HlzZeImtJBdYu9IEQuytqGzmojAo89dRCfXn6O9hykUVjGfX+ZNKEiy50uWrRI7NixI+9hZI7N9H/umu8aLbAG6aqU8erwaJMnm1dXMNVnkGXG2DZ36e6q4Edr3jb2u01HsCC/icjQUe23RIRRIWJ/j1lmB3HYqT0gop1CiEVR27Gef8GwLRyLkz0yWK1ps2r8toky6QTduG3f42OTGeNrB5kKWYQ9b1kBWBR+CqkO1X5HhGj4Hj/R94T0PKnOgQCsz2cc8i5YZLKHPf+CofIgwx6sj8wTLncQjp8yyTgc5EMAbl9xrjTGH54VhDNbjg4NN2W2mM4kZJ9B934b713meUeNXYbq/Ic/R1QBXjiDKlxLoBuHvwifhjdue90xxcXU8+eYf8EwTXcMTs+vWtiNx546OGbMiIDBYzWpQSl3eEZJtsZ5SlfFKPYsy2wJYxOvtl1XsInbqySUww+yKH2kgcEqetY/ojW+wf3OXfNd6TayvgRAY3aQ6qH90rFaaovA3Lhm4sFhn4IRFQKRTc/v3zmA1UvPwO0rzsWrw6N46VgNAnWjLDyPkeB5lyBIDb+fvWJiBEyLzWwMR1C7x/c0VWEkk1CXTOFUVZi1rKcbu29egs+uOFerjPrSsRpWf2uPUSgkTjjOzw7ShbTSkoHmorSJBxt/xySJfQPRomQ6z1yXbqgSRAO80MOUcgdWbdqNDoXxCxoBU6Me13BExZ91cftKuYTPrjgXo4pwpm7sy3q68S+9C7RrArURgXVb90V+BtkYTdYp/JlP1DauyaPHNJMvbPwd4mLRbFlPNz69/BxlU3KdZx7ltesUN/3ZgkmuvYlRNzUcsodllMxD8BwB415+8FzF7R/g71vHYLUW+Z3Kvsf3XnBq5GKzH/LSbZeGNx513THtB8f8HWKTq61Lq9PlyEdp1ev+ZlohDOhTFFXFZsdPmWRczQqoC5tUIaXgw0t3jvp2DeDlV5pbMJZLZNw/QCd7Aej7Bwf34297YLCKx546OLY+I1MODQvmydYh0vTGsyxYZPKHjb9DbLpdRVVzqh4OUXpCur/J3qtiVAhlfrkrWQvVw1KlNGrq8d768NPSqt1pdRlpk3z21UvPwOr79iirf3X9g1WZRP76jO9RmzgAnHvPpAUbf4ck7Xble5MmDwedQQj/DfAWT32DNKXcMeahqyqETcIjpvr4tlWxvmx0XME81X6P1MM1JjIK/s+rNu+Wav7Izo9tFpTJOXThjfMDhJHBef4xkd1QgNzzDsdOdVW5OkXMODnXUTn0tjn2SY5LAN57waljAnO63PLVS8+IbbB0+wXkoTH/3Ia/18VnzpLq+sjOj039QVTFsCvS+n6Z4sIVvimiWtgFYLRopvKqg01TZMSRJbBZPHW50KfSx//69me1WTvBuHcw9dNmPLr96kJzqjTaqxZ2G50f0ywck4phV5j2SGAmHhz2iYHuhjIxVDrJYx3BTlWmmKxDuFzoC7ZClOE3XAke08TDtwld6Park6hWfa+PPXXQaMZluqAePAe2n80WLt5iVLDxj0HSG0pmnOIYDRNM1yFsUBkrU9E12wePLE7/+ANfwJJH7sfU6u+AztnAxWuB+b2R+9UtmK/atDtyvDoWnzkLX9v+rNG2/j7TlnJO4/tn2gMO+8TARTVkOKzRbfheW4/NdfGOrpbBtPLX1vCE9/vOjsexnjZiavV5AAI48hzwnY8AezePv2nvZuD2NwLrurz/63/ThbmSfq+PPXXQ+DP5+0w7LMPFW4wKNv4xSOOGMlWbtDWcYWPXVc/2WbVpd6wKZJ2xMnkwxTlP4f3+w6TNmEpDjRvVqsC29d7Pezd7D4Mjz0H2cFCtJyT9Xm0ezP4+0w7LcPEWo4LDPjFIkueuCpmE96lSyozzgAnmjMtCDDt+e3hMGC6YuSQbp85YqUIMppr2KsL7PYVelG94pN/7f9t672EQxH84BEJDYZLWL9gU0fn7zCIsw8VbjAxO9cwQ27Q71wuBqlREk8Vmf5yqBVM/PTOLtNHHJ38EszskDwAqAVd+EdiyUvGJCFg3GHsctuNUMX1qeay1I6diFoi9mz0H4Ui/dB2pVTBN9WTjnyFpa6brFmKj5ApMMDHwaWWuBPd77fE/wSfEFzFp5JXmDcsVYFIFqB5u+lP/6IlYMfVLWHzmrKaZjutsJ3/29odXhxt6KpdLhFuvXqDsjcBFWDnhhwqDM8ZyBbj8zpZ7ALDxLyCuW/WZNFS5amF3U5FSXPxxFsJY7d0MPHADICSfqzIDGK423MjHxGSsqV2PraNvbd68fp5MHgi2n70Q50pD0ceXGbe/sb5GJKFzTkvNAtj4FxAbzz/qpjQNMah0cnxMQj66cebKui4owzvLNwLb1mP0SD8OjM7EZ4Z7pYY/8I4mkTVZ97KsQjRZGGUOOQVQXkt1WmgWwBW+BUSl8T4wWG3IvDGRhjZNq9QZflOZYaCg6YGds9Wvz+8FVj2J173ydbx16E6t4Qeab3tZumVW1bKy7/9jm3ajZ/0jTiuDufo3gOpa8glmk7UJbPwzJKxDH/Q2o/Llwzdl0lRA34v/1LJzmsYUZvrUcjG9wYvXeh5ZkHLFe71OkqyZ8DnOqlpW9WD32zi6egBw9W8A2bUUxs8maxM41TNFdGmdshBQVL588HWbtMIwYS8+mArYUjFgfwr+vZvGF3gnNd7ANjLWYcIPjqyqZXXG16Y3chRc/RvAv5a2rdfE/iNmBy0GG/+UiCrbV93gA4NVIz17mVHrADAaMa7uCIMuzQkvegrccOBcVg97WRsAML9X2xhFR/gB2bdrAEdfbW4Qk0Y4LOrB7sozj+oNUVjSuh7n93r/VJk/gRllO8Bhn5SICt3ovCuTVoqyys1ORetCHz/UY+U1RlTL5o6uoCvAq8NRj0VvcVxWBes/yMMPj7TCYVm1cdRV/ybtRZ0aWVyP83u9xd3OOQDI+1+12KuQEWkF2PNPiajQjU04Quaty8IzKmEyIIFHF7Na1gQnISZVHDbwusnieDjLxTd+Bwar6FDMxKbWO4PZEvW5s2zjKJvppS02l4gUr8cG/FmAjvAMwX8Q+e8vOOz5p0SUSFh48VeFzFtXZQOpmpaXiOJ7qAbGNQ4umt0D0Gf81NGFSXSevj82VcZUnPCL6ede1tON3TcvwWdXnJu5Lk+hs4BSuh5jYTjrLCrs+aeESTxVt/jrIzMwqpuzWhsxyle3onO2fAEs4eKXTbN7LRevjYzPqmLoqrqFtNRJVfvWfe48dHmiZq25JgWkdD3GokgPohiw8U8JE5EwE9mFU7oqTTebbnuB8RTSqMVdIwyMaxycpRk2ZGnIFwBtFzZNxkDw9PttieokFm4hmZYMRZDwcbumlpV9nXMPCaVxPT54I7DzHq9anErAwvcBl90W/b4iPYhiwMbfITKPSFURa1KhWymXcPrMClZt2t1QDxBVlesbfifVuAbGNQ5O0wwj4rO2ap0mabQCwP07B7DotBlOmut0VspNRjXYGCYtIysz5uUOQrlEUkVZZzO2uLi+Hh+8Edhx1/jvYmT896gHQEqOUVaw8XeErUekCi0E5Y8XnzkLX9/+bJOhN5FjcFqoEzCufbsGcOtDT+PAvd9N5I0WOc3QtM1mtTaCdVv3GT9UdOmiRIgMNamMbN+uAWUq6/SpZdx8+dnKMcmuw9qoQFeljGnHTWr6XEm7nTnBZDEWMEsJ3XmP/L0774k2/gZ1JkXGifEnorcDuANACcCXhRAbQn+/CMC3ATxTf2mLEKI1VkUMsfWIVDfLqBBjIm8XbnjUWHcnTBqFOi6n/Mt6utH93IOY87NbcZI4iBdoFp47bzXe1PP23Mdt02ZzsFobM7q6/apmer5x/pgmUytI+Lrp2zWA1fftQW1UfqW8dKyG1d/aIx2TbH8+R6o17L55SdPrLVMYZpqJIxMG1L0uQ1NnUmQSZ/sQUQnA5wFcAuAsAO8horMkm/6HEOLc+r+2MvyAfQxblZkTfD2uN5WWB+00C2TvZrzpiZvxGhxEBwGvwUG86Ymbm/OkHeRRxxl33Dabqv2qZnpTJ3v+l0xWQ0bYyN768NNKw+9TGxHKz2rburJl2kKaZuKQop5C9Xrc4xQQF6me5wP4lRDi10KIIQDfBHCFg/22FLY3kUpvLfh6HG8qzXRAp1owJjeNo4IeF+M2bbOp2q9uDLc+/LTRDE9mZE0/w8BgVVqwZWvMW6YtpGkmzsL3ybdTvR73OAXERdinG0BwybsfwJsl272FiPYAOADg74UQ+xwcuzCoYtiLz5w1ViwUjJ2qpAYGq7WGLKBwrJkA/I/XzcDPnj2SuRSv0ym/yU3jqKAn7rjDC/hhzf9jQ8PSrJgOIsxd07gmohuDzoB31/+uWk+w0XgK1hUAjWmkNqmbLdEW0jQTx4/rx8n2sTlOAUms509E7wKwVAhxff33vwRwvhDibwPb/DcAo0KIl4noUgB3CCHmKfa3EsBKADj11FMX/va3v000viyRpeqFG6lEZeoQgCnlkvQ93YH0v6AGkJOUTgOc6r+rmmdUZgCTp9UfAqozZdeOMc64Td5jmrH16eXnAIByf7rWmFEZW327BnDjpt2Rmk5x9t3SuOjMFV4wnrcE2P9I4wIyULgOYFnq+fcDmBP4fTY8734MIcR/CSFerv/8EIAyEZ0o25kQYqMQYpEQYtGsWfZ51HkSjhM/9tTBJsMQ9agVaM76CObs379zYMxQjAgxNkXPwhNzOuWXSeh2lIGhl8fDPCosvao44zZZJwjvt0TNkfvgor9qDEnj6KWS6YrBOG0v22yjzyNDFnLccVdzCBJIdpwcceH5TwLwSwAXAxgA8FMA1wTDOkT0GgC/F0IIIjofwLcAnCYiDl7ETl6m1Y19uwaMMzhMINhXqmaKqdJicLvKdO+16kvee4aOSnvvNpCRVxWn5WaSNp1xq2ajusOl0Te6pWS/46Jr6xikcw6w6sn0x2OBqeefOOYvhBgmog8DeBhequfdQoh9RHRD/e9fBHA1gL8homEAVQDvjjL8RcQ0ZdDfzpZKuYQp5Q5ldWVhm2+YptWFt6se9oz58o3eduu6NAehTOWk46wTJFkTkfVUWLVpd6RxjSMgmCQ7J/cK36wwXbA1eUAUFCfCbkKIh4QQ/10I8TohxD/XX/ti3fBDCPE5IcTZQogFQogLhBD/z8Vxs8Y0ZdBUGwZolhG++fKzlSEA24yizDBNd4vaThnOqffkXfVkZtPpOKEYF2mQn+h7Aqs27TYWvLMREHSRnVNo0TeXGIcWqaVknIOwqqcFpp63qSdeKZfwL70LcPuKcwEAqzbtxq0PP42rFnanEhtODdN0t6jtLl4Leca7yDxvOo7RTGpo+3YNSCu6dcZVlYJ6bGh47IERXotK4qEXdvbpGpO2jgDyuDZdwfIOCmRxTdNpvWo7Wck8gKZp9P07B6RGI05aXiaYprtFbTe/F9jyAfkxcsibjpPSmCQNUpfvPzBYxYUbHjXW/n/pWA2r79uDT35nHwaP1ZxdKy1T4WuCbp1KpiGkCvG0QE6/DPb8Jag01xefOcvI85Z5YwSM3Zy3rzh3zAOznUa79OKcYdBI3Xi7zjmQ0gJ501oMKpWjvGed9v+045r9uNqowEvHamPX8Opv7Unckauws09bTAoI5/d6ocZ1g97/bXZtsvGXoDLIjz110GhaH27UEsztD9/AbTGNNk2rM9nO5AFhK/mQ9vZRGFYqm3jPKsfA5HqpjQh88jvJaitbpsI3ijiyDKprc96SlmzlmDjVM03ySvVMkrIXJm4qnkpV0ZZEaXl5NW7XHVdWvNNRBo47YTxlNGp7Xbqoi+KgMKq0wVCaYN+ugQb5bhWy61DXECjMbyyv4ZYk6tpd1wV5LYmigHBsf895VcBixPv+5i0B9tw7YYu82g6XWTUmqXjhaXS5g3B0aDhxi8NErRLzbNwenm4HbyKZxzZaq9cHSMZp6+EZbm/V4NxwQXxZT7eRxo/sOrTRHmpbxmZsncCWlfprVxWq8WtPwvsduxfgGX5/Nrr/kQkt7NZ2uIxrKoXd4HlrAJqm0cdPmdTQSAOIl06XKC2vqGqFJotrwXHaCm8ZvG79UFUYmv7RmU0Pjij10OB1GHwAhbPEVDW/XRW5mmzLEzbQ4cdo+Nq9eK03YwxTPew1eAmiuxdaWNiNjb8El3FNnUcWLJAJLuIOSoq8/O0jvcwAJr1Yld5rUS9q08U1f5wGDd5tX7d+qEpixcfEZHxmuHfsGvhE3xNjoZuw4fZ/D16HsgfQ/TsHsHrpGXhmwztw+4pzUe5o3FO5g7DunWfLx9jqyAx0mOC1O7/XCxXK2HF34yxBdy/YXkdRuF5v0sCpngpcKRcG0zNlMVlZwxedUmNURWUwxt9RF34LY9SLtahqhbLWeTL8cdq22jPY3nqRPpA2OHqkHwdGZ+Izw73YOvpWAN41EMzvN+nDHNU8qLBpwWlh4pSEr93qS4oNRaNyrO5ecNnK0bRS3hFs/FMkvNiqImzoZSX5QXTt/ILvkxl+416sRe1PGs6/rkz3xOBGhsa3CY7Ttuerwfaxct3rrQdfp0gmkLXq1OnvmDyAWkJ62RW6PHxAfu2a5u7r7gWXPYUdSZibwsY/JWSetUrOmerb+zdq1GwBkN/8Jn2BjXuxptS43QnhHq5RmR2mPV8Nt0+il2Ojvy9r2Wgyq2sbbLLNpDPC+h3XOUf+3ovXqosKg7OEqHvB9vpSfbaMQ61s/FNCZohVmRyivn24cnNZT7cyhU92k5v0BQ6+P3K/cS7qPMh4nLYhlaDR7qyUUeogjES0XgQavwubWV1bYBsCie2sdADhbgilyc2zBJfXmOqzVabLVW1TCrWy8Q/gSqq2b9eAsXfnozLcNl6mTTjCtdpj5uRVg1DHNKQSNtqqDm5hwt9FlFig3wi+bcI8cUIgtgZ623o0GX4AmHx8uteS6rNNqnjhpIxCrZztUydRTrxkPypkDT8A9XTdJvPIJkW1pSs149YgZJhJ4WOj8OpDAK5a2PhwiargffnV4cj9WtUm5E0WIRDVvpQLwRkcN8PGMOz514lcAE2wH59yB2HF+XOw6afPNeTxl0uk9bhNvUzbcETLLgjG8QozzqTwiSPTIQA89tTBhtei1gpqI0J7rbacDn8W2WZZZbSFZ6m68E6GIUw2/nVcaexot/edfllqhwLbUFTLGnQb4niFNg+MqJCSRcjJZoE3SPg6Wr30jEjph2D9RviaceXcZEYW2WZZHEPmdHSUvXUFVYZaRrRd2Cfu1NaVpINu+9qIwNe2P4taaLGvNiqkBUKuQlFtR5zCGtMHRlRIyTLkFFd2IXwdmUg/BOs3gteM3xxGRmEFBJP24HV9jKB0xCdneP+bhA5VciSTj8+9729bGf8kxtKVpEPcm11WvTthuibZYiohHcTkgbF3M/DADXpZC0vZC9nayl9ccOrY712VMsqhBuyq604n/eCHDm2yzICCp4bqNJ6yPIZM2weIXmvau1ldR1B9Kf3PFkFbhX2STG1dVUT62//d5j3SdDwdwTis/7uMwnprWeCHXGrVRnXFqGyfqCm+f4MLxeKsP0OIEXKKCsWpQnvh1xefOQv37xxousanTS7hn688R1u/AaCpziSsEzRhqoF9HrwR2HmP951TCVj4PuCy25q300lH6EKH/pqSjLwr5dFmxj9p3N61pIOuSldFtTaCj23arRTmAgruraVJOH4aVFeM8pyi8sCjtGH8mzXOImHEGoHsupMt0N6/cwBXLezGY08dVBpp3RqDXzXs1xsQea1D123dh6NDw2NJCIVfDAaSp/o+eCOw467x38XI+O/hB0BUhpHs77rrqQiV8mgz4++yxVxSTyg8k1BVZKpQbdlSufhRqDTSVTfy925KVv6uy6TQ3uDkjfH2N6r121U3c8wso09+Z5+yoZBK8gHQLwz7chEmtQeFXgyWndMtH/Cuj0tuMbsWdt6jfj1s/KOkI2QPft31lKPWf5C2ivm7itu7WmgNtlz8l94FTvTW08rFzzwHXBdH7fsgcMvcxnz8vZvl6XGAm9xv7TRcjI9tz73AgmvMF+tiSGP37RrASwpl16hZ7LKebrz3glObZo7B+8C09qCw4UWVV109bN5zQhXek72ua+auevAr15jmFMLwA23m+buK26eRFmei1xNFd1clNcOfeQ64zIv3GWvOgnGvjjR+iqwBhy06bZggtarXwCPQgUtLjDUC3YK+ySz2U8vOwaLTZijvA1OjXpjwYjDEo8qR9zGdCfozTdnrYRpChoaz1KIKIwZoK+MPuInbp9VX1x+bqk2kjjTDPZnngOu8eBVCUobvEtmagIniYxQx1gh015npNaC7D0xqDwoTXgyHeEyuG5PvZ+H7GmP+wddlxBEHBIopjFin7Yy/C0zWDpKsCaj2H/YzozTdXeHkYWezAOe6G5jtg0RF+AZX9d6tTK//LabaZIQHqLo+uirlSPG4gcEqSvX1JdV1I9N1KncQjp8yCYPHasXK9jFp0hJG9WANX6Nz/xT4zePR2T5xKbgwIht/CVGiZ0nDJKr9R2VypEXihXLbRU3XErWyqboLZIa7o+z1DwiGpRyrTS4+c1ZDcxfAuz5UXbhUip+q67KlGr3YXiuqB6vsGj32InDlF/Mz0DmLE5KwzEXPkkWLFokdO3bkcmydZ6+SWdY137DZf9aEjQfgGRvjxWWVh9w5Rx4bV20PAJUZzc1ZTFh3ZPxnlzdVeF9DRxW6LIrPaonsuyAA773gVHxq2TnS96iuRx+b67Jw6K4VHyp5YUHdd217jbpAdx2GH0aA9+BykAlERDuFEIuitmPPX4EuZuoiTFIkDZ7EnqDtoqYqFOJf+Hs3ewvCTUZW0Q6nc874z64F3MJT93Vd8u0czWZUFbphobcgUdddYbN2TIhq22lqMLPuSR11HWbctUsGG/8YuKwnKAqJHka2i5qmnZHCntO8JcDPvuplA/l0lBun+WnfVCkrQaoM9cBgFXPXfNe6sAsAOitlXLjh0YYHO9AiYR9Z207Ak0ewmdUpF/CFNytwHXKJug6zfhhJYOMfg7QboRQpJGREnLQ23WJY2Ogv3zj+MNj1b43bhvsjpH1TKdcBjnqzgoRhpqgKXVkcX9fzudxBODo0PFbINTBYxer79gCE1qnodbFwqptBmMwObUOJykyx+utZyUlraKsiryTYFDm5aISiOl7cArNcG3W4VGDUqWZuW9+8FjAy1Jg9FEfx04bwZ63M8B5A1cPN443B4jNnaaU9AC8N9+827xn7rgGMXY/AeMOg7q4Kjp8yqaF3BOCpyIZfa3vBQP97q8yQ/11XeBeneZAqCcF/PY44oWN4wRcOFjwdHk9VBKZbtMt6/KmiW5g70g+58AV56ohAqgtp1uO1XEiUfY8m6L5rm5oSApp6Pbcd2gXkwHVk8h7dd7yuUz0GPzkhpWwf0wVf9vyRvXSy7nhxFpNbQvrZtIWiLmxj4tVnoQMfHpfN6xritHwE9N+1zTpU4des4rThDL/HVqMHiPcdB5MQVK+H5aSBTNuMcswf6VX0xjlenMXkrMdvTFC4LZipo4ux6mKhpmsLWRbXOIzdJvm+VO9VFXQFY/5AgSp6VcTJ4pK9R5UxBlKHXOJ8x7brYDm0GXXi+RPR24noaSL6FRGtkfydiOjO+t/3EtF5Lo7rClddvFwcL444XdbjNyIs3CbTyJHFWHWx0Cy8elvv0mHsVvV9dVXKY+tLpfACd8R7ZetTt75rAW69ekGiNavMiSGQJ68OFkDTqgoBc//E297/3h+8cfw6GDrqtV0MYpLQYHOtxvl8CUkc8yeiEoBfAvhzAP0AfgrgPUKInwe2uRTA3wK4FMCbAdwhhHhz1L4nYsw/3MTD113Xld0XMuZvUpyjirFmUfkoOwYQb73A0XhNvkfX33VumWW252xdFyLXe4zfg/E1JD+FOCzT3URHfdIwmo4URJzPp8A05u/C+L8FwDohxNL67x8HACHEpwPb/CuAfxdCfKP++9MALhJCPK/bd5YVvi5uApt9mGxrc6MXLj1Ud+P5mC6Kun4YqBaFJ1VSrd41wfS6cPFd5+Y0yM5/Rxk47gR1/n6cRVfdey5eO35NUYda4lmF6yQCh4kDWRr/qwG8XQhxff33vwTwZiHEhwPbPAhggxDi8frv2wDcJITQWvY85R1MCQpqydrkJbmRXMhI5EaU5y+7eeJ443EeDEazkiD23lcrkNv1ZXL+w9dHnCwu1XsWXGPg6Rvg0ilwmKWWZbaPLAgZfqKYbONtSLSSiHYQ0Y6DB9Ul7UUgmJMPNH+gpBk3hV3INUHaAKN+Gcjin6pcal33rjj514B9Jk4B+q2mQW7Xl8n5D8e746z3qN6z/5Hkhh9wW42bdZYa3GT79AMI5jXNBnAgxjYAACHERgAbAc/zdzC+1DBJzUtyI7W0jIRKwsF/bctK73/fU1cteKlu0iP9ZlIOslaRqkYeMgrWgMMluV1fUW0RfcLGNU4Wl+w9W1ba7UOFa6cgYwloF57/TwHMI6K5RDQZwLsBbA1tsxXAX9Wzfi4AcCQq3t8KmBj2JDeSq7aUuSHLY1Z56nG88aj8a1WrSJv4bkH6raZBbteXri1ikLRmXLb7LU+zz/ZpARIbfyHEMIAPA3gYwC8AbBZC7COiG4johvpmDwH4NYBfAfgSgA8mPW4RiDLsSW8kFzIShULnqatuyMoMbzEwiC/mFlX0FdUIhEoASF2KX6B+q0mRyX/kdn3JJDLCxjWol+S64Mn04eMzdQZwxeczDclkAcs7SDDNplBpr2fRfasl0aWzLd+oXpzb9W+Nmj6lyd7NCKj77nbOMU81lS22AZ5RuuSWlr/JC5kKHCbcpzfc08F1do1MMVbW1hFAqy34Z5btkyZ5GH/bG6VwKZZFJiqdTZa5M1YhHPUeWfWmqpoztA9A3UOgowws+4K90UmSnuo4tVWV1dNVKWPacZOKd+3m0XhFd1wq5dvxyxI2/jFp6fTKohMnnc20+EWZPqh4AMiOe8tceZ5/ZQZw0zPy8clIkraXgjCdibjbOzsex03lzTiFDoHybjbusODJCtUMEEhXHNAxLOwWk5ZOr8walRSC6vU46WymEs3KBWMxLqblx/ZVx1U1grdtEJ+kVF/33jjCZohem3pnx+PYUP4yuulFkANZ6sSkLcutwr8+ZWtAKUst5AELu4Vo6fTKLFEJUT27vbGAJixQZZvOZto8RSm+lV117hhJlD6V730utvCXrtkLAPzDpM2YSqE+CVm2FJTF38NFWFll18zvVaeCZthlKwvY8w/R8umVWaHyUHfe41agyrR5yrwlyQXWVI0+VK+rUGYuTY/23FXvpVLs8yrL6pk+dTyD6hR6Uf5GU2MXc0Yy9t5w+u+ee72F/rwE/PKaeWQMe/4hEjcznyioDIMqhz6O1xTOAKlMl4dgalWvavPyO5MtlF5yC/DtDzVnFl1yi924lbOVl8fHr/LcVVLAumI3A8I9moOJDQfEiZgtewCYGLukUsQqJ2L/I+nN2KLGHKctaQvCxl9CombmEwVVmIU6POVD2fY2hG/QqLj7kf7kFZJRjeWT7GfoaPNnkIVWVGNQZj3F80aX9XSj+7kHMednt+Ik8SJGEQoDmBo7kyprHaYhMpsMKFlVty/mpqsm98fs6jrQji1FxVpD2Pgz8VB5tzLDX5ps7zVFFWiFcdmj1+RmjLqJw/tZ1yXfj8z4qcbg0hvduxlveuJmANUxyaVReD9S0FBGkbSTWVSjFFkKrm52EXYa/Jlo8D3K5uqBMachtZBDwxYdHPNn4iHL3DnuBHnYZ/Lx9he3TZgo6yl5HEG5pHFk18JfkodrB4AD4kT0XfSw+X6Tfi5Zte3Ygn6nt/iqCvXJ1jt0TkOt6j1IpDqTFmOOSw4NW3Sw58/Ex9S7rb5kv29T8S+QtziYpeekUxpVjcNFHDmmNyotRFQ8XE/GIdz68NPmYc+knyscYilPBWrBEJmmQkH2GaKcBmX4UNPG0RUO+z27gD3/giLTYik8LrMkjPVXhLc46JMk88SEvZvVBkRxE/ftGsCFD52Ijx79a/wOsyAy1IcJyo4LAAODVXx8yxM4VnmNdPsDYqZX0xI+j8G2hklrN8L4AoDLNwK1Y+bvk11Xsb13kb4DUbAsIjb+BUR1wxb+AeCwn600xVOFVMUzQbGS7gGim6JLbuLgd/nt0bfiglfuwFkj37QLrSRAJjterY3gM7UVqOK4htePicn4zHAvrj3+J83nccdd6vMaVm+NanmpPbeGigOq68pWtM1HJe7nEpf3hwPY+BcQ1Q2bpDFMJiTxAmVGIWhUbnpmvFI3jE7F0zam+uCNXpxZZeh0U3TJTZz3d6mqTP/Ky+fjyfP+FwbEiRgVhP7RE7Gmdj2+X/pT/EN5U/Rie/C8ms62oh7OpuGPygz1ddVwDcLcqIuRwOfoBD45w/vf5ewxh4YtOjjmX0CSSkzkKjYXJy5tmgURFV9OGlPduxnYcTeavM9gPF+1FlGZIf3cecuF6CrW3/TO/4m+OZc1XCufXnoGpn77d2Y7P9Jvl8ESlWIZtc5jmoUkuwajWkdWZkRnCbkw0hk3bNHBnn8BUUlJmEhMtGTIyNRjj/KcksZUdWEH/wGimrorCsGSfJcuiKpYX9bTjR+teRue2fAO/GjN2zwnwTgGLYAHbjCfbemkKwB1689F1wHrjkSHlHTowkF+vwhdllCb6foAbPwLSRKJibzDDLGw8dh18WWVYZ63xCwsoZsh+AbRcuqet1xIrIYtNnFzm4pu5UOFxsN84XO7fCNw2W1mY9Hh71u2djQmF6KhzXR9AA77FJIkEhN5hxliEVXoY4qsMjMsEqabxivDDqE0wPDU3Y8VSwq+iiAXYl2xrjqP+x8xTL+F/Lu7eG1dNC08uxKN1bVphUX86t6woR8Ziu7r3Ga6PgDr+bcdLdmPQKdhDyQrh7dpDCLVcydg0fvV3mcK+vuFIlzJbGL8dZ9/XafiTRl1y1L2CoBaQ6nFvk/W85+g5B1miIUqlAIkT920DSnZhh0KVrXpFFl2jqo6NojOUEZlbKWNcl1ojjxLqE369crgsE+bUYQwQyxUGRpJRMMA+5CSbBw6HR+Th0ueYl5hbRxfeM8kc0YqlSCgbY+pyHoaw7QiODxuV/2UdccvUCZOFrDxb0PaRpXURTl8UvmBqFRGE2GyvMS89m4G+j4IjNbGX/OF90zGoeuOVpkhXyQdenl88VaGiWKmbNzVw57ctm68JqSp2NlicMyfKS5xG3nLOkPtfyTeza5s6t0BXPmv3s+6mL/tZ3A5S4jKbQ+PI3xsmQx18D2qnsfhz2b7mXTjzqMzW4vBMX+m9YlTDq/qDHXxWjP5gTDKpjWj456oLvXTZvYiG/uWlV7VcRxs2kbKjv3qHzw57gbIe5gCasG+cMjLdt1GN+42TLnMCzb+THEIywQA9uXwrhdgdQuRI0NeXFrn1SrfL+TaNrIY+4679cZSJa9gsoiqk8YYrdULoIKLvMJ7mO7dbFZUF+f70I27DVMu84KNP5M9MmOl8hABc9EwwL1sbtTaQPWw3qvVFUw1aduoQjRCbSxV5+3BG72wjQ4TaYzaUSjlLrRa/F368E2URlJHufn1OE2BkpK2SmyOsPFnskVlrHQa+TbEkXjQ3eDze+0auIfHHBYa022vEyFTGUuVZ73jbnk8nuq3fOccrw/CtvXe5yZLU3DkOe+9wUbrlRmBatmI1FDd9zG/F1j2hcbzXpkBXPH5bBdmo0T+Whxe8I1JruJprYzJImQDlsU/tkVXJoVdsuyTOGPWFRh1zokWNZMtdOr2qduH9HOHKFeASRW99IHJ4nY4NbQViqb2blZUI6Pwi8684JsiLSmeVhRswy9xJB5s1glM4uwqT1Q1I4gz+9AWUGm6TNmcnyPPjc9sVO0OqYSG83bJLXqdn+DMRZcamkTGOI3QS9Q+TUT+WhzO84+BTjyNvf8IdJLIw9VmgzR0VJ83LsOmWEdnsILFZKriL9kswxeSCy8Cy2oOwsdsKqCqz0Js2kPqirD80IVqDGJUPmvZtj46fq+seUjgKcvqJLasBJ7dHl/wzaT2wkTkr8Vhzz8GLSmeVhR0ksgy1cXq4XTjrFpvPMLDk80yFlzjZcPI4sRR8X8A414y6l54vU2l6vPLxrDo/dHeump9QXY+fCXVKGmGeUvQNHuJ26nK98y3fCB6ZmY7MzDJQNIpkObUecs1bPxjkLdGe0ujC8vM7wUmT2t+T5paObobuTI9+v1hien9j+gNS6QhnTP+gAw3FNE9AIJjuOy26IeMGLGvodDVXezd7D30wrOWBdd449MZaFm/4LGkAOUH8M6pyzqC4OvK3gKaWViLwcY/Bi0pnlYkdJr8rlM1TcYie+DExXT8OkPqolYh6iFTmeEt5gZ/j4rF6x7cqrUTf9aiMtCyv+24O7qNJOCdU5d1BMHX0+wtUBA45h+DlhVPawVUcWPq8DzDNLRYho7JX1dVsOowFZLTacxsWSnfd5wH4LwlXvP1MK8eAUYD61bDGmNrIs+ge+hFGWipeJwBnbPjOQumek9tLvTGxj8mbSOeVjRUi6JJe6rqDJirZjKq8avCKSrjEmc8qs+3/xH59qONCQtKtVRTYTrdmFOZzdH4LMn2XLG4G4CEYR8imkFE3yei/fX/pUFSIvoNET1BRLuJqJiJ+0wxCE+3ZQuTtiGQqLhwHA0h0/HHSW1UxZt9TZ0wus9nY2Bl25qGVXTnUBdm0S2sahHjGVRxvjtd6HGCkDTmvwbANiHEPADb6r+rWCyEONek+ICZ4ARvTF+COIyNUYsyYLL+rpMSLN4nNSzze72FUpWmThjd57OavUj0hky9dn/M/sOaSuOLvToDrfrbovfrF6z9v7l42E5QkoZ9rgBwUf3nrwD4dwA3Jdwnw4zjIiRjasCCcW8/xRTIx5DsfwRKTR3jePtzwPIveeqjI0Pjr1MJ6Cg1vhZ8j02/Ah8/28cPz4kR7/dTLzALs6j+ZltLwRiT1PP/IyHE8wBQ//8kxXYCwCNEtJOIFKtZDCPBRUgmLfXJNLGJk+tCJ89uB8ISLtQB9Pylmd6QSpjOL77zMZldqWZDUX+zqaVgjIk0/kT0AyJ6UvLvCovjXCiEOA/AJQA+RER/ojneSiLaQUQ7Dh48aHEIpi1JK4YefoBknWIahY1ExMVrIY+RC2DnPc2aRKM1b2ax6knF+zD+uWUhMcCbGW35gNfQRbe24OL82dZSMEZEhn2EEH+m+hsR/Z6IThZCPE9EJwN4QbGPA/X/XyCiBwCcD+CHim03AtgIeMJu0R+BaXvipNyFs18WXKPv5uUy4ydqLKoQRXC7ynRPwjgYmtFlDW35gPzYYkT+eqQkQyjnfdt6ucBb9bAnekfUPMMI7ycK0/NUtAd1i5I07LMVwLX1n68F8O3wBkQ0jYhO8H8GsARAcSXxmNYnTjcvlxk/UWORhSjC21UPe8a0MgPaGY9fHasiSsZBlVkUFIED9IZ1tCZfmI/TK9kklBNHOI9pIqnx3wDgz4loP4A/r/8OIjqFiB6qb/NHAB4noj0AfgLgu0KI/5vwuAyjJk78Pq2sEdOxqDppTZ6mfmA1GEwJ5Qqw8H36h1qT3lBAFC5ogG0NK5Xszp/Nd5bkQd3GzVlsSZTtI4Q4BOBiyesHAFxa//nXABYkOQ7DWBE3LJBGRafJWPZujtfxSiXLDIxrBM3v9TJudOEU/3PL9PiDXbui9P+DiFE3vZJlr8ct0jItWJsgcIUv036kGb93PRbfIOner0IpfEaNEsqmDzWdAfbf/72b9M1dfGzPte13FudBrZtdTEDjz8JuTPuRVvzelGBoYeiot3CrGovOe5dV9Y7tu1N9/LgPuahY+vxe4KZnvNqBYOtG3eczJYvvjBeKG2Djz7QftvF7l3Fg24VbreEJVfVGxfh9gg3UbT6LqQEOpl7e9IzXWzfpWkkWlbq8UNwA9/BlJja2PX+jUPWxVXWzMulp7L/Xuv8x7D+LabplK+L6uy4o3MOXYUxwXdlrG1pQVdDK3hsnPBGnD4AvxubLMetmD62UPcM6QA3wgi8zsXEdB9b1I5D1Im7IXFF49X5YQrXvKGw+i01GTCtmz7S5Rr8N7PkzExtdHDiOV6vy5MWIumjJj6Ev/5I+5q6UcYjAJqZtMxMqmh4SYwUbf2Zio1rknLfEvjcsMB5aMO1DEHzAbFvvyVCowhLze2Hc5cqnNNkuY8ZmJsTZMy0NG39mYqOKAycRD5vfa9aHII4MhU7jXsbk4+3CHDYZMZw909Kw8WcYmaRwUq82LRlplRaPCts+xDb59nnXUzCJYOPPMDKSerVpyUjLZirLN6pnBLZeuE1GDGfPtDSc7cMwMmwascsw0Z+JK0OhylhJMl6T/Ztu2861Am0EG3+GkRFXPCy8D932SR8wccabtmFuxfTPCQpX+DJMnmTpJWdR4Wpb4cw4x7TClz1/hsmTLIuOslC15PTPloGNP8O4pGjx7uB4VDUCLg1zEjntop27NoeNP8O4Iu94d9h4zlvi1Q1ENWBxmZcfdx0j73M3AeFUT4ZxRZ5yB3s3A9/+UGPB2I67og2/67z8uOmfLBWROez5M4wr8ox3f+8mYGTI4g1kFlqJE4qJs47BawWZw8afYVyhindXptezYFKMZZu0VvQxzbzJMhSTtPUmrxdYw2EfhnGFrKq3owwMvWwvEJcWNmGeLEMxSaQiZBpJeZ7jFoE9f4ZxhazQauhos1deq3phmrCnGn6vjfdamSH3/svTgKkz4u0zy1BMkqI6bsweCzb+DOOScLxb1Wi9enjcWB95Duj7IEA0Hre3DbFccou3j9Ha+GsdZeDyz8Y3gFGhGNehlrg1D7xeEAsO+zBMWuzdDOPmK6O15gVbmxDL/F5g2Rcas2yWfSGZMdaFYooUamFp6Viw588wabFtPaybr4Sx8V5dVwvrQjG3v7E4oRaXGkkTCDb+DJMWLsIOeXuvqgdKkUItLkT4JiBs/BkmLZSpnzOA4Wqjp9pRboz5A8X2XpOmZrqGG7NbwzF/hkkLVcz8kluaq2CXfQG44vONry24xvNmbRrIZwV38Wp52PNnmLSICkeoumMBxde64VBLy8N6/gxTRFgXn4mJqZ4/h30YpogUaUGVaUvY+DNMEeHcdSZl2PgzTBHhBVUmZdj4M0wRiauLzzCGJMr2IaJ3AVgH4A0AzhdCSFdniejtAO4AUALwZSHEhiTHZZgJAeeuMymS1PN/EsByAD9UbUBEJQCfB3AJgLMAvIeIzkp4XIZhGCYBiTx/IcQvAIBIK151PoBfCSF+Xd/2mwCuAPDzJMdmGIZh4pNFzL8bQDBhub/+GsMwDJMTkZ4/Ef0AwGskf/pHIcS3DY4hmxYoK8uIaCWAlQBw6qmnGuyeYRiGsSXS+Ash/izhMfoBzAn8PhvAAc3xNgLYCHgVvgmPzTAMw0jIQtvnpwDmEdFcAAMA3g3gGpM37ty580Ui+q3izycCeNHNEFOh6OMDij9GHl9yij5GHl9ywmM8zeRNibR9iOhKAP8bwCwAgwB2CyGWEtEp8FI6L61vdymAz8JL9bxbCPHPsQ86fuwdJvoVeVH08QHFHyOPLzlFHyOPLzlxx5g02+cBAA9IXj8A4NLA7w8BeCjJsRiGYRh3cIUvwzDMBKSVjf/GvAcQQdHHBxR/jDy+5BR9jDy+5MQaY6H1/BmGYZh0aGXPn2EYhokJG3+GYZgJSMsYfyJ6FxHtI6JRIlKmNRHRb4joCSLaTUSZ9YC0GN/biehpIvoVEa3Janz1Y88gou8T0f76/9MV22V6DqPOCXncWf/7XiI6L+0xWY7vIiI6Uj9fu4koU9F9IrqbiF4gIml/xwKcv6jx5X3+5hDRY0T0i/o9/FHJNrmdQ8Px2Z9DIURL/IMnG30GgH8HsEiz3W8AnFjE8cGrc/hPAK8FMBnAHgBnZTjGzwBYU/95DYBb8j6HJucEXtrw9+BJhVwA4McZnjOT8V0E4MGsr7nA8f8EwHkAnlT8PbfzZzi+vM/fyQDOq/98AoBfFuwaNBmf9TlsGc9fCPELIcTTeY9DheH4xhROhRBDAHyF06y4AsBX6j9/BcCyDI+twuScXAHgq8JjO4AuIjq5QOPLFSHEDwEc1myS5/kzGV+uCCGeF0L8rP7zHwD8As3ik7mdQ8PxWdMyxt8CAeARItpZF4krEnkrnP6REOJ5wLugAJyk2C7Lc2hyTvI8b6bHfgsR7SGi7xHR2dkMzZi8rzsTCnH+iOh0AD0Afhz6UyHOoWZ8gOU5zELbxxgHCqIAcKEQ4gARnQTg+0T0VN3zKML4rBRO46Abo8VuUjuHEkzOSernTYPJsX8G4DQhxMvkSZn0AZiX9sAsyPP8mVCI80dExwO4H8DHhBD/Ff6z5C2ZnsOI8Vmfw0IZf5FcQRTCk5aAEOIFInoA3rTdieFyMD4rhdM46MZIRL8nopOFEM/Xp6wvKPaR2jmUYHJOUj9vGiKPHbwRhRAPEdEXiOhEIURRBMHyPH+RFOH8EVEZnmH9uhBii2STXM9h1PjinMO2CvsQ0TQiOsH/GcASeK0mi8KYwikRTYancLo1w+NvBXBt/edrATTNVnI4hybnZCuAv6pnXFwA4IgfvsqAyPER0WuIvHZ2RHQ+vPvqUEbjMyHP8xdJ3uevfuy7APxCCHGbYrPczqHJ+GKdw6xWrJP+A3AlvKfvqwB+D+Dh+uunAHio/vNr4WVj7AGwD144pjDjE+NZA7+El0GS2fjqx54JYBuA/fX/ZxThHMrOCYAbANxQ/5ng9YH+TwBPQJPtldP4Plw/V3sAbAfwPzIe3zcAPA+gVr8GryvY+YsaX97n763wQjh7Aeyu/7u0KOfQcHzW55DlHRiGYSYgbRX2YRiGYcxg488wDDMBYePPMAwzAWHjzzAMMwFh488wDDMBYePPMAwzAWHjzzAMMwH5/1y5lPK9c1rUAAAAAElFTkSuQmCC\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": 151,
   "id": "4ff4819c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from ML_Models.ANN.model import ANN\n",
    "kr = ANN(input_dim=2, hidden_layer = 40, n_epochs = 15000, weighted_model=True, train_set_size=len(labels), fit_scipy=True, l2_reg_lambda=0.14)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "5b1c6644",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sklearn loss: 67.6449606601218\n"
     ]
    }
   ],
   "source": [
    "kr.fit(data, labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "ed78bf0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "yhat = kr.predict_with_logits(data_test).detach()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "dfe2514f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f795437a790>"
      ]
     },
     "execution_count": 154,
     "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_test[yhat<0.0,0], data_test[yhat<0.0,1], label=\"y=0\")\n",
    "plt.scatter(data_test[yhat>0.0,0], data_test[yhat>0.0,1], label=\"y=1\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "id": "cc5b7c1d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3000, 2])\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).detach()\n",
    "yhatbg = yhatbg.reshape(len(v1), len(v2)).t()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "8c3a5efc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7f795497f700>"
      ]
     },
     "execution_count": 156,
     "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": [
    "c = plt.pcolor(v1, v2, yhatbg, shading=\"auto\")\n",
    "plt.scatter(data_test[yhat<0.0,0], data_test[yhat<0.0,1], label=\"y=0\")\n",
    "plt.scatter(data_test[yhat>0.0,0], data_test[yhat>0.0,1], label=\"y=1\")\n",
    "plt.colorbar(c)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "babd0ae3",
   "metadata": {},
   "source": [
    "## Find counterfactuals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "85de6e99",
   "metadata": {},
   "outputs": [],
   "source": [
    "from Recourse_Methods.gradient_methods import SCFE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "044fb184",
   "metadata": {},
   "outputs": [],
   "source": [
    "scfe = SCFE(kr, setting=\"regression\", lr=1e-3, max_iter=1000, target_thres= 0.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "85f33fd5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/dsar/miniconda3/envs/tobiaspytorch/lib/python3.8/site-packages/torch/nn/modules/loss.py:528: 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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No counterfactual explanation found\n",
      "No counterfactual explanation found\n",
      "No counterfactual explanation found\n",
      "No counterfactual explanation found\n",
      "No counterfactual explanation found\n"
     ]
    }
   ],
   "source": [
    "# Randomly sample some points and compute cfs\n",
    "yhat = kr.predict_with_logits(data_test)\n",
    "mycfs = []\n",
    "for i in range(len(data_test)):\n",
    "    if yhat[i] < 0.0:\n",
    "        org_point = data_test[i].reshape(1,-1)\n",
    "        res = scfe.generate_counterfactuals(org_point, target_class = 1, _lambda = 10, step=0.0)\n",
    "        mycfs.append(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "33089d78",
   "metadata": {},
   "outputs": [],
   "source": [
    "mycfs = [i if i is not None else torch.empty(0,2) for i in mycfs ]\n",
    "mycfs = torch.cat(mycfs, dim=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "c36c1c1b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2.7802e-03, 5.1022e-03, 2.7812e-03, 1.7412e-03, 5.3580e-03, 4.2813e-03,\n",
       "        1.5500e-03, 3.2742e-03, 2.1834e-03, 8.7862e-03, 4.9772e-03, 1.8620e-03,\n",
       "        3.6314e-03, 2.2883e-03, 2.3861e-03, 2.9795e-03, 1.4143e-03, 1.9963e-03,\n",
       "        1.0120e-02, 1.1053e-03, 1.1923e-03, 2.4295e-04, 4.8769e-03, 2.0177e-03,\n",
       "        4.1225e-03, 1.7402e-03, 3.9933e-03, 4.6213e-03, 1.5852e-03, 8.3947e-04,\n",
       "        1.3697e-03, 2.0373e-03, 5.8563e-03, 1.2205e-03, 6.5112e-04, 3.9685e-03,\n",
       "        3.5565e-03, 3.1133e-03, 1.3461e-03, 5.5623e-04, 3.9158e-03, 3.4022e-04,\n",
       "        3.4502e-03, 9.0473e-03, 1.9596e-03, 3.7653e-03, 2.3510e-03, 2.2213e-03,\n",
       "        1.4661e-02, 9.3150e-04, 2.9018e-03, 6.3658e-05, 4.1349e-03, 1.6878e-03,\n",
       "        1.0672e-03, 4.4835e-03, 2.4998e-03, 3.5284e-03, 2.1551e-03, 1.5581e-03,\n",
       "        2.8026e-03, 4.8909e-03, 8.2471e-03, 4.7486e-03, 1.9829e-03, 1.8337e-03,\n",
       "        3.7122e-04, 2.4893e-03, 4.6237e-03, 1.7545e-03, 1.0803e-03, 1.4327e-03,\n",
       "        4.4281e-03, 3.8624e-04, 2.5570e-03, 9.7172e-03, 6.0582e-04, 1.8718e-03,\n",
       "        2.7869e-03, 7.3290e-04, 3.6366e-03, 3.6819e-03, 1.9886e-03, 9.5272e-04,\n",
       "        6.0534e-04, 2.6615e-03, 2.0549e-03, 6.2585e-04, 2.1083e-03, 1.2925e-02,\n",
       "        3.6132e-03, 3.3336e-03, 8.0903e-03, 4.1034e-03, 7.0119e-04, 1.7858e-04,\n",
       "        1.1213e-03, 2.7263e-03, 1.9066e-03, 1.8799e-03, 5.0759e-04, 4.3728e-03,\n",
       "        3.8502e-03, 2.9325e-05, 1.6448e-03, 2.0816e-03, 7.0882e-04, 2.6727e-04,\n",
       "        3.0453e-03, 5.8663e-03, 2.4819e-04, 1.7302e-03, 1.0998e-03, 7.8368e-04,\n",
       "        2.1937e-03, 6.6209e-04, 1.2324e-03, 4.8399e-05, 1.5478e-03, 5.1849e-03,\n",
       "        2.7895e-05, 7.4928e-03, 1.8859e-04, 1.6856e-02, 1.5504e-03, 2.2488e-03,\n",
       "        2.7235e-03, 5.6195e-04, 3.3832e-04, 6.6543e-04, 2.3859e-03, 1.3483e-03,\n",
       "        3.9887e-04, 3.0015e-03, 1.3921e-03, 4.7088e-04, 2.8980e-03, 7.2687e-03,\n",
       "        3.0131e-03, 1.1327e-03, 9.8443e-04, 3.6931e-04, 2.9514e-03, 1.4145e-03,\n",
       "        2.9378e-03, 3.2804e-03, 1.2300e-03, 4.8525e-03, 2.5756e-03, 2.0001e-03,\n",
       "        1.5347e-03, 1.0133e-03, 6.8746e-03, 1.1611e-04, 2.9924e-03, 2.7966e-04,\n",
       "        4.5657e-04, 5.2640e-03, 1.1261e-03, 1.6475e-04, 2.7897e-03, 4.8399e-05,\n",
       "        5.7673e-04, 2.5282e-03, 3.5450e-03, 3.4988e-03, 1.1966e-03, 4.1125e-03,\n",
       "        1.4223e-02, 1.8191e-04, 5.9605e-04, 1.0023e-03, 2.5599e-03, 2.2998e-03,\n",
       "        5.3196e-03, 4.6561e-03, 2.1086e-03, 4.8900e-04, 3.1292e-03, 8.4264e-03,\n",
       "        1.2100e-03, 6.4921e-03, 5.5187e-03, 3.7973e-03, 1.7962e-03, 5.3954e-04,\n",
       "        1.4961e-03, 5.8889e-04, 4.1177e-03, 3.3276e-03, 4.4792e-03, 3.8588e-03,\n",
       "        2.0916e-03, 4.4608e-04, 2.7111e-03, 2.7659e-03, 1.4336e-03, 2.7966e-03,\n",
       "        1.3390e-02, 5.3954e-04, 8.5855e-04, 2.1384e-03, 2.9576e-03, 3.9847e-03,\n",
       "        1.9057e-03, 1.6806e-03, 4.4019e-03, 1.3082e-03, 7.1144e-04, 5.7440e-03,\n",
       "        1.7362e-03, 2.0421e-03, 3.4318e-03, 4.7436e-03, 3.0272e-03, 1.5812e-02,\n",
       "        1.8096e-03, 9.2208e-03, 4.0634e-03, 7.4744e-04, 2.3179e-03, 6.9633e-03,\n",
       "        1.2169e-03, 6.6519e-04, 2.5194e-03, 3.6519e-03, 1.6062e-03, 1.7011e-03,\n",
       "        6.8688e-04, 9.4700e-04, 1.3707e-03, 6.5112e-04, 8.1189e-03, 5.3215e-04,\n",
       "        2.3532e-03, 4.3130e-03, 4.1091e-03, 2.3401e-03, 1.4570e-03, 2.6751e-03])"
      ]
     },
     "execution_count": 161,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kr.predict_with_logits(mycfs).detach()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d66b9b93",
   "metadata": {},
   "source": [
    "### Plot the CFEs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "id": "a7c38261",
   "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(mycfs)):\n",
    "    plt.scatter(mycfs[i][0], mycfs[i][1], c=\"k\")\n",
    "    #plt.annotate(\"\", xy=(mycfs[i][0], mycfs[i][1]), xytext=(data_test[i][0], data_test[i][1]), arrowprops=dict(arrowstyle=\"->\"))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "118d0bca",
   "metadata": {},
   "source": [
    "## Compute the deletion curve"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "d2d55acb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sklearn loss: 67.6449606601218\n",
      "Invalidation rate (0)  0.0\n",
      "Computing 1th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 500])\n",
      "tensor(47) tensor(172)\n",
      "Deletion of point 172.\n",
      "Sklearn loss: 63.60793058133011\n",
      "Invalidation rate (1)  0.5416666865348816\n",
      "Computing 2th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 499])\n",
      "tensor(30) tensor(176)\n",
      "Deletion of point 177.\n",
      "Sklearn loss: 62.25847609519728\n",
      "Invalidation rate (2)  0.625\n",
      "Computing 3th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 498])\n",
      "tensor(34) tensor(279)\n",
      "Deletion of point 281.\n",
      "Sklearn loss: 61.55624766866162\n",
      "Invalidation rate (3)  0.8541666865348816\n",
      "Computing 4th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 497])\n",
      "tensor(48) tensor(102)\n",
      "Deletion of point 102.\n",
      "Sklearn loss: 57.97844680599964\n",
      "Invalidation rate (4)  0.6875\n",
      "Computing 5th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 496])\n",
      "tensor(40) tensor(102)\n",
      "Deletion of point 103.\n",
      "Sklearn loss: 55.8106755331955\n",
      "Invalidation rate (5)  0.7708333134651184\n",
      "Computing 6th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 495])\n",
      "tensor(48) tensor(110)\n",
      "Deletion of point 112.\n",
      "Sklearn loss: 54.62527971052737\n",
      "Invalidation rate (6)  1.0\n",
      "Computing 7th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 494])\n",
      "tensor(48) tensor(0)\n",
      "Deletion of point 0.\n",
      "Sklearn loss: 54.82018036673742\n",
      "Invalidation rate (7)  1.0\n",
      "Computing 8th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 493])\n",
      "tensor(48) tensor(0)\n",
      "Deletion of point 1.\n",
      "Sklearn loss: 54.74948029602321\n",
      "Invalidation rate (8)  1.0\n",
      "Computing 9th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 492])\n",
      "tensor(48) tensor(0)\n",
      "Deletion of point 2.\n",
      "Sklearn loss: 54.73362538845665\n",
      "Invalidation rate (9)  1.0\n",
      "Computing 10th removal...\n",
      "Fitting model...\n",
      "0\n",
      "torch.Size([48, 491])\n",
      "tensor(48) tensor(0)\n",
      "Deletion of point 3.\n",
      "Sklearn loss: 54.746914512783775\n",
      "Invalidation rate (10)  1.0\n"
     ]
    }
   ],
   "source": [
    "from Tools.deletion_methods import select_random_point, find_impactful_data_greedy, compute_invalidation_curve\n",
    "deletion_curve, indices = compute_invalidation_curve(kr, mycfs[::5], data, labels.long(), find_impactful_data_greedy, n_points_removed=10, params={\"mode\": \"cnt\", \"addc\": 0})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "55f4ff59",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([190., 131., 369.,  44., 447., 497., 465., 212., 361.,   5.])"
      ]
     },
     "execution_count": 113,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "indices"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b9d46b46",
   "metadata": {},
   "source": [
    "## Use the analytical formula to calculate the change in the CFs under model change."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 426,
   "id": "82925bb9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([100, 20, 2])\n"
     ]
    }
   ],
   "source": [
    "jkx = kr.jac_kx(cf_vect)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7c6d3f98",
   "metadata": {},
   "source": [
    "## Sort them by their x value."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 427,
   "id": "9c006473",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([20, 100, 2])"
      ]
     },
     "execution_count": 427,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "jkx.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 428,
   "id": "8024d566",
   "metadata": {},
   "outputs": [],
   "source": [
    "v = (jkx*kr.internal_weights.reshape(1, -1, 1)).sum(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 429,
   "id": "bebd2e2f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 2])\n"
     ]
    }
   ],
   "source": [
    "print(v.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 430,
   "id": "ae6b3c6d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 100])\n"
     ]
    }
   ],
   "source": [
    "u = kr.kernel(cf_vect, kr.points)\n",
    "print(u.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 431,
   "id": "a642e3af",
   "metadata": {},
   "outputs": [],
   "source": [
    "normsv2 = v.pow(2).sum(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 432,
   "id": "271a4d73",
   "metadata": {},
   "outputs": [],
   "source": [
    "jac_q = torch.bmm(v.unsqueeze(2), u.unsqueeze(1))/normsv2.reshape(-1,1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 433,
   "id": "0b1eb489",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 2, 100])\n"
     ]
    }
   ],
   "source": [
    "print(jac_q.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 434,
   "id": "593b1c9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "norms_jq = torch.norm(jac_q, dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 435,
   "id": "fc15de91",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7fdb749c59d0>"
      ]
     },
     "execution_count": 435,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "plt.matshow(norms_jq)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 436,
   "id": "feb780f6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.9058)\n"
     ]
    }
   ],
   "source": [
    "print(torch.max(norms_jq))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 437,
   "id": "adfbc1d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "## Use the removal equation to compute changes in internal_weights."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 438,
   "id": "7b990719",
   "metadata": {},
   "outputs": [],
   "source": [
    "chng = kr.compute_weights_under_removal(labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 439,
   "id": "220ec8eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100, 100])"
      ]
     },
     "execution_count": 439,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "chng.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 440,
   "id": "8d4e7d8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7fdb74997f10>"
      ]
     },
     "execution_count": 440,
     "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": 441,
   "id": "bee7fc0d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(4.7920)"
      ]
     },
     "execution_count": 441,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.max(chng)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 442,
   "id": "98d4ac33",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([20, 2, 100])"
      ]
     },
     "execution_count": 442,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Now compute the matrix of the final changes of cfs\n",
    "chmat = torch.matmul(jac_q, chng)\n",
    "chmat.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 443,
   "id": "15073f54",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Maximal change:  tensor(0.0517)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA6wAAADfCAYAAADyZV62AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAsyUlEQVR4nO3de5ykdXXn8e+p6u7p7um5X2C4zYCCCgqogBESL6CJtw0mi1FWo5s1slGjJGqyZpOsirmsWVejeSk6a1RilEQJJmi8BhVUFGcQRK4yDAMMDDPD3KfvVXX2j67RZuiuc6b76eqq7s/79ZrXdFWd/v1OPc/v+T3Pr+tyzN0FAAAAAECrKc12AgAAAAAATIQFKwAAAACgJbFgBQAAAAC0JBasAAAAAICWxIIVAAAAANCSWLACAAAAAFpS2y1YzexFZna3mW0ys3fOdj5Ahpkdb2bfNrM7zex2M7u0fv9yM/ummd1T/3/ZbOcKZJhZ2cxuNrMv128zltFWzGypmV1lZnfV5+ZnM47RjszsD+vXFreZ2ZVm1s1YxlzSVgtWMytL+oikF0s6VdLFZnbq7GYFpFQkvd3dnyLplyS9uT523ynpWnc/WdK19dtAO7hU0p3jbjOW0W4+JOlr7v5kSWdobDwzjtFWzOxYSW+VdJa7P1VSWdKrxFjGHNJWC1ZJ50ja5O6b3X1E0j9JunCWcwJC7r7N3X9c//mAxi6MjtXY+L2iHnaFpJfPSoLAETCz4yS9VNInxt3NWEbbMLPFkp4j6e8lyd1H3H2vGMdoTx2SesysQ1KvpIfFWMYc0m4L1mMlPTju9tb6fUDbMLN1kp4u6UZJR7n7NmlsUStp9SymBmT9raQ/llQbdx9jGe3kJEk7JX2q/tb2T5jZQjGO0Wbc/SFJ75f0gKRtkva5+zfEWMYc0m4LVpvgPm96FsAUmVmfpH+R9Afuvn+28wGOlJm9TNIOd79ptnMBpqFD0jMkXe7uT5fUL94yiTZU/2zqhZJOlHSMpIVm9prZzQooVrstWLdKOn7c7eM09rYHoOWZWafGFqufdfer63dvN7M19cfXSNoxW/kBSedJ+nUz26Kxj2Wcb2b/KMYy2stWSVvd/cb67as0toBlHKPdvEDSfe6+091HJV0t6VwxljGHtNuCdYOkk83sRDPr0tiHyq+Z5ZyAkJmZxj4rdae7f2DcQ9dIel3959dJ+rdm5wYcCXf/E3c/zt3XaWwO/pa7v0aMZbQRd39E0oNm9qT6XRdIukOMY7SfByT9kpn11q81LtDY92QwljFnmHt7vaPWzF6isc9PlSV90t3/cnYzAmJm9suSvivpp/rF5/7+p8Y+x/p5SSdo7KTzCnffPStJAkfIzJ4n6R3u/jIzWyHGMtqImZ2psS8O65K0WdLvaOwP+YxjtBUze4+kV2qsIsHNkn5XUp8Yy5gj2m7BCgAAAACYH9rtLcEAAAAAgHmCBSsAAAAAoCWxYAUAAAAAtCQWrAAAAACAltSWC1Yzu2S2cwCKwFjGXMFYxlzAOMZcwVjGXNKWC1ZJHISYKxjLmCsYy5gLGMeYKxjLmDPadcEKAAAAAJjj2qIOa5d1e0+p7+e3R3xIXdb9mBiv1cJ2rFwOY2q9C448wYn6ymzX/qHGbSTyHV4d59v1cH8YU12xMIwp74rbMbMwRpmYUhzjlWohfVlnZ9zXyEghfemwcTGqYXXqsfsws9/DbqqJbZOR2X6p/Zn421gm58y+Gk3sqwSzOOfMvJNRWdn4+Ot4ND72fHFvGFM62HjOkZLPaYJ9PupD6jxsXg6b6UiM9cRx3szzWG1ZPFeW9sT7q93Ygq4wxoeLOfZSpjDfTtzOY2+O+rA67bA5uSvx3EdGi8mnANYdXxcMr+iIG0pMBV3bmjfWrSPO2SuVuJ3EOTY3t8f7s5DzyBTH+kTXF6HCjqti2rHEtUNq/s/0lTgfpa47M4Ltkzo3Jsao14rZNimZfZ5wwHc/6u6rDr8/MWPNvp5Sn36p92UNY2oDA2E75SVLw5jhp58UJ5S5Ph+JB1L5h7c3bmP50rCNzW98Qhiz9t0/CmN2X3hOGLP80z8MY0oLEpNj4mRhPfGFb3X33ridRF/l49aEMZUtD8R9dRSzmCovXhLGRKp79027DUmyzvhCzTrjacQWxhf5fuBAGFNac1QYU33woTAmI3ORmpl3Mna9/NkNH1/xqfgYHjn36WFM93fvCGNqg4NhTGasZ/7oVF62NM4nMZZrQ/FCvCgHX/isMKbvCzc2IRPlLhASF8zy+HzVcdzaMKayeUvcV0Esca7x4eG4ncQiqHzccWFM9cGH43wyf0yL9mni4rJ80slhzKbfXhm3MxSPrxMuuyGMKepCtrzycdewj1PdviNuJ3GOrQ0m5pTEH1mLOI9kzsNF/ZE6tZhPjOPU8Tka/3GhlLgWzPyxKHXttWxFGFN9dFcYo1LiGje4biovXxa24f3x9UctMQdm9oNqibGeGKcZ3xz53P0T3T8rbwk2sxeZ2d1mtsnM3jkbOQAAAAAAWlvTF6xmVpb0EUkvlnSqpIvN7NRm5wEAAAAAaG2z8QrrOZI2uftmdx+R9E+SLpyFPAAAAAAALWw2FqzHSnpw3O2t9fsew8wuMbONZrZxxJv3+SQAAAAAQGuYjQXrRJ++f9y3CLj7enc/y93POvwbgQEAAAAAc99sLFi3Sjp+3O3jJMVfrwcAAAAAmFdmY8G6QdLJZnaimXVJepWka2YhDwAAAABAC2t6HVZ3r5jZ70v6uqSypE+6e8OCpO61uJ5aotZc7WBc4HrBT+4LY6wzrkFY3bUnjIlq39V27Q6bWHRfXIe144THfUT4caqZ2tKZwstrE/Xq7t4UxpQTtT0ztQNVitu56y1xHdYnvj2uw5qSqEd3/xtPa/j4us9MWKLqsfYfjGMSdbW8Etc3G3rhGWFM1964Blppw51hzPC6uE5aOVEzNzNfZOrRFWX11Xc1fDxTYa9n4+YwpjoU12TLSNXhS9S3zNS080qiRlwTLd2wLYxpWsaZgu9eTH1G31NMbefCFFR30mvxNvTd8fm8qDqYqX0a2R3vqxO+uSiMsdHEOTajiOek3DVRhifmwaJqUxYxf6Xq92Ykrj8Kmi4K236periZa8EET6wRihJtHx+J93lqbCXmt8K2X2YOnEZfTV+wSpK7f0XSV2ajbwAAAABAe5iNtwQDAAAAABBiwQoAAAAAaEksWAEAAAAALYkFKwAAAACgJbFgBQAAAAC0JBasAAAAAICWxIIVAAAAANCSZqUO6xHzRIHcggoie/9AHNPZGcckCj1bZ1fjgFL8nLr3JorwluK/S3QMxs2ktnF3vG1UKochmWLRVo7bsa5gG0vylYmi3JnC54mCyJmcB9Y2Huu1lUvCNkp79oYxtf5EkWyLx87Iovg5dQzEMZm/ng2uivdnXyLnVlNbd0zjgJv3hG1k5q6iCoRnjuFUEfGC+soUoC+K92cmy7knU8i+MIlzTWESx4SPBtcfyXaaZmQ0DOk4kLhGqcTPqZnPurA5JdVZQc8sM5aj64tmHg9FaebxkLk+yzRTLSZnS1y7ey3IOXpckmoFbeOCtl9qn0+jr/a7sgMAAAAAzAssWAEAAAAALYkFKwAAAACgJbFgBQAAAAC0JBasAAAAAICWxIIVAAAAANCSWLACAAAAAFoSC1YAAAAAQEvqmO0EMqxUUqmnNwiKC/XW+vvjmKFEYeqhoTgmkU9UBNtUDtvou3dfnEuiiPiircUUhc8UGrfOeNhlitRbV1cc090dxvT2DYcxKsX7IlPUvNTXF8Y887TNDR9/+MlPDNtYtn9VGFPbHB8PqsXPaXhpPNa79sfbryNRdHr/2vhvbEuWLw1jqrt2hzHNtPOcxQ0fX3VbPNZrw4lxnCnanZi7MoXRVY5zTh3nmfliODFvF6S6c2fT+iqCdSS2X6USxmTOn83ktaKK3cftZLZP6tjKiM41iTnZBwfDmPL2vXEuiecUz9pJiXmnqG3smXaK2p/tJnEezrVT1PFZ2Ahrq748cT73apxv5rq0MDN8zPAKKwAAAACgJbFgBQAAAAC0JBasAAAAAICWxIIVAAAAANCSWLACAAAAAFoSC1YAAAAAQEtiwQoAAAAAaEksWAEAAAAALSmuKN4K3KVakwr6RkW7s810dYYxtaGhho97okC4bXog7idRkLv7jrivSqYo8I7dYYiPjIQx1hFvP2UKIo/GfQ3/bHHcThMd3X2g4eP3Lo//zrR4ycJikkmMneqCRMH3xJ/GvBaPr6FViTG4ankcsysep5Z47tYRT6FeqYQxu5/ZOOaoq/rifvoHwphozpGkUm9v3E5/fxjTsXJFGFPZ8WgYk5kvmqlj7fFhTOX+B5uQiVLnq8z4yxzn5ZUrw5jqzp1xXxmpAvQFXRMknnvqXNNCvBpvm8qDW+OGMtumKJY5SRSzHzJzuwqa29tO6thLyGzjTF9F5ZPgBR3nRYyLTC6pfBPriHbBK6wAAAAAgJbEghUAAAAA0JLCBauZnTrBfc+biWQAAAAAADgk8wrr583sf9iYHjP7O0l/PdOJAQAAAADmt8yC9VmSjpd0g6QNkh6WdN5MJgUAAAAAQGbBOippUFKPpG5J97l7k76yFwAAAAAwX2UWrBs0tmA9W9IvS7rYzK6a0awAAAAAAPNepg7r6919Y/3nRyRdaGa/PYM5AQAAAACQWrDeZGavkXSSu19mZidIunuG83oMl8eFeDNFp5vIiyh2nCi8XBsYiJvp7Irb2X8glVJoeDiOSWwb64yHZm0o7stH4wLOPTsSBa4zxZcLKkC/pX95w8fLw4ntlyk6HUbkWKZGdvNqfxenlNifBSkvDDZiqdycRCRZuaC+OjKnl4QmFo7PHMPe19uERHIsMUbdixnH1ttdSDupeTJzPi/ok0mZ8e61Jo7BzLkmYN0LwphST7w/a4nzuWfO+S2mkOuzfGet0Ua7yswXBW2f1FwQrUWkXM6B1PGpoTDGRxOdFTDnSCrkeUua9Hoxc0XxUUk1SedLukzSAUn/orG3CE+JmW2pt1OVVHH3s6baFgAAAABgbsosWJ/l7s8ws5slyd33mFn8kl3s+e7+aAHtAAAAAADmoNS3BJtZWfUXac1slcZecQUAAAAAYMZkFqwflvRFSavN7C8lfU/SX02zX5f0DTO7ycwumSjAzC4xs41mtnHU2+8zEgAAAACA6QnfEuzunzWzmyRdIMkkvdzd75xmv+e5+8NmtlrSN83sLne//rB+10taL0mLS8vn8SfOAQAAAGB+mnTBambjv6p0h6Qrxz/m7run2qm7P1z/f4eZfVHSOZKub/xbAAAAAID5pNErrDdp7K27JukESXvqPy+V9ICkE6fSoZktlFRy9wP1n39VY98+DAAAAADAz026YHX3EyXJzD4m6Rp3/0r99oslvWAafR4l6Ys2Vq+nQ9Ln3P1r02gPAAAAADAHZcranO3uv3fohrt/1czeO9UO3X2zpDOO7JcSxXqLKlibkCrWXkQx7UQx5NKiRWFM7cCBMMbKme/filUTfRW2rxLFjmsDA2HMMd+Nc/ZEztbRGeczOBjG3PvDxofH2p/FxaJLO/bEuYQROT274pY6DySKbXvczoLdif2wvz/uqyBeLabgdnioj44k2kh81D8xjlPPKXMMZwqsZwqWl+Ji7oUVPk8YWLc4jFlwexMSkSSL523riGO8EleXry3ti/O5Pw7JsHK8z320mH1uHfFlkI/E26coUT5ei49zO3pVGDNy7NIwpqM/8bw3/DSOyWjiMWyJ+auW2M5zUmZuz5xripKY4+QFzQU9PXFXmevpxLVg2Ebi2j5z1V6rxdecnrj2Su3z1L6a+pVnZsH6qJn9maR/1NhbhF8jadeUewQAAAAAICGzQL9Y0iqNlbb5V0mr6/cBAAAAADBjMmVtdku6tAm5AAAAAADwc+GC1cxOkfQOSevGx7v7+TOXFgAAAABgvst8hvULkj4m6ROSmvepeAAAAADAvJZZsFbc/fIZzwQAAAAAgHEyX7r0JTN7k5mtMbPlh/7NeGYAAAAAgHkt8wrr6+r//9G4+1zSScWnAwAAAADAmMy3BJ/YjEQaskRx70TBWh8dKSihmHV2hTFF5GPd3XFQ/0DcTt/CuJ2hobidTMH3SiWMqQ3EOadkih3f+rNC2vFKosh6op11/9b4uXfcuSVso7L/YJxLRuK4WrwpLqRdOhCPncwH5FfcHo+d6o5HEy0lZArHF1RAvWtT44Ll1cT+tFJc8D1zfGaOPeuK57fa3n1hTKZIfal7QdxXZr5I9JXZn/vWxkXhV8c9FcKriaOmlohJbBsvZd6QVZBMcflSPJZTzz2hvCJ+U1l1585C+ormXCvF22bkuKVhzOaL4nFcGoqP8ydsCENyx/mC+Dj3zHl4eDiMqZ15ShijG38ax2Q0cZwWoqBzWlHXgk3dNpn5NCFzLWgdwfHXmXg9MVoXZRW0z1Pz9jT6mvTZmtn57v4tM/vNifv0q6fcKwAAAAAAgUbL8+dK+pak/zTBYy6JBSsAAAAAYMZMumB193fV//+d5qUDAAAAAMCYJn4oBQAAAACAPBasAAAAAICWxIIVAAAAANCSGn1L8ITfDnwI3xIMAAAAAJhJjb4leKJvBz6EbwkGAAAAAMyoRt8S3ELfDmxSoghxs3gtLnxb6orfbe1xbeFQbf/+RC5xgfCilJYsDmOqu3aHMZYoIp4p8lzq7Q1jNr/9qWHM2nf/IM4nURC5tHBhGHPMB+9t+PjNVzwtbGP1D+Nx4TffHsZkCkE/cu6SMGbp5ng/LNi0JYx56DnxPHDKprVhTPWuTWFMhiUKd2eKow+tbVzsvrx8adzPwf4wpjY0FMaUFi2K2zlwIIwprzk6bmf7zjhmcDCMSckULDcLQ4752sNhTLzH20/5kV1hTOp5J/aDJ+b2otRGEifixDmrKF4J8klsv84f3BHGnPLdeG9l5q6URM6p/VArZlyUbvlZGOOJa87U9kmcQ0OJeSk1vzVRM4/hotSGGp+H0zJz3OhI41we2RG3MdK4Dak998Nk4qstSWb2UkmnSeo+dJ+7XzZTSQEAAAAAEL4MaGYfk/RKSW+RZJJeISl+CQMAAAAAgGnIfEvwue7+Wkl73P09kp4t6fiZTQsAAAAAMN9lFqyHPkA0YGbHSBqVdOLMpQQAAAAAQO4zrF82s6WS/o+kH2vsG4I/MZNJAQAAAAAQLljd/b31H//FzL4sqdvd981sWgAAAACA+S5csJrZaye4T+7+DzOTEgAAAAAAubcEnz3u525JF2jsrcEsWAEAAAAAMybzluC3jL9tZkskfWbGMppMrXWKIlspLuLsRRRxThSLLi1eHMZUE0XPy5b5/q1Ybf/BQtpRothxpmh3df/+MOYJ67eEMZXM/kzsr1p/fxjz0K90NXx81egPwjYKO1oSz/uYK++O28nsq0RR+FM+sTNu5+5NcT4JqaLcmcLxCWu+3tnw8cwxbB2N2xiLif9GWTsYH8Ol7u4wprLtkTBGpXIc0tsbxmSOq8zxmRnvD778mDBmzQe2xH1FMvkmjhlbsCCM8eHhOGbpojifzD4vaD9kxmBtaChOpzM+Jkrr4sII1XvuC2NS+6scHxORgReeHsb8ynvj88iox7nc8ozE/kwo9y0MY6y3J4ypPLI9jNlz0ZlhzNIv3BzGZM5r5SWJa7S9jT9lZ12NrwkkyUfjXEpd8TlCifGXmW9T8/bAQNxOYv6qJeavzJySOT4zUnPTyGjjNo5aFbbhe+Pr2+revWFMYYpY9zQwlVXKgKSTi04EAAAAAIDxMp9h/ZJ+8YJNSdKpkr4wk0kBAAAAAJD5DOv7x/1ckXS/u2+doXwAAAAAAJCUe0vwS9z9uvq/77v7VjN734xnBgAAAACY1zIL1hdOcN+Li04EAAAAAIDxJn1LsJm9UdKbJD3BzG4d99AiSTfMdGIAAAAAgPmt0WdYPyfpq5L+WtI7x91/wN3jGgsAAAAAAEzDpAtWd98naZ+ZfUjSbnc/IElmtsjMnuXuNzYrSbnLR4OaiJnabk2UqWsXN5KoaZTpJ1Fbyg8cSCQUC/eTlNpXmXqRqRqYmdqoq5bG7Ty8Le4qUQfTK41rb0nSff/rmQ0fX/vVuHZZx71xvtXtO8KYzPbbd35c5ar34bgeYun7PwljHrxwdRhzwmfiOqKZWn3WHdd/Sx1/ieN4+0sbt7P0a3Etv9pgvI19JJ4LSj1xrcPa4GAY03H0UWFMZj9knldKQbWUl91TTO3dUCJf64zrM6ZqmCeet3dlvqOxGJnnlamxmuorc464d0vcUEE1HCOe2J8L794Vxvzg7eeEMeXBeKybx/N2RqZmujIxCcuuvjWMqSXqmmZENVYzCrmelFQbSozRgq6lMzVWM3NcVK80205GaVFca7qWuFb2ai2MCest1+I2Moq6Lk1t40RddXnieU3SVeYzrJdLGn8F2F+/DwAAAACAGZNZsJr7L5bW7l5Trn7rJ81sh5ndNu6+5Wb2TTO7p/7/sqmlDQAAAACY6zIL1s1m9lYz66z/u1TS5sTvfVrSiw67752SrnX3kyVdq8d+NhYAAAAAgJ/LLFh/T9K5kh6StFXSsyRdEv2Su18v6fAvZ7pQ0hX1n6+Q9PJsogAAAACA+SV8a6+775D0qoL6O8rdt9Xb3WZmk36DipldovrCuFu9BXUPAAAAAGgXmc+idkt6vaTTJHUfut/d/9sM5iV3Xy9pvSQttuXFfAUYAAAAAKBtZN4S/BlJR0v6NUnXSTpO0lRroGw3szWSVP8/UVcDAAAAADAfZRasT3T3P5fU7+5XSHqppKdNsb9rJL2u/vPrJP3bFNsBAAAAAMxxmUrghyrK7jWzp0p6RNK66JfM7EpJz5O00sy2SnqXpP8t6fNm9npJD0h6RTrToCCtlRKFzyuJQtCJoraeqQ+eKaBbQKFxzxTzzRSC7oyLCytTqL2g550qFp2R2D724CPFdFUtpnD8SX9zW8PHM4WrqwUV/87ou2pDHJQqFh3vq2M/uDGMqRRUBLu6/2AYU1TB8if9ReN9WjvYH7ZhCxaEMT4yUkiMdXWFMdVde8KYjFJ3/LxSReoLOiYGV8RzXHcYkZDIN1PwvdTXF7dzIN7npV37w5hUqfvEMZOZS0sLF8b59MfHTea6wE47OYzRHffGfY0mjr/a9OeUg6euCGM+9aEPhDHLS/FrGq864bw4ocQ+L69aFbezcmkYUr3znjDmgUvPDGPWfqTxeVjKzTvlE44LYyqbtzRuY2W8P31gMIyxRfFckJnbKw9uDWMy807mWqZjzVFxO3v2xjGJfWW9PWGMEjmXFsfPvbpnX8PHvT/O1wfjfV7UtVdKoi8rZ9YIE9+dWbCur9dL/TONvULaJ+nPo19y94sneeiCRJ8AAAAAgHlu0gWrmV3q7h+SdKe775F0vaSTmpYZAAAAAGBea/R+j9+p//93zUgEAAAAAIDxGr0l+E4z2yJptZndOu5+k+TufvqMZgYAAAAAmNcmXbC6+8VmdrSkr0v69ealBAAAAABA/KVLOyX91N3vb0YyAAAAAAAc0vA7y929qrGyNPH3XAMAAAAAUKBMWZv7JX3fzK6R9POiZu4eF/ECAAAAAGCKMgvWh+v/SpIWzWw6kzDLFZstpK+4ULaVEgXoE/n6cFAcPVE43roTJeoTBYhT7SQKJmf2k9fiovBN1ZE4DDKFlb2Y5xXtC0sUi/ZKpZBcMjqOPyYOGh4JQyqPbI/bOfNJccyGn8YxCaWe+Jio9feHMRnbn7uq4eMr795USD+p4zMxdnLtjMYJlRLzemIeLEziOB9a3sR8CuBDw3FQYhvXliZO/1sTCWX2Z6IAfWFzXGIslw7Ec24lM94TwmMrsW1KI/E4vvS+V4Qxg5XOMKZDD4YxmX3uQ0NxM488GveVsPyu+FxdG4zzyYzB2vadqZwatrF3XyG52Eh8Hs4cDymjieMhMS6q23eEMUXNBdWduwppp7ZvfxgTrSNscWK+TZyvanvisdNM09lX4ZW6u79HksxsobsXc3UGAAAAAEAgfDnRzJ5tZndIurN++wwz++iMZwYAAAAAmNfi979Kfyvp1yTtkiR3/4mk58xgTgAAAAAApBascvfDP6TQYh9CBAAAAADMNZkvXXrQzM6V5PXyNm9V/e3BAAAAAADMlMwrrL8n6c2SjtXYdwCeKelNM5gTAAAAAACpV1if5O6vHn+HmZ0n6fszkxIAAAAAALlXWP8ueR8AAAAAAIWZ9BVWM3u2pHMlrTKzt417aLGkgioLZ3mqWHYxXSUKlie+cios/l2QTLHt1HPKtJPg1YK+j6tWUDuZIvVFtWOJv/8k9kVtf+Oi04Vt44xMYepHd8fNFFTYu7wt7qva2RXG+GhcQD1TOL4oK24fbPi4JZ5T6jjPFJfviN9444kC9KWenjCmNjAQxxS1HxJjOeP4f304jClktGfyTcxLmbGesmlLMe0UtB8yYzDVzvBwGFN9YGuioWKel3V1Nu5mZDRso3fDljCm9oZFYUzn4vgY9sx5L3E+Ly3sDWMq23fEfSV4IuXy6pVhTOWheC7I7K+wjSae80t9C8OYauKYSUkcM+U1R4cxtd174pjEuWbgwrPCmN4v3hjGlBbFx5af0Ph5PfCry8I2lt57VBjT+8UfhTG2YEEYk5knrStxnZIxySm/0ZVJl6S+esz4rb9f0kXFZAUAAAAAwMQmXbC6+3WSrjOzT7v7/U3MCQAAAACA1JcuLTCz9ZLWjY939/NnKikAAAAAADIL1i9I+pikT0hq4ofnAAAAAADzWWbBWnH3y2c8EwAAAAAAxsmUtfmSmb3JzNaY2fJD/2Y8MwAAAADAvJZ5hfV19f//aNx9Lumk4tMBAAAAAGBMuGB19xObkQgAAAAAAOOFC1Yze+1E97v7PxSfziQ8V/C+mL5aqKh5IpfagQPT76fAdjIFwltNNVOM3CwOKcUxntg8FvSVKtQep5LbV4nnrUxR81oxx1WmQLhXpl+ofayzJhZr33jntNvIFO0uah61js44qFZLNJQ4rjrjNwL5cEH7KpFPdcnCYvpqkkwR+9rBg3FD5XIB2Si3zwvqKzXeE/mUj10TxlQe2JpIKHFOHxyK2wkMP+2EMOYp77stjDmpZ2cY8/WnLYkTypxHEspPjF8/qd6zOYzZ9dR4fC2+bjiMsY54biqtOy6MiXIur14VtuEH++Nclsb7ypfG84V27Y7bqSbm/1K8H2pL+sIYGxyM+xoYCEN6tyXaSYxlH06MnYcaX3ce95FENdFELom9kMo3w0fj+bbU0z3l9jNvCT573M/dki6Q9GNJzVuwAgAAAADmncxbgt8y/raZLZH0mRnLCAAAAAAA5b4l+HADkk4uOhEAAAAAAMbLfIb1Sxr7VmBJKkt6iqTPz2RSAAAAAABkPsP6/nE/VyTd7+6JbxcAAAAAAGDqwrcEu/t1ku6StEjSMkkFfP0tAAAAAACNhQtWM/stST+S9ApJvyXpRjO7aKYTAwAAAADMb5m3BP+ppLPdfYckmdkqSf8h6aqZTAwAAAAAML9lFqylQ4vVul2a2rcLT08RhacTRbsL06S+rLMrjPHR+F3cRbWT2k+ZbVNUO4mYUndcyLhWUGHllHJQTNsTuVjzDlFP7YdM+epYbaiJ+6GJSgsWNHy8lih6Ho6bJkuNiwTLFGovpKecwWMXhjHdNzchkSIl9pVlCr739xfSl9cS83ZXZ9xOJS5kn5krfWFP3Ezi+EvlE82ViXyrPXHMRcs3hDHHd+wPY76uXwljUvs8M190Zi5ZC1JNnLMy59lSk87FRfUzmhijCZbYV6lr08w5f2Q0jkmMr/LueP6qZubK4HwuST4w2PjxajVuI3Fdah2J/ZCZl4qSeF6TyRz9XzOzr0u6sn77lZK+OuUeAQAAAABIyHzp0h9J+rik0yWdIWm9u/9x9Htm9kkz22Fmt427791m9pCZ3VL/95LpJA8AAAAAmLsmXbCa2RPN7DxJcver3f1t7v6HknaZ2RMSbX9a0osmuP+D7n5m/d9XppQ1AAAAAGDOa/QK699KOjDB/QP1xxpy9+sl7Z5SVgAAAACAea/RgnWdu996+J3uvlHSumn0+ftmdmv9LcPLJgsys0vMbKOZbRzV3PyiFQAAAADA5BotWBt9JWD8lXkTu1zSEySdKWmbpP87WaC7r3f3s9z9rE7F37gFAAAAAJhbGi1YN5jZGw6/08xeL+mmqXTm7tvdveruNUn/T9I5U2kHAAAAADD3NSpr8weSvmhmr9YvFqhnSeqS9BtT6czM1rj7tvrN35B0W6N4AAAAAMD8NemC1d23SzrXzJ4v6an1u//d3b+VadjMrpT0PEkrzWyrpHdJep6ZnamxOu9bJP33KWeOMVGR8aa3kyj+3WI8UyAc05MpsJ5pplwOY7zSfvvTR+IC6qFa+z3vdlQanYPb2SyOKWqeTPRlpUQ+zdTMc0QRc2Ui3b213jBmaW1w+rm0oszwarUx2CyZuSAjcz7K9FVKHA9F7auO+PoiJXM9HT33anX6bcwxjV5hlSS5+7clfftIG3b3iye4+++PtB0AAAAAwPxUzMseAAAAAAAUjAUrAAAAAKAlsWAFAAAAALQkFqwAAAAAgJbEghUAAAAA0JJYsAIAAAAAWhILVgAAAABASwrrsLYEk6wcFPRNFNv20ZFEX8UU4rWurjDGh4ennUupNy7+XT3YH7fTtzBuZ+++MMY64iHllUoYI/c4JiOxDcsrl4cxlUe2hzFeKyjnoGB0eCxI8kzR6YzEfkiN9ZHEsZdQPuaoMKa2fWccMzQUd1ZKFBGvFbOdR847reHjnd+7LWwjdVwVxCujYUyppyduJzG+UvuqKIl8urcdDGMSZeOLkdl+/QOFtFPUMZzqKzGXhufPrMQx7PdvjWMKOv7Kwbm4NhgfDz3X3xHGXH7KyWFMqfeMMEaWOD493saWOFdX7vhZ3FfCmu/FY8cy89eu3WFM9Z77Ujk1bGP7jmm3IUm1g/HclbmmbKrde8OQWv9gIV0NnLgkjFkQH1qy7u4wxtetaPj4plfHuSyPLwu04p9vjoMy15SJ+bbU1RnGWPeCOJ9JdievsAIAAAAAWhILVgAAAABAS2LBCgAAAABoSSxYAQAAAAAtiQUrAAAAAKAlsWAFAAAAALQkFqwAAAAAgJbEghUAAAAA0JI6ZjsBADPAEn+LShRzR3O4zXYGAHAY99nOAJifLHPsJS4cSolrwWp7XAvyCisAAAAAoCWxYAUAAAAAtCQWrAAAAACAlsSCFQAAAADQkliwAgAAAABaEgtWAAAAAEBLYsEKAAAAAGhJLFgBAAAAAC2pY7YTyDCZrCNINVEc10dH4s4yhbItUay3CJlcFiwIQ2x4OI5ZuDDua+++uJ1EPp4pUmyJv6V4rZB2fOmiuJ1tjyTyKab4cmnVyiAgHn9+sD+Mqe7aHSeTGOu2oCtuJ7HPM2Wyq6uXhjGloXi8a2go0VtCZi5IHMePnt74uDn2hnIhuXhiLsgoJY5zlYvJubwoPj6r+/fHfWUk8tn/5KVhTN+tBeRSkI7jjwljKg9sDWNKK5eHMbX+eN5J7fO++HxUPXAg7qsg1p0Y7wXNKbZkcePHR+LrGFt7bBhzz5uXxe2MxvvqiW/bELcTXb9J8uHE9VlB823P7Q/F7STmr9TzqlTivkqJuTLKJXNdkMjFMvN2glcT12cJmWvKUs9oGFNNXIP0/vDeuJ3EvqqcsDqMKe9pPFdu+i+fC9s48ctvCGOWbHlSGFO6/pYwJnV9kRhflTOeEvf1nYnv5hVWAAAAAEBLYsEKAAAAAGhJLFgBAAAAAC2JBSsAAAAAoCWxYAUAAAAAtCQWrAAAAACAlsSCFQAAAADQkliwAgAAAABaknmiyPJsM7Odku4fd9dKSY/OUjpAkRjLmCsYy5gLGMeYKxjLaEdr3X3V4Xe2xYL1cGa20d3Pmu08gOliLGOuYCxjLmAcY65gLGMu4S3BAAAAAICWxIIVAAAAANCS2nXBun62EwAKwljGXMFYxlzAOMZcwVjGnNGWn2EFAKARM1sh6dr6zaMlVSXtrN8+x91HGvzuWZJe6+5vDfq4wd3PLSLfw9r9jqR3uPvGBjF/IGm9uw8cQbuXSbre3f/jCH5ni6Sz3J0vbwEAzAoWrACAOc3M3i3poLu/f9x9He5emb2sJpdcsG5RExaSLFgBALOtXd8SDADAETGzT5vZB8zs25LeZ2bnmNkNZnZz/f8n1eOeZ2Zfrv/8bjP7pJl9x8w2m9lbx7V3cFz8d8zsKjO7y8w+a2ZWf+wl9fu+Z2YfPtTuYXn1mNk/mdmtZvbPknrGPXa5mW00s9vN7D31+94q6RhJ364/lwnjJnn+F9V/3mJm7zGzH5vZT83syfX7V5jZN+rb5OOSbNzvv8bMfmRmt5jZx82sbGZn1/PuNrOF9f6fOo3dBADAY3TMdgIAADTRKZJe4O5VM1ss6TnuXjGzF0j6K0n/eYLfebKk50taJOluM7vc3UcPi3m6pNMkPSzp+5LOM7ONkj5e7+M+M7tykpzeKGnA3U83s9Ml/XjcY3/q7rvNrCzpWjM73d0/bGZvk/T8ca98ThR3a7AtHnX3Z5jZmyS9Q9LvSnqXpO+5+2Vm9lJJl0iSmT1F0islnefuo2b2UUmvdvd/MLNrJP2Fxhba/+jutwX9AgCQxoIVADCffMHdq/Wfl0i6wsxOluSSOif5nX9392FJw2a2Q9JRkrYeFvMjd98qSWZ2i6R1kg5K2uzu99VjrlR9AXiY50j6sCS5+61mNn6h+VtmdonGztdrJJ0qaaKFaDZuvKvr/98k6TfH5fKb9Vz+3cz21O+/QNIzJW2ov3jcI2lH/bHLJG2QNCSp4ed+AQA4UixYAQDzSf+4n98r6dvu/htmtk7Sdyb5neFxP1c18blzohibIG4yj/tCCTM7UWOvfJ7t7nvM7NOSuqca1yDnw5/TRF9uYZKucPc/meCx5ZL6NLbg79ZjtzEAANPCZ1gBAPPVEkkP1X/+rzPQ/l2STqovhqWxt9RO5HpJr5ak+uc/T6/fv1hji799ZnaUpBeP+50DGnuLchR3pMbn8mJJy+r3XyvpIjNbXX9suZmtrT+2XtKfS/qspPdNo28AAB6HV1gBAPPV32jsLcFvk/Stoht398H650O/ZmaPSvrRJKGXS/pU/a3AtxyKc/efmNnNkm6XtFljn409ZL2kr5rZNnd/foO4I/UeSVea2Y8lXSfpgXoud5jZn0n6hpmVJI1KerOZPVdSxd0/V//87A1mdr67F749AQDzE2VtAACYIWbW5+4H698a/BFJ97j7B2c7LwAA2gVvCQYAYOa8of4lTLdr7C3IH5/ddAAAaC+8wgoAAAAAaEm8wgoAAAAAaEksWAEAAAAALYkFKwAAAACgJbFgBQAAAAC0JBasAAAAAICW9P8B2MACVbaMx9UAAAAASUVORK5CYII=\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",
   "id": "a3fb661b",
   "metadata": {},
   "source": [
    "## Verfication of the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 462,
   "id": "0f7b05d4",
   "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": 463,
   "id": "737683cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([68, 17, 66,  8, 86, 12, 91, 99,  3, 43,  0, 20, 57, 51, 15, 69, 46, 78,\n",
      "        63, 49])\n"
     ]
    }
   ],
   "source": [
    "print(ind)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 464,
   "id": "497d5345",
   "metadata": {},
   "outputs": [],
   "source": [
    "## Recompute the CFs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 465,
   "id": "7ddb5b4d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Removing point 68\n",
      "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",
      "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",
      "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",
      "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.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",
      "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.4998]])\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 12\n",
      "torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\n",
      "Counterfactual explanation found\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.5007]])\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.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "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.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.4994]])\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",
      "10\n",
      "output: tensor([[0.4991]])\n",
      "Counterfactual explanation found\n",
      "Removing point 91\n",
      "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",
      "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 99\n",
      "torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5005]])\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.5007]])\n",
      "Counterfactual explanation found\n",
      "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.4991]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5005]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4998]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5015]])\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.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "Removing point 3\n",
      "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 43\n",
      "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.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5006]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5001]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5000]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4989]])\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.4997]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4999]])\n",
      "Counterfactual explanation found\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.5009]])\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.4994]])\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 0\n",
      "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 20\n",
      "torch.Size([99])\n",
      "10\n",
      "output: tensor([[0.5009]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5002]])\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.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4988]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4985]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5002]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4991]])\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.4994]])\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.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "Removing point 57\n",
      "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.5010]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\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",
      "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.5002]])\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.5016]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5003]])\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.4987]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4992]])\n",
      "Counterfactual explanation found\n",
      "Removing point 51\n",
      "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",
      "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.4993]])\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",
      "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 46\n",
      "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.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5004]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4996]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4986]])\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.5013]])\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.5008]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.5014]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4994]])\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.4993]])\n",
      "Counterfactual explanation found\n",
      "10\n",
      "output: tensor([[0.4990]])\n",
      "Counterfactual explanation found\n",
      "Removing point 78\n",
      "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.5013]])\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",
      "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.4998]])\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",
      "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",
      "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(se_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": 466,
   "id": "f84d2ac9",
   "metadata": {},
   "outputs": [],
   "source": [
    "ana_change_norms = chnorms[:, ind]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 467,
   "id": "114c76e1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 20])\n"
     ]
    }
   ],
   "source": [
    "print(ana_change_norms.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 468,
   "id": "719f3ba3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 20])\n"
     ]
    }
   ],
   "source": [
    "print(real_change_norms.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 481,
   "id": "5ce5614a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7fdb80225f10>"
      ]
     },
     "execution_count": 481,
     "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": 470,
   "id": "c29813e4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7fdb7555ad00>"
      ]
     },
     "execution_count": 470,
     "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": 477,
   "id": "4cb847d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'actual change')"
      ]
     },
     "execution_count": 477,
     "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(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": 480,
   "id": "2c47b9e3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1.         0.86864587]\n",
      " [0.86864587 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": "tobiaspytorch",
   "language": "python",
   "name": "tobiaspytorch"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
