{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "from pathlib import Path\n",
    "import json\n",
    "import pandas\n",
    "import glob\n",
    "import pandas  as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import ast\n",
    "from collections import defaultdict\n",
    "import sys\n",
    "from datetime import datetime\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Some useful functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "# Transforms strings to python objects. e.g. \"True\" into the value True\n",
    "def string_to_python(string):\n",
    "    try:\n",
    "        return ast.literal_eval(string)\n",
    "    except:\n",
    "        return string\n",
    "\n",
    "# Reads experiment name (e.g. \"meta-l_mp=2-stage=skipsum-agg=add-us=20-action=edge-meta_nl=2-rw=loss_clf_pred_penalty-ps=0.0-ps=False-mel=1-dataset=TU_PROTEINS\")\n",
    "# Returns a dict: {'l_mp': 2, 'stage': 'skipsum', ...}\n",
    "def name_to_dict(run):\n",
    "    cols = run.split('-')[1:]\n",
    "    keys, vals = [], []\n",
    "    for col in cols:\n",
    "        try:\n",
    "            key, val = col.split('=')\n",
    "        except:\n",
    "            print(col)\n",
    "        keys.append(key)\n",
    "        vals.append(string_to_python(val))\n",
    "    return dict(zip(keys, vals))\n",
    "\n",
    "mapping_dict = {\n",
    "    'l_type_full': 'Model',\n",
    "    None: '',  \n",
    "    \n",
    "}\n",
    "mapping_dict.update({\n",
    "    'ourgatv1': 'GATv1',\n",
    "    'ourgatv2': 'GATv2',\n",
    "    'gingatv1': 'GINGAT'\n",
    "})\n",
    "\n",
    "\n",
    "mapping_dict.update({\n",
    "    'individual': '-ind', \n",
    "    'individual2': '-ind2', \n",
    "    'learn_new': '-lallv2', \n",
    "    'learn12': '-lall', \n",
    "    'learn2': '-l2',\n",
    "    'mlp': '-mlp', \n",
    "    'gcn_gat': '-gcngat', \n",
    "    'learn1': '-l1'\n",
    "})\n",
    "\n",
    "def column_mapping(col):\n",
    "    if 'TU_' == col[:3]:\n",
    "        return col[3:]\n",
    "    if col in mapping_dict:\n",
    "        return mapping_dict[col]\n",
    "    return col\n",
    "\n",
    "\n",
    "\n",
    "def get_mode(row):\n",
    "    if row['gcn_mode']:\n",
    "        base_name = row['l_type']\n",
    "        if base_name in ['GATv1', 'GATv2']:\n",
    "            return 'GCN'\n",
    "        elif base_name in ['GINGAT']:\n",
    "            return 'GIN'\n",
    "        else:\n",
    "            raise NotImplementedError\n",
    "    else:\n",
    "        return ''\n",
    "\n",
    "def get_l_type_full(df):\n",
    "    lmbda = df['l_lambda'].map(mapping_dict).fillna('')\n",
    "    share = df['share'].map({False: '', True: 'Share'}).fillna('')\n",
    "    convolve =  df['convolve'].map({False: '', True: '-Conv'}).fillna('')\n",
    "    if 'gcn_mode' in df.columns:\n",
    "        mode = df.apply(lambda row: get_mode(row), axis=1)\n",
    "    else:\n",
    "        mode = ''\n",
    "    l_type = df['l_type']\n",
    "    full_name = share  + mode + l_type + convolve +  lmbda\n",
    "    if 'gcn_mode' in df.columns:\n",
    "        cond = df['gcn_mode']\n",
    "        full_name[cond] = mode[cond]\n",
    "    cond = df['l_mp'].apply(lambda x: x == 0 )\n",
    "    full_name[cond] = 'Dense'\n",
    "    return full_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Loading all data\n",
    "\n",
    "Be sure to run `python agg_batch.py --dir EXPER_ROOT_DIR` before executing the following code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting! 11:25:46\n",
      "Subfolders:\n",
      "\tgcnbasic_grid_node_1\n",
      "\tgcnbasic\n",
      "\tgcnbasic_grid_node_gin_1\n",
      "\tgcnbasic_grid_node_gin_ind\n",
      "\tgcnbasic_grid_node_gin_2\n",
      "\tgin\n",
      "\tgcnbasic_grid_node_gin_3\n"
     ]
    }
   ],
   "source": [
    "root_folder = os.path.join('..', 'run','results')\n",
    "subfolders = os.listdir(root_folder)\n",
    "\n",
    "splits = ['val', 'test', 'train']\n",
    "\n",
    "\n",
    "print(\"Starting!\", datetime.now().strftime(\"%H:%M:%S\"))\n",
    "# subfolders = ['ourgatv1_grid_node']\n",
    "print(\"Subfolders:\")\n",
    "\n",
    "for subf in subfolders:\n",
    "    print(f\"\\t{subf}\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Select the experiment sets you would like to evaluate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from yacs.config import CfgNode as CN\n",
    "cfg = CN()\n",
    "\n",
    "cfg.folder = []\n",
    "\n",
    "cfg.folder.append('gcnbasic_grid_node_gin_1')\n",
    "cfg.folder.append('gcnbasic_grid_node_gin_2')\n",
    "cfg.folder.append('gcnbasic_grid_node_gin_3')\n",
    "cfg.folder.append('gcnbasic_grid_node_gin_ind')\n",
    "\n",
    "\n",
    "# cfg.folder.append('gcnbasic_all_grid_node_1')\n",
    "# cfg.folder.append('gcnbasic_all_grid_node_2')\n",
    "# cfg.folder.append('gcnbasic_all_grid_node_3')\n",
    "# cfg.folder.append('gcnbasic_all_grid_node_ind')\n",
    "# cfg.folder.append('gcnbasic_all_grid_node_mlp')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "len:720\n",
      "len:1440\n",
      "len:1800\n",
      "len:1760\n",
      "2860\n",
      "[None 'learn12']\n",
      "[False  True]\n",
      "l_type_full: ['GINGAT-Conv' 'GIN' 'ShareGINGAT-Conv' 'GINGAT' 'ShareGINGAT'\n",
      " 'ShareGINGAT-Conv-lall' 'GINGAT-Conv-lall']\n",
      "IS CLF: True\n"
     ]
    }
   ],
   "source": [
    "\n",
    "cfg.is_clf = False if all(['_reg' in f for f in cfg.folder]) else True\n",
    "\n",
    "if cfg.is_clf:\n",
    "#     cfg.pickle_file = 'results_last_accuracy.pkl'\n",
    "    cfg.pickle_file = 'results_accuracy.pkl'\n",
    "\n",
    "else:\n",
    "    cfg.pickle_file = 'results_mse.pkl'\n",
    "    \n",
    "df_list = []\n",
    "for f in cfg.folder:\n",
    "    df = pd.read_pickle(os.path.join(root_folder, f, cfg.pickle_file))\n",
    "    df['l_type'] = df['l_type'].map(mapping_dict)\n",
    "    df['l_type_full'] = get_l_type_full(df).fillna('')\n",
    "    df_list.append(df)\n",
    "    print(f\"len:{len(df)}\")\n",
    "\n",
    "df = pd.concat(df_list, ignore_index=True)\n",
    "df['l_type'] = df['l_type_full'].apply(lambda x: x.split('-')[0])\n",
    "\n",
    "max_epochs = 3000\n",
    "max_epochs_val = max_epochs/10\n",
    "for c in df.columns:\n",
    "    if 'area' in c:\n",
    "        if 'train' in c:\n",
    "            df[c] = df[c]/df['best_epoch']\n",
    "        else:\n",
    "            df[c] = df[c]/(df['best_epoch'] +1)*10\n",
    "df = df[df['l_mp']==4]\n",
    "# df = df[df['lr']< 0.01]\n",
    "# df = df[df['lr'] ==  0.0001]\n",
    "# df = df[df['drop']==0.0]\n",
    "# df = df[df.dataset == 'TwitchEN']\n",
    "# cond1 = df['gcn_mode'] == True\n",
    "\n",
    "# cond2 = df['g_heads'] == 4\n",
    "\n",
    "# print(sum(cond1))\n",
    "# print(sum(cond2))\n",
    "# df = df.loc[cond2 | cond1]\n",
    "# df = df.loc[cond1 | cond2]\n",
    "print(len(df))\n",
    "print(df['l_lambda'].unique())\n",
    "print(df['gcn_mode'].unique())\n",
    "print(f\"l_type_full: {df.l_type_full.unique()}\")\n",
    "print(f\"IS CLF: {cfg.is_clf}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "220\n",
      "[0] kfold \n",
      "\t[1]\n",
      "[1] task \n",
      "\t['node']\n",
      "[2] trans \n",
      "\t[ True]\n",
      "[3] l_pre \n",
      "\t[1]\n",
      "[4] l_mp \n",
      "\t[4]\n",
      "[5] l_post \n",
      "\t[1]\n",
      "[6] stage \n",
      "\t['skipsum']\n",
      "[7] drop \n",
      "\t[0.]\n",
      "[8] lr \n",
      "\t[0.005 0.01 ]\n",
      "[9] l_type \n",
      "\t['GIN']\n",
      "[10] g_heads \n",
      "\t[1]\n",
      "[11] l_lambda \n",
      "\t[None]\n",
      "[12] convolve \n",
      "\t[ True]\n",
      "[13] share \n",
      "\t[ True]\n",
      "[14] gcn_mode \n",
      "\t[ True]\n",
      "[15] dataset \n",
      "[16] seed \n",
      "[17] best_epoch \n",
      "[52] config_folder \n",
      "[53] l_type_full \n",
      "\t['GIN']\n"
     ]
    }
   ],
   "source": [
    "df_tmp = df[df.l_type_full == 'GIN']\n",
    "print(len(df_tmp))\n",
    "for i, col in enumerate(df_tmp.columns):\n",
    "    cond = all([split not in  col for split in ['train', 'val', 'test']])\n",
    "    if cond:\n",
    "        print(f\"[{i}] {col} \")\n",
    "        unique = df_tmp[col].unique()\n",
    "        if len(unique) < 5:\n",
    "            print(f\"\\t{unique}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0] kfold\n",
      "[1] task\n",
      "[2] trans\n",
      "[3] l_pre\n",
      "[4] l_mp\n",
      "[5] l_post\n",
      "[6] stage\n",
      "[7] drop\n",
      "[8] lr\n",
      "[9] l_type\n",
      "[10] g_heads\n",
      "[11] l_lambda\n",
      "[12] convolve\n",
      "[13] share\n",
      "[14] gcn_mode\n",
      "[15] dataset\n",
      "[16] seed\n",
      "[17] best_epoch\n",
      "[52] config_folder\n",
      "[53] l_type_full\n",
      "\n",
      "TRAIN\n",
      "[18] epoch_train\n",
      "[19] eta_train\n",
      "[20] loss_train\n",
      "[21] lr_train\n",
      "[22] params_train\n",
      "[23] time_iter_train\n",
      "[24] accuracy_train\n",
      "[25] lmbda2_train\n",
      "[26] lmbda_train\n",
      "[27] eps_train\n",
      "[28] loss_area_train\n",
      "[29] accuracy_area_train\n",
      "[54] precision_train\n",
      "[55] recall_train\n",
      "[56] f1_train\n",
      "[57] auc_train\n",
      "[58] f1_area_train\n",
      "\n",
      "VAL\n",
      "[30] epoch_val\n",
      "[31] loss_val\n",
      "[32] lr_val\n",
      "[33] params_val\n",
      "[34] time_iter_val\n",
      "[35] accuracy_val\n",
      "[36] lmbda2_val\n",
      "[37] lmbda_val\n",
      "[38] eps_val\n",
      "[39] loss_area_val\n",
      "[40] accuracy_area_val\n",
      "[59] precision_val\n",
      "[60] recall_val\n",
      "[61] f1_val\n",
      "[62] auc_val\n",
      "[63] f1_area_val\n",
      "\n",
      "TEST\n",
      "[41] epoch_test\n",
      "[42] loss_test\n",
      "[43] lr_test\n",
      "[44] params_test\n",
      "[45] time_iter_test\n",
      "[46] accuracy_test\n",
      "[47] lmbda2_test\n",
      "[48] lmbda_test\n",
      "[49] eps_test\n",
      "[50] loss_area_test\n",
      "[51] accuracy_area_test\n",
      "[64] precision_test\n",
      "[65] recall_test\n",
      "[66] f1_test\n",
      "[67] auc_test\n",
      "[68] f1_area_test\n"
     ]
    }
   ],
   "source": [
    "for i, col in enumerate(df.columns):\n",
    "    cond = all([split not in  col for split in ['train', 'val', 'test']])\n",
    "    if cond:\n",
    "        print(f\"[{i}] {col}\")\n",
    "\n",
    "        \n",
    "for split in ['train', 'val', 'test']:\n",
    "    print(f'\\n{split.upper()}')\n",
    "    for i, col in enumerate(df.columns):\n",
    "        if split in col:\n",
    "            print(f\"[{i}] {col}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unique models\n",
      "GIN\n",
      "GINGAT\n",
      "GINGAT-Conv\n",
      "GINGAT-Conv-lall\n",
      "ShareGINGAT\n",
      "ShareGINGAT-Conv\n",
      "ShareGINGAT-Conv-lall\n"
     ]
    }
   ],
   "source": [
    "unique_l_type_full = df['l_type_full'].unique()\n",
    "unique_l_type_full.sort()\n",
    "print('Unique models')\n",
    "for el in unique_l_type_full:\n",
    "    print(el)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "#V2\n",
    "def get_best_configuration_df(config_columns, metric_cols, extra_cols, group_by_cols, metric_val, maximize_metric):\n",
    "\n",
    "    metric_cols_total = []\n",
    "    for metric in metric_cols:\n",
    "        for split in splits:\n",
    "            metric_col_i = f\"{metric}_{split}\"\n",
    "            if metric_col_i not in df.columns:\n",
    "                print(f'[SKIP] Metric not in column: {metric_col_i}')\n",
    "                continue\n",
    "            metric_cols_total.append(metric_col_i)\n",
    "            metric_cols_total.append(f\"{metric}_area_{split}\")\n",
    "    metric_cols_total.append('best_epoch')\n",
    "\n",
    "    total_cols = [*config_columns, *metric_cols_total]\n",
    "    if len(extra_cols) > 0: total_cols.extend(extra_cols)\n",
    "\n",
    "\n",
    "    df_mean_list = []\n",
    "    \n",
    "    df_dict = {}\n",
    "    \n",
    "\n",
    "#     df.fillna('N/A', inplace=True)\n",
    "    accuracy_test_seeds = []\n",
    "    for key, df_i in df.groupby(group_by_cols):\n",
    "        metric_val_tmp = metric_val\n",
    "        df_config = df_i[total_cols].groupby(config_columns)\n",
    "        \n",
    "\n",
    "        df_mean = df_config.agg(['mean', 'std', 'count'])\n",
    "        print(f\"{key} --> {len(df_mean)} hyperparams configs\")\n",
    "    #     df_mean = df_mean[df_mean[(metric_val, 'count')] > 8]\n",
    "        try:\n",
    "            idx_max = df_mean[(metric_val, 'mean')].argmax()\n",
    "        except:\n",
    "            print(f\"[ERROR] {key}\")\n",
    "            metric_val_tmp = 'accuracy_val'\n",
    "        idx_max = df_mean[(metric_val_tmp, 'mean')].argmax()\n",
    "\n",
    "        # print(key)\n",
    "        count = df_i[total_cols].groupby(config_columns).count()\n",
    "#         for tmp1, tmp2 in df_i.nunique().iteritems():\n",
    "#             print(f\"{tmp1}: {tmp2}\")\n",
    "#         print(f\"\\nCount: {count.max().max()} {key} {len(df_i)}\")\n",
    "#         for key_tmp, df_tmp in df_i[total_cols].groupby(config_columns):\n",
    "#             print(key_tmp)\n",
    "#             print(len(df_tmp))\n",
    "#             print(df_tmp.nunique())\n",
    "        \n",
    "#         print('-------------------------')\n",
    "\n",
    "        assert count.max().max() <=10, f\"Count: {count.max().max()} {key} {len(df_i)}\"\n",
    "        df_best = df_mean.iloc[idx_max]\n",
    "        \n",
    "        assert tuple(df_config.groups.keys())[idx_max] == df_best.name, f\"{tuple(df_config.groups.keys())[idx_max]} {df_best.name}\"\n",
    "        df_dict[key] = df_config.get_group(tuple(df_config.groups.keys())[idx_max])\n",
    "        \n",
    "        for idx, key_i in enumerate(key):\n",
    "            df_best[group_by_cols[idx]] = key_i\n",
    "        \n",
    "        \n",
    "        df_mean_list.append(df_best)\n",
    "    return pd.concat(df_mean_list, axis=1, keys=[s.name for s in df_mean_list]).T, df_dict\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'AmazonComputers', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'AmazonComputers', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonComputers', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'AmazonComputers', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonComputers', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonComputers', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'AmazonComputers', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonPhoto', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'AmazonPhoto', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'AmazonPhoto', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonPhoto', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonPhoto', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'AmazonPhoto', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'AmazonPhoto', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CiteSeer', 'GIN', 'GIN') --> 2 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'CiteSeer', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CiteSeer', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CiteSeer', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'CiteSeer', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CiteSeer', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CiteSeer', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorCS', 'GIN', 'GIN') --> 2 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'CoauthorCS', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorCS', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorCS', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorCS', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'CoauthorCS', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorCS', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorPhysics', 'GIN', 'GIN') --> 2 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'CoauthorPhysics', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorPhysics', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorPhysics', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'CoauthorPhysics', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorPhysics', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'CoauthorPhysics', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'Cora', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'Cora', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'Cora', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'Cora', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'Cora', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'Cora', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'Cora', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'DBLP', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'DBLP', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'DBLP', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'DBLP', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'DBLP', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'DBLP', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'DBLP', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'FacebookPagePage', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'FacebookPagePage', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'FacebookPagePage', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'FacebookPagePage', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'FacebookPagePage', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'FacebookPagePage', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'FacebookPagePage', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'GitHub', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'GitHub', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'GitHub', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'GitHub', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'GitHub', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'GitHub', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'GitHub', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'PubMed', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'PubMed', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'PubMed', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'PubMed', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'PubMed', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'PubMed', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'PubMed', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'TwitchEN', 'GIN', 'GIN') --> 2 hyperparams configs\n",
      "('node', 'TwitchEN', 'GINGAT', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'TwitchEN', 'GINGAT-Conv', 'GINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "('node', 'TwitchEN', 'GINGAT-Conv-lall', 'GINGAT') --> 4 hyperparams configs\n",
      "('node', 'TwitchEN', 'ShareGINGAT', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'TwitchEN', 'ShareGINGAT-Conv', 'ShareGINGAT') --> 4 hyperparams configs\n",
      "('node', 'TwitchEN', 'ShareGINGAT-Conv-lall', 'ShareGINGAT') --> 4 hyperparams configs\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n",
      "/var/folders/m4/wx5myxg14yx88f60qfxw54q8000750/T/ipykernel_66290/968815899.py:60: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_best[group_by_cols[idx]] = key_i\n"
     ]
    }
   ],
   "source": [
    "\n",
    "config_columns = []\n",
    "config_columns.append('l_pre')\n",
    "config_columns.append('l_mp')\n",
    "config_columns.append('l_post')\n",
    "config_columns.append('stage')\n",
    "config_columns.append('drop')\n",
    "config_columns.append('lr')\n",
    "config_columns.append('g_heads')\n",
    "# config_columns.append('gcn_mode')\n",
    "\n",
    "metric_cols = []\n",
    "\n",
    "if cfg.is_clf:\n",
    "    cfg.metric_val= 'accuracy_val'\n",
    "    cfg.maximize_metric= True\n",
    "    metric_cols.append('accuracy')\n",
    "    # metric_cols.append('f1')\n",
    "\n",
    "else:\n",
    "    cfg.metric_val= 'mse_val'\n",
    "    cfg.maximize_metric= False \n",
    "    metric_cols.append('mae')\n",
    "    metric_cols.append('mse')\n",
    "\n",
    "\n",
    "\n",
    "group_by_cols = ['task', 'dataset', 'l_type_full', 'l_type']\n",
    "extra_cols=['seed']\n",
    "extra_cols.extend([c for c in df.columns if (('lmbda' in c) and ('train' in c))])\n",
    "\n",
    "df_best, dict_best_with_seeds = get_best_configuration_df(config_columns=config_columns, \n",
    "                                   metric_cols=metric_cols, \n",
    "                                   extra_cols=extra_cols, \n",
    "                                   group_by_cols=group_by_cols, \n",
    "                                   metric_val=cfg.metric_val,  # accuracy_val f1_val\n",
    "                                   maximize_metric=cfg.maximize_metric)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "77\n",
      "Objective metric: accuracy_val\n"
     ]
    },
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_val</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_area_val</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_test</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_area_test</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_train</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_area_train</th>\n",
       "      <th colspan=\"3\" halign=\"left\">best_epoch</th>\n",
       "      <th colspan=\"3\" halign=\"left\">seed</th>\n",
       "      <th colspan=\"3\" halign=\"left\">lmbda2_train</th>\n",
       "      <th colspan=\"3\" halign=\"left\">lmbda_train</th>\n",
       "      <th>task</th>\n",
       "      <th>dataset</th>\n",
       "      <th>l_type_full</th>\n",
       "      <th>l_type</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">1</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">1</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">skipsum</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.0</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.005</th>\n",
       "      <th>1</th>\n",
       "      <td>0.88085</td>\n",
       "      <td>0.00739</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.837965</td>\n",
       "      <td>0.012197</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89079</td>\n",
       "      <td>0.004888</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.850599</td>\n",
       "      <td>0.01346</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.91861</td>\n",
       "      <td>0.009524</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.869517</td>\n",
       "      <td>0.014678</td>\n",
       "      <td>10.0</td>\n",
       "      <td>2202.0</td>\n",
       "      <td>349.095657</td>\n",
       "      <td>10.0</td>\n",
       "      <td>5.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GIN</td>\n",
       "      <td>GIN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.88249</td>\n",
       "      <td>0.008168</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.837576</td>\n",
       "      <td>0.019382</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89049</td>\n",
       "      <td>0.005108</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.848979</td>\n",
       "      <td>0.017867</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.93705</td>\n",
       "      <td>0.009388</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.88033</td>\n",
       "      <td>0.023831</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1869.0</td>\n",
       "      <td>568.506816</td>\n",
       "      <td>10.0</td>\n",
       "      <td>5.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GINGAT</td>\n",
       "      <td>GINGAT</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.88443</td>\n",
       "      <td>0.007227</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.838383</td>\n",
       "      <td>0.015972</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89192</td>\n",
       "      <td>0.006832</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.847491</td>\n",
       "      <td>0.014718</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.92526</td>\n",
       "      <td>0.010445</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.871346</td>\n",
       "      <td>0.019727</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1929.0</td>\n",
       "      <td>494.503118</td>\n",
       "      <td>10.0</td>\n",
       "      <td>5.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GINGAT-Conv</td>\n",
       "      <td>GINGAT</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.88365</td>\n",
       "      <td>0.006067</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.842845</td>\n",
       "      <td>0.011147</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89046</td>\n",
       "      <td>0.0063</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.851075</td>\n",
       "      <td>0.009324</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.92686</td>\n",
       "      <td>0.008585</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.87812</td>\n",
       "      <td>0.011856</td>\n",
       "      <td>10.0</td>\n",
       "      <td>2110.0</td>\n",
       "      <td>356.135118</td>\n",
       "      <td>10.0</td>\n",
       "      <td>5.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.463802</td>\n",
       "      <td>0.231751</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.635399</td>\n",
       "      <td>0.135311</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GINGAT-Conv-lall</td>\n",
       "      <td>GINGAT</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.88643</td>\n",
       "      <td>0.005073</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.84407</td>\n",
       "      <td>0.011168</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89867</td>\n",
       "      <td>0.005997</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.858164</td>\n",
       "      <td>0.013813</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.94387</td>\n",
       "      <td>0.012158</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.888476</td>\n",
       "      <td>0.015439</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1872.0</td>\n",
       "      <td>418.862215</td>\n",
       "      <td>10.0</td>\n",
       "      <td>5.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>ShareGINGAT</td>\n",
       "      <td>ShareGINGAT</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          accuracy_val                 accuracy_area_val  \\\n",
       "                                  mean       std count              mean   \n",
       "1 4 1 skipsum 0.0 0.005 1      0.88085   0.00739  10.0          0.837965   \n",
       "                        4      0.88249  0.008168  10.0          0.837576   \n",
       "                        4      0.88443  0.007227  10.0          0.838383   \n",
       "                        4      0.88365  0.006067  10.0          0.842845   \n",
       "                        1      0.88643  0.005073  10.0           0.84407   \n",
       "\n",
       "                                          accuracy_test                  \\\n",
       "                                std count          mean       std count   \n",
       "1 4 1 skipsum 0.0 0.005 1  0.012197  10.0       0.89079  0.004888  10.0   \n",
       "                        4  0.019382  10.0       0.89049  0.005108  10.0   \n",
       "                        4  0.015972  10.0       0.89192  0.006832  10.0   \n",
       "                        4  0.011147  10.0       0.89046    0.0063  10.0   \n",
       "                        1  0.011168  10.0       0.89867  0.005997  10.0   \n",
       "\n",
       "                          accuracy_area_test                 accuracy_train  \\\n",
       "                                        mean       std count           mean   \n",
       "1 4 1 skipsum 0.0 0.005 1           0.850599   0.01346  10.0        0.91861   \n",
       "                        4           0.848979  0.017867  10.0        0.93705   \n",
       "                        4           0.847491  0.014718  10.0        0.92526   \n",
       "                        4           0.851075  0.009324  10.0        0.92686   \n",
       "                        1           0.858164  0.013813  10.0        0.94387   \n",
       "\n",
       "                                          accuracy_area_train                  \\\n",
       "                                std count                mean       std count   \n",
       "1 4 1 skipsum 0.0 0.005 1  0.009524  10.0            0.869517  0.014678  10.0   \n",
       "                        4  0.009388  10.0             0.88033  0.023831  10.0   \n",
       "                        4  0.010445  10.0            0.871346  0.019727  10.0   \n",
       "                        4  0.008585  10.0             0.87812  0.011856  10.0   \n",
       "                        1  0.012158  10.0            0.888476  0.015439  10.0   \n",
       "\n",
       "                          best_epoch                   seed                 \\\n",
       "                                mean         std count mean      std count   \n",
       "1 4 1 skipsum 0.0 0.005 1     2202.0  349.095657  10.0  5.5  3.02765  10.0   \n",
       "                        4     1869.0  568.506816  10.0  5.5  3.02765  10.0   \n",
       "                        4     1929.0  494.503118  10.0  5.5  3.02765  10.0   \n",
       "                        4     2110.0  356.135118  10.0  5.5  3.02765  10.0   \n",
       "                        1     1872.0  418.862215  10.0  5.5  3.02765  10.0   \n",
       "\n",
       "                          lmbda2_train                 lmbda_train            \\\n",
       "                                  mean       std count        mean       std   \n",
       "1 4 1 skipsum 0.0 0.005 1          1.0       0.0  10.0         0.0       0.0   \n",
       "                        4          1.0       0.0  10.0         1.0       0.0   \n",
       "                        4          1.0       0.0  10.0         1.0       0.0   \n",
       "                        4     0.463802  0.231751  10.0    0.635399  0.135311   \n",
       "                        1          1.0       0.0  10.0         1.0       0.0   \n",
       "\n",
       "                                 task          dataset       l_type_full  \\\n",
       "                          count                                            \n",
       "1 4 1 skipsum 0.0 0.005 1  10.0  node  AmazonComputers               GIN   \n",
       "                        4  10.0  node  AmazonComputers            GINGAT   \n",
       "                        4  10.0  node  AmazonComputers       GINGAT-Conv   \n",
       "                        4  10.0  node  AmazonComputers  GINGAT-Conv-lall   \n",
       "                        1  10.0  node  AmazonComputers       ShareGINGAT   \n",
       "\n",
       "                                l_type  \n",
       "                                        \n",
       "1 4 1 skipsum 0.0 0.005 1          GIN  \n",
       "                        4       GINGAT  \n",
       "                        4       GINGAT  \n",
       "                        4       GINGAT  \n",
       "                        1  ShareGINGAT  "
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.set_option('display.max_columns', None)\n",
    "\n",
    "print(len(df_best))\n",
    "print(f\"Objective metric: {cfg.metric_val}\")\n",
    "df_best.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 ('node', 'AmazonComputers', 'GIN', 'GIN')\n",
      "1 ('node', 'AmazonComputers', 'GINGAT', 'GINGAT')\n",
      "2 ('node', 'AmazonComputers', 'GINGAT-Conv', 'GINGAT')\n",
      "3 ('node', 'AmazonComputers', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "4 ('node', 'AmazonComputers', 'ShareGINGAT', 'ShareGINGAT')\n",
      "5 ('node', 'AmazonComputers', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "6 ('node', 'AmazonComputers', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "7 ('node', 'AmazonPhoto', 'GIN', 'GIN')\n",
      "8 ('node', 'AmazonPhoto', 'GINGAT', 'GINGAT')\n",
      "9 ('node', 'AmazonPhoto', 'GINGAT-Conv', 'GINGAT')\n",
      "10 ('node', 'AmazonPhoto', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "11 ('node', 'AmazonPhoto', 'ShareGINGAT', 'ShareGINGAT')\n",
      "12 ('node', 'AmazonPhoto', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "13 ('node', 'AmazonPhoto', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "14 ('node', 'CiteSeer', 'GIN', 'GIN')\n",
      "15 ('node', 'CiteSeer', 'GINGAT', 'GINGAT')\n",
      "16 ('node', 'CiteSeer', 'GINGAT-Conv', 'GINGAT')\n",
      "17 ('node', 'CiteSeer', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "18 ('node', 'CiteSeer', 'ShareGINGAT', 'ShareGINGAT')\n",
      "19 ('node', 'CiteSeer', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "20 ('node', 'CiteSeer', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "21 ('node', 'CoauthorCS', 'GIN', 'GIN')\n",
      "22 ('node', 'CoauthorCS', 'GINGAT', 'GINGAT')\n",
      "23 ('node', 'CoauthorCS', 'GINGAT-Conv', 'GINGAT')\n",
      "24 ('node', 'CoauthorCS', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "25 ('node', 'CoauthorCS', 'ShareGINGAT', 'ShareGINGAT')\n",
      "26 ('node', 'CoauthorCS', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "27 ('node', 'CoauthorCS', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "28 ('node', 'CoauthorPhysics', 'GIN', 'GIN')\n",
      "29 ('node', 'CoauthorPhysics', 'GINGAT', 'GINGAT')\n",
      "30 ('node', 'CoauthorPhysics', 'GINGAT-Conv', 'GINGAT')\n",
      "31 ('node', 'CoauthorPhysics', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "32 ('node', 'CoauthorPhysics', 'ShareGINGAT', 'ShareGINGAT')\n",
      "33 ('node', 'CoauthorPhysics', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "34 ('node', 'CoauthorPhysics', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "35 ('node', 'Cora', 'GIN', 'GIN')\n",
      "36 ('node', 'Cora', 'GINGAT', 'GINGAT')\n",
      "37 ('node', 'Cora', 'GINGAT-Conv', 'GINGAT')\n",
      "38 ('node', 'Cora', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "39 ('node', 'Cora', 'ShareGINGAT', 'ShareGINGAT')\n",
      "40 ('node', 'Cora', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "41 ('node', 'Cora', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "42 ('node', 'DBLP', 'GIN', 'GIN')\n",
      "43 ('node', 'DBLP', 'GINGAT', 'GINGAT')\n",
      "44 ('node', 'DBLP', 'GINGAT-Conv', 'GINGAT')\n",
      "45 ('node', 'DBLP', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "46 ('node', 'DBLP', 'ShareGINGAT', 'ShareGINGAT')\n",
      "47 ('node', 'DBLP', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "48 ('node', 'DBLP', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "49 ('node', 'FacebookPagePage', 'GIN', 'GIN')\n",
      "50 ('node', 'FacebookPagePage', 'GINGAT', 'GINGAT')\n",
      "51 ('node', 'FacebookPagePage', 'GINGAT-Conv', 'GINGAT')\n",
      "52 ('node', 'FacebookPagePage', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "53 ('node', 'FacebookPagePage', 'ShareGINGAT', 'ShareGINGAT')\n",
      "54 ('node', 'FacebookPagePage', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "55 ('node', 'FacebookPagePage', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "56 ('node', 'GitHub', 'GIN', 'GIN')\n",
      "57 ('node', 'GitHub', 'GINGAT', 'GINGAT')\n",
      "58 ('node', 'GitHub', 'GINGAT-Conv', 'GINGAT')\n",
      "59 ('node', 'GitHub', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "60 ('node', 'GitHub', 'ShareGINGAT', 'ShareGINGAT')\n",
      "61 ('node', 'GitHub', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "62 ('node', 'GitHub', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "63 ('node', 'PubMed', 'GIN', 'GIN')\n",
      "64 ('node', 'PubMed', 'GINGAT', 'GINGAT')\n",
      "65 ('node', 'PubMed', 'GINGAT-Conv', 'GINGAT')\n",
      "66 ('node', 'PubMed', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "67 ('node', 'PubMed', 'ShareGINGAT', 'ShareGINGAT')\n",
      "68 ('node', 'PubMed', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "69 ('node', 'PubMed', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n",
      "70 ('node', 'TwitchEN', 'GIN', 'GIN')\n",
      "71 ('node', 'TwitchEN', 'GINGAT', 'GINGAT')\n",
      "72 ('node', 'TwitchEN', 'GINGAT-Conv', 'GINGAT')\n",
      "73 ('node', 'TwitchEN', 'GINGAT-Conv-lall', 'GINGAT')\n",
      "74 ('node', 'TwitchEN', 'ShareGINGAT', 'ShareGINGAT')\n",
      "75 ('node', 'TwitchEN', 'ShareGINGAT-Conv', 'ShareGINGAT')\n",
      "76 ('node', 'TwitchEN', 'ShareGINGAT-Conv-lall', 'ShareGINGAT')\n"
     ]
    }
   ],
   "source": [
    "# df_config.get_group(df_config.groups.keys()[0])\n",
    "keys = list(dict_best_with_seeds.keys())\n",
    "for i, key in enumerate(dict_best_with_seeds.keys()):\n",
    "    print(f\"{i} {key}\")\n",
    "# dict_best_with_seeds[('graph', 'TU_BZR', 'gcnconvbasic', 'N/A', 'gcnconvbasic')].sort_values('seed')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AmazonComputers\n",
      "AmazonPhoto\n",
      "CiteSeer\n",
      "CoauthorCS\n",
      "CoauthorPhysics\n",
      "Cora\n",
      "DBLP\n",
      "FacebookPagePage\n",
      "GitHub\n",
      "PubMed\n",
      "TwitchEN\n"
     ]
    }
   ],
   "source": [
    "for data_name in df_best['dataset'].unique():\n",
    "    print(data_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [],
   "source": [
    "################################\n",
    "########  DATASET FILTER\n",
    "################################\n",
    "datasets_filter = []\n",
    "\n",
    "# Datasetes node\n",
    "datasets_filter.append('Cora')\n",
    "datasets_filter.append('CiteSeer')\n",
    "datasets_filter.append('GitHub')\n",
    "datasets_filter.append('TwitchEN')\n",
    "datasets_filter.append('FacebookPagePage')\n",
    "datasets_filter.append('PubMed')\n",
    "\n",
    "datasets_filter.append('DBLP')\n",
    "datasets_filter.append('CoauthorCS')\n",
    "datasets_filter.append('CoauthorPhysics')\n",
    "datasets_filter.append('AmazonComputers')\n",
    "datasets_filter.append('AmazonPhoto')\n",
    "\n",
    "\n",
    "# Datasets graph\n",
    "datasets_filter.append('TU_BZR')\n",
    "datasets_filter.append('TU_COX2')\n",
    "datasets_filter.append('TU_ENZYMES')\n",
    "datasets_filter.append('TU_DD')\n",
    "datasets_filter.append('TU_IMDB')\n",
    "datasets_filter.append('TU_MUTAG')\n",
    "datasets_filter.append('TU_PROTEINS')\n",
    "datasets_filter.append('QM9')\n",
    "datasets_filter.append('QM7b')\n",
    "\n",
    "################################\n",
    "########  MODELS FILTER\n",
    "################################\n",
    "baselines = []\n",
    "baselines.append('GCN')\n",
    "baselines.append('GIN')\n",
    "\n",
    "baselines.append('GATv1')\n",
    "baselines.append('GATv2')\n",
    "baselines.append('GINGAT')\n",
    "\n",
    "baselines.append('ShareGATv1')\n",
    "baselines.append('ShareGATv2')\n",
    "baselines.append('ShareGINGAT')\n",
    "\n",
    "our_models_to_compare = [\n",
    "    '-Conv',\n",
    "#                         '-gcngat',\n",
    "#                          '-Conv-ind', \n",
    "#                          '-l1',\n",
    "#                          '-l2', \n",
    "                         '-Conv-lall', \n",
    "#                         '-Conv-lallv2'\n",
    "]\n",
    "\n",
    "models_filter = baselines.copy()\n",
    "for ours in our_models_to_compare:\n",
    "    for baseline in baselines:\n",
    "        models_filter.append(baseline + ours)\n",
    "models_filter.append('Dense')\n",
    "# models_filter = ['ourgatv2-share', 'ourgatv2', 'ourgatv2-full-share',\n",
    "#        'ourgatv1-share', 'ourgatv1-full', 'ourgatv1-full-2-share',\n",
    "#        'ourgatv2-full', 'ourgatv2-full-2', 'ourgatv2-full-2-share',\n",
    "#        'ourgatv1', 'ourgatv2-full-share-gcn', 'ourgatv1-full-share',\n",
    "#        'ourgatv1-full-2']\n",
    "\n",
    "\n",
    "################################\n",
    "########  COLUMNS TO SHOW \n",
    "################################\n",
    "cols_to_show = []\n",
    "cols_to_show.append(('task', ''))\n",
    "cols_to_show.append(('dataset', ''))\n",
    "cols_to_show.append(('l_type_full', ''))\n",
    "cols_to_show.append(('l_type', ''))\n",
    "# cols_to_show.append(('convolve', ''))\n",
    "\n",
    "################################\n",
    "########  METRICS TO SHOW \n",
    "################################\n",
    "if cfg.is_clf:\n",
    "    cfg.metrics_to_add = [\n",
    "        'accuracy_test', 'accuracy_val', 'accuracy_train',\n",
    "    #                  'f1_test', 'f1_val', 'f1_train'\n",
    "    ]\n",
    "else:\n",
    "    cfg.metrics_to_add = [\n",
    "        'mse_test', 'mse_val', 'mse_train',\n",
    "         'mae_test', 'mae_val', 'mae_train',\n",
    "    ]\n",
    "cols_metric_to_show = []\n",
    "for c in cfg.metrics_to_add:\n",
    "    cols_metric_to_show.append((c, 'mean'))\n",
    "    cols_metric_to_show.append((c, 'std'))\n",
    "    cols_metric_to_show.append((c, 'count'))\n",
    "    \n",
    "cols_to_show.extend(cols_metric_to_show)\n",
    "\n",
    "more_cols = ['best_epoch']\n",
    "for c in df.columns:\n",
    "    if 'lmbda' in c and 'train' in c:\n",
    "        more_cols.append(c)\n",
    "# mroe_cols.extend(['accuracy_area_test',  'accuracy_area_val',  'accuracy_area_train'])\n",
    "for c in more_cols:\n",
    "    cols_to_show.append((c, 'mean'))\n",
    "    cols_to_show.append((c, 'std'))\n",
    "\n",
    "\n",
    "\n",
    "################################\n",
    "########  COLUMNS TO SORT \n",
    "################################\n",
    "sort_by_columns = []\n",
    "sort_by_columns.append(('task', ''))\n",
    "sort_by_columns.append(('dataset', ''))\n",
    "# sort_by_columns.append(('l_type', ''))\n",
    "# sort_by_columns.append(('convolve', ''))\n",
    "sort_by_columns.append(('l_type_full', ''))\n",
    "# sort_by_columns.append(('f1_test', 'mean'))\n",
    "# sort_by_columns.append(('accuracy_test', 'mean'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def clean_df_best(my_df_best, datasets_filter, models_filter, cols_to_show, cols_metric_to_show, sort_by_columns):\n",
    "    \n",
    "    # Copy dataframe\n",
    "    my_df = my_df_best[cols_to_show[:]].copy()\n",
    "\n",
    "    # Filter datasets\n",
    "    my_df = my_df[my_df.dataset.isin(datasets_filter)]\n",
    "\n",
    "    # Filter models\n",
    "    my_df = my_df[my_df.l_type_full.isin(models_filter)]\n",
    "\n",
    "    cols_metric_to_show = [c for c in cols_metric_to_show if c[1] !='count']\n",
    "    my_df[cols_metric_to_show] *= 100\n",
    "    my_df =  my_df.sort_values(by=sort_by_columns, ascending=False)\n",
    "    # my_df = my_df.drop(['l_type', 'convolve'], axis=1)\n",
    "    return my_df\n",
    "my_df = clean_df_best(my_df_best=df_best, \n",
    "               datasets_filter=datasets_filter, \n",
    "               models_filter=models_filter, \n",
    "              cols_to_show=cols_to_show, \n",
    "              cols_metric_to_show=cols_metric_to_show, \n",
    "              sort_by_columns=sort_by_columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.set_option('display.max_rows', 200)\n",
    "# my_df[my_df.dataset == 'PubMed'].sort_values('l_type_full')[['l_type_full', 'accuracy_test', 'best_epoch']]\n",
    "# my_df[my_df[('accuracy_test', 'count')] == 10]\n",
    "# my_df[my_df.dataset=='TU_IMDB']\n",
    "\n",
    "# my_df[['l_type_full'] + ['accuracy_test']]\n",
    "# my_df[['l_type_full'] + ['mse_test']]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Latex table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Performance metric: accuracy_test\n"
     ]
    }
   ],
   "source": [
    "if cfg.is_clf:\n",
    "    cfg.performance_metric = 'accuracy_test'  # accuracy_test f1_test best_epoch accuracy_area_test\n",
    "else:\n",
    "    cfg.performance_metric = 'mae_test'  # accuracy_test f1_test best_epoch accuracy_area_test\n",
    "\n",
    "my_dict = {\n",
    "    'accuracy_test': True,\n",
    "    'accuracy_area_test': True,\n",
    "    'best_epoch': False,\n",
    "    'mse_test': False,\n",
    "    'mae_test': False\n",
    "}\n",
    "performance_metric_maximize = my_dict[cfg.performance_metric]\n",
    "print(f'Performance metric: {cfg.performance_metric}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      " [BETTER]TwitchEN | ShareGINGAT-Conv-lall | ShareGINGAT -- 0.5823 0.5952\n",
      "stats: -2.65 pvalue: 0.03\n",
      "\n",
      " [BETTER]GitHub | ShareGINGAT-Conv-lall | ShareGINGAT -- 0.8298 0.8379\n",
      "stats: -2.62 pvalue: 0.03\n",
      "\n",
      " [BETTER]GitHub | ShareGINGAT-Conv | ShareGINGAT -- 0.8298 0.8371\n",
      "stats: -2.56 pvalue: 0.03\n",
      "\n",
      " [BETTER]GitHub | GINGAT-Conv-lall | GINGAT -- 0.8317 0.8390\n",
      "stats: -2.82 pvalue: 0.02\n",
      "\n",
      " [BETTER]FacebookPagePage | GINGAT-Conv-lall | GINGAT -- 0.9349 0.9425\n",
      "stats: -9.61 pvalue: 0.00\n",
      "\n",
      " [BETTER]FacebookPagePage | GINGAT-Conv | GINGAT -- 0.9349 0.9409\n",
      "stats: -4.95 pvalue: 0.00\n",
      "\n",
      "\t[WORSE]CoauthorPhysics | ShareGINGAT-Conv | ShareGINGAT -- 0.9619 0.9607\n",
      "\tstats: 2.61 pvalue: 0.03\n",
      "\n",
      "\t[WORSE]CoauthorPhysics | GINGAT-Conv | GINGAT -- 0.9618 0.9600\n",
      "\tstats: 2.62 pvalue: 0.03\n",
      "\n",
      "\t[WORSE]CoauthorCS | ShareGINGAT-Conv | ShareGINGAT -- 0.9240 0.9209\n",
      "\tstats: 4.16 pvalue: 0.00\n",
      "\n",
      "\t[WORSE]CoauthorCS | GINGAT-Conv | GINGAT -- 0.9245 0.9211\n",
      "\tstats: 2.67 pvalue: 0.03\n",
      "\n",
      "\t[WORSE]AmazonComputers | ShareGINGAT-Conv-lall | ShareGINGAT -- 0.8987 0.8880\n",
      "\tstats: 4.67 pvalue: 0.00\n",
      "\n",
      "\t[WORSE]AmazonComputers | ShareGINGAT-Conv | ShareGINGAT -- 0.8987 0.8892\n",
      "\tstats: 4.70 pvalue: 0.00\n",
      "1.0\n"
     ]
    }
   ],
   "source": [
    "def intersection(lst1, lst2):\n",
    "    lst3 = [value for value in lst1 if value in lst2]\n",
    "    return lst3\n",
    "\n",
    "from scipy.stats import ttest_rel\n",
    "is_better = []\n",
    "is_worse = []\n",
    "for _, row in my_df.iterrows():\n",
    "    dataset_name = row['dataset'].item()\n",
    "    model_name = row['l_type_full'].item()\n",
    "    bs_name = row['l_type'].item()\n",
    "    index = (row['task'].item(), \n",
    "             row['dataset'].item(), \n",
    "             row['l_type_full'].item(), \n",
    "             bs_name)\n",
    "    index_bs = (row['task'].item(), \n",
    "             row['dataset'].item(), \n",
    "             row['l_type'].item(), \n",
    "             bs_name)\n",
    "    df_ii = dict_best_with_seeds[index].sort_values('seed')\n",
    "    seeds = list(df_ii['seed'].values)\n",
    "    df_ii_bs = dict_best_with_seeds[index_bs].sort_values('seed')\n",
    "    seeds_bs = list(df_ii_bs['seed'].values)\n",
    "    seeds = intersection(seeds, seeds_bs)\n",
    "\n",
    "    df_ii = df_ii[df_ii.seed.isin(seeds)]\n",
    "    df_ii_bs = df_ii_bs[df_ii_bs.seed.isin(seeds)]\n",
    "    try:\n",
    "        performance = df_ii[cfg.performance_metric].values.astype(float)\n",
    "    except:\n",
    "        print('ERROR')\n",
    "        performance = df_ii['accuracy_test'].values\n",
    "    try:\n",
    "        performance_bs = df_ii_bs[cfg.performance_metric].values.astype(float)\n",
    "    except: \n",
    "        print(f'ERROR --> {index}')\n",
    "        performance_bs = df_ii_bs['accuracy_test'].values\n",
    "    try:\n",
    "        statistic, pvalue = ttest_rel(performance_bs, performance)\n",
    "    except:\n",
    "        print(f\"\\n[ERROR]{dataset_name} | {model_name} | {bs_name}\")\n",
    "        is_better.append(False)\n",
    "        continue\n",
    "\n",
    "    if pvalue < 0.05:\n",
    "        is_better_i = statistic < 0 if performance_metric_maximize else statistic > 0\n",
    "        is_better.append(is_better_i) \n",
    "        is_worse_i = statistic > 0 if performance_metric_maximize else statistic < 0\n",
    "        is_worse.append(is_worse_i) \n",
    "        perf_str = f\"{np.mean(performance_bs):.4f} {np.mean(performance):.4f}\"\n",
    "        if not is_better_i:\n",
    "            print(f\"\\n\\t[WORSE]{dataset_name} | {model_name} | {bs_name} -- {perf_str}\")\n",
    "            print(f\"\\tstats: {statistic:.2f} pvalue: {pvalue:.2f}\")\n",
    "        else:\n",
    "            print(f\"\\n [BETTER]{dataset_name} | {model_name} | {bs_name} -- {perf_str}\")\n",
    "            print(f\"stats: {statistic:.2f} pvalue: {pvalue:.2f}\")\n",
    "    else: \n",
    "        is_better.append(False) \n",
    "        is_worse.append(False)           \n",
    "my_df['is_better'] = is_better\n",
    "my_df['is_worse'] = is_worse\n",
    "if sum(is_worse) > 0:\n",
    "    print(f\"{sum(is_better)/sum(is_worse)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "# dataset_order = [\n",
    "#     'AmazonComputers',\n",
    "#     'AmazonPhoto',\n",
    "#     'GitHub',\n",
    "#     'FacebookPagePage',\n",
    "#     'CoauthorPhysics',\n",
    "#     'TwitchEN',\n",
    "#     'CoauthorCS',\n",
    "#     'DBLP',\n",
    "#     'PubMed',\n",
    "#     'Cora',\n",
    "#     'CiteSeer',\n",
    "#     'QM7b',\n",
    "#     'QM9',\n",
    "# ]\n",
    "\n",
    "# dataset_order = [\n",
    "#     'AmazonComputers',\n",
    "#     'AmazonPhoto',\n",
    "#     'GitHub',\n",
    "#     'FacebookPagePage',\n",
    "#     'CoauthorPhysics',\n",
    "#     'TwitchEN',\n",
    "# ]\n",
    "\n",
    "dataset_order = [\n",
    "    'CoauthorCS',\n",
    "    'DBLP',\n",
    "    'PubMed',\n",
    "    'Cora',\n",
    "    'CiteSeer',\n",
    "    'QM7b',\n",
    "    'QM9',\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best models with metric: accuracy_test\n",
      "\n",
      "CiteSeer: GINGAT-Conv-lall\n",
      "CoauthorCS: GINGAT-Conv-lall\n",
      "Cora: GINGAT-Conv\n",
      "DBLP: GINGAT\n",
      "PubMed: GINGAT-Conv-lall\n",
      "\n",
      "\n",
      "\n",
      "\\begin{tabular}{lccccc}\n",
      "\\toprule\n",
      "Model & CoauthorCS & DBLP & PubMed & Cora & CiteSeer \\\\ \\midrule\n",
      "GIN&  91.95 $\\pm$ 0.41&  80.11 $\\pm$ 0.49&  85.58 $\\pm$ 0.49&  84.33 $\\pm$ 1.01&  73.14 $\\pm$ 0.58 \\\\\n",
      "\\midrule\n",
      "GINGAT&  92.33 $\\pm$ 0.32& { \\color{teal}  81.07 $\\pm$ 0.36 }&  86.20 $\\pm$ 0.46&  84.74 $\\pm$ 0.85&  73.80 $\\pm$ 0.90 \\\\\n",
      "GINGAT-Conv&  {\\color{red} \\bfseries 91.90 $\\pm$ 0.31}&  {\\color{red} \\bfseries 80.46 $\\pm$ 0.53}&  86.37 $\\pm$ 0.44& { \\color{teal}  85.06 $\\pm$ 0.97 }&  73.80 $\\pm$ 1.08 \\\\\n",
      "GINGAT-Conv-lall& { \\color{teal}  92.50 $\\pm$ 0.34 }&  80.53 $\\pm$ 0.68& { \\color{teal}  86.44 $\\pm$ 0.45 }&  {\\color{red} \\bfseries 84.01 $\\pm$ 0.70}& { \\color{teal}  73.80 $\\pm$ 0.74 } \\\\\n",
      "\\midrule\n",
      "ShareGINGAT&  92.06 $\\pm$ 0.43&  80.58 $\\pm$ 0.42&  85.84 $\\pm$ 0.42&  84.84 $\\pm$ 1.11&  73.44 $\\pm$ 0.69 \\\\\n",
      "ShareGINGAT-Conv&  {\\color{red} \\bfseries 91.90 $\\pm$ 0.37}&  {\\color{red} \\bfseries 80.09 $\\pm$ 0.39}&  85.78 $\\pm$ 0.41&  84.69 $\\pm$ 0.76&  73.76 $\\pm$ 0.45 \\\\\n",
      "ShareGINGAT-Conv-lall&  92.10 $\\pm$ 0.28&  80.36 $\\pm$ 0.49&  85.63 $\\pm$ 0.31&  84.42 $\\pm$ 0.77&  73.46 $\\pm$ 0.55 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "best_dict = {'dataset': {},\n",
    "            'l_type_full': {}}\n",
    "\n",
    "\n",
    "\n",
    "df_latex = my_df.copy()\n",
    "df_latex = df_latex[df_latex.dataset.isin(dataset_order)]\n",
    "print(f'Best models with metric: {cfg.performance_metric}\\n')\n",
    "baselines_df = pd.DataFrame(columns = ['baseline', 'dataset', 'performance'])\n",
    "\n",
    "\n",
    "for dataset_name, my_df_dataset in df_latex.groupby('dataset'):\n",
    "    if performance_metric_maximize:\n",
    "        idx = my_df_dataset[(cfg.performance_metric, 'mean')].astype(float).argmax()\n",
    "    else: \n",
    "        idx = my_df_dataset[(cfg.performance_metric, 'mean')].astype(float).argmin()\n",
    "    best_model = my_df_dataset.iloc[idx]['l_type_full'].item()\n",
    "    if dataset_name not in best_dict['dataset']:\n",
    "        best_dict['dataset'][dataset_name] = []\n",
    "    best_dict['dataset'][dataset_name].append(best_model)\n",
    "    if best_model not in best_dict['l_type_full']:\n",
    "        best_dict['l_type_full'][best_model] = []\n",
    "    best_dict['l_type_full'][best_model].append(dataset_name)\n",
    "    print(f\"{dataset_name}: {best_model}\")\n",
    "\n",
    "    \n",
    "# %%\n",
    "print('\\n\\n')\n",
    "# V1\n",
    "col_name = 'dataset'\n",
    "row_name = 'l_type_full'\n",
    "\n",
    "\n",
    "\n",
    "col_unique_all = sorted(df_latex[col_name].unique())\n",
    "col_unique = []\n",
    "for my_col in dataset_order:\n",
    "    if my_col in col_unique_all:\n",
    "        col_unique.append(my_col)\n",
    "        col_unique_all.remove(my_col)\n",
    "\n",
    "col_unique = [*col_unique, *col_unique_all]\n",
    "\n",
    "\n",
    "\n",
    "row_unique = sorted(df_latex[row_name].unique())\n",
    "\n",
    "ccc = ''.join(['c',]*len(col_unique))\n",
    "print(\"\\\\begin{tabular}{l\" + f\"{ccc}\" + \"}\")\n",
    "print(\"\\\\toprule\")\n",
    "\n",
    "row_str = f\"{column_mapping(row_name)} & \"\n",
    "row_str += ' & '.join([column_mapping(str(c)) for c in col_unique ])\n",
    "row_str += ' \\\\\\\\ \\\\midrule'\n",
    "print(row_str)\n",
    "\n",
    "for row_name_i, row_name_next in zip(row_unique, [*row_unique[1:], row_unique[-1]]):\n",
    "    my_row = df_latex[df_latex[row_name] == row_name_i]\n",
    "#     print(row_name_i)\n",
    "    row_str = f'{column_mapping(row_name_i)}'\n",
    "    for col_name_i in col_unique:\n",
    "        my_col = my_row[my_row[col_name] == col_name_i]\n",
    "        if len(my_col[(cfg.performance_metric, 'mean')])>0:\n",
    "            mean = my_col[(cfg.performance_metric, 'mean')].item()\n",
    "            std = my_col[(cfg.performance_metric, 'std')].item()\n",
    "            is_better = my_col['is_better'].item()\n",
    "            is_worse =  my_col['is_worse'].item()\n",
    "            best_model_list = best_dict[col_name][col_name_i]\n",
    "        else:\n",
    "            mean = 0.0\n",
    "            std = 0.0\n",
    "            is_better = False\n",
    "            is_worse = False\n",
    "            best_model_list = []\n",
    "            \n",
    "        \n",
    "        # if row_name_i in best_dict[col_name][col_name_i] or my_col['is_better'].item():\n",
    "        str_tmp = ''\n",
    "        if is_better:\n",
    "            str_tmp = f' \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        elif is_worse:\n",
    "            str_tmp = f' {{\\color{{red}} \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}}}'\n",
    "        else:\n",
    "            str_tmp = f' {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        if row_name_i in best_model_list:\n",
    "            str_tmp = f\"{{ \\color{{teal}} {str_tmp} }}\"\n",
    "        row_str += f'& {str_tmp}'\n",
    "            \n",
    "        \n",
    "#         print(f\"\\t{col_name_i} {mean:.2f} \\pm {std:.2f}\")\n",
    "    print(f\"{row_str} \\\\\\\\\")\n",
    "    if row_name_next.split('-')[0] != row_name_i.split('-')[0]:\n",
    "        print('\\\\midrule')\n",
    "    \n",
    "\n",
    "print('\\\\bottomrule')\n",
    "print('\\\\end{tabular}')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Correlation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "items in new_categories are not the same as in old categories",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Input \u001b[0;32mIn [90]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m my_df[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdataset\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[43mmy_df\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mdataset\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mastype\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpd\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mCategoricalDtype\u001b[49m\u001b[43m(\u001b[49m\u001b[43mordered\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcat\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreorder_categories\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mAmazonComputers\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      2\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mAmazonPhoto\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      3\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mGitHub\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      4\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mFacebookPagePage\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      5\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mCoauthorPhysics\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      6\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mTwitchEN\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      7\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mCoauthorCS\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      8\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mDBLP\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m      9\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mPubMed\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m     10\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mCora\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m     11\u001b[0m \u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mCiteSeer\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mordered\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m     13\u001b[0m order \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marray([\u001b[38;5;241m35.76\u001b[39m, \u001b[38;5;241m31.13\u001b[39m, \u001b[38;5;241m2.74\u001b[39m, \u001b[38;5;241m8.93\u001b[39m, \u001b[38;5;241m14.38\u001b[39m, \u001b[38;5;241m3.90\u001b[39m, \u001b[38;5;241m5.97\u001b[39m, \u001b[38;5;241m15.22\u001b[39m, \u001b[38;5;241m15.33\u001b[39m, \u001b[38;5;241m4.50\u001b[39m, \u001b[38;5;241m10.91\u001b[39m])\u001b[38;5;241m.\u001b[39margsort()[::\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\n\u001b[1;32m     14\u001b[0m np\u001b[38;5;241m.\u001b[39marray([\u001b[38;5;241m35.76\u001b[39m, \u001b[38;5;241m31.13\u001b[39m, \u001b[38;5;241m2.74\u001b[39m, \u001b[38;5;241m8.93\u001b[39m, \u001b[38;5;241m14.38\u001b[39m, \u001b[38;5;241m3.90\u001b[39m, \u001b[38;5;241m5.97\u001b[39m, \u001b[38;5;241m15.22\u001b[39m, \u001b[38;5;241m15.33\u001b[39m, \u001b[38;5;241m4.50\u001b[39m, \u001b[38;5;241m10.91\u001b[39m])[order]\n",
      "File \u001b[0;32m~/miniconda3/envs/lcat/lib/python3.9/site-packages/pandas/core/accessor.py:94\u001b[0m, in \u001b[0;36mPandasDelegate._add_delegate_accessors.<locals>._create_delegator_method.<locals>.f\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m     93\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mf\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[0;32m---> 94\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_delegate_method\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/miniconda3/envs/lcat/lib/python3.9/site-packages/pandas/core/arrays/categorical.py:2747\u001b[0m, in \u001b[0;36mCategoricalAccessor._delegate_method\u001b[0;34m(self, name, *args, **kwargs)\u001b[0m\n\u001b[1;32m   2744\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mpandas\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m Series\n\u001b[1;32m   2746\u001b[0m method \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mgetattr\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_parent, name)\n\u001b[0;32m-> 2747\u001b[0m res \u001b[38;5;241m=\u001b[39m \u001b[43mmethod\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   2748\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m res \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m   2749\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m Series(res, index\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_index, name\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_name)\n",
      "File \u001b[0;32m~/miniconda3/envs/lcat/lib/python3.9/site-packages/pandas/core/arrays/categorical.py:1126\u001b[0m, in \u001b[0;36mCategorical.reorder_categories\u001b[0;34m(self, new_categories, ordered, inplace)\u001b[0m\n\u001b[1;32m   1124\u001b[0m inplace \u001b[38;5;241m=\u001b[39m validate_bool_kwarg(inplace, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124minplace\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m   1125\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mset\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdtype\u001b[38;5;241m.\u001b[39mcategories) \u001b[38;5;241m!=\u001b[39m \u001b[38;5;28mset\u001b[39m(new_categories):\n\u001b[0;32m-> 1126\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m   1127\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mitems in new_categories are not the same as in old categories\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   1128\u001b[0m     )\n\u001b[1;32m   1130\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m catch_warnings():\n\u001b[1;32m   1131\u001b[0m     simplefilter(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mignore\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[0;31mValueError\u001b[0m: items in new_categories are not the same as in old categories"
     ]
    }
   ],
   "source": [
    "my_df['dataset'] = my_df['dataset'].astype(pd.CategoricalDtype(ordered=True)).cat.reorder_categories(['AmazonComputers',\n",
    " 'AmazonPhoto',\n",
    " 'GitHub',\n",
    " 'FacebookPagePage',\n",
    " 'CoauthorPhysics',\n",
    " 'TwitchEN',\n",
    " 'CoauthorCS',\n",
    " 'DBLP',\n",
    " 'PubMed',\n",
    " 'Cora',\n",
    " 'CiteSeer'], ordered=True)\n",
    "\n",
    "order = np.array([35.76, 31.13, 2.74, 8.93, 14.38, 3.90, 5.97, 15.22, 15.33, 4.50, 10.91]).argsort()[::-1]\n",
    "np.array([35.76, 31.13, 2.74, 8.93, 14.38, 3.90, 5.97, 15.22, 15.33, 4.50, 10.91])[order]\n",
    "# [col_unique[x] for x in order]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_val</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_area_val</th>\n",
       "      <th colspan=\"3\" halign=\"left\">accuracy_test</th>\n",
       "      <th>accuracy_area_test</th>\n",
       "      <th>...</th>\n",
       "      <th colspan=\"2\" halign=\"left\">lmbda_4_train</th>\n",
       "      <th colspan=\"3\" halign=\"left\">lmbda2_4_train</th>\n",
       "      <th>task</th>\n",
       "      <th>dataset</th>\n",
       "      <th>l_type_full</th>\n",
       "      <th>l_type</th>\n",
       "      <th>degree</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>...</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>count</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">1</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">1</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">skipsum</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.0</th>\n",
       "      <th>1.00e-02</th>\n",
       "      <th>4</th>\n",
       "      <td>0.89</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.79</td>\n",
       "      <td>0.03</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.8</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GATv1</td>\n",
       "      <td>GATv1</td>\n",
       "      <td>35.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">5.00e-03</th>\n",
       "      <th>4</th>\n",
       "      <td>0.9</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.03</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.86</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GATv1-Conv</td>\n",
       "      <td>GATv1</td>\n",
       "      <td>35.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.9</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.86</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.63</td>\n",
       "      <td>0.33</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GATv1-Conv-ind</td>\n",
       "      <td>GATv1</td>\n",
       "      <td>35.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.9</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.86</td>\n",
       "      <td>...</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.32</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GATv1-Conv-ind2</td>\n",
       "      <td>GATv1</td>\n",
       "      <td>35.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.88</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.04</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.89</td>\n",
       "      <td>0.01</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0.79</td>\n",
       "      <td>...</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>10.0</td>\n",
       "      <td>node</td>\n",
       "      <td>AmazonComputers</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>35.76</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 53 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                             accuracy_val             accuracy_area_val        \\\n",
       "                                     mean   std count              mean   std   \n",
       "1 4 1 skipsum 0.0 1.00e-02 4         0.89  0.01  10.0              0.79  0.03   \n",
       "                  5.00e-03 4          0.9   0.0  10.0              0.85  0.03   \n",
       "                           4          0.9   0.0  10.0              0.85  0.02   \n",
       "                           4          0.9   0.0  10.0              0.85  0.02   \n",
       "                           4         0.88  0.01  10.0              0.78  0.04   \n",
       "\n",
       "                                   accuracy_test              \\\n",
       "                             count          mean   std count   \n",
       "1 4 1 skipsum 0.0 1.00e-02 4  10.0          0.89  0.01  10.0   \n",
       "                  5.00e-03 4  10.0           0.9  0.01  10.0   \n",
       "                           4  10.0           0.9  0.01  10.0   \n",
       "                           4  10.0           0.9  0.01  10.0   \n",
       "                           4  10.0          0.89  0.01  10.0   \n",
       "\n",
       "                             accuracy_area_test  ... lmbda_4_train        \\\n",
       "                                           mean  ...           std count   \n",
       "1 4 1 skipsum 0.0 1.00e-02 4                0.8  ...           0.0  10.0   \n",
       "                  5.00e-03 4               0.86  ...           0.0  10.0   \n",
       "                           4               0.86  ...           0.0  10.0   \n",
       "                           4               0.86  ...          0.01  10.0   \n",
       "                           4               0.79  ...           0.0  10.0   \n",
       "\n",
       "                             lmbda2_4_train              task  \\\n",
       "                                       mean   std count         \n",
       "1 4 1 skipsum 0.0 1.00e-02 4            1.0   0.0  10.0  node   \n",
       "                  5.00e-03 4            1.0   0.0  10.0  node   \n",
       "                           4           0.63  0.33  10.0  node   \n",
       "                           4           0.35  0.32  10.0  node   \n",
       "                           4            1.0   0.0  10.0  node   \n",
       "\n",
       "                                      dataset      l_type_full l_type degree  \n",
       "                                                                              \n",
       "1 4 1 skipsum 0.0 1.00e-02 4  AmazonComputers            GATv1  GATv1  35.76  \n",
       "                  5.00e-03 4  AmazonComputers       GATv1-Conv  GATv1  35.76  \n",
       "                           4  AmazonComputers   GATv1-Conv-ind  GATv1  35.76  \n",
       "                           4  AmazonComputers  GATv1-Conv-ind2  GATv1  35.76  \n",
       "                           4  AmazonComputers            GATv2  GATv2  35.76  \n",
       "\n",
       "[5 rows x 53 columns]"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "avg_degree = np.array([35.76, 31.13, 15.33, 15.22, 14.38, 10.91,  8.93,  5.97,  4.5 , 3.9 ,  2.74])\n",
    "col_unique = ['AmazonComputers', 'AmazonPhoto', 'CiteSeer', 'CoauthorCS', 'CoauthorPhysics', 'Cora', 'DBLP', 'FacebookPagePage', 'GitHub', 'PubMed', 'TwitchEN']\n",
    "col_unique = [col_unique[x] for x in order]\n",
    "\n",
    "avg_degree = {k: v for k, v in zip(col_unique, avg_degree)}\n",
    "def foo(row):\n",
    "    return avg_degree[row[('dataset', '')]]\n",
    "df_best[('degree', '')] = df_best.apply(foo, axis=1)\n",
    "df_best.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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>kfold</th>\n",
       "      <th>task</th>\n",
       "      <th>trans</th>\n",
       "      <th>l_pre</th>\n",
       "      <th>l_mp</th>\n",
       "      <th>l_post</th>\n",
       "      <th>stage</th>\n",
       "      <th>drop</th>\n",
       "      <th>lr</th>\n",
       "      <th>l_type</th>\n",
       "      <th>...</th>\n",
       "      <th>recall_val</th>\n",
       "      <th>f1_val</th>\n",
       "      <th>auc_val</th>\n",
       "      <th>f1_area_val</th>\n",
       "      <th>precision_test</th>\n",
       "      <th>recall_test</th>\n",
       "      <th>f1_test</th>\n",
       "      <th>auc_test</th>\n",
       "      <th>f1_area_test</th>\n",
       "      <th>degree</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>1</td>\n",
       "      <td>node</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>skipsum</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>1</td>\n",
       "      <td>node</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>skipsum</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>1</td>\n",
       "      <td>node</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>skipsum</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>1</td>\n",
       "      <td>node</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>skipsum</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>1</td>\n",
       "      <td>node</td>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>skipsum</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>GATv2</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.9</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 85 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    kfold  task  trans  l_pre  l_mp  l_post    stage  drop    lr l_type  ...  \\\n",
       "10      1  node   True      1     4       1  skipsum   0.0  0.01  GATv2  ...   \n",
       "11      1  node   True      1     4       1  skipsum   0.0  0.01  GATv2  ...   \n",
       "12      1  node   True      1     4       1  skipsum   0.0  0.01  GATv2  ...   \n",
       "13      1  node   True      1     4       1  skipsum   0.0  0.01  GATv2  ...   \n",
       "14      1  node   True      1     4       1  skipsum   0.0  0.01  GATv2  ...   \n",
       "\n",
       "    recall_val f1_val  auc_val  f1_area_val  precision_test recall_test  \\\n",
       "10         NaN    NaN      NaN          NaN             NaN         NaN   \n",
       "11         NaN    NaN      NaN          NaN             NaN         NaN   \n",
       "12         NaN    NaN      NaN          NaN             NaN         NaN   \n",
       "13         NaN    NaN      NaN          NaN             NaN         NaN   \n",
       "14         NaN    NaN      NaN          NaN             NaN         NaN   \n",
       "\n",
       "    f1_test  auc_test  f1_area_test  degree  \n",
       "10      NaN       NaN           NaN     3.9  \n",
       "11      NaN       NaN           NaN     3.9  \n",
       "12      NaN       NaN           NaN     3.9  \n",
       "13      NaN       NaN           NaN     3.9  \n",
       "14      NaN       NaN           NaN     3.9  \n",
       "\n",
       "[5 rows x 85 columns]"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "avg_degree = np.array([35.76, 31.13, 15.33, 15.22, 14.38, 10.91,  8.93,  5.97,  4.5 , 3.9 ,  2.74])\n",
    "col_unique = ['AmazonComputers', 'AmazonPhoto', 'CiteSeer', 'CoauthorCS', 'CoauthorPhysics', 'Cora', 'DBLP', 'FacebookPagePage', 'GitHub', 'PubMed', 'TwitchEN']\n",
    "col_unique = [col_unique[x] for x in order]\n",
    "\n",
    "avg_degree = {k: v for k, v in zip(col_unique, avg_degree)}\n",
    "def foo(row):\n",
    "    return avg_degree[row['dataset']]\n",
    "df['degree'] = df.apply(foo, axis=1)\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['GATv2', 'ShareGATv1-Conv', 'GCN', 'ShareGATv2', 'GATv1',\n",
       "       'GATv1-Conv', 'GATv2-Conv', 'ShareGATv1', 'ShareGATv2-Conv',\n",
       "       'ShareGATv2-Conv-ind', 'ShareGATv1-Conv-ind',\n",
       "       'ShareGATv2-Conv-ind2', 'GATv1-Conv-ind2', 'GATv2-Conv-ind',\n",
       "       'GATv2-Conv-ind2', 'ShareGATv1-Conv-ind2', 'GATv1-Conv-ind'],\n",
       "      dtype=object)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df['l_type_full'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_best(df, field, **kwargs):\n",
    "    index = df[field] != None\n",
    "    for k, v in kwargs.items():\n",
    "        index = index & (df[k] == v)\n",
    "    assert sum(index) != 0, 'No matches!'\n",
    "    return df[index].sort_values(field, ascending=False).iloc[0].name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['kfold', 'task', 'trans', 'l_pre', 'l_mp', 'l_post', 'stage', 'drop',\n",
       "       'lr', 'l_type', 'g_heads', 'l_lambda', 'convolve', 'share', 'gcn_mode',\n",
       "       'dataset', 'seed', 'best_epoch', 'epoch_train', 'eta_train',\n",
       "       'loss_train', 'lr_train', 'params_train', 'time_iter_train',\n",
       "       'accuracy_train', 'lmbda_1_train', 'lmbda2_1_train', 'lmbda_2_train',\n",
       "       'lmbda2_2_train', 'loss_area_train', 'accuracy_area_train', 'epoch_val',\n",
       "       'loss_val', 'lr_val', 'params_val', 'time_iter_val', 'accuracy_val',\n",
       "       'lmbda_1_val', 'lmbda2_1_val', 'lmbda_2_val', 'lmbda2_2_val',\n",
       "       'loss_area_val', 'accuracy_area_val', 'epoch_test', 'loss_test',\n",
       "       'lr_test', 'params_test', 'time_iter_test', 'accuracy_test',\n",
       "       'lmbda_1_test', 'lmbda2_1_test', 'lmbda_2_test', 'lmbda2_2_test',\n",
       "       'loss_area_test', 'accuracy_area_test', 'config_folder',\n",
       "       'lmbda_3_train', 'lmbda2_3_train', 'lmbda_4_train', 'lmbda2_4_train',\n",
       "       'lmbda_3_val', 'lmbda2_3_val', 'lmbda_4_val', 'lmbda2_4_val',\n",
       "       'lmbda_3_test', 'lmbda2_3_test', 'lmbda_4_test', 'lmbda2_4_test',\n",
       "       'l_type_full', 'precision_train', 'recall_train', 'f1_train',\n",
       "       'auc_train', 'f1_area_train', 'precision_val', 'recall_val', 'f1_val',\n",
       "       'auc_val', 'f1_area_val', 'precision_test', 'recall_test', 'f1_test',\n",
       "       'auc_test', 'f1_area_test', 'degree'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_match(df, row, fields):\n",
    "    index = df[fields[0]] != None\n",
    "#     print(sum(index))\n",
    "    for f in fields:\n",
    "#         print(f'{f} == {row[f]}')\n",
    "        index = index & (df[f] == row[f])\n",
    "#         print(sum(index))\n",
    "    return index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['GATv2', 'ShareGATv2', 'GATv1', 'ShareGATv1-Conv', 'GATv1-Conv',\n",
       "       'GCN', 'GATv2-Conv', 'ShareGATv2-Conv', 'ShareGATv1',\n",
       "       'ShareGATv2-Conv-ind', 'ShareGATv1-Conv-ind',\n",
       "       'ShareGATv2-Conv-ind2', 'GATv1-Conv-ind2', 'GATv2-Conv-ind',\n",
       "       'ShareGATv1-Conv-ind2', 'GATv2-Conv-ind2', 'GATv1-Conv-ind'],\n",
       "      dtype=object)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ddf = df.groupby(['dataset', 'l_type_full', 'lr', 'drop', 'l_mp', 'g_heads']).agg('mean').reset_index(drop=False)\n",
    "ddf.columns\n",
    "all_rows = ~(df['accuracy_val'] != None)\n",
    "for dataset in df['dataset'].unique():\n",
    "    for layer in df['l_type_full'].unique():\n",
    "#         print(dataset, layer)\n",
    "        row = ddf.loc[get_best(ddf, 'accuracy_val', dataset=dataset, l_type_full=layer)]\n",
    "#         display(ddf.loc[[get_best(ddf, 'accuracy_val', dataset=dataset, l_type_full=layer)]])\n",
    "        rows = get_match(df, row, ['dataset', 'l_type_full', 'lr', 'drop', 'l_mp', 'g_heads'])\n",
    "        all_rows = all_rows | rows\n",
    "        assert len(df.loc[rows]) == 10, len(df.loc[rows])\n",
    "#         break\n",
    "#     break\n",
    "\n",
    "def foo(row):\n",
    "    index = df[(df['l_type'] == row['l_type']) & (df['convolve'] == False) & (df['dataset'] == row['dataset']) & (df['l_mp'] == row['l_mp']) & (df['seed'] == row['seed']) &\n",
    "                     (df['g_heads'] == row['g_heads']) & (df['lr'] == row['lr'])]\n",
    "    \n",
    "    assert len(index) == 1\n",
    "    return (row['accuracy_test'] - index['accuracy_test'].iloc[0]) * 100\n",
    "\n",
    "df['impr'] = df.apply(foo, axis=1)\n",
    "df_filter_new = df[all_rows].copy()\n",
    "df_filter_new['l_type_full'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 259.2x226.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "c = 0.9\n",
    "plt.figure(figsize=(4 * c, 3.5 * c))\n",
    "\n",
    "# df_filter = df[df['l_type_full'].isin(['ShareGATv2', 'ShareGATv2-Conv', 'ShareGATv2-Conv-ind'])]\n",
    "df_filter = df_filter_new[~df_filter_new['l_type_full'].isin(['GCN'])]\n",
    "df_filter = df_filter.copy()\n",
    "\n",
    "def foo(row):\n",
    "#     index = df_filter[(df_filter['l_type'] == row['l_type']) & (df_filter['convolve'] == False) & (df_filter['dataset'] == row['dataset']) & (df_filter['l_mp'] == row['l_mp']) & (df_filter['seed'] == row['seed']) &\n",
    "#                      (df_filter['g_heads'] == row['g_heads']) & (df_filter['lr'] == row['lr'])]\n",
    "    index = df_filter[(df_filter['l_type'] == row['l_type']) & (df_filter['convolve'] == False) & (df_filter['dataset'] == row['dataset']) & (df_filter['seed'] == row['seed'])]\n",
    "    \n",
    "    assert len(index) == 1\n",
    "    return (row['accuracy_test'] - index['accuracy_test'].iloc[0]) * 100\n",
    "\n",
    "# df_filter['impr'] = df_filter.apply(foo, axis=1)\n",
    "# sns.scatterplot(x=df_filter['degree_'], y=df_filter['accuracy_test_mean'], hue=df_filter['l_type_full_'])\n",
    "\n",
    "# df_filter = df_filter[df_filter['l_type_full'].isin(['ShareGATv2-Conv', 'ShareGATv1-Conv'])]\n",
    "# df_filter = df_filter[df_filter['l_type_full'].isin(['ShareGATv2-Conv-ind', 'ShareGATv1-Conv-ind'])]\n",
    "# df_filter = df_filter[df_filter['l_type_full'].isin(['ShareGATv2-Conv-ind', 'ShareGATv1-Conv-ind'] + ['ShareGATv2-Conv', 'ShareGATv1-Conv'])]\n",
    "df_filter = df_filter[df_filter['l_type_full'].isin(['ShareGATv2-Conv-ind', 'ShareGATv1-Conv-ind'])]\n",
    "\n",
    "# sns.boxplot(data=df_filter, x='degree', y='impr', hue='l_type_full')\n",
    "\n",
    "# sns.regplot(data=df_filter, x='degree', y='impr', logx=True,  x_estimator=np.mean)\n",
    "sns.regplot(data=df_filter, x='degree', y='impr', logx=False,  x_estimator=np.mean, line_kws={'linestyle': '--'})\n",
    "plt.axhline(y=0., color='gray', linestyle='--')\n",
    "left, right = plt.xlim()\n",
    "plt.xlim(left-1, right+1)\n",
    "plt.ylabel('Acc. Improvement')\n",
    "plt.xlabel('Node average degree')\n",
    "\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.savefig('avg_degree.png', dpi=200, transparent=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.03043728, -0.07396854])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.polyfit(df_filter['degree'], df_filter['impr'], 1)\n",
    "# np.poly1d(np.polyfit(df_filter['degree'], df_filter['impr'], 1))(597)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# BAR PLOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def get_df_total(dict_best_with_seeds):\n",
    "    df_list = []\n",
    "    for key, df_key in dict_best_with_seeds.items():\n",
    "        df_copy = df_key.copy()\n",
    "        df_copy['Dataset'] = key[1]\n",
    "        df_copy['Model'] = key[2]\n",
    "        df_copy['Baseline'] = key[3]\n",
    "\n",
    "        df_list.append(df_copy)\n",
    "    \n",
    "    return pd.concat(df_list, ignore_index=True)\n",
    "df_total = get_df_total(dict_best_with_seeds)\n",
    "\n",
    "ii = models_filter.copy()\n",
    "# ii.remove('Dense')\n",
    "df_total = df_total[df_total.Model.isin(ii)]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "cfg.fontsize=20\n",
    "cfg.title_fontsize = 24\n",
    "cfg.tick_fontsize = 16\n",
    "cfg.figsize = (10, 6)\n",
    "cfg.palette = [\n",
    "    '#c1272d',\n",
    "    '#0000a7',\n",
    "    '#eecc16',\n",
    "    '#008176',\n",
    "    '#b3b3b3'\n",
    "]\n",
    "\n",
    "\n",
    "plt.close('all')\n",
    "\n",
    "n_datasets = len(df_total['Dataset'].unique())\n",
    "\n",
    "y = 'accuracy_test'\n",
    "# dataset_list = [\n",
    "#         'AmazonComputers',\n",
    "#         'AmazonPhoto',\n",
    "#         'GitHub',\n",
    "#         'FacebookPagePage',\n",
    "#         'CoauthorPhysics',\n",
    "#         'TwitchEN',\n",
    "#         'CoauthorCS',\n",
    "#         'DBLP',\n",
    "#         'PubMed',\n",
    "#         'Cora',\n",
    "#         'CiteSeer'\n",
    "#     ]\n",
    "dataset_list = list(df_total.Dataset.unique()) \n",
    "print(dataset_list)\n",
    "model_list = df_total['Model'].unique()\n",
    "model_list.sort()\n",
    "n_models = len(model_list)\n",
    "\n",
    "palette = []\n",
    "for m in model_list:\n",
    "    if any([cc in m for cc in ['Conv-ind', 'Conv-ind2']]):\n",
    "        palette.append('#eecc16') # YELLOW\n",
    "    elif 'Conv' in m:\n",
    "        palette.append('#0000a7') # Blue\n",
    "    elif 'GAT' in m:\n",
    "        palette.append('#c1272d') # RED\n",
    "    elif 'GCN' in m:\n",
    "        palette.append('#008176') # GREEN\n",
    "    else:\n",
    "        palette.append('#000000') # BLACK\n",
    "nrows = np.ceil(n_datasets/4).astype(int)\n",
    "fig, axes = plt.subplots(nrows=nrows,ncols=4, figsize=(15,6))\n",
    "\n",
    "\n",
    "i, j = 0, 0\n",
    "for dataset_name in dataset_list:\n",
    "    df_dataset = df_total[df_total.Dataset == dataset_name]\n",
    "    if nrows >1:\n",
    "        ax = axes[i, j]\n",
    "    else:\n",
    "         ax = axes[j]   \n",
    "    _ = sns.boxplot(x=\"Model\", y=y,\n",
    "                     data=df_dataset, linewidth=1.5,\n",
    "                    ax=ax,\n",
    "                   palette = palette)\n",
    "    ax.set_xticks([])\n",
    "    ax.set_title(dataset_name)\n",
    "    j+=1\n",
    "    if j == 4:\n",
    "        i+=1\n",
    "        j=0\n",
    "\n",
    "    for tick in ax.get_xticklabels():\n",
    "        tick.set_rotation(45)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_df_lambdas(dict_best_with_seeds):\n",
    "    df_list = []\n",
    "    for key, df_key in dict_best_with_seeds.items():\n",
    "        if '-ind' not in key[2]: continue\n",
    "        print(key)\n",
    "        lmbda_cols = [c for c in df_key.columns if 'lmbda' in c]\n",
    "        \n",
    "        rename_dict = {}\n",
    "\n",
    "        my_dict = {'Lambda': [], 'Value': []}\n",
    "        n_rows = len(df_key)\n",
    "        for col in lmbda_cols:\n",
    "            layer = col.split('_')[1]\n",
    "            if 'lmbda2' in col:\n",
    "                rename_dict[col] = r'$\\lambda_2$' + f' ({layer})'\n",
    "            else:\n",
    "                rename_dict[col] = r'$\\lambda_1$' + f' ({layer})'\n",
    "            my_dict['Lambda'].extend([col, ]*n_rows)\n",
    "            my_dict['Value'].extend(df_key[col].values)\n",
    "        df_copy = pd.DataFrame.from_dict(my_dict)\n",
    "        \n",
    "        \n",
    "        df_copy['Dataset'] = key[1]\n",
    "        df_copy['Model'] = key[2]\n",
    "        df_copy['Baseline'] = key[3]\n",
    "\n",
    "        df_list.append(df_copy)\n",
    "        \n",
    "    \n",
    "    df_out = pd.concat(df_list, ignore_index=True)\n",
    "    print(rename_dict)\n",
    "    df_out['Lambda'] = df_out['Lambda'].replace(rename_dict)\n",
    "    return df_out\n",
    "\n",
    "df_lmbdas_all = get_df_lambdas(dict_best_with_seeds)\n",
    "\n",
    "# # df_lmbdas_all = df_lmbdas_all[df_lmbdas_all.Model.isin(models_filter)]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# dict_best_with_seeds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_lmbdas = df_lmbdas_all.copy()\n",
    "print(df_lmbdas.Model.unique())\n",
    "df_lmbdas = df_lmbdas[df_lmbdas.Model == 'ShareGATv2-Conv-ind']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "\n",
    "cfg.fontsize=20\n",
    "cfg.title_fontsize = 24\n",
    "cfg.tick_fontsize = 16\n",
    "cfg.figsize = (10, 6)\n",
    "cfg.palette = [\n",
    "    '#c1272d',\n",
    "    '#0000a7',\n",
    "    '#eecc16',\n",
    "    '#008176',\n",
    "    '#b3b3b3'\n",
    "]\n",
    "\n",
    "\n",
    "plt.close('all')\n",
    "\n",
    "n_datasets = len(df_lmbdas['Dataset'].unique())\n",
    "\n",
    "dataset_list = [\n",
    "    'AmazonComputers',\n",
    "    'AmazonPhoto',\n",
    "    'GitHub',\n",
    "    'FacebookPagePage',\n",
    "    'CoauthorPhysics',\n",
    "    'TwitchEN',\n",
    "    'CoauthorCS',\n",
    "    'DBLP',\n",
    "    'PubMed',\n",
    "    'Cora',\n",
    "    'CiteSeer'\n",
    "]\n",
    "\n",
    "if y == 'accuracy_test':\n",
    "    dataset_list = [\n",
    "        'AmazonComputers',\n",
    "        'AmazonPhoto',\n",
    "        'GitHub',\n",
    "        'FacebookPagePage',\n",
    "        'CoauthorPhysics',\n",
    "        'TwitchEN',\n",
    "        'CoauthorCS',\n",
    "        'DBLP',\n",
    "        'PubMed',\n",
    "        'Cora',\n",
    "        'CiteSeer'\n",
    "    ]\n",
    "else:\n",
    "    dataset_list = list(df_total.Dataset.unique()) \n",
    "    \n",
    "model_list = df_lmbdas['Lambda'].unique()\n",
    "n_models = len(model_list)\n",
    "\n",
    "palette = []\n",
    "for m in model_list:\n",
    "    print(m)\n",
    "    if '_1' in m:\n",
    "        palette.append('#eecc16')\n",
    "    elif '_2' in m:\n",
    "        palette.append('#0000a7')\n",
    "#     elif 'GAT' in m:\n",
    "#         palette.append('#c1272d')\n",
    "#     else:\n",
    "#         palette.append('#008176')\n",
    "\n",
    "\n",
    "\n",
    "nrows = np.ceil(n_datasets/4).astype(int)\n",
    "fig, axes = plt.subplots(nrows=nrows,ncols=4, figsize=(15,8))\n",
    "\n",
    "\n",
    "i, j = 0, 0\n",
    "for dataset_name in dataset_list:\n",
    "    df_dataset = df_lmbdas[df_lmbdas.Dataset == dataset_name]\n",
    "    ax = axes[i, j] if nrows > 1 else axes[j]\n",
    "    df_dataset['Value'] = df_dataset['Value'] + np.random.normal(0,0.05,(len(df_dataset),))\n",
    "    _ = sns.boxplot(x=\"Lambda\", y=\"Value\",\n",
    "                     data=df_dataset, linewidth=1.5,\n",
    "                    ax=ax,\n",
    "                   palette = palette)\n",
    "#     ax.set_xticks([])\n",
    "    for tick in ax.get_xticklabels():\n",
    "        tick.set_rotation(45)\n",
    "    ax.set_title(dataset_name)\n",
    "    ax.set_ylim(-0.05, 1.05)\n",
    "    j+=1\n",
    "    if j == 4:\n",
    "        i+=1\n",
    "        j=0\n",
    "\n",
    "        \n",
    "models_str = ', '.join(df_lmbdas.Model.unique())\n",
    "fig.suptitle(f\"Models: {models_str}\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "cfg.fontsize=20\n",
    "cfg.title_fontsize = 24\n",
    "cfg.tick_fontsize = 16\n",
    "cfg.figsize = (10, 6)\n",
    "cfg.palette = [\n",
    "    '#c1272d',\n",
    "    '#0000a7',\n",
    "    '#eecc16',\n",
    "    '#008176',\n",
    "    '#b3b3b3'\n",
    "]\n",
    "\n",
    "\n",
    "plt.close('all')\n",
    "\n",
    "n_datasets = len(df_total['Dataset'].unique())\n",
    "\n",
    "dataset_list = [\n",
    "    'AmazonComputers',\n",
    "    'AmazonPhoto',\n",
    "    'GitHub',\n",
    "    'FacebookPagePage',\n",
    "    'CoauthorPhysics',\n",
    "    'TwitchEN',\n",
    "    'CoauthorCS',\n",
    "    'DBLP',\n",
    "    'PubMed',\n",
    "    'Cora',\n",
    "    'CiteSeer'\n",
    "]\n",
    "model_list = df_total['Model'].unique()\n",
    "n_models = len(model_list)\n",
    "\n",
    "palette = []\n",
    "for m in model_list:\n",
    "    if 'Conv-ind' in m:\n",
    "        palette.append('#eecc16')\n",
    "    elif 'Conv' in m:\n",
    "        palette.append('#0000a7')\n",
    "    elif 'GAT' in m:\n",
    "        palette.append('#c1272d')\n",
    "    else:\n",
    "        palette.append('#008176')\n",
    "nrows = np.ceil(n_datasets/4).astype(int)\n",
    "fig, axes = plt.subplots(nrows=nrows,ncols=4, figsize=(15,6))\n",
    "\n",
    "\n",
    "i, j = 0, 0\n",
    "for dataset_name in dataset_list:\n",
    "    df_dataset = df_total[df_total.Dataset == dataset_name]\n",
    "    ax = axes[i, j]\n",
    "    _ = sns.boxplot(x=\"Model\", y=\"accuracy_test\",\n",
    "                     data=df_dataset, linewidth=1.5,\n",
    "                    ax=ax,\n",
    "                   palette = palette)\n",
    "    ax.set_xticks([])\n",
    "    ax.set_title(dataset_name)\n",
    "    j+=1\n",
    "    if j == 4:\n",
    "        i+=1\n",
    "        j=0\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# LATEX TABLE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Performance metric: accuracy_test\n"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "def intersection(lst1, lst2):\n",
    "    lst3 = [value for value in lst1 if value in lst2]\n",
    "    return lst3\n",
    "\n",
    "from scipy.stats import ttest_rel\n",
    "is_better = []\n",
    "is_worse = []\n",
    "for _, row in my_df.iterrows():\n",
    "    dataset_name = row['dataset'].item()\n",
    "    model_name = row['l_type_full'].item()\n",
    "    bs_name = row['l_type'].item()\n",
    "    index = (row['task'].item(), \n",
    "             row['dataset'].item(), \n",
    "             row['l_type_full'].item(), \n",
    "             bs_name)\n",
    "    index_bs = (row['task'].item(), \n",
    "             row['dataset'].item(), \n",
    "             row['l_type'].item(), \n",
    "             bs_name)\n",
    "    df_ii = dict_best_with_seeds[index].sort_values('seed')\n",
    "    seeds = list(df_ii['seed'].values)\n",
    "    df_ii_bs = dict_best_with_seeds[index_bs].sort_values('seed')\n",
    "    seeds_bs = list(df_ii_bs['seed'].values)\n",
    "    seeds = intersection(seeds, seeds_bs)\n",
    "\n",
    "    df_ii = df_ii[df_ii.seed.isin(seeds)]\n",
    "    df_ii_bs = df_ii_bs[df_ii_bs.seed.isin(seeds)]\n",
    "    try:\n",
    "        performance = df_ii[cfg.performance_metric].values.astype(float)\n",
    "    except:\n",
    "        print('ERROR')\n",
    "        performance = df_ii['accuracy_test'].values\n",
    "    try:\n",
    "        performance_bs = df_ii_bs[cfg.performance_metric].values.astype(float)\n",
    "    except: \n",
    "        print(f'ERROR --> {index}')\n",
    "        performance_bs = df_ii_bs['accuracy_test'].values\n",
    "    try:\n",
    "        statistic, pvalue = ttest_rel(performance_bs, performance)\n",
    "    except:\n",
    "        print(f\"\\n[ERROR]{dataset_name} | {model_name} | {bs_name}\")\n",
    "        is_better.append(False)\n",
    "        continue\n",
    "\n",
    "    if pvalue < 0.05:\n",
    "        is_better_i = statistic < 0 if performance_metric_maximize else statistic > 0\n",
    "        is_better.append(is_better_i) \n",
    "        is_worse_i = statistic > 0 if performance_metric_maximize else statistic < 0\n",
    "        is_worse.append(is_worse_i) \n",
    "        perf_str = f\"{np.mean(performance_bs):.4f} {np.mean(performance):.4f}\"\n",
    "        if not is_better_i:\n",
    "            print(f\"\\n\\t[WORSE]{dataset_name} | {model_name} | {bs_name} -- {perf_str}\")\n",
    "            print(f\"\\tstats: {statistic:.2f} pvalue: {pvalue:.2f}\")\n",
    "        else:\n",
    "            print(f\"\\n [BETTER]{dataset_name} | {model_name} | {bs_name} -- {perf_str}\")\n",
    "            print(f\"stats: {statistic:.2f} pvalue: {pvalue:.2f}\")\n",
    "    else: \n",
    "        is_better.append(False) \n",
    "        is_worse.append(False)           \n",
    "my_df['is_better'] = is_better\n",
    "my_df['is_worse'] = is_worse\n",
    "if sum(is_worse) > 0:\n",
    "    print(f\"{sum(is_better)/sum(is_worse)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "# performance_metric = 'accuracy_test'\n",
    "# baselines = ['gcnconvbasic', 'ourgatv1', 'ourgatv2']\n",
    "# baselines_df = pd.DataFrame(columns = ['baseline', 'dataset', 'performance'])\n",
    "# # Get performance for baselines\n",
    "# for dataset_name, my_df_dataset in my_df.groupby('dataset'):\n",
    "#     for bs_name in baselines:\n",
    "#         row_ii = my_df_dataset[my_df_dataset['l_type_full'] == bs_name]\n",
    "#         perf_ii = row_ii[(performance_metric, 'mean')].item()\n",
    "#         dict_ii ={'baseline': bs_name, 'dataset': dataset_name, 'performance': perf}\n",
    "#         baselines_df = baselines_df.append(dict_ii, ignore_index=True) \n",
    "# baselines_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'accuracy_test'"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cfg.performance_metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_order = [\n",
    "    'AmazonComputers',\n",
    "    'AmazonPhoto',\n",
    "    'GitHub',\n",
    "    'FacebookPagePage',\n",
    "    'CoauthorPhysics',\n",
    "    'TwitchEN',\n",
    "    'CoauthorCS',\n",
    "    'DBLP',\n",
    "    'PubMed',\n",
    "    'Cora',\n",
    "    'CiteSeer',\n",
    "    'QM7b',\n",
    "    'QM9',\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best models with metric: accuracy_test\n",
      "\n",
      "CiteSeer: GINGAT-Conv\n",
      "Cora: GINGAT-Conv\n",
      "\n",
      "\n",
      "\n",
      "\\begin{tabular}{lcc}\n",
      "\\toprule\n",
      "Model & Cora & CiteSeer \\\\ \\midrule\n",
      "GIN&  84.33 $\\pm$ 1.01&  73.14 $\\pm$ 0.58 \\\\\n",
      "\\midrule\n",
      "GINGAT&  84.74 $\\pm$ 0.85&  73.80 $\\pm$ 0.90 \\\\\n",
      "GINGAT-Conv& { \\color{teal}  85.06 $\\pm$ 0.97 }& { \\color{teal}  73.80 $\\pm$ 1.08 } \\\\\n",
      "\\midrule\n",
      "ShareGINGAT&  84.84 $\\pm$ 1.11&  73.44 $\\pm$ 0.69 \\\\\n",
      "ShareGINGAT-Conv&  84.69 $\\pm$ 0.76&  73.76 $\\pm$ 0.45 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "best_dict = {'dataset': {},\n",
    "            'l_type_full': {}}\n",
    "\n",
    "\n",
    "\n",
    "print(f'Best models with metric: {cfg.performance_metric}\\n')\n",
    "baselines_df = pd.DataFrame(columns = ['baseline', 'dataset', 'performance'])\n",
    "for dataset_name, my_df_dataset in my_df.groupby('dataset'):\n",
    "    if performance_metric_maximize:\n",
    "        idx = my_df_dataset[(cfg.performance_metric, 'mean')].astype(float).argmax()\n",
    "    else: \n",
    "        idx = my_df_dataset[(cfg.performance_metric, 'mean')].astype(float).argmin()\n",
    "    best_model = my_df_dataset.iloc[idx]['l_type_full'].item()\n",
    "    if dataset_name not in best_dict['dataset']:\n",
    "        best_dict['dataset'][dataset_name] = []\n",
    "    best_dict['dataset'][dataset_name].append(best_model)\n",
    "    if best_model not in best_dict['l_type_full']:\n",
    "        best_dict['l_type_full'][best_model] = []\n",
    "    best_dict['l_type_full'][best_model].append(dataset_name)\n",
    "    print(f\"{dataset_name}: {best_model}\")\n",
    "\n",
    "    \n",
    "# %%\n",
    "print('\\n\\n')\n",
    "# V1\n",
    "col_name = 'dataset'\n",
    "row_name = 'l_type_full'\n",
    "\n",
    "\n",
    "\n",
    "col_unique_all = sorted(my_df[col_name].unique())\n",
    "col_unique = []\n",
    "for my_col in dataset_order:\n",
    "    if my_col in col_unique_all:\n",
    "        col_unique.append(my_col)\n",
    "        col_unique_all.remove(my_col)\n",
    "\n",
    "col_unique = [*col_unique, *col_unique_all]\n",
    "\n",
    "\n",
    "\n",
    "row_unique = sorted(my_df[row_name].unique())\n",
    "\n",
    "ccc = ''.join(['c',]*len(col_unique))\n",
    "print(\"\\\\begin{tabular}{l\" + f\"{ccc}\" + \"}\")\n",
    "print(\"\\\\toprule\")\n",
    "\n",
    "row_str = f\"{column_mapping(row_name)} & \"\n",
    "row_str += ' & '.join([column_mapping(str(c)) for c in col_unique ])\n",
    "row_str += ' \\\\\\\\ \\\\midrule'\n",
    "print(row_str)\n",
    "\n",
    "for row_name_i, row_name_next in zip(row_unique, [*row_unique[1:], row_unique[-1]]):\n",
    "    my_row = my_df[my_df[row_name] == row_name_i]\n",
    "#     print(row_name_i)\n",
    "    row_str = f'{column_mapping(row_name_i)}'\n",
    "    for col_name_i in col_unique:\n",
    "        my_col = my_row[my_row[col_name] == col_name_i]\n",
    "        if len(my_col[(cfg.performance_metric, 'mean')])>0:\n",
    "            mean = my_col[(cfg.performance_metric, 'mean')].item()\n",
    "            std = my_col[(cfg.performance_metric, 'std')].item()\n",
    "            is_better = my_col['is_better'].item()\n",
    "            is_worse =  my_col['is_worse'].item()\n",
    "            best_model_list = best_dict[col_name][col_name_i]\n",
    "        else:\n",
    "            mean = 0.0\n",
    "            std = 0.0\n",
    "            is_better = False\n",
    "            is_worse = False\n",
    "            best_model_list = []\n",
    "            \n",
    "        \n",
    "        # if row_name_i in best_dict[col_name][col_name_i] or my_col['is_better'].item():\n",
    "        str_tmp = ''\n",
    "        if is_better:\n",
    "            str_tmp = f' \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        elif is_worse:\n",
    "            str_tmp = f' {{\\color{{red}} \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}}}'\n",
    "        else:\n",
    "            str_tmp = f' {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        if row_name_i in best_model_list:\n",
    "            str_tmp = f\"{{ \\color{{teal}} {str_tmp} }}\"\n",
    "        row_str += f'& {str_tmp}'\n",
    "            \n",
    "        \n",
    "#         print(f\"\\t{col_name_i} {mean:.2f} \\pm {std:.2f}\")\n",
    "    print(f\"{row_str} \\\\\\\\\")\n",
    "    if row_name_next.split('-')[0] != row_name_i.split('-')[0]:\n",
    "        print('\\\\midrule')\n",
    "    \n",
    "\n",
    "print('\\\\bottomrule')\n",
    "print('\\\\end{tabular}')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best models with metric: accuracy_test\n",
      "\n",
      "CiteSeer: GINGAT-Conv\n",
      "Cora: GINGAT-Conv\n",
      "\n",
      "\n",
      "\n",
      "\\begin{tabular}{lcc}\n",
      "\\toprule\n",
      "Model & CiteSeer & Cora \\\\ \\midrule\n",
      " GIN CiteSeer  73.14 $\\pm$ 0.58\n",
      " GIN Cora  84.33 $\\pm$ 1.01\n",
      " GINGAT CiteSeer  73.80 $\\pm$ 0.90\n",
      " GINGAT Cora  84.74 $\\pm$ 0.85\n",
      " GINGAT-Conv CiteSeer { \\color{teal}  73.80 $\\pm$ 1.08 }\n",
      " GINGAT-Conv Cora { \\color{teal}  85.06 $\\pm$ 0.97 }\n",
      " ShareGINGAT CiteSeer  73.44 $\\pm$ 0.69\n",
      " ShareGINGAT Cora  84.84 $\\pm$ 1.11\n",
      " ShareGINGAT-Conv CiteSeer  73.76 $\\pm$ 0.45\n",
      " ShareGINGAT-Conv Cora  84.69 $\\pm$ 0.76\n",
      "\\bottomrule\n",
      "\\end{tabular}\n"
     ]
    }
   ],
   "source": [
    "best_dict = {'dataset': {},\n",
    "            'l_type_full': {}}\n",
    "\n",
    "\n",
    "\n",
    "print(f'Best models with metric: {cfg.performance_metric}\\n')\n",
    "baselines_df = pd.DataFrame(columns = ['baseline', 'dataset', 'performance'])\n",
    "for dataset_name, my_df_dataset in my_df.groupby('dataset'):\n",
    "    if performance_metric_maximize:\n",
    "        idx = my_df_dataset[(cfg.performance_metric, 'mean')].astype(float).argmax()\n",
    "    else: \n",
    "        idx = my_df_dataset[(cfg.performance_metric, 'mean')].astype(float).argmin()\n",
    "    best_model = my_df_dataset.iloc[idx]['l_type_full'].item()\n",
    "    if dataset_name not in best_dict['dataset']:\n",
    "        best_dict['dataset'][dataset_name] = []\n",
    "    best_dict['dataset'][dataset_name].append(best_model)\n",
    "    if best_model not in best_dict['l_type_full']:\n",
    "        best_dict['l_type_full'][best_model] = []\n",
    "    best_dict['l_type_full'][best_model].append(dataset_name)\n",
    "    print(f\"{dataset_name}: {best_model}\")\n",
    "\n",
    "    \n",
    "# %%\n",
    "print('\\n\\n')\n",
    "# V1\n",
    "col_name = 'dataset'\n",
    "row_name = 'l_type_full'\n",
    "\n",
    "\n",
    "\n",
    "col_unique = sorted(my_df[col_name].unique())\n",
    "row_unique = sorted(my_df[row_name].unique())\n",
    "\n",
    "ccc = ''.join(['c',]*len(col_unique))\n",
    "print(\"\\\\begin{tabular}{l\" + f\"{ccc}\" + \"}\")\n",
    "print(\"\\\\toprule\")\n",
    "\n",
    "row_str = f\"{column_mapping(row_name)} & \"\n",
    "row_str += ' & '.join([column_mapping(str(c)) for c in col_unique ])\n",
    "row_str += ' \\\\\\\\ \\\\midrule'\n",
    "print(row_str)\n",
    "\n",
    "for row_name_i, row_name_next in zip(row_unique, [*row_unique[1:], row_unique[-1]]):\n",
    "    my_row = my_df[my_df[row_name] == row_name_i]\n",
    "#     print(row_name_i)\n",
    "    row_str = f'{column_mapping(row_name_i)}'\n",
    "    for col_name_i in col_unique:\n",
    "        my_col = my_row[my_row[col_name] == col_name_i]\n",
    "        if len(my_col[(cfg.performance_metric, 'mean')])>0:\n",
    "            mean = my_col[(cfg.performance_metric, 'mean')].item()\n",
    "            std = my_col[(cfg.performance_metric, 'std')].item()\n",
    "            is_better = my_col['is_better'].item()\n",
    "            is_worse =  my_col['is_worse'].item()\n",
    "            best_model_list = best_dict[col_name][col_name_i]\n",
    "        else:\n",
    "            mean = 0.0\n",
    "            std = 0.0\n",
    "            is_better = False\n",
    "            is_worse = False\n",
    "            best_model_list = []\n",
    "            \n",
    "        \n",
    "        # if row_name_i in best_dict[col_name][col_name_i] or my_col['is_better'].item():\n",
    "        str_tmp = ''\n",
    "        if is_better:\n",
    "            str_tmp = f' \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        elif is_worse:\n",
    "            str_tmp = f' {{\\color{{red}} \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}}}'\n",
    "        else:\n",
    "            str_tmp = f' {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        if row_name_i in best_model_list:\n",
    "            str_tmp = f\"{{ \\color{{teal}} {str_tmp} }}\"\n",
    "        print(f' {row_name_i} {col_name_i} {str_tmp}')\n",
    "            \n",
    "        \n",
    "    \n",
    "\n",
    "print('\\\\bottomrule')\n",
    "print('\\\\end{tabular}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PLOT LAMBDAS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_l_type_convolve_l_lambda(cleaned_full):\n",
    "    out = cleaned_full.split('-')\n",
    "    my_dict = {'ShareGATv1': 'ourgatv1',\n",
    "              'ShareGATv2': 'ourgatv2',\n",
    "              'GATv1': 'ourgatv1',\n",
    "              'GATv2': 'ourgatv2'}\n",
    "    my_dict_2 = {'lallv2': 'learn_new',\n",
    "              'lall': 'learn12',\n",
    "              'ind': 'individual'}\n",
    "    l = my_dict[out[0]]\n",
    "    convolve= len(out)>1\n",
    "    if len(out) <3:\n",
    "        llambda = None\n",
    "    else:\n",
    "        llambda = my_dict_2[out[2]]\n",
    "    return l, convolve, llambda\n",
    "    \n",
    "\n",
    "# which = 'worse'\n",
    "which = 'better'\n",
    "# which = 'worse'\n",
    "\n",
    "\n",
    "index_dict = {\n",
    "    'better_sharev1': ('node', 'AmazonComputers', 'ShareGATv1-Conv-ind',  'ShareGATv1'),\n",
    "    'equal_sharev1': ('node', 'Cora', 'ShareGATv1-Conv-ind',  'ShareGATv1'),\n",
    "    'worse_sharev1': ('node', 'DBLP', 'ShareGATv1-Conv-ind',  'ShareGATv1'),\n",
    "    'better': ('node', 'GitHub', 'ShareGATv2-Conv-ind',  'ShareGATv2'),\n",
    "    'better2': ('node', 'GitHub', 'ShareGATv2-Conv-lallv2',  'ShareGATv2'),\n",
    "    'equal': ('node', 'Cora', 'GATv1-Conv-ind',  'GATv1'),\n",
    "    'equal2': ('node', 'Cora', 'GATv1',  'GATv1'),\n",
    "#     'worse': ('node', 'DBLP', 'ShareGATv2-Conv-lall',  'ShareGATv2'),\n",
    "    'worse': ('node', 'PubMed', 'ShareGATv1-Conv-ind',  'ShareGATv1')\n",
    "\n",
    "}\n",
    "\n",
    "\n",
    "\n",
    "index = index_dict[which]\n",
    "\n",
    "dataset = index[1]\n",
    "l_type_full = index[2]\n",
    "\n",
    "\n",
    "df_ii = dict_best_with_seeds[index].sort_values('seed')\n",
    "\n",
    "my_str = \"grep \\\"arguments\\\" cgcnbasic_grid_node_3.sub\"\n",
    "my_str += f' | grep \\\"dataset={dataset}\\\"'\n",
    "l_type, convolve, llambda = get_l_type_convolve_l_lambda(l_type_full)\n",
    "my_str += f' | grep \\\"l_type={l_type}\\\"'\n",
    "my_str += f' | grep \\\"convolve={convolve}\\\"'\n",
    "share = 'Share' in l_type_full\n",
    "my_str += f' | grep \\\"share={share}\\\"'\n",
    "my_str += f' | grep \\\"l_lambda={llambda}\\\"'\n",
    "\n",
    "for c in df_ii.columns:\n",
    "    cond = all([ split not in c for split in ['test', 'val', 'train']])\n",
    "    cond = cond and 'epoch' not in c\n",
    "    cond = cond and 'seed' not in c\n",
    "    if cond:\n",
    "        values = df_ii[c].unique()\n",
    "        if len(values) == 1:\n",
    "            my_str +=f' | grep \\\"{c}={values[0]}\\\"' \n",
    "print(my_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(index)\n",
    "df_ii[['best_epoch', 'accuracy_test']].agg(['median','mean','std'])\n",
    "# df_ii[['best_epoch', 'accuracy_test']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(f\"We do {which} in {index}\")\n",
    "lambda_cols = [c for c in df_ii.columns if ('lmbda' in c) and ('train' in c)]\n",
    "rename_cols = {}\n",
    "for c in lambda_cols:\n",
    "    cout = c.replace('_train', '')\n",
    "    cout = ' | '.join(cout.split('_'))\n",
    "    rename_cols[c] = cout\n",
    "df_out = df_ii[lambda_cols].agg(['median','mean', 'std']).round(2)\n",
    "df_out.rename(rename_cols,axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_ii[lambda_cols]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "cfg.fontsize=20\n",
    "cfg.title_fontsize = 24\n",
    "cfg.tick_fontsize = 16\n",
    "cfg.figsize = (10, 6)\n",
    "cfg.palette = [\n",
    "    '#c1272d',\n",
    "    '#0000a7',\n",
    "    '#eecc16',\n",
    "    '#008176',\n",
    "    '#b3b3b3'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "plt.close('all')\n",
    "\n",
    "palette = [\n",
    "    '#c1272d',\n",
    "    '#0000a7',\n",
    "    '#eecc16',\n",
    "    '#008176'\n",
    "]\n",
    "df_new = pd.DataFrame(columns=['lambda-1', 'lambda-2', 'layer'])\n",
    "\n",
    "rows = []\n",
    "\n",
    "which_all = [\n",
    "    'better_sharev1',\n",
    "    'equal_sharev1',\n",
    "    'worse_sharev1'\n",
    "]\n",
    "\n",
    "for which in which_all:\n",
    "    index = index_dict[which]\n",
    "    df_ii =  dict_best_with_seeds[index]\n",
    "    for i in range(1, 5):\n",
    "        for _, li in df_ii.iterrows():\n",
    "            rnd_1 = np.random.rand(1)[0]*0.1 - 0.05\n",
    "            rnd_2 = np.random.rand(1)[0]*0.1 - 0.05\n",
    "            rows.append({'lambda-1':li[f'lmbda_{i}_train'] + rnd_1 , \n",
    "                         'lambda-2': li[f'lmbda2_{i}_train'] + rnd_2 , \n",
    "                         'layer': i,\n",
    "                        'type': f\"{index[1]} {index[2]} \"})\n",
    "\n",
    "df_new = pd.DataFrame.from_dict(rows)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=cfg.figsize)\n",
    "\n",
    "sns.scatterplot(data=df_new, \n",
    "                x='lambda-1', \n",
    "                y='lambda-2', \n",
    "                hue='type',\n",
    "                palette=cfg.palette[:len(which_all)], \n",
    "#                 size='type', \n",
    "#                 sizes=(600,800),\n",
    "               ax=ax,\n",
    "               s=400,\n",
    "                alpha=0.8,\n",
    "               style='layer')\n",
    "\n",
    "ax.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.rand(1)[0]*0.1 - 0.05"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# V2\n",
    "col_name = 'dataset'\n",
    "row_name = 'l_type_full'\n",
    "\n",
    "col_unique = sorted(my_df[col_name].unique())\n",
    "row_unique = sorted(my_df[row_name].unique())\n",
    "\n",
    "ccc = ''.join(['c',]*len(col_unique))\n",
    "print(\"\\\\begin{tabular}{l\" + f\"{ccc}\" + \"}\")\n",
    "print(\"\\\\toprule\")\n",
    "\n",
    "row_str = f\"{column_mapping(row_name)} & \"\n",
    "row_str += ' & '.join([column_mapping(str(c)) for c in col_unique ])\n",
    "row_str += ' \\\\\\\\ \\\\midrule'\n",
    "print(row_str)\n",
    "\n",
    "for row_name_i, row_name_next in zip(row_unique, [*row_unique[1:], row_unique[-1]]):\n",
    "    my_row = my_df[my_df[row_name] == row_name_i]\n",
    "#     print(row_name_i)\n",
    "    row_str = f'{column_mapping(row_name_i)}'\n",
    "    for col_name_i in col_unique:\n",
    "        my_col = my_row[my_row[col_name] == col_name_i]\n",
    "        mean = my_col[('accuracy_test', 'mean')].item()\n",
    "        std = my_col[('accuracy_test', 'std')].item()\n",
    "        if row_name_i in best_dict[col_name][col_name_i]:\n",
    "            row_str += f' & \\\\bfseries {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        else:\n",
    "            row_str += f' & {mean:.2f} $\\pm$ {std:.2f}'\n",
    "        \n",
    "#         print(f\"\\t{col_name_i} {mean:.2f} \\pm {std:.2f}\")\n",
    "    print(f\"{row_str} \\\\\\\\\")\n",
    "    if row_name_next.split('-')[0] != row_name_i.split('-')[0]:\n",
    "        print('\\\\midrule')\n",
    "    \n",
    "\n",
    "print('\\\\bottomrule')\n",
    "print('\\\\end{tabular}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "folder"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
