{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import seaborn as sn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "def pop_std(x):\n",
    "    return x.std(ddof=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "folder ='results_sts-b'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error results_sts-b/results_MINE_1_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_1_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_1_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_1_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_2_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_2_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_2_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_2_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_2_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_2_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_2_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_2_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_2_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_3_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_3_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_3_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_3_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_3_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_3_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_3_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_3_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_3_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_4_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_4_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_4_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_4_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_4_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_5_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_5_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_5_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_5_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_5_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_5_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_5_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_5_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_6_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_6_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_6_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_7_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_7_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_7_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_7_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_7_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_7_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_7_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_8_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_8_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_8_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_8_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_9_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_9_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_9_288_0.00001.csv\n",
      "Error results_sts-b/results_baseline_10.csv\n",
      "results_sts-b/results_ibbaseline_10_144_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_144_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_144_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_144_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_144_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_144_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_144_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_192_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_192_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_192_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_192_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_192_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_192_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_192_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_288_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_288_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_288_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_288_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_288_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_288_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_288_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_384_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_384_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_384_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_384_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_384_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_384_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_384_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_144_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_144_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_144_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_144_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_144_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_144_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_144_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_144_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_192_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_192_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_192_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_192_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_192_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_192_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_192_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_192_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_288_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_288_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_288_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_288_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_288_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_288_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_288_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_288_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_384_0.001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_384_0.001.csv\n",
      "Error results_sts-b/results_MINE_10_384_0.001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_384_0.001.csv\n",
      "Error results_sts-b/results_NWJ_10_384_0.001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_384_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_384_0.001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_384_0.001.csv\n",
      "results_sts-b/results_ibbaseline_10_144_0.00001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_144_0.00001.csv\n",
      "Error results_sts-b/results_MINE_10_144_0.00001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_144_0.00001.csv\n",
      "Error results_sts-b/results_NWJ_10_144_0.00001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_144_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_144_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_144_0.00001.csv\n",
      "results_sts-b/results_ibbaseline_10_192_0.00001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_192_0.00001.csv\n",
      "Error results_sts-b/results_MINE_10_192_0.00001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_192_0.00001.csv\n",
      "Error results_sts-b/results_NWJ_10_192_0.00001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_192_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_192_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_192_0.00001.csv\n",
      "results_sts-b/results_ibbaseline_10_288_0.00001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_288_0.00001.csv\n",
      "Error results_sts-b/results_MINE_10_288_0.00001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_288_0.00001.csv\n",
      "Error results_sts-b/results_NWJ_10_288_0.00001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_288_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_288_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_288_0.00001.csv\n",
      "results_sts-b/results_ibbaseline_10_384_0.00001.csv\n",
      "Error results_sts-b/results_CLUBSample_10_384_0.00001.csv\n",
      "Error results_sts-b/results_MINE_10_384_0.00001.csv\n",
      "Error results_sts-b/results_L1OutUB_10_384_0.00001.csv\n",
      "Error results_sts-b/results_NWJ_10_384_0.00001.csv\n",
      "Error results_sts-b/results_InfoNCE_10_384_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_E_10_384_0.00001.csv\n",
      "Error results_sts-b/results_KERNEL_A_10_384_0.00001.csv\n"
     ]
    }
   ],
   "source": [
    "resuts = {\n",
    "    \"seed\" : [], \n",
    "    \"ib_dims\" : [], \n",
    "    \"betas\" : [], \n",
    "    \"estimators\":[],\n",
    "    \"pearson_dev\" : [],\n",
    "        \"spearman_dev\" : []\n",
    "    \n",
    "    \n",
    "    \n",
    "}\n",
    "\n",
    "SEEDS=[1,2, 3, 4, 5, 6, 7, 8 ,9 ,10]\n",
    "IB_DIMS = [144, 192, 288 ,384]\n",
    "BETAS = [\"0.001\" ,\"0.001\" ,\"0.00001\"]\n",
    "ESTIMATORS  = ['CLUBSample', 'MINE' ,'L1OutUB', 'NWJ', 'InfoNCE', 'KERNEL_E' ,'KERNEL_A']\n",
    "for SEED in SEEDS:\n",
    "    filename = '{}/results_baseline_{}.csv'.format(folder,SEED)\n",
    "    try :\n",
    "        resuts[\"pearson_dev\"].append(max(pd.read_csv(filename,delimiter=';').pearson_dev.values))\n",
    "        resuts[\"spearman_dev\"].append(max(pd.read_csv(filename,delimiter=';').spearmanr_dev.values))\n",
    "        resuts[\"seed\"].append(SEED)\n",
    "        resuts[\"ib_dims\"].append(0)\n",
    "        resuts[\"betas\"].append(0)\n",
    "        resuts[\"estimators\"].append('BASELINE')\n",
    "    except:\n",
    "        print('Error',filename)\n",
    "    for BETA in BETAS:\n",
    "        for IB_DIM in IB_DIMS:\n",
    "            filename = '{}/results_ibbaseline_{}_{}_{}.csv'.format(folder,SEED,IB_DIM,BETA)\n",
    "            try :\n",
    "                resuts[\"pearson_dev\"].append(max(pd.read_csv(filename,delimiter=';').pearson_dev.values))\n",
    "                resuts[\"spearman_dev\"].append(max(pd.read_csv(filename,delimiter=';').spearmanr_dev.values))\n",
    "                resuts[\"seed\"].append(SEED)\n",
    "                resuts[\"ib_dims\"].append(IB_DIM)\n",
    "                resuts[\"betas\"].append(BETA)\n",
    "                resuts[\"estimators\"].append('IB_BASELINE')\n",
    "            except :\n",
    "                print(filename)\n",
    "            for ESTIMATOR in ESTIMATORS:\n",
    "                filename = '{}/results_{}_{}_{}_{}.csv'.format(folder,ESTIMATOR,SEED,IB_DIM,BETA)\n",
    "                try:\n",
    "                    resuts[\"pearson_dev\"].append(max(pd.read_csv(filename,delimiter=';').pearson_dev.values))\n",
    "                    resuts[\"spearman_dev\"].append(max(pd.read_csv(filename,delimiter=';').spearmanr_dev.values))\n",
    "                    resuts[\"seed\"].append(SEED)\n",
    "                    resuts[\"ib_dims\"].append(IB_DIM)\n",
    "                    resuts[\"betas\"].append(BETA)\n",
    "                    resuts[\"estimators\"].append(ESTIMATOR)\n",
    "                except:\n",
    "                    print('Error',filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['seed', 'ib_dims', 'betas', 'estimators', 'pearson_dev', 'spearman_dev'])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "resuts.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "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>seed</th>\n",
       "      <th>ib_dims</th>\n",
       "      <th>betas</th>\n",
       "      <th>estimators</th>\n",
       "      <th>pearson_dev</th>\n",
       "      <th>spearman_dev</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>BASELINE</td>\n",
       "      <td>0.887011</td>\n",
       "      <td>0.882406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.899504</td>\n",
       "      <td>0.894702</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.899708</td>\n",
       "      <td>0.895522</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.869207</td>\n",
       "      <td>0.871893</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.896585</td>\n",
       "      <td>0.894515</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.898787</td>\n",
       "      <td>0.895310</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>InfoNCE</td>\n",
       "      <td>0.899197</td>\n",
       "      <td>0.896176</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.894789</td>\n",
       "      <td>0.891796</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>1</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.899650</td>\n",
       "      <td>0.897769</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.898255</td>\n",
       "      <td>0.893006</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.898837</td>\n",
       "      <td>0.896460</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.890941</td>\n",
       "      <td>0.886714</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.898088</td>\n",
       "      <td>0.894819</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.877055</td>\n",
       "      <td>0.874528</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>InfoNCE</td>\n",
       "      <td>0.898019</td>\n",
       "      <td>0.893908</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.896692</td>\n",
       "      <td>0.893933</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>1</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.899461</td>\n",
       "      <td>0.894889</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.900701</td>\n",
       "      <td>0.896248</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.901096</td>\n",
       "      <td>0.896800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.869061</td>\n",
       "      <td>0.869605</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.891846</td>\n",
       "      <td>0.888831</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.897822</td>\n",
       "      <td>0.893626</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>InfoNCE</td>\n",
       "      <td>0.892627</td>\n",
       "      <td>0.888796</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.894066</td>\n",
       "      <td>0.890932</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>1</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.901747</td>\n",
       "      <td>0.896910</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>1</td>\n",
       "      <td>384</td>\n",
       "      <td>0.001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.899300</td>\n",
       "      <td>0.895760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>1</td>\n",
       "      <td>384</td>\n",
       "      <td>0.001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.900515</td>\n",
       "      <td>0.896286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>1</td>\n",
       "      <td>384</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.874329</td>\n",
       "      <td>0.875061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>1</td>\n",
       "      <td>384</td>\n",
       "      <td>0.001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.895994</td>\n",
       "      <td>0.892134</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>1</td>\n",
       "      <td>384</td>\n",
       "      <td>0.001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.899391</td>\n",
       "      <td>0.895980</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>420</th>\n",
       "      <td>5</td>\n",
       "      <td>144</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.901010</td>\n",
       "      <td>0.897326</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>421</th>\n",
       "      <td>5</td>\n",
       "      <td>144</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.898655</td>\n",
       "      <td>0.894356</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>422</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.897505</td>\n",
       "      <td>0.892804</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>423</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.898272</td>\n",
       "      <td>0.895097</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>424</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.900127</td>\n",
       "      <td>0.896020</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>425</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.897772</td>\n",
       "      <td>0.892898</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>426</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>InfoNCE</td>\n",
       "      <td>0.896417</td>\n",
       "      <td>0.892915</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>427</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.899296</td>\n",
       "      <td>0.895260</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>428</th>\n",
       "      <td>5</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.900332</td>\n",
       "      <td>0.895177</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>429</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.902914</td>\n",
       "      <td>0.898686</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>430</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.896397</td>\n",
       "      <td>0.892627</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>431</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.900162</td>\n",
       "      <td>0.896198</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.897964</td>\n",
       "      <td>0.894782</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>433</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>InfoNCE</td>\n",
       "      <td>0.901993</td>\n",
       "      <td>0.898305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>434</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.897739</td>\n",
       "      <td>0.895791</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>435</th>\n",
       "      <td>5</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.898795</td>\n",
       "      <td>0.894272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>436</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>IB_BASELINE</td>\n",
       "      <td>0.897844</td>\n",
       "      <td>0.894332</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>437</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>CLUBSample</td>\n",
       "      <td>0.898511</td>\n",
       "      <td>0.894356</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>438</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>L1OutUB</td>\n",
       "      <td>0.897161</td>\n",
       "      <td>0.894337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>439</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>NWJ</td>\n",
       "      <td>0.897844</td>\n",
       "      <td>0.895227</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>440</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>InfoNCE</td>\n",
       "      <td>0.902613</td>\n",
       "      <td>0.898121</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>441</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_E</td>\n",
       "      <td>0.897391</td>\n",
       "      <td>0.894338</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>442</th>\n",
       "      <td>5</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>KERNEL_A</td>\n",
       "      <td>0.896910</td>\n",
       "      <td>0.892963</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>446</th>\n",
       "      <td>6</td>\n",
       "      <td>144</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.874535</td>\n",
       "      <td>0.878967</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>454</th>\n",
       "      <td>6</td>\n",
       "      <td>192</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.866465</td>\n",
       "      <td>0.876434</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>462</th>\n",
       "      <td>6</td>\n",
       "      <td>288</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.890040</td>\n",
       "      <td>0.888945</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>470</th>\n",
       "      <td>6</td>\n",
       "      <td>384</td>\n",
       "      <td>0.001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.870839</td>\n",
       "      <td>0.881102</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>524</th>\n",
       "      <td>6</td>\n",
       "      <td>288</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.874045</td>\n",
       "      <td>0.879168</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>607</th>\n",
       "      <td>7</td>\n",
       "      <td>192</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.882053</td>\n",
       "      <td>0.877692</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>808</th>\n",
       "      <td>9</td>\n",
       "      <td>384</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>MINE</td>\n",
       "      <td>0.883812</td>\n",
       "      <td>0.881368</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>310 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     seed  ib_dims    betas   estimators  pearson_dev  spearman_dev\n",
       "0       1        0        0     BASELINE     0.887011      0.882406\n",
       "1       1      144    0.001  IB_BASELINE     0.899504      0.894702\n",
       "2       1      144    0.001   CLUBSample     0.899708      0.895522\n",
       "3       1      144    0.001         MINE     0.869207      0.871893\n",
       "4       1      144    0.001      L1OutUB     0.896585      0.894515\n",
       "..    ...      ...      ...          ...          ...           ...\n",
       "462     6      288    0.001         MINE     0.890040      0.888945\n",
       "470     6      384    0.001         MINE     0.870839      0.881102\n",
       "524     6      288  0.00001         MINE     0.874045      0.879168\n",
       "607     7      192  0.00001         MINE     0.882053      0.877692\n",
       "808     9      384  0.00001         MINE     0.883812      0.881368\n",
       "\n",
       "[310 rows x 6 columns]"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2.581988897471611"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy\n",
    "numpy.std(list(range(9)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).mean().to_csv('ib_results_sts.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "(pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).std() ).to_csv('ib_results_sts_var.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "folder ='results_mrpc'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "resuts = {\n",
    "    \"seed\" : [], \n",
    "    \"ib_dims\" : [], \n",
    "    \"betas\" : [], \n",
    "    \"estimators\":[],\n",
    "    \"accuracy\" : [],\n",
    "    \n",
    "    \"f1\" : []\n",
    "    \n",
    "}\n",
    "\n",
    "SEEDS=[1,2, 3, 4, 5, 6, 7, 8 ,9]\n",
    "IB_DIMS = [144, 192, 288 ,384]\n",
    "BETAS = [\"0.001\" ,\"0.0001\" ,\"0.00001\"]\n",
    "ESTIMATORS  = ['CLUBSample', 'MINE' ,'L1OutUB', 'NWJ', 'InfoNCE', 'KERNEL_E' ,'KERNEL_A']\n",
    "for SEED in SEEDS:\n",
    "    filename = '{}/results_baseline_{}.csv'.format(folder,SEED)\n",
    "    try :\n",
    "        resuts[\"accuracy\"].append(max(pd.read_csv(filename,delimiter=';').acc_dev.values))\n",
    "        resuts[\"f1\"].append(max(pd.read_csv(filename,delimiter=';').f1_dev.values))\n",
    "        \n",
    "        resuts[\"seed\"].append(SEED)\n",
    "        resuts[\"ib_dims\"].append(0)\n",
    "        resuts[\"betas\"].append(0)\n",
    "        resuts[\"estimators\"].append('BASELINE')\n",
    "    except:\n",
    "        print('Error',filename)\n",
    "    for BETA in BETAS:\n",
    "        for IB_DIM in IB_DIMS:\n",
    "            filename = '{}/results_ibbaseline_{}_{}_{}.csv'.format(folder,SEED,IB_DIM,BETA)\n",
    "            try :\n",
    "                resuts[\"accuracy\"].append(max(pd.read_csv(filename,delimiter=';').acc_dev.values))\n",
    "                resuts[\"seed\"].append(SEED)\n",
    "                resuts[\"f1\"].append(max(pd.read_csv(filename,delimiter=';').f1_dev.values))\n",
    "                resuts[\"ib_dims\"].append(IB_DIM)\n",
    "                resuts[\"betas\"].append(BETA)\n",
    "                resuts[\"estimators\"].append('IB_BASELINE')\n",
    "            except :\n",
    "                print(filename)\n",
    "            for ESTIMATOR in ESTIMATORS:\n",
    "                filename = '{}/results_{}_{}_{}_{}.csv'.format(folder,ESTIMATOR,SEED,IB_DIM,BETA)\n",
    "                try:\n",
    "                    resuts[\"accuracy\"].append(max(pd.read_csv(filename,delimiter=';').acc_dev.values))\n",
    "                    resuts[\"seed\"].append(SEED)\n",
    "                    resuts[\"f1\"].append(max(pd.read_csv(filename,delimiter=';').f1_dev.values))\n",
    "                    resuts[\"ib_dims\"].append(IB_DIM)\n",
    "                    resuts[\"betas\"].append(BETA)\n",
    "                    resuts[\"estimators\"].append(ESTIMATOR)\n",
    "                except:\n",
    "                    print('Error',filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).mean().to_csv('ib_results_mrpc.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).std().to_csv('ib_results_mrpc_var.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "folder ='results_rte'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "resuts = {\n",
    "    \"seed\" : [], \n",
    "    \"ib_dims\" : [], \n",
    "    \"betas\" : [], \n",
    "    \"estimators\":[],\n",
    "    \"accuracy\" : []\n",
    "    \n",
    "    \n",
    "}\n",
    "\n",
    "SEEDS=[1,2, 3, 4, 5, 6, 7, 8 ,9 ,10]\n",
    "IB_DIMS = [144, 192, 288 ,384]\n",
    "BETAS = [\"0.001\" ,\"0.0001\" ,\"0.00001\"]\n",
    "ESTIMATORS  = ['CLUBSample', 'MINE' ,'L1OutUB', 'NWJ', 'InfoNCE', 'KERNEL_E' ,'KERNEL_A']\n",
    "for SEED in SEEDS:\n",
    "    filename = '{}/results_baseline_{}.csv'.format(folder,SEED)\n",
    "    try :\n",
    "        resuts[\"accuracy\"].append(max(pd.read_csv(filename,delimiter=';').acc_dev.values))\n",
    "        resuts[\"seed\"].append(SEED)\n",
    "        resuts[\"ib_dims\"].append(0)\n",
    "        resuts[\"betas\"].append(0)\n",
    "        resuts[\"estimators\"].append('BASELINE')\n",
    "    except:\n",
    "        print(filename)\n",
    "    for BETA in BETAS:\n",
    "        for IB_DIM in IB_DIMS:\n",
    "            filename = '{}/results_ibbaseline_{}_{}_{}.csv'.format(folder,SEED,IB_DIM,BETA)\n",
    "            try :\n",
    "                resuts[\"accuracy\"].append(max(pd.read_csv(filename,delimiter=';').acc_dev.values))\n",
    "                resuts[\"seed\"].append(SEED)\n",
    "                resuts[\"ib_dims\"].append(IB_DIM)\n",
    "                resuts[\"betas\"].append(BETA)\n",
    "                resuts[\"estimators\"].append('IB_BASELINE')\n",
    "            except :\n",
    "                print(filename)\n",
    "            for ESTIMATOR in ESTIMATORS:\n",
    "                filename = '{}/results_{}_{}_{}_{}.csv'.format(folder,ESTIMATOR,SEED,IB_DIM,BETA)\n",
    "                try:\n",
    "                    resuts[\"accuracy\"].append(max(pd.read_csv(filename,delimiter=';').acc_dev.values))\n",
    "                    resuts[\"seed\"].append(SEED)\n",
    "                    resuts[\"ib_dims\"].append(IB_DIM)\n",
    "                    resuts[\"betas\"].append(BETA)\n",
    "                    resuts[\"estimators\"].append(ESTIMATOR)\n",
    "                except:\n",
    "                    print(filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(resuts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "970"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(pd.DataFrame.from_dict(resuts))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).mean().to_csv('ib_results_rte.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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>seed</th>\n",
       "      <th>ib_dims</th>\n",
       "      <th>pearson_dev</th>\n",
       "      <th>spearman_dev</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>estimators</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>BASELINE</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.889310</td>\n",
       "      <td>0.885863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLUBSample</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>246.545455</td>\n",
       "      <td>0.897771</td>\n",
       "      <td>0.894536</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>IB_BASELINE</th>\n",
       "      <td>4.820896</td>\n",
       "      <td>247.164179</td>\n",
       "      <td>0.898728</td>\n",
       "      <td>0.894455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InfoNCE</th>\n",
       "      <td>4.769231</td>\n",
       "      <td>248.123077</td>\n",
       "      <td>0.898238</td>\n",
       "      <td>0.894835</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>KERNEL_A</th>\n",
       "      <td>4.820896</td>\n",
       "      <td>247.164179</td>\n",
       "      <td>0.898447</td>\n",
       "      <td>0.894833</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>KERNEL_E</th>\n",
       "      <td>4.757576</td>\n",
       "      <td>248.727273</td>\n",
       "      <td>0.897780</td>\n",
       "      <td>0.894268</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>L1OutUB</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>246.545455</td>\n",
       "      <td>0.896149</td>\n",
       "      <td>0.893181</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MINE</th>\n",
       "      <td>2.846154</td>\n",
       "      <td>232.615385</td>\n",
       "      <td>0.873875</td>\n",
       "      <td>0.877023</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NWJ</th>\n",
       "      <td>4.769231</td>\n",
       "      <td>248.123077</td>\n",
       "      <td>0.896549</td>\n",
       "      <td>0.892986</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 seed     ib_dims  pearson_dev  spearman_dev\n",
       "estimators                                                  \n",
       "BASELINE     4.000000    0.000000     0.889310      0.885863\n",
       "CLUBSample   4.833333  246.545455     0.897771      0.894536\n",
       "IB_BASELINE  4.820896  247.164179     0.898728      0.894455\n",
       "InfoNCE      4.769231  248.123077     0.898238      0.894835\n",
       "KERNEL_A     4.820896  247.164179     0.898447      0.894833\n",
       "KERNEL_E     4.757576  248.727273     0.897780      0.894268\n",
       "L1OutUB      4.833333  246.545455     0.896149      0.893181\n",
       "MINE         2.846154  232.615385     0.873875      0.877023\n",
       "NWJ          4.769231  248.123077     0.896549      0.892986"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby('estimators').mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', 0, '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.001', '0.001',\n",
       "       '0.001', '0.001', '0.001', '0.001', '0.001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.0001', '0.0001', '0.0001', '0.0001', '0.0001', '0.0001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001', '0.00001', '0.00001', '0.00001', '0.00001',\n",
       "       '0.00001', '0.00001'], dtype=object)"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame.from_dict(resuts).betas.values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).mean().to_csv('ib_results.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>seed</th>\n",
       "      <th>pearson_dev</th>\n",
       "      <th>spearman_dev</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>estimators</th>\n",
       "      <th>ib_dims</th>\n",
       "      <th>betas</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>BASELINE</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.889310</td>\n",
       "      <td>0.885863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"12\" valign=\"top\">CLUBSample</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">144</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.897358</td>\n",
       "      <td>0.893822</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.897276</td>\n",
       "      <td>0.893860</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896663</td>\n",
       "      <td>0.894734</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">192</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.898003</td>\n",
       "      <td>0.894330</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896650</td>\n",
       "      <td>0.893044</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.897772</td>\n",
       "      <td>0.894603</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">288</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.896854</td>\n",
       "      <td>0.893654</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897045</td>\n",
       "      <td>0.893751</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.899375</td>\n",
       "      <td>0.896240</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">384</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.899343</td>\n",
       "      <td>0.895698</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897477</td>\n",
       "      <td>0.894201</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.899591</td>\n",
       "      <td>0.896580</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"12\" valign=\"top\">IB_BASELINE</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">144</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.897573</td>\n",
       "      <td>0.893540</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896986</td>\n",
       "      <td>0.892900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.898152</td>\n",
       "      <td>0.894132</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">192</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.899504</td>\n",
       "      <td>0.895094</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.899225</td>\n",
       "      <td>0.894950</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.898904</td>\n",
       "      <td>0.894484</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">288</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.896627</td>\n",
       "      <td>0.892445</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.898078</td>\n",
       "      <td>0.893608</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.897974</td>\n",
       "      <td>0.893698</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">384</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.901341</td>\n",
       "      <td>0.897100</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.900145</td>\n",
       "      <td>0.895827</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.900798</td>\n",
       "      <td>0.896268</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">InfoNCE</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">144</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.898455</td>\n",
       "      <td>0.895140</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.897616</td>\n",
       "      <td>0.893965</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.899417</td>\n",
       "      <td>0.895949</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">192</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896547</td>\n",
       "      <td>0.893113</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.897445</td>\n",
       "      <td>0.893758</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"12\" valign=\"top\">L1OutUB</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">144</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.895931</td>\n",
       "      <td>0.892295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896761</td>\n",
       "      <td>0.894205</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.894323</td>\n",
       "      <td>0.892406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">192</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.898395</td>\n",
       "      <td>0.894779</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.897394</td>\n",
       "      <td>0.894160</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.894152</td>\n",
       "      <td>0.891866</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">288</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897540</td>\n",
       "      <td>0.894146</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897858</td>\n",
       "      <td>0.894434</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.893723</td>\n",
       "      <td>0.891560</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">384</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.896776</td>\n",
       "      <td>0.893652</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897669</td>\n",
       "      <td>0.894316</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.893376</td>\n",
       "      <td>0.890393</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"6\" valign=\"top\">MINE</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">144</th>\n",
       "      <th>0.0001</th>\n",
       "      <td>3.000000</td>\n",
       "      <td>0.862839</td>\n",
       "      <td>0.874410</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.876765</td>\n",
       "      <td>0.879494</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">192</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.868046</td>\n",
       "      <td>0.865033</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>3.000000</td>\n",
       "      <td>0.876321</td>\n",
       "      <td>0.877255</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>288</th>\n",
       "      <th>0.001</th>\n",
       "      <td>2.500000</td>\n",
       "      <td>0.875521</td>\n",
       "      <td>0.879573</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>384</th>\n",
       "      <th>0.001</th>\n",
       "      <td>2.000000</td>\n",
       "      <td>0.872008</td>\n",
       "      <td>0.874164</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"12\" valign=\"top\">NWJ</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">144</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.898414</td>\n",
       "      <td>0.894734</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.897965</td>\n",
       "      <td>0.894351</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.000000</td>\n",
       "      <td>0.894616</td>\n",
       "      <td>0.891463</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">192</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896162</td>\n",
       "      <td>0.892746</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.894236</td>\n",
       "      <td>0.890078</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.894123</td>\n",
       "      <td>0.891030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">288</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.898510</td>\n",
       "      <td>0.895398</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897618</td>\n",
       "      <td>0.893910</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>4.833333</td>\n",
       "      <td>0.896204</td>\n",
       "      <td>0.892963</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">384</th>\n",
       "      <th>0.00001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.896780</td>\n",
       "      <td>0.893061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.0001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.897956</td>\n",
       "      <td>0.894047</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.001</th>\n",
       "      <td>5.000000</td>\n",
       "      <td>0.896724</td>\n",
       "      <td>0.892723</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>91 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                seed  pearson_dev  spearman_dev\n",
       "estimators ib_dims betas                                       \n",
       "BASELINE   0       0        4.000000     0.889310      0.885863\n",
       "CLUBSample 144     0.00001  4.833333     0.897358      0.893822\n",
       "                   0.0001   4.000000     0.897276      0.893860\n",
       "                   0.001    4.833333     0.896663      0.894734\n",
       "           192     0.00001  4.833333     0.898003      0.894330\n",
       "...                              ...          ...           ...\n",
       "NWJ        288     0.0001   5.000000     0.897618      0.893910\n",
       "                   0.001    4.833333     0.896204      0.892963\n",
       "           384     0.00001  5.000000     0.896780      0.893061\n",
       "                   0.0001   5.000000     0.897956      0.894047\n",
       "                   0.001    5.000000     0.896724      0.892723\n",
       "\n",
       "[91 rows x 3 columns]"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame.from_dict(resuts).groupby(['estimators','ib_dims','betas']).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
