{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.8/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "WARNING:root:Cuda kernels could not loaded -> no CUDA support!\n",
      "2024-05-17 21:52:13,020\tINFO util.py:154 -- Missing packages: ['ipywidgets']. Run `pip install -U ipywidgets`, then restart the notebook server for rich notebook output.\n",
      "WARNING:evotorch:The logger is already configured. The default configuration will not be applied. Call `set_default_logger_config` with `override=True` to override the current configuration.\n"
     ]
    }
   ],
   "source": [
    "# import sys\n",
    "# sys.path.append(\"/workspace/Project_EvoWire/EVAttack/adversarial_training\")\n",
    "\n",
    "import os\n",
    "import yaml\n",
    "from ml_collections import ConfigDict\n",
    "from tqdm import tqdm\n",
    "from copy import deepcopy\n",
    "from torch_sparse import SparseTensor\n",
    "import torch.nn.functional as F\n",
    "\n",
    "import torch\n",
    "import torch_geometric\n",
    "\n",
    "from utils.data import load_dataset, make_dataset_splits, load_dataset_splits, check_dataset_valid\n",
    "from utils.split import SplitManager, node_induced_subgraph\n",
    "from utils.storage import TensorHash\n",
    "from utils.model import load_model_class, accuracy, load_model_instance, create_model_instance, load_robust_model_instance, from_sparse_GCN, from_sparse_GPRGNN\n",
    "from utils.attack import load_attack_class, attack_storage_label, create_attack_instance, load_attack_instance, attack_graph\n",
    "\n",
    "from robust_diffusion.data import SparseGraph\n",
    "from robust_diffusion.data import count_edges_for_idx\n",
    "from robust_diffusion.helper import utils as robust_utils\n",
    "from robust_diffusion.train import train\n",
    "\n",
    "from sacred import Experiment\n",
    "\n",
    "# from sparse_smoothing.models import GCN, GAT, APPNPNet, CNN_MNIST, GIN\n",
    "# from sparse_smoothing.training import train_gnn, train_pytorch\n",
    "# from sparse_smoothing.prediction import predict_smooth_gnn, predict_smooth_pytorch, sample_multiple_graphs\n",
    "# from sparse_smoothing.cert import binary_certificate, binary_certificate_grid\n",
    "# from sparse_smoothing.utils import (load_and_standardize, split, accuracy_majority,\n",
    "#                                     sample_perturbed_mnist, sample_batch_pyg, get_mnist_dataloaders)\n",
    "\n",
    "\n",
    "from robust_diffusion.helper.utils import calculate_loss\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Experiment configs\n",
    "dataset_name = \"cora_ml\"\n",
    "\n",
    "# model_name in [\"GCN\", \"DenseGCN\", \"GAT\", \"GPRGNN\", \"DenseGPRGNN\", \"APPNP\", \"ChebNetII\", \"SoftMedian_GDC\"]\n",
    "model_name = \"GCN\"\n",
    "n_splits = 10\n",
    "\n",
    "training_split = None\n",
    "validation_split = None\n",
    "training_split_type = None\n",
    "validation_split_type = None\n",
    "test_split = None\n",
    "test_split_type = None\n",
    "\n",
    "model_params = None\n",
    "epsilon = 0.01\n",
    "\n",
    "# attack_name in [\"PRBCD\", \"LRBCD\", \"EvaAttack\", \"Evafast\", \"PGD\"]\n",
    "attack_name = \"EvaAttack\"\n",
    "train_attack_name = None\n",
    "attack_params = None\n",
    "\n",
    "inductive = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experiment Started\n",
      "Loading dataset = cora_ml\n",
      "Found 10 splits!\n",
      "Loading pretrained GCN model on cora_ml dataset for 10 splits\n"
     ]
    }
   ],
   "source": [
    "general_config = yaml.safe_load(open(\"conf/general-config.yaml\"))\n",
    "default_dataset_configs = yaml.safe_load(open(\"conf/data-configs.yaml\")).get(\"configs\").get(\"default\")\n",
    "default_model_configs = yaml.safe_load(open(\"conf/model-configs.yaml\")).get(\"configs\")\n",
    "default_attack_configs = yaml.safe_load(open(\"conf/attack-configs.yaml\")).get(\"configs\")\n",
    "\n",
    "\n",
    "# extracting configs \n",
    "dataset_root = general_config.get(\"dataset_root\", \"data/\")\n",
    "splits_root = general_config.get(\"splits_root\", \"splits/\")\n",
    "models_root = general_config.get(\"models_root\", \"models/\")\n",
    "results_root = general_config.get(\"results_root\", \"results/\")\n",
    "reports_root = general_config.get(\"reports_root\", \"reports/\")\n",
    "    \n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "print(\"Experiment Started\")\n",
    "# Trains the specified model on the given graph and saves the model artifacts, and the splits.\n",
    "\n",
    "print(\"Loading dataset =\", dataset_name)\n",
    "\n",
    "dataset_splits = [\n",
    "    split_record for split_record in os.listdir(splits_root) \n",
    "    if split_record.split(\"-\")[0] == dataset_name \n",
    "    and check_dataset_valid(split_record=split_record, training_split=training_split,\n",
    "                            validation_split=validation_split, training_split_type=training_split_type, \n",
    "                            validation_split_type=validation_split_type, test_split=test_split, \n",
    "                            test_split_type=test_split_type, splits_root=splits_root)]\n",
    "creating_splits = max(n_splits - len(dataset_splits), 0)\n",
    "\n",
    "if creating_splits > 0:\n",
    "    raise ValueError(\"Not enough splits for the dataset. Create the splits by running training scripts.\")\n",
    "\n",
    "# creating remaining needed dataset splits\n",
    "print(f\"Found {len(dataset_splits)} splits!\")\n",
    "\n",
    "print(f\"Loading pretrained {model_name} model on {dataset_name} dataset for {n_splits} splits\")\n",
    "\n",
    "clean_accs = []\n",
    "pert_accs = []\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for split_file in tqdm(dataset_splits[:n_splits]):\n",
    "split_file = dataset_splits[4]\n",
    "split_code = split_file.split(\"-\")[1].replace(\".pt\", \"\")\n",
    "\n",
    "data = load_dataset_splits(\n",
    "    dataset_name, split_code, inductive=inductive, \n",
    "    dataset_root=dataset_root, splits_root=splits_root, device=device)\n",
    "\n",
    "training_attr = data[\"training_attr\"]\n",
    "training_adj = data[\"training_adj\"]\n",
    "labels = data[\"labels\"]\n",
    "training_idx = data[\"training_idx\"]\n",
    "validation_idx = data[\"validation_idx\"]\n",
    "test_attr = data[\"test_attr\"]\n",
    "test_adj = data[\"test_adj\"]\n",
    "test_mask = data[\"test_mask\"]\n",
    "unlabeled_mask = data[\"unlabeled_mask\"]\n",
    "test_idx = test_mask.nonzero(as_tuple=True)[0]\n",
    "dataset_info = data[\"dataset_info\"]\n",
    "split_name = data[\"split_name\"]\n",
    "\n",
    "try:\n",
    "    if train_attack_name is None:\n",
    "        model_instance = load_model_instance(\n",
    "            model_name=model_name, model_params=model_params, \n",
    "            test_attr=test_attr, test_adj=test_adj, labels=labels, \n",
    "            test_mask=test_mask, unlabeled_mask=unlabeled_mask,\n",
    "            split_name=split_name, dataset_info=dataset_info, \n",
    "            inductive=inductive,\n",
    "            models_root=models_root,\n",
    "            default_model_configs=default_model_configs, device=device)\n",
    "    else:\n",
    "        model_instance = load_robust_model_instance(\n",
    "            model_name=model_name, model_params=model_params, \n",
    "            dataset_info=dataset_info, \n",
    "            test_attr=test_attr, test_adj=test_adj, labels=labels, test_mask=test_mask, unlabeled_mask=unlabeled_mask,\n",
    "            split_name=split_name, inductive=inductive,\n",
    "            models_root=models_root, self_training=True, robust_training=True, train_attack_name=train_attack_name, robust_epsilon=0.2,\n",
    "            default_model_configs=default_model_configs, suffix='', device=device)\n",
    "\n",
    "except FileNotFoundError as e:\n",
    "    print(e)\n",
    "    raise ValueError(\"Model not found. Run training scripts to train the model.\")\n",
    "\n",
    "\n",
    "model = model_instance[\"model\"]\n",
    "acc = model_instance[\"accuracy\"]\n",
    "model_params = model_instance[\"model_params\"]\n",
    "model_storage_name = model_instance[\"model_storage_name\"]\n",
    "clean_accs.append(acc)\n",
    "\n",
    "if attack_name == \"PGD\" and model_name == \"GCN\":\n",
    "    model = from_sparse_GCN(model, model_params)\n",
    "elif attack_name == \"PGD\" and model_name == \"GPRGNN\":\n",
    "    model = from_sparse_GPRGNN(model, model_params)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(indices=tensor([[   0,    0,    0,  ..., 2808, 2808, 2809],\n",
       "                       [1579, 1581, 2241,  ...,  730, 1787, 1399]]),\n",
       "       values=tensor([1., 1., 1.,  ..., 1., 1., 1.]),\n",
       "       device='cuda:0', size=(2810, 2810), nnz=15962, layout=torch.sparse_coo)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_adj_tensor = test_adj.to_torch_sparse_coo_tensor().to(device)\n",
    "test_adj_tensor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.8221, device='cuda:0')"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "original_acc = (model(test_attr, test_adj).argmax(1) == labels)[test_mask].float().mean()\n",
    "original_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "# loss_comp = []\n",
    "# for n_perts in [10, 20, 50, 100, 200, 500, 1000, 2000, 5000]:\n",
    "#     for iteration in range(100):\n",
    "#         perturbation_matrix = torch.sparse_coo_tensor(\n",
    "#             indices=torch.stack([(torch.rand(n_perts) * test_attr.shape[0]).long(), (torch.rand(n_perts) * test_attr.shape[0]).long()]),\n",
    "#             values=torch.ones(n_perts), size=(test_attr.shape[0], test_attr.shape[0])\n",
    "#         ).coalesce().to(device)\n",
    "#         pert_adj = ((test_adj_tensor + perturbation_matrix) - (test_adj_tensor * perturbation_matrix * 2)).coalesce()\n",
    "#         pert_pred = model(test_attr, pert_adj)\n",
    "#         perturbed_acc = (pert_pred.argmax(1) == labels)[test_mask].float().mean()\n",
    "#         perturbed_loss = {\n",
    "#             \"CW\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"CW\").item(),\n",
    "#             \"LCW\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"LCW\").item(),\n",
    "#             \"tanhMargin\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"tanhMargin\").item(),\n",
    "#             \"Margin\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"Margin\").item(),\n",
    "#             # \"eluMargin\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"eluMargin\"),\n",
    "#             \"MCE\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"MCE\").item(),\n",
    "#             \"acc\": ((original_acc - perturbed_acc) / original_acc).item(),\n",
    "#             \"n_pert\": n_perts,\n",
    "#         }\n",
    "#         loss_comp.append(perturbed_loss)\n",
    "# loss_comp = pd.DataFrame(loss_comp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.8286136388778687\n",
      "pop_best_eval : 0.8245059251785278\n",
      "  median_eval : 0.8288537263870239\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.8234946131706238\n",
      "pop_best_eval : 0.8177865743637085\n",
      "  median_eval : 0.8237153887748718\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/anonymous/anonymous-home/projects/eva-evolutionary-attacks-on-graphs/EVAttack/experiments/eva_attack.py:60: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  var_coef = var - torch.tensor(self.variances[-10]).mean()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         iter : 15\n",
      "    mean_eval : 0.8191136121749878\n",
      "pop_best_eval : 0.8158102631568909\n",
      "  median_eval : 0.8193675875663757\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.815718412399292\n",
      "pop_best_eval : 0.812252938747406\n",
      "  median_eval : 0.8158102631568909\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.8120560646057129\n",
      "pop_best_eval : 0.8079051375389099\n",
      "  median_eval : 0.812252938747406\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.808271050453186\n",
      "pop_best_eval : 0.804347813129425\n",
      "  median_eval : 0.8083003759384155\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.8045184016227722\n",
      "pop_best_eval : 0.8011857271194458\n",
      "  median_eval : 0.8047430515289307\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.8004601001739502\n",
      "pop_best_eval : 0.7976284623146057\n",
      "  median_eval : 0.8007904887199402\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.7970131635665894\n",
      "pop_best_eval : 0.7948616743087769\n",
      "  median_eval : 0.7972331643104553\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.7945181131362915\n",
      "pop_best_eval : 0.7924901247024536\n",
      "  median_eval : 0.7944663763046265\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.7924947738647461\n",
      "pop_best_eval : 0.7909090518951416\n",
      "  median_eval : 0.7924901247024536\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.7912155389785767\n",
      "pop_best_eval : 0.78972327709198\n",
      "  median_eval : 0.791304349899292\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.7902830243110657\n",
      "pop_best_eval : 0.78972327709198\n",
      "  median_eval : 0.7901185750961304\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.7896777391433716\n",
      "pop_best_eval : 0.7893280386924744\n",
      "  median_eval : 0.78972327709198\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.789326548576355\n",
      "pop_best_eval : 0.7889328002929688\n",
      "  median_eval : 0.7893280386924744\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.7892917394638062\n",
      "pop_best_eval : 0.7889328002929688\n",
      "  median_eval : 0.7893280386924744\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.7890431880950928\n",
      "pop_best_eval : 0.7889328002929688\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.7890293002128601\n",
      "pop_best_eval : 0.7889328002929688\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.7889328002929688\n",
      "pop_best_eval : 0.7889328002929688\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.7889204621315002\n",
      "pop_best_eval : 0.7885375618934631\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.7888162136077881\n",
      "pop_best_eval : 0.7885375618934631\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.78880774974823\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.7888007760047913\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.7887891530990601\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.7887753248214722\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.7887660264968872\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.7887567281723022\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.788739800453186\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.7887251377105713\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7885375618934631\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.7887135744094849\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7885375618934631\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.7886965274810791\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7885375618934631\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.7886703014373779\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7885375618934631\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.7885259389877319\n",
      "pop_best_eval : 0.7881422638893127\n",
      "  median_eval : 0.7885375618934631\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.7881407737731934\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7881422638893127\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.7881059646606445\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7881422638893127\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.78783118724823\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.7878111004829407\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.7877470254898071\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.7877470254898071\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.7877470254898071\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.787746250629425\n",
      "pop_best_eval : 0.7873517870903015\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.787746250629425\n",
      "pop_best_eval : 0.7873517870903015\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.787746250629425\n",
      "pop_best_eval : 0.7873517870903015\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.787746250629425\n",
      "pop_best_eval : 0.7873517870903015\n",
      "  median_eval : 0.7877470254898071\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.787746250629425\n",
      "pop_best_eval : 0.7873517870903015\n",
      "  median_eval : 0.7877470254898071\n",
      "\n"
     ]
    }
   ],
   "source": [
    "n_perts = 100\n",
    "attack = attack_graph(\n",
    "    attack_name='EVAFAST', \n",
    "    attack_params=None, epsilon=0.01,\n",
    "    test_attr=test_attr, test_adj=test_adj, labels=labels, model=model,\n",
    "    dataset_info=dataset_info, model_storage_name=model_storage_name, \n",
    "    split_name=split_name, test_mask=test_mask,\n",
    "    unlabeled_mask=unlabeled_mask, \n",
    "    default_attack_configs=default_attack_configs, reports_root=reports_root,\n",
    "    device=device, inductive=False, save=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pert_adj,_ = attack.get_pertubations()\n",
    "\n",
    "pert_pred = model(test_attr, pert_adj)\n",
    "perturbed_acc = (pert_pred.argmax(1) == labels)[test_mask].float().mean()\n",
    "perturbed_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 31.18it/s]\n"
     ]
    }
   ],
   "source": [
    "attack = attack_graph(\n",
    "    attack_name='PRBCD', attack_params={\"epochs\": 300}, epsilon=0.1,\n",
    "    test_attr=test_attr, test_adj=test_adj, labels=labels, model=model,\n",
    "    dataset_info=dataset_info, model_storage_name=model_storage_name, \n",
    "    split_name=split_name, test_mask=test_mask,\n",
    "    unlabeled_mask=unlabeled_mask, n_perturbations=n_perts,\n",
    "    default_attack_configs=default_attack_configs, reports_root=reports_root,\n",
    "    device=device, inductive=False, save=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.7758, device='cuda:0')"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pert_adj,_ = attack.get_pertubations()\n",
    "\n",
    "pert_pred = model(test_attr, pert_adj)\n",
    "perturbed_acc = (pert_pred.argmax(1) == labels)[test_mask].float().mean()\n",
    "perturbed_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 10\n",
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.8157870769500732\n",
      "pop_best_eval : 0.8142292499542236\n",
      "  median_eval : 0.8158102631568909\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.8129956126213074\n",
      "pop_best_eval : 0.8110671639442444\n",
      "  median_eval : 0.813043475151062\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/anonymous/anonymous-home/projects/eva-evolutionary-attacks-on-graphs/EVAttack/experiments/eva_attack.py:60: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  var_coef = var - torch.tensor(self.variances[-10]).mean()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         iter : 15\n",
      "    mean_eval : 0.8110594749450684\n",
      "pop_best_eval : 0.8098813891410828\n",
      "  median_eval : 0.8110671639442444\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.8098628520965576\n",
      "pop_best_eval : 0.8094861507415771\n",
      "  median_eval : 0.8098813891410828\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.8094807863235474\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8094861507415771\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.8093363642692566\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8094861507415771\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.8090909123420715\n",
      "pop_best_eval : 0.8090909123420715\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.8090792894363403\n",
      "pop_best_eval : 0.8086956143379211\n",
      "  median_eval : 0.8090909123420715\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.8087619543075562\n",
      "pop_best_eval : 0.8086956143379211\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.8086956143379211\n",
      "pop_best_eval : 0.8086956143379211\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.8086956143379211\n",
      "pop_best_eval : 0.8086956143379211\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.8086956143379211\n",
      "pop_best_eval : 0.8086956143379211\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.8086956143379211\n",
      "pop_best_eval : 0.8086956143379211\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.8086910247802734\n",
      "pop_best_eval : 0.8083003759384155\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.8085451126098633\n",
      "pop_best_eval : 0.8079051375389099\n",
      "  median_eval : 0.8086956143379211\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.8079051375389099\n",
      "pop_best_eval : 0.8079051375389099\n",
      "  median_eval : 0.8079051375389099\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.8078773021697998\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8079051375389099\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 230\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 235\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 240\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 245\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 250\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 255\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 260\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 265\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 270\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 275\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 280\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 285\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 290\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 295\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "         iter : 300\n",
      "    mean_eval : 0.8075098395347595\n",
      "pop_best_eval : 0.8075098395347595\n",
      "  median_eval : 0.8075098395347595\n",
      "\n",
      "n_perts = 20\n",
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.8145202398300171\n",
      "pop_best_eval : 0.8118577003479004\n",
      "  median_eval : 0.8146244883537292\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.8107051253318787\n",
      "pop_best_eval : 0.8079051375389099\n",
      "  median_eval : 0.8110671639442444\n",
      "\n",
      "         iter : 15\n",
      "    mean_eval : 0.8079969882965088\n",
      "pop_best_eval : 0.8055335879325867\n",
      "  median_eval : 0.8083003759384155\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.8054826259613037\n",
      "pop_best_eval : 0.803557276725769\n",
      "  median_eval : 0.8055335879325867\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.803013801574707\n",
      "pop_best_eval : 0.8019762635231018\n",
      "  median_eval : 0.8031620383262634\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.8016319870948792\n",
      "pop_best_eval : 0.8011857271194458\n",
      "  median_eval : 0.8015810251235962\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.8011857271194458\n",
      "pop_best_eval : 0.8011857271194458\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.8011857271194458\n",
      "pop_best_eval : 0.8011857271194458\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.8011857271194458\n",
      "pop_best_eval : 0.8011857271194458\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.8011857271194458\n",
      "pop_best_eval : 0.8011857271194458\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.8011849522590637\n",
      "pop_best_eval : 0.8007904887199402\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.8011679649353027\n",
      "pop_best_eval : 0.8007904887199402\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.801033616065979\n",
      "pop_best_eval : 0.8007904887199402\n",
      "  median_eval : 0.8011857271194458\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.8007866144180298\n",
      "pop_best_eval : 0.8003952503204346\n",
      "  median_eval : 0.8007904887199402\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.8005288243293762\n",
      "pop_best_eval : 0.8003952503204346\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.8003952503204346\n",
      "pop_best_eval : 0.8003952503204346\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.8003952503204346\n",
      "pop_best_eval : 0.8003952503204346\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.8003952503204346\n",
      "pop_best_eval : 0.8003952503204346\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.8003944754600525\n",
      "pop_best_eval : 0.800000011920929\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.8003798127174377\n",
      "pop_best_eval : 0.800000011920929\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.8002462387084961\n",
      "pop_best_eval : 0.800000011920929\n",
      "  median_eval : 0.8003952503204346\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.799976110458374\n",
      "pop_best_eval : 0.7996047139167786\n",
      "  median_eval : 0.800000011920929\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.7995306253433228\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.7996047139167786\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.799209475517273\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.7992071509361267\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.79915851354599\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.799209475517273\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.7988512516021729\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 230\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 235\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 240\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 245\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 250\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 255\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 260\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 265\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 270\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 275\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 280\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 285\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 290\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 295\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 300\n",
      "    mean_eval : 0.7988142371177673\n",
      "pop_best_eval : 0.7988142371177673\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "n_perts = 50\n",
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.812549352645874\n",
      "pop_best_eval : 0.8094861507415771\n",
      "  median_eval : 0.8126481771469116\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.8078734874725342\n",
      "pop_best_eval : 0.8039525747299194\n",
      "  median_eval : 0.8079051375389099\n",
      "\n",
      "         iter : 15\n",
      "    mean_eval : 0.8039255142211914\n",
      "pop_best_eval : 0.8003952503204346\n",
      "  median_eval : 0.804347813129425\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.8006908893585205\n",
      "pop_best_eval : 0.7972331643104553\n",
      "  median_eval : 0.8007904887199402\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.7978554368019104\n",
      "pop_best_eval : 0.7940711379051208\n",
      "  median_eval : 0.7980237007141113\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.7947643995285034\n",
      "pop_best_eval : 0.7920948266983032\n",
      "  median_eval : 0.7948616743087769\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.7915606498718262\n",
      "pop_best_eval : 0.7885375618934631\n",
      "  median_eval : 0.7916995882987976\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.7886502146720886\n",
      "pop_best_eval : 0.7861660122871399\n",
      "  median_eval : 0.7889328002929688\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.7864863276481628\n",
      "pop_best_eval : 0.7849802374839783\n",
      "  median_eval : 0.7865612506866455\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.7850674390792847\n",
      "pop_best_eval : 0.7841897010803223\n",
      "  median_eval : 0.7849802374839783\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.7841541767120361\n",
      "pop_best_eval : 0.7837944626808167\n",
      "  median_eval : 0.7841897010803223\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.7837944626808167\n",
      "pop_best_eval : 0.7837944626808167\n",
      "  median_eval : 0.7837944626808167\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.7837550640106201\n",
      "pop_best_eval : 0.783399224281311\n",
      "  median_eval : 0.7837944626808167\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.7835806608200073\n",
      "pop_best_eval : 0.783399224281311\n",
      "  median_eval : 0.783399224281311\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.7835080623626709\n",
      "pop_best_eval : 0.783399224281311\n",
      "  median_eval : 0.783399224281311\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.7833861112594604\n",
      "pop_best_eval : 0.7830039262771606\n",
      "  median_eval : 0.783399224281311\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.7829414010047913\n",
      "pop_best_eval : 0.782608687877655\n",
      "  median_eval : 0.7830039262771606\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.7826665639877319\n",
      "pop_best_eval : 0.7822134494781494\n",
      "  median_eval : 0.782608687877655\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.7825816869735718\n",
      "pop_best_eval : 0.7822134494781494\n",
      "  median_eval : 0.782608687877655\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.7822072505950928\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.7822134494781494\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.782184898853302\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.7822134494781494\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.7819902896881104\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.7819146513938904\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.781818151473999\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.781818151473999\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.781818151473999\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.781818151473999\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.781818151473999\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.7818173766136169\n",
      "pop_best_eval : 0.7814229130744934\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.7818166017532349\n",
      "pop_best_eval : 0.7814229130744934\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.7818150520324707\n",
      "pop_best_eval : 0.7814229130744934\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.7818112373352051\n",
      "pop_best_eval : 0.7814229130744934\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.7818073034286499\n",
      "pop_best_eval : 0.7814229130744934\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.7817965149879456\n",
      "pop_best_eval : 0.7814229130744934\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.7817818522453308\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.7817564010620117\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.7817317247390747\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.7816799879074097\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.781605064868927\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.781818151473999\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.7814738750457764\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7814229130744934\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.7812044620513916\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.7810276746749878\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.7810276746749878\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.7810276746749878\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.7810276746749878\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 230\n",
      "    mean_eval : 0.7810276746749878\n",
      "pop_best_eval : 0.7810276746749878\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 235\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 240\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 245\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 250\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 255\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 260\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 265\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 270\n",
      "    mean_eval : 0.7810268998146057\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 275\n",
      "    mean_eval : 0.7810253500938416\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 280\n",
      "    mean_eval : 0.7810238003730774\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 285\n",
      "    mean_eval : 0.7810230255126953\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 290\n",
      "    mean_eval : 0.7810192108154297\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 295\n",
      "    mean_eval : 0.7810153365135193\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 300\n",
      "    mean_eval : 0.7810091376304626\n",
      "pop_best_eval : 0.7806323766708374\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "n_perts = 100\n",
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.809731662273407\n",
      "pop_best_eval : 0.803557276725769\n",
      "  median_eval : 0.8098813891410828\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.8036460876464844\n",
      "pop_best_eval : 0.7984189391136169\n",
      "  median_eval : 0.8039525747299194\n",
      "\n",
      "         iter : 15\n",
      "    mean_eval : 0.7984883785247803\n",
      "pop_best_eval : 0.7928853631019592\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.7934573888778687\n",
      "pop_best_eval : 0.7889328002929688\n",
      "  median_eval : 0.7936758995056152\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.7890671491622925\n",
      "pop_best_eval : 0.7837944626808167\n",
      "  median_eval : 0.7893280386924744\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.7849377393722534\n",
      "pop_best_eval : 0.781818151473999\n",
      "  median_eval : 0.7849802374839783\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.7806679010391235\n",
      "pop_best_eval : 0.7762845754623413\n",
      "  median_eval : 0.7810276746749878\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.7767801880836487\n",
      "pop_best_eval : 0.7739130258560181\n",
      "  median_eval : 0.7770751118659973\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.7734181880950928\n",
      "pop_best_eval : 0.7707509994506836\n",
      "  median_eval : 0.7735177874565125\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.7705610990524292\n",
      "pop_best_eval : 0.76798415184021\n",
      "  median_eval : 0.7707509994506836\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.7681679725646973\n",
      "pop_best_eval : 0.7660079002380371\n",
      "  median_eval : 0.7683794498443604\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.7661762237548828\n",
      "pop_best_eval : 0.7648221254348755\n",
      "  median_eval : 0.7664031386375427\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.7647271156311035\n",
      "pop_best_eval : 0.7636363506317139\n",
      "  median_eval : 0.7648221254348755\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.7638656497001648\n",
      "pop_best_eval : 0.7632411122322083\n",
      "  median_eval : 0.7640315890312195\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.7634495496749878\n",
      "pop_best_eval : 0.7624505758285522\n",
      "  median_eval : 0.7636363506317139\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.7629562616348267\n",
      "pop_best_eval : 0.7620553374290466\n",
      "  median_eval : 0.7628458142280579\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.7628844380378723\n",
      "pop_best_eval : 0.7620553374290466\n",
      "  median_eval : 0.7628458142280579\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.7628620862960815\n",
      "pop_best_eval : 0.7620553374290466\n",
      "  median_eval : 0.7628458142280579\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.7626606225967407\n",
      "pop_best_eval : 0.7616600394248962\n",
      "  median_eval : 0.7628458142280579\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.7620738744735718\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7620553374290466\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.7616539001464844\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7616600394248962\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.7615512609481812\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7616600394248962\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.7612648010253906\n",
      "pop_best_eval : 0.7612648010253906\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.7612640261650085\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 230\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 235\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 240\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 245\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 250\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 255\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 260\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 265\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 270\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 275\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 280\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 285\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 290\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 295\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "         iter : 300\n",
      "    mean_eval : 0.7612632513046265\n",
      "pop_best_eval : 0.760869562625885\n",
      "  median_eval : 0.7612648010253906\n",
      "\n",
      "n_perts = 200\n",
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.8050040006637573\n",
      "pop_best_eval : 0.799209475517273\n",
      "  median_eval : 0.8055335879325867\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.7983162999153137\n",
      "pop_best_eval : 0.7928853631019592\n",
      "  median_eval : 0.7988142371177673\n",
      "\n",
      "         iter : 15\n",
      "    mean_eval : 0.7917528748512268\n",
      "pop_best_eval : 0.7877470254898071\n",
      "  median_eval : 0.7920948266983032\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.785079836845398\n",
      "pop_best_eval : 0.7790513634681702\n",
      "  median_eval : 0.7853754758834839\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.7789286375045776\n",
      "pop_best_eval : 0.7731224894523621\n",
      "  median_eval : 0.7794466018676758\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.7736636400222778\n",
      "pop_best_eval : 0.76798415184021\n",
      "  median_eval : 0.7739130258560181\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.7682343125343323\n",
      "pop_best_eval : 0.7640315890312195\n",
      "  median_eval : 0.7683794498443604\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.7624204158782959\n",
      "pop_best_eval : 0.7569169998168945\n",
      "  median_eval : 0.7628458142280579\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.7570844888687134\n",
      "pop_best_eval : 0.7509881258010864\n",
      "  median_eval : 0.7573122382164001\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.7525884509086609\n",
      "pop_best_eval : 0.7486165761947632\n",
      "  median_eval : 0.752964437007904\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.7483989000320435\n",
      "pop_best_eval : 0.7446640133857727\n",
      "  median_eval : 0.7486165761947632\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.7440255880355835\n",
      "pop_best_eval : 0.739130437374115\n",
      "  median_eval : 0.7442687749862671\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.7398730516433716\n",
      "pop_best_eval : 0.7367588877677917\n",
      "  median_eval : 0.7399209141731262\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.7364809513092041\n",
      "pop_best_eval : 0.7328063249588013\n",
      "  median_eval : 0.7367588877677917\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.7337666749954224\n",
      "pop_best_eval : 0.731225311756134\n",
      "  median_eval : 0.7339920997619629\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.7313944101333618\n",
      "pop_best_eval : 0.7284584641456604\n",
      "  median_eval : 0.7316205501556396\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.7294489741325378\n",
      "pop_best_eval : 0.7276679873466492\n",
      "  median_eval : 0.729644238948822\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.7276772260665894\n",
      "pop_best_eval : 0.7256916761398315\n",
      "  median_eval : 0.7276679873466492\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.7260815501213074\n",
      "pop_best_eval : 0.7241106629371643\n",
      "  median_eval : 0.7260869145393372\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.7246255874633789\n",
      "pop_best_eval : 0.7229248881340027\n",
      "  median_eval : 0.7249011993408203\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.7231611013412476\n",
      "pop_best_eval : 0.7213438749313354\n",
      "  median_eval : 0.7233201265335083\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.7218270301818848\n",
      "pop_best_eval : 0.7205533385276794\n",
      "  median_eval : 0.7217391133308411\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.720838189125061\n",
      "pop_best_eval : 0.7197628617286682\n",
      "  median_eval : 0.7209485769271851\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.720108687877655\n",
      "pop_best_eval : 0.7189723253250122\n",
      "  median_eval : 0.7201581001281738\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.7194811105728149\n",
      "pop_best_eval : 0.7185770869255066\n",
      "  median_eval : 0.7193675637245178\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.7188464403152466\n",
      "pop_best_eval : 0.7181817889213562\n",
      "  median_eval : 0.7189723253250122\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.718368649482727\n",
      "pop_best_eval : 0.7177865505218506\n",
      "  median_eval : 0.7185770869255066\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.7178946137428284\n",
      "pop_best_eval : 0.7169960141181946\n",
      "  median_eval : 0.7177865505218506\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.7175000905990601\n",
      "pop_best_eval : 0.716600775718689\n",
      "  median_eval : 0.717391312122345\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.7171064615249634\n",
      "pop_best_eval : 0.7162055373191833\n",
      "  median_eval : 0.7169960141181946\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.7168022394180298\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.7169960141181946\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.7166571617126465\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.7166440486907959\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.7166440486907959\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.7166440486907959\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.716643214225769\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.7166416645050049\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.7166409492492676\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.7166393995285034\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.7166385650634766\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.7166378498077393\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.7166363000869751\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.7166324257850647\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.7166308760643005\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.716625452041626\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 230\n",
      "    mean_eval : 0.7165892124176025\n",
      "pop_best_eval : 0.715810239315033\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 235\n",
      "    mean_eval : 0.7164154648780823\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.716600775718689\n",
      "\n",
      "         iter : 240\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 245\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 250\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 255\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 260\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 265\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 270\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 275\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 280\n",
      "    mean_eval : 0.7163228392601013\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 285\n",
      "    mean_eval : 0.7163220643997192\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 290\n",
      "    mean_eval : 0.7163220643997192\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 295\n",
      "    mean_eval : 0.7163220643997192\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "         iter : 300\n",
      "    mean_eval : 0.7163220643997192\n",
      "pop_best_eval : 0.7154150009155273\n",
      "  median_eval : 0.7162055373191833\n",
      "\n",
      "n_perts = 500\n",
      "eva fast called with capacity = 512\n",
      "         iter : 5\n",
      "    mean_eval : 0.7962327003479004\n",
      "pop_best_eval : 0.7909090518951416\n",
      "  median_eval : 0.7968379259109497\n",
      "\n",
      "         iter : 10\n",
      "    mean_eval : 0.789265513420105\n",
      "pop_best_eval : 0.7790513634681702\n",
      "  median_eval : 0.78972327709198\n",
      "\n",
      "         iter : 15\n",
      "    mean_eval : 0.7824805378913879\n",
      "pop_best_eval : 0.7766798138618469\n",
      "  median_eval : 0.7830039262771606\n",
      "\n",
      "         iter : 20\n",
      "    mean_eval : 0.7767122387886047\n",
      "pop_best_eval : 0.7707509994506836\n",
      "  median_eval : 0.7770751118659973\n",
      "\n",
      "         iter : 25\n",
      "    mean_eval : 0.7700345516204834\n",
      "pop_best_eval : 0.7636363506317139\n",
      "  median_eval : 0.7703557014465332\n",
      "\n",
      "         iter : 30\n",
      "    mean_eval : 0.7650730609893799\n",
      "pop_best_eval : 0.7588932514190674\n",
      "  median_eval : 0.7656126618385315\n",
      "\n",
      "         iter : 35\n",
      "    mean_eval : 0.7594861388206482\n",
      "pop_best_eval : 0.7533596754074097\n",
      "  median_eval : 0.7596837878227234\n",
      "\n",
      "         iter : 40\n",
      "    mean_eval : 0.7531404495239258\n",
      "pop_best_eval : 0.7442687749862671\n",
      "  median_eval : 0.7537549138069153\n",
      "\n",
      "         iter : 45\n",
      "    mean_eval : 0.7469707131385803\n",
      "pop_best_eval : 0.7395256757736206\n",
      "  median_eval : 0.7474308013916016\n",
      "\n",
      "         iter : 50\n",
      "    mean_eval : 0.7420300245285034\n",
      "pop_best_eval : 0.7339920997619629\n",
      "  median_eval : 0.7422924637794495\n",
      "\n",
      "         iter : 55\n",
      "    mean_eval : 0.7368391752243042\n",
      "pop_best_eval : 0.7300395369529724\n",
      "  median_eval : 0.7371541261672974\n",
      "\n",
      "         iter : 60\n",
      "    mean_eval : 0.731580376625061\n",
      "pop_best_eval : 0.7245059013366699\n",
      "  median_eval : 0.7320157885551453\n",
      "\n",
      "         iter : 65\n",
      "    mean_eval : 0.7272650003433228\n",
      "pop_best_eval : 0.7205533385276794\n",
      "  median_eval : 0.7276679873466492\n",
      "\n",
      "         iter : 70\n",
      "    mean_eval : 0.723233699798584\n",
      "pop_best_eval : 0.7169960141181946\n",
      "  median_eval : 0.7237154245376587\n",
      "\n",
      "         iter : 75\n",
      "    mean_eval : 0.718402624130249\n",
      "pop_best_eval : 0.7118576765060425\n",
      "  median_eval : 0.7185770869255066\n",
      "\n",
      "         iter : 80\n",
      "    mean_eval : 0.7131778001785278\n",
      "pop_best_eval : 0.7083003520965576\n",
      "  median_eval : 0.7134387493133545\n",
      "\n",
      "         iter : 85\n",
      "    mean_eval : 0.7088531255722046\n",
      "pop_best_eval : 0.7027667760848999\n",
      "  median_eval : 0.7090908885002136\n",
      "\n",
      "         iter : 90\n",
      "    mean_eval : 0.7047067880630493\n",
      "pop_best_eval : 0.699209451675415\n",
      "  median_eval : 0.7051383256912231\n",
      "\n",
      "         iter : 95\n",
      "    mean_eval : 0.7006052136421204\n",
      "pop_best_eval : 0.6964426636695862\n",
      "  median_eval : 0.700790524482727\n",
      "\n",
      "         iter : 100\n",
      "    mean_eval : 0.6971428394317627\n",
      "pop_best_eval : 0.6924901008605957\n",
      "  median_eval : 0.6976284384727478\n",
      "\n",
      "         iter : 105\n",
      "    mean_eval : 0.6936565637588501\n",
      "pop_best_eval : 0.6889327764511108\n",
      "  median_eval : 0.6940711140632629\n",
      "\n",
      "         iter : 110\n",
      "    mean_eval : 0.6902320384979248\n",
      "pop_best_eval : 0.6849802136421204\n",
      "  median_eval : 0.6905138492584229\n",
      "\n",
      "         iter : 115\n",
      "    mean_eval : 0.686887800693512\n",
      "pop_best_eval : 0.6830039620399475\n",
      "  median_eval : 0.6873517632484436\n",
      "\n",
      "         iter : 120\n",
      "    mean_eval : 0.6839712858200073\n",
      "pop_best_eval : 0.6802371144294739\n",
      "  median_eval : 0.6841897368431091\n",
      "\n",
      "         iter : 125\n",
      "    mean_eval : 0.6811133623123169\n",
      "pop_best_eval : 0.6766798496246338\n",
      "  median_eval : 0.6814228892326355\n",
      "\n",
      "         iter : 130\n",
      "    mean_eval : 0.6784075498580933\n",
      "pop_best_eval : 0.6747035384178162\n",
      "  median_eval : 0.6786561012268066\n",
      "\n",
      "         iter : 135\n",
      "    mean_eval : 0.6757681369781494\n",
      "pop_best_eval : 0.6711462140083313\n",
      "  median_eval : 0.6758893132209778\n",
      "\n",
      "         iter : 140\n",
      "    mean_eval : 0.6733919382095337\n",
      "pop_best_eval : 0.6703557372093201\n",
      "  median_eval : 0.6735177636146545\n",
      "\n",
      "         iter : 145\n",
      "    mean_eval : 0.6711940765380859\n",
      "pop_best_eval : 0.6679841876029968\n",
      "  median_eval : 0.6715415120124817\n",
      "\n",
      "         iter : 150\n",
      "    mean_eval : 0.6692085266113281\n",
      "pop_best_eval : 0.6664031744003296\n",
      "  median_eval : 0.6695652008056641\n",
      "\n",
      "         iter : 155\n",
      "    mean_eval : 0.6673025488853455\n",
      "pop_best_eval : 0.6640316247940063\n",
      "  median_eval : 0.6675889492034912\n",
      "\n",
      "         iter : 160\n",
      "    mean_eval : 0.66529381275177\n",
      "pop_best_eval : 0.6620553135871887\n",
      "  median_eval : 0.6656126379966736\n",
      "\n",
      "         iter : 165\n",
      "    mean_eval : 0.663390040397644\n",
      "pop_best_eval : 0.6600790619850159\n",
      "  median_eval : 0.663636326789856\n",
      "\n",
      "         iter : 170\n",
      "    mean_eval : 0.661514937877655\n",
      "pop_best_eval : 0.6592885255813599\n",
      "  median_eval : 0.6616600751876831\n",
      "\n",
      "         iter : 175\n",
      "    mean_eval : 0.6599377393722534\n",
      "pop_best_eval : 0.6569169759750366\n",
      "  median_eval : 0.6600790619850159\n",
      "\n",
      "         iter : 180\n",
      "    mean_eval : 0.658464789390564\n",
      "pop_best_eval : 0.6553359627723694\n",
      "  median_eval : 0.6584979891777039\n",
      "\n",
      "         iter : 185\n",
      "    mean_eval : 0.6570953130722046\n",
      "pop_best_eval : 0.6537549495697021\n",
      "  median_eval : 0.6573122143745422\n",
      "\n",
      "         iter : 190\n",
      "    mean_eval : 0.6562862992286682\n",
      "pop_best_eval : 0.6533596515655518\n",
      "  median_eval : 0.656521737575531\n",
      "\n",
      "         iter : 195\n",
      "    mean_eval : 0.6548550128936768\n",
      "pop_best_eval : 0.6525691747665405\n",
      "  median_eval : 0.6549407243728638\n",
      "\n",
      "         iter : 200\n",
      "    mean_eval : 0.6536321640014648\n",
      "pop_best_eval : 0.6509881019592285\n",
      "  median_eval : 0.6537549495697021\n",
      "\n",
      "         iter : 205\n",
      "    mean_eval : 0.6523422002792358\n",
      "pop_best_eval : 0.6498023867607117\n",
      "  median_eval : 0.6525691747665405\n",
      "\n",
      "         iter : 210\n",
      "    mean_eval : 0.6513200998306274\n",
      "pop_best_eval : 0.6490118503570557\n",
      "  median_eval : 0.6513833999633789\n",
      "\n",
      "         iter : 215\n",
      "    mean_eval : 0.6500825881958008\n",
      "pop_best_eval : 0.6474308371543884\n",
      "  median_eval : 0.6501976251602173\n",
      "\n",
      "         iter : 220\n",
      "    mean_eval : 0.6489354372024536\n",
      "pop_best_eval : 0.6462450623512268\n",
      "  median_eval : 0.6490118503570557\n",
      "\n",
      "         iter : 225\n",
      "    mean_eval : 0.6477550268173218\n",
      "pop_best_eval : 0.6454545259475708\n",
      "  median_eval : 0.647826075553894\n",
      "\n",
      "         iter : 230\n",
      "    mean_eval : 0.6470425128936768\n",
      "pop_best_eval : 0.6446640491485596\n",
      "  median_eval : 0.647035539150238\n",
      "\n",
      "         iter : 235\n",
      "    mean_eval : 0.6461369395256042\n",
      "pop_best_eval : 0.643478274345398\n",
      "  median_eval : 0.6462450623512268\n",
      "\n",
      "         iter : 240\n",
      "    mean_eval : 0.645150363445282\n",
      "pop_best_eval : 0.6426877379417419\n",
      "  median_eval : 0.6454545259475708\n",
      "\n",
      "         iter : 245\n",
      "    mean_eval : 0.644362211227417\n",
      "pop_best_eval : 0.6426877379417419\n",
      "  median_eval : 0.6442687511444092\n",
      "\n",
      "         iter : 250\n",
      "    mean_eval : 0.6433431506156921\n",
      "pop_best_eval : 0.6415019631385803\n",
      "  median_eval : 0.643478274345398\n",
      "\n",
      "         iter : 255\n",
      "    mean_eval : 0.642316460609436\n",
      "pop_best_eval : 0.6395256519317627\n",
      "  median_eval : 0.6422924995422363\n",
      "\n",
      "         iter : 260\n",
      "    mean_eval : 0.6414794921875\n",
      "pop_best_eval : 0.6395256519317627\n",
      "  median_eval : 0.6415019631385803\n",
      "\n",
      "         iter : 265\n",
      "    mean_eval : 0.6408032774925232\n",
      "pop_best_eval : 0.6391304135322571\n",
      "  median_eval : 0.6407114267349243\n",
      "\n",
      "         iter : 270\n",
      "    mean_eval : 0.6399896144866943\n",
      "pop_best_eval : 0.6379446387290955\n",
      "  median_eval : 0.6399209499359131\n",
      "\n",
      "         iter : 275\n",
      "    mean_eval : 0.6393009424209595\n",
      "pop_best_eval : 0.6367588639259338\n",
      "  median_eval : 0.6395256519317627\n",
      "\n",
      "         iter : 280\n",
      "    mean_eval : 0.6386000514030457\n",
      "pop_best_eval : 0.6367588639259338\n",
      "  median_eval : 0.6387351751327515\n",
      "\n",
      "         iter : 285\n",
      "    mean_eval : 0.6379462480545044\n",
      "pop_best_eval : 0.6359683871269226\n",
      "  median_eval : 0.6379446387290955\n",
      "\n",
      "         iter : 290\n",
      "    mean_eval : 0.63730388879776\n",
      "pop_best_eval : 0.6359683871269226\n",
      "  median_eval : 0.6375494003295898\n",
      "\n",
      "         iter : 295\n",
      "    mean_eval : 0.6367018222808838\n",
      "pop_best_eval : 0.6351778507232666\n",
      "  median_eval : 0.6367588639259338\n",
      "\n",
      "         iter : 300\n",
      "    mean_eval : 0.6361459493637085\n",
      "pop_best_eval : 0.6343873143196106\n",
      "  median_eval : 0.6363636255264282\n",
      "\n"
     ]
    }
   ],
   "source": [
    "loss_comp_attack = []\n",
    "\n",
    "for n_perts in [10, 20, 50, 100, 200, 500]:\n",
    "    print(\"n_perts =\", n_perts)\n",
    "    attack = attack_graph(\n",
    "        attack_name='EVAFAST', attack_params={\"debug\": True, \"mutation_rate\": 0.02, \"mutation_method\": 'adaptive', \"capacity\":512}, epsilon=0.1,\n",
    "        test_attr=test_attr, test_adj=test_adj, labels=labels, model=model,\n",
    "        dataset_info=dataset_info, model_storage_name=model_storage_name, \n",
    "        split_name=split_name, test_mask=test_mask,\n",
    "        unlabeled_mask=unlabeled_mask, n_perturbations=n_perts,\n",
    "        default_attack_configs=default_attack_configs, reports_root=reports_root,\n",
    "        device=device, inductive=False, save=False)\n",
    "    perturbations = attack.debug_info\n",
    "    for iter_n, perturbation in enumerate(perturbations):\n",
    "        \n",
    "        _, pert_adj = attack._create_perturbed_graph(test_attr, test_adj, perturbation)\n",
    "        pert_pred = model(test_attr, pert_adj)\n",
    "        perturbed_acc = (pert_pred.argmax(1) == labels)[test_mask].float().mean()\n",
    "        perturbed_loss = {\n",
    "            \"CW\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"CW\").item(),\n",
    "            \"LCW\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"LCW\").item(),\n",
    "            \"tanhMargin\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"tanhMargin\").item(),\n",
    "            \"Margin\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"Margin\").item(),\n",
    "            # \"eluMargin\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"eluMargin\"),\n",
    "            \"MCE\": calculate_loss(pert_pred[test_mask], labels[test_mask], \"MCE\").item(),\n",
    "            \"acc\": ((original_acc - perturbed_acc) / original_acc).item(),\n",
    "            \"n_pert\": n_perts,\n",
    "            \"iter_n\": iter_n,\n",
    "        }\n",
    "        loss_comp_attack.append(perturbed_loss)\n",
    "    # worst_acc = perturbed_loss[-1][\"acc\"]\n",
    "loss_comp_attack = pd.DataFrame(loss_comp_attack)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>CW</th>\n",
       "      <th>LCW</th>\n",
       "      <th>tanhMargin</th>\n",
       "      <th>Margin</th>\n",
       "      <th>MCE</th>\n",
       "      <th>acc</th>\n",
       "      <th>n_pert</th>\n",
       "      <th>iter_n</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-3.825426</td>\n",
       "      <td>-3.800310</td>\n",
       "      <td>-0.691199</td>\n",
       "      <td>-3.574266</td>\n",
       "      <td>0.163434</td>\n",
       "      <td>0.004149</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-3.830685</td>\n",
       "      <td>-3.804309</td>\n",
       "      <td>-0.688570</td>\n",
       "      <td>-3.566918</td>\n",
       "      <td>0.162492</td>\n",
       "      <td>0.004149</td>\n",
       "      <td>10</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-3.844673</td>\n",
       "      <td>-3.819551</td>\n",
       "      <td>-0.694745</td>\n",
       "      <td>-3.593446</td>\n",
       "      <td>0.165127</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-3.843632</td>\n",
       "      <td>-3.818055</td>\n",
       "      <td>-0.687996</td>\n",
       "      <td>-3.587862</td>\n",
       "      <td>0.159204</td>\n",
       "      <td>0.008299</td>\n",
       "      <td>10</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-3.843632</td>\n",
       "      <td>-3.818055</td>\n",
       "      <td>-0.687996</td>\n",
       "      <td>-3.587862</td>\n",
       "      <td>0.159204</td>\n",
       "      <td>0.008299</td>\n",
       "      <td>10</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1795</th>\n",
       "      <td>-3.379749</td>\n",
       "      <td>-3.340671</td>\n",
       "      <td>-0.487015</td>\n",
       "      <td>-2.988968</td>\n",
       "      <td>0.084441</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>500</td>\n",
       "      <td>295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1796</th>\n",
       "      <td>-3.368761</td>\n",
       "      <td>-3.331148</td>\n",
       "      <td>-0.485985</td>\n",
       "      <td>-2.992628</td>\n",
       "      <td>0.083775</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>500</td>\n",
       "      <td>296</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1797</th>\n",
       "      <td>-3.368761</td>\n",
       "      <td>-3.331148</td>\n",
       "      <td>-0.485985</td>\n",
       "      <td>-2.992628</td>\n",
       "      <td>0.083775</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>500</td>\n",
       "      <td>297</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1798</th>\n",
       "      <td>-3.368761</td>\n",
       "      <td>-3.331148</td>\n",
       "      <td>-0.485985</td>\n",
       "      <td>-2.992628</td>\n",
       "      <td>0.083775</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>500</td>\n",
       "      <td>298</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1799</th>\n",
       "      <td>-3.368761</td>\n",
       "      <td>-3.331148</td>\n",
       "      <td>-0.485985</td>\n",
       "      <td>-2.992628</td>\n",
       "      <td>0.083775</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>500</td>\n",
       "      <td>299</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1800 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "            CW       LCW  tanhMargin    Margin       MCE       acc  n_pert  \\\n",
       "0    -3.825426 -3.800310   -0.691199 -3.574266  0.163434  0.004149      10   \n",
       "1    -3.830685 -3.804309   -0.688570 -3.566918  0.162492  0.004149      10   \n",
       "2    -3.844673 -3.819551   -0.694745 -3.593446  0.165127  0.000000      10   \n",
       "3    -3.843632 -3.818055   -0.687996 -3.587862  0.159204  0.008299      10   \n",
       "4    -3.843632 -3.818055   -0.687996 -3.587862  0.159204  0.008299      10   \n",
       "...        ...       ...         ...       ...       ...       ...     ...   \n",
       "1795 -3.379749 -3.340671   -0.487015 -2.988968  0.084441  0.195021     500   \n",
       "1796 -3.368761 -3.331148   -0.485985 -2.992628  0.083775  0.195021     500   \n",
       "1797 -3.368761 -3.331148   -0.485985 -2.992628  0.083775  0.195021     500   \n",
       "1798 -3.368761 -3.331148   -0.485985 -2.992628  0.083775  0.195021     500   \n",
       "1799 -3.368761 -3.331148   -0.485985 -2.992628  0.083775  0.195021     500   \n",
       "\n",
       "      iter_n  \n",
       "0          0  \n",
       "1          1  \n",
       "2          2  \n",
       "3          3  \n",
       "4          4  \n",
       "...      ...  \n",
       "1795     295  \n",
       "1796     296  \n",
       "1797     297  \n",
       "1798     298  \n",
       "1799     299  \n",
       "\n",
       "[1800 rows x 8 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# loss_comp_attack = pd.DataFrame(loss_comp_attack)\n",
    "loss_comp_attack.to_csv(\"../../loss_comp_attack.csv\")\n",
    "loss_comp_attack"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 30.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 31.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 50\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 32.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 180/300 [00:05<00:03, 33.95it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 32.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 200\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 30.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:08<00:00, 34.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_perts = 1000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:09<00:00, 32.43it/s]\n"
     ]
    }
   ],
   "source": [
    "loss_comp_attack_prbcd = []\n",
    "\n",
    "for n_perts in [10, 20, 50, 100, 200, 500, 1000]:\n",
    "    print(\"n_perts =\", n_perts)\n",
    "    attack = attack_graph(\n",
    "        attack_name='PRBCD', attack_params={\"epochs\": 300}, epsilon=0.1,\n",
    "        test_attr=test_attr, test_adj=test_adj, labels=labels, model=model,\n",
    "        dataset_info=dataset_info, model_storage_name=model_storage_name, \n",
    "        split_name=split_name, test_mask=test_mask,\n",
    "        unlabeled_mask=unlabeled_mask, n_perturbations=n_perts,\n",
    "        default_attack_configs=default_attack_configs, reports_root=reports_root,\n",
    "        device=device, inductive=False, save=False)\n",
    "    losses = [item.item() if isinstance(item, torch.Tensor) else item for item in attack.attack_statistics[\"loss\"]]\n",
    "    accs = attack.attack_statistics[\"accuracy\"]\n",
    "    # worst_accuracy = accs[-1]\n",
    "    # print(\"Worst Accuracy =\", worst_accuracy)\n",
    "    loss_comp_attack_prbcd += [{\n",
    "        \"iter_n\": i, \"n_pert\": n_perts, \n",
    "        \"acc\": ((original_acc - accs[i])/original_acc).item(), \"tanhMargin\": losses[i]\n",
    "        } for i in range(len(accs))]\n",
    "    \n",
    "loss_comp_attack_prbcd = pd.DataFrame(loss_comp_attack_prbcd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>iter_n</th>\n",
       "      <th>n_pert</th>\n",
       "      <th>acc</th>\n",
       "      <th>tanhMargin</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>0.045560</td>\n",
       "      <td>-0.622758</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>0.055238</td>\n",
       "      <td>-0.622758</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>10</td>\n",
       "      <td>0.060307</td>\n",
       "      <td>-0.614217</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>10</td>\n",
       "      <td>0.063994</td>\n",
       "      <td>-0.609338</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>10</td>\n",
       "      <td>0.065376</td>\n",
       "      <td>-0.606602</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2102</th>\n",
       "      <td>296</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.372309</td>\n",
       "      <td>-0.098087</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2103</th>\n",
       "      <td>297</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.372309</td>\n",
       "      <td>-0.098083</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2104</th>\n",
       "      <td>298</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.372309</td>\n",
       "      <td>-0.098076</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2105</th>\n",
       "      <td>299</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.372309</td>\n",
       "      <td>-0.098089</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2106</th>\n",
       "      <td>300</td>\n",
       "      <td>1000</td>\n",
       "      <td>0.372309</td>\n",
       "      <td>-0.098085</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>2107 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      iter_n  n_pert       acc  tanhMargin\n",
       "0          0      10  0.045560   -0.622758\n",
       "1          1      10  0.055238   -0.622758\n",
       "2          2      10  0.060307   -0.614217\n",
       "3          3      10  0.063994   -0.609338\n",
       "4          4      10  0.065376   -0.606602\n",
       "...      ...     ...       ...         ...\n",
       "2102     296    1000  0.372309   -0.098087\n",
       "2103     297    1000  0.372309   -0.098083\n",
       "2104     298    1000  0.372309   -0.098076\n",
       "2105     299    1000  0.372309   -0.098089\n",
       "2106     300    1000  0.372309   -0.098085\n",
       "\n",
       "[2107 rows x 4 columns]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_comp_attack_prbcd.to_csv(\"../../loss_comp_attack_prbcd.csv\")\n",
    "loss_comp_attack_prbcd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>CW</th>\n",
       "      <th>LCW</th>\n",
       "      <th>tanhMargin</th>\n",
       "      <th>Margin</th>\n",
       "      <th>MCE</th>\n",
       "      <th>acc</th>\n",
       "      <th>n_pert</th>\n",
       "      <th>iter_n</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-3.816213</td>\n",
       "      <td>-3.790802</td>\n",
       "      <td>-0.690704</td>\n",
       "      <td>-3.562103</td>\n",
       "      <td>0.165012</td>\n",
       "      <td>0.004149</td>\n",
       "      <td>50</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-3.818451</td>\n",
       "      <td>-3.792803</td>\n",
       "      <td>-0.682738</td>\n",
       "      <td>-3.561976</td>\n",
       "      <td>0.160238</td>\n",
       "      <td>0.008299</td>\n",
       "      <td>50</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-3.827033</td>\n",
       "      <td>-3.801488</td>\n",
       "      <td>-0.692392</td>\n",
       "      <td>-3.571582</td>\n",
       "      <td>0.162979</td>\n",
       "      <td>0.004149</td>\n",
       "      <td>50</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-3.811241</td>\n",
       "      <td>-3.785928</td>\n",
       "      <td>-0.690276</td>\n",
       "      <td>-3.558108</td>\n",
       "      <td>0.162992</td>\n",
       "      <td>0.004149</td>\n",
       "      <td>50</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-3.811241</td>\n",
       "      <td>-3.785928</td>\n",
       "      <td>-0.690276</td>\n",
       "      <td>-3.558108</td>\n",
       "      <td>0.162992</td>\n",
       "      <td>0.004149</td>\n",
       "      <td>50</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>495</th>\n",
       "      <td>-3.114490</td>\n",
       "      <td>-3.076871</td>\n",
       "      <td>-0.468360</td>\n",
       "      <td>-2.738299</td>\n",
       "      <td>0.116675</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>1000</td>\n",
       "      <td>95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>496</th>\n",
       "      <td>-3.114490</td>\n",
       "      <td>-3.076871</td>\n",
       "      <td>-0.468360</td>\n",
       "      <td>-2.738299</td>\n",
       "      <td>0.116675</td>\n",
       "      <td>0.195021</td>\n",
       "      <td>1000</td>\n",
       "      <td>96</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>497</th>\n",
       "      <td>-3.108041</td>\n",
       "      <td>-3.075352</td>\n",
       "      <td>-0.508811</td>\n",
       "      <td>-2.781152</td>\n",
       "      <td>0.148728</td>\n",
       "      <td>0.153527</td>\n",
       "      <td>1000</td>\n",
       "      <td>97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>498</th>\n",
       "      <td>-3.119618</td>\n",
       "      <td>-3.083733</td>\n",
       "      <td>-0.494597</td>\n",
       "      <td>-2.760770</td>\n",
       "      <td>0.123871</td>\n",
       "      <td>0.174274</td>\n",
       "      <td>1000</td>\n",
       "      <td>98</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>499</th>\n",
       "      <td>-3.119618</td>\n",
       "      <td>-3.083733</td>\n",
       "      <td>-0.494597</td>\n",
       "      <td>-2.760770</td>\n",
       "      <td>0.123871</td>\n",
       "      <td>0.174274</td>\n",
       "      <td>1000</td>\n",
       "      <td>99</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>500 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           CW       LCW  tanhMargin    Margin       MCE       acc  n_pert  \\\n",
       "0   -3.816213 -3.790802   -0.690704 -3.562103  0.165012  0.004149      50   \n",
       "1   -3.818451 -3.792803   -0.682738 -3.561976  0.160238  0.008299      50   \n",
       "2   -3.827033 -3.801488   -0.692392 -3.571582  0.162979  0.004149      50   \n",
       "3   -3.811241 -3.785928   -0.690276 -3.558108  0.162992  0.004149      50   \n",
       "4   -3.811241 -3.785928   -0.690276 -3.558108  0.162992  0.004149      50   \n",
       "..        ...       ...         ...       ...       ...       ...     ...   \n",
       "495 -3.114490 -3.076871   -0.468360 -2.738299  0.116675  0.195021    1000   \n",
       "496 -3.114490 -3.076871   -0.468360 -2.738299  0.116675  0.195021    1000   \n",
       "497 -3.108041 -3.075352   -0.508811 -2.781152  0.148728  0.153527    1000   \n",
       "498 -3.119618 -3.083733   -0.494597 -2.760770  0.123871  0.174274    1000   \n",
       "499 -3.119618 -3.083733   -0.494597 -2.760770  0.123871  0.174274    1000   \n",
       "\n",
       "     iter_n  \n",
       "0         0  \n",
       "1         1  \n",
       "2         2  \n",
       "3         3  \n",
       "4         4  \n",
       "..      ...  \n",
       "495      95  \n",
       "496      96  \n",
       "497      97  \n",
       "498      98  \n",
       "499      99  \n",
       "\n",
       "[500 rows x 8 columns]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_comp_attack"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(indices=tensor([[   0,    0,    0,  ..., 2808, 2808, 2809],\n",
       "                       [1579, 1581, 2241,  ...,  730, 1787, 1399]]),\n",
       "       values=tensor([1., 1., 1.,  ..., 1., 1., 1.]),\n",
       "       device='cuda:0', size=(2810, 2810), nnz=15962, layout=torch.sparse_coo)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_adj_tensor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'pert_' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Input \u001b[0;32mIn [10]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mpert_\u001b[49m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'pert_' is not defined"
     ]
    }
   ],
   "source": [
    "pert_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([-0.0653, -0.2453, -0.3212,  1.5174,  1.1180, -0.3996,  0.7618, -1.1082,\n",
       "        -2.0809,  1.0490])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(torch.randn(n_perts))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.undefined"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
