{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4003dd9c-c67e-4aba-9d5e-54a63c4417de",
   "metadata": {},
   "source": [
    "# Inspect results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "773536fa-9538-4411-b8da-f3246ba442c4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0601713f-da60-4a88-a1ec-632bace20893",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2ac9c674-b3f9-4381-b79d-efcdb3c51d4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_path = Path(\"./outputs/SMI.2025.05.NR.1/\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d0e5a7ea-5dff-4e31-9aad-453868b3b5f1",
   "metadata": {},
   "outputs": [],
   "source": [
    "method = \"csv\"\n",
    "\n",
    "if method == \"bebeziana\":\n",
    "    import bebeziana\n",
    "    data = bebeziana.read(data_path, [\"setup.yaml\", \"results.yaml\"])\n",
    "    \n",
    "elif method == \"csv\":\n",
    "    data = pd.read_csv(data_path / \"data.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cb39f0ad-fb31-42c4-af46-5b7a02f44553",
   "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>distribution._target_</th>\n",
       "      <th>distribution.dimensionality</th>\n",
       "      <th>distribution.mutual_information._args_</th>\n",
       "      <th>distribution.mutual_information._target_</th>\n",
       "      <th>distribution.randomize_interactions</th>\n",
       "      <th>estimator._target_</th>\n",
       "      <th>estimator.estimator._target_</th>\n",
       "      <th>estimator.projection_dim</th>\n",
       "      <th>metaparams.dimensionality</th>\n",
       "      <th>metaparams.mutual_information</th>\n",
       "      <th>...</th>\n",
       "      <th>n_samples</th>\n",
       "      <th>mutual_information.half_interquartile_range</th>\n",
       "      <th>mutual_information.lower_quartile</th>\n",
       "      <th>mutual_information.mean</th>\n",
       "      <th>mutual_information.median</th>\n",
       "      <th>mutual_information.std</th>\n",
       "      <th>mutual_information.upper_quartile</th>\n",
       "      <th>mutual_information.values</th>\n",
       "      <th>distribution.X_dim</th>\n",
       "      <th>distribution.Y_dim</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[16.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>16.0</td>\n",
       "      <td>...</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.014439</td>\n",
       "      <td>0.089840</td>\n",
       "      <td>0.096629</td>\n",
       "      <td>0.093300</td>\n",
       "      <td>0.010855</td>\n",
       "      <td>0.104279</td>\n",
       "      <td>[0.09358203647361789, 0.08524433560972237, 0.0...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[16.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>16.0</td>\n",
       "      <td>...</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.020152</td>\n",
       "      <td>0.585577</td>\n",
       "      <td>0.600149</td>\n",
       "      <td>0.596560</td>\n",
       "      <td>0.026803</td>\n",
       "      <td>0.605730</td>\n",
       "      <td>[0.6018589205664671, 0.5719792195381666, 0.664...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[13.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>13.0</td>\n",
       "      <td>...</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.020152</td>\n",
       "      <td>0.585576</td>\n",
       "      <td>0.600148</td>\n",
       "      <td>0.596559</td>\n",
       "      <td>0.026803</td>\n",
       "      <td>0.605728</td>\n",
       "      <td>[0.6018577620664085, 0.5719778695020107, 0.664...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[13.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>13.0</td>\n",
       "      <td>...</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.014440</td>\n",
       "      <td>0.089839</td>\n",
       "      <td>0.096627</td>\n",
       "      <td>0.093299</td>\n",
       "      <td>0.010856</td>\n",
       "      <td>0.104279</td>\n",
       "      <td>[0.09358184163910493, 0.08523519088637317, 0.0...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[13.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>13.0</td>\n",
       "      <td>...</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.063227</td>\n",
       "      <td>1.543301</td>\n",
       "      <td>1.581835</td>\n",
       "      <td>1.583282</td>\n",
       "      <td>0.039837</td>\n",
       "      <td>1.606528</td>\n",
       "      <td>[1.5268071220419084, 1.6403877397723665, 1.539...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                            distribution._target_  \\\n",
       "0  mutinfo.distributions.base.LogGammaExponential   \n",
       "1  mutinfo.distributions.base.LogGammaExponential   \n",
       "2  mutinfo.distributions.base.LogGammaExponential   \n",
       "3  mutinfo.distributions.base.LogGammaExponential   \n",
       "4  mutinfo.distributions.base.LogGammaExponential   \n",
       "\n",
       "   distribution.dimensionality distribution.mutual_information._args_  \\\n",
       "0                          8.0                              [16.0, 8]   \n",
       "1                          8.0                              [16.0, 8]   \n",
       "2                          8.0                              [13.0, 8]   \n",
       "3                          8.0                              [13.0, 8]   \n",
       "4                          8.0                              [13.0, 8]   \n",
       "\n",
       "  distribution.mutual_information._target_  \\\n",
       "0                   builtins.float.__mul__   \n",
       "1                   builtins.float.__mul__   \n",
       "2                   builtins.float.__mul__   \n",
       "3                   builtins.float.__mul__   \n",
       "4                   builtins.float.__mul__   \n",
       "\n",
       "   distribution.randomize_interactions          estimator._target_  \\\n",
       "0                                False  mutinfo.estimators.smi.SMI   \n",
       "1                                False  mutinfo.estimators.smi.SMI   \n",
       "2                                False  mutinfo.estimators.smi.SMI   \n",
       "3                                False  mutinfo.estimators.smi.SMI   \n",
       "4                                False  mutinfo.estimators.smi.SMI   \n",
       "\n",
       "  estimator.estimator._target_  estimator.projection_dim  \\\n",
       "0   mutinfo.estimators.knn.KSG                         1   \n",
       "1   mutinfo.estimators.knn.KSG                         2   \n",
       "2   mutinfo.estimators.knn.KSG                         2   \n",
       "3   mutinfo.estimators.knn.KSG                         1   \n",
       "4   mutinfo.estimators.knn.KSG                         3   \n",
       "\n",
       "   metaparams.dimensionality  metaparams.mutual_information  ...  n_samples  \\\n",
       "0                          8                           16.0  ...      10000   \n",
       "1                          8                           16.0  ...      10000   \n",
       "2                          8                           13.0  ...      10000   \n",
       "3                          8                           13.0  ...      10000   \n",
       "4                          8                           13.0  ...      10000   \n",
       "\n",
       "   mutual_information.half_interquartile_range  \\\n",
       "0                                     0.014439   \n",
       "1                                     0.020152   \n",
       "2                                     0.020152   \n",
       "3                                     0.014440   \n",
       "4                                     0.063227   \n",
       "\n",
       "   mutual_information.lower_quartile  mutual_information.mean  \\\n",
       "0                           0.089840                 0.096629   \n",
       "1                           0.585577                 0.600149   \n",
       "2                           0.585576                 0.600148   \n",
       "3                           0.089839                 0.096627   \n",
       "4                           1.543301                 1.581835   \n",
       "\n",
       "   mutual_information.median  mutual_information.std  \\\n",
       "0                   0.093300                0.010855   \n",
       "1                   0.596560                0.026803   \n",
       "2                   0.596559                0.026803   \n",
       "3                   0.093299                0.010856   \n",
       "4                   1.583282                0.039837   \n",
       "\n",
       "   mutual_information.upper_quartile  \\\n",
       "0                           0.104279   \n",
       "1                           0.605730   \n",
       "2                           0.605728   \n",
       "3                           0.104279   \n",
       "4                           1.606528   \n",
       "\n",
       "                           mutual_information.values  distribution.X_dim  \\\n",
       "0  [0.09358203647361789, 0.08524433560972237, 0.0...                 NaN   \n",
       "1  [0.6018589205664671, 0.5719792195381666, 0.664...                 NaN   \n",
       "2  [0.6018577620664085, 0.5719778695020107, 0.664...                 NaN   \n",
       "3  [0.09358184163910493, 0.08523519088637317, 0.0...                 NaN   \n",
       "4  [1.5268071220419084, 1.6403877397723665, 1.539...                 NaN   \n",
       "\n",
       "  distribution.Y_dim  \n",
       "0                NaN  \n",
       "1                NaN  \n",
       "2                NaN  \n",
       "3                NaN  \n",
       "4                NaN  \n",
       "\n",
       "[5 rows x 22 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "51b371f5-9cf1-4eef-8438-9ffff07cfe5d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['distribution._target_', 'distribution.dimensionality',\n",
       "       'distribution.mutual_information._args_',\n",
       "       'distribution.mutual_information._target_',\n",
       "       'distribution.randomize_interactions', 'estimator._target_',\n",
       "       'estimator.estimator._target_', 'estimator.projection_dim',\n",
       "       'metaparams.dimensionality', 'metaparams.mutual_information',\n",
       "       'n_parameters', 'n_runs', 'n_samples',\n",
       "       'mutual_information.half_interquartile_range',\n",
       "       'mutual_information.lower_quartile', 'mutual_information.mean',\n",
       "       'mutual_information.median', 'mutual_information.std',\n",
       "       'mutual_information.upper_quartile', 'mutual_information.values',\n",
       "       'distribution.X_dim', 'distribution.Y_dim'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0cd9d011-d858-4259-be41-0b4a1e5f8c6c",
   "metadata": {},
   "outputs": [],
   "source": [
    "data.loc[data[\"distribution.dimensionality\"].isna(), \"distribution.dimensionality\"] = data[data[\"distribution.dimensionality\"].isna()][\"distribution.X_dim\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "ebf25b31-d74a-445f-a0c7-993bcd0b06e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = data.drop(columns=[\"distribution.X_dim\", \"distribution.Y_dim\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "974af9b6-7e4a-4ba1-8e65-91833ffe9ac8",
   "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>distribution._target_</th>\n",
       "      <th>distribution.dimensionality</th>\n",
       "      <th>distribution.mutual_information._args_</th>\n",
       "      <th>distribution.mutual_information._target_</th>\n",
       "      <th>distribution.randomize_interactions</th>\n",
       "      <th>estimator._target_</th>\n",
       "      <th>estimator.estimator._target_</th>\n",
       "      <th>estimator.projection_dim</th>\n",
       "      <th>metaparams.dimensionality</th>\n",
       "      <th>metaparams.mutual_information</th>\n",
       "      <th>n_parameters</th>\n",
       "      <th>n_runs</th>\n",
       "      <th>n_samples</th>\n",
       "      <th>mutual_information.half_interquartile_range</th>\n",
       "      <th>mutual_information.lower_quartile</th>\n",
       "      <th>mutual_information.mean</th>\n",
       "      <th>mutual_information.median</th>\n",
       "      <th>mutual_information.std</th>\n",
       "      <th>mutual_information.upper_quartile</th>\n",
       "      <th>mutual_information.values</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[16.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>16.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.014439</td>\n",
       "      <td>0.089840</td>\n",
       "      <td>0.096629</td>\n",
       "      <td>0.093300</td>\n",
       "      <td>0.010855</td>\n",
       "      <td>0.104279</td>\n",
       "      <td>[0.09358203647361789, 0.08524433560972237, 0.0...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[16.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>16.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.020152</td>\n",
       "      <td>0.585577</td>\n",
       "      <td>0.600149</td>\n",
       "      <td>0.596560</td>\n",
       "      <td>0.026803</td>\n",
       "      <td>0.605730</td>\n",
       "      <td>[0.6018589205664671, 0.5719792195381666, 0.664...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[13.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>2</td>\n",
       "      <td>8</td>\n",
       "      <td>13.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.020152</td>\n",
       "      <td>0.585576</td>\n",
       "      <td>0.600148</td>\n",
       "      <td>0.596559</td>\n",
       "      <td>0.026803</td>\n",
       "      <td>0.605728</td>\n",
       "      <td>[0.6018577620664085, 0.5719778695020107, 0.664...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[13.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>1</td>\n",
       "      <td>8</td>\n",
       "      <td>13.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.014440</td>\n",
       "      <td>0.089839</td>\n",
       "      <td>0.096627</td>\n",
       "      <td>0.093299</td>\n",
       "      <td>0.010856</td>\n",
       "      <td>0.104279</td>\n",
       "      <td>[0.09358184163910493, 0.08523519088637317, 0.0...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>mutinfo.distributions.base.LogGammaExponential</td>\n",
       "      <td>8.0</td>\n",
       "      <td>[13.0, 8]</td>\n",
       "      <td>builtins.float.__mul__</td>\n",
       "      <td>False</td>\n",
       "      <td>mutinfo.estimators.smi.SMI</td>\n",
       "      <td>mutinfo.estimators.knn.KSG</td>\n",
       "      <td>3</td>\n",
       "      <td>8</td>\n",
       "      <td>13.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.063227</td>\n",
       "      <td>1.543301</td>\n",
       "      <td>1.581835</td>\n",
       "      <td>1.583282</td>\n",
       "      <td>0.039837</td>\n",
       "      <td>1.606528</td>\n",
       "      <td>[1.5268071220419084, 1.6403877397723665, 1.539...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                            distribution._target_  \\\n",
       "0  mutinfo.distributions.base.LogGammaExponential   \n",
       "1  mutinfo.distributions.base.LogGammaExponential   \n",
       "2  mutinfo.distributions.base.LogGammaExponential   \n",
       "3  mutinfo.distributions.base.LogGammaExponential   \n",
       "4  mutinfo.distributions.base.LogGammaExponential   \n",
       "\n",
       "   distribution.dimensionality distribution.mutual_information._args_  \\\n",
       "0                          8.0                              [16.0, 8]   \n",
       "1                          8.0                              [16.0, 8]   \n",
       "2                          8.0                              [13.0, 8]   \n",
       "3                          8.0                              [13.0, 8]   \n",
       "4                          8.0                              [13.0, 8]   \n",
       "\n",
       "  distribution.mutual_information._target_  \\\n",
       "0                   builtins.float.__mul__   \n",
       "1                   builtins.float.__mul__   \n",
       "2                   builtins.float.__mul__   \n",
       "3                   builtins.float.__mul__   \n",
       "4                   builtins.float.__mul__   \n",
       "\n",
       "   distribution.randomize_interactions          estimator._target_  \\\n",
       "0                                False  mutinfo.estimators.smi.SMI   \n",
       "1                                False  mutinfo.estimators.smi.SMI   \n",
       "2                                False  mutinfo.estimators.smi.SMI   \n",
       "3                                False  mutinfo.estimators.smi.SMI   \n",
       "4                                False  mutinfo.estimators.smi.SMI   \n",
       "\n",
       "  estimator.estimator._target_  estimator.projection_dim  \\\n",
       "0   mutinfo.estimators.knn.KSG                         1   \n",
       "1   mutinfo.estimators.knn.KSG                         2   \n",
       "2   mutinfo.estimators.knn.KSG                         2   \n",
       "3   mutinfo.estimators.knn.KSG                         1   \n",
       "4   mutinfo.estimators.knn.KSG                         3   \n",
       "\n",
       "   metaparams.dimensionality  metaparams.mutual_information  n_parameters  \\\n",
       "0                          8                           16.0             0   \n",
       "1                          8                           16.0             0   \n",
       "2                          8                           13.0             0   \n",
       "3                          8                           13.0             0   \n",
       "4                          8                           13.0             0   \n",
       "\n",
       "   n_runs  n_samples  mutual_information.half_interquartile_range  \\\n",
       "0      10      10000                                     0.014439   \n",
       "1      10      10000                                     0.020152   \n",
       "2      10      10000                                     0.020152   \n",
       "3      10      10000                                     0.014440   \n",
       "4      10      10000                                     0.063227   \n",
       "\n",
       "   mutual_information.lower_quartile  mutual_information.mean  \\\n",
       "0                           0.089840                 0.096629   \n",
       "1                           0.585577                 0.600149   \n",
       "2                           0.585576                 0.600148   \n",
       "3                           0.089839                 0.096627   \n",
       "4                           1.543301                 1.581835   \n",
       "\n",
       "   mutual_information.median  mutual_information.std  \\\n",
       "0                   0.093300                0.010855   \n",
       "1                   0.596560                0.026803   \n",
       "2                   0.596559                0.026803   \n",
       "3                   0.093299                0.010856   \n",
       "4                   1.583282                0.039837   \n",
       "\n",
       "   mutual_information.upper_quartile  \\\n",
       "0                           0.104279   \n",
       "1                           0.605730   \n",
       "2                           0.605728   \n",
       "3                           0.104279   \n",
       "4                           1.606528   \n",
       "\n",
       "                           mutual_information.values  \n",
       "0  [0.09358203647361789, 0.08524433560972237, 0.0...  \n",
       "1  [0.6018589205664671, 0.5719792195381666, 0.664...  \n",
       "2  [0.6018577620664085, 0.5719778695020107, 0.664...  \n",
       "3  [0.09358184163910493, 0.08523519088637317, 0.0...  \n",
       "4  [1.5268071220419084, 1.6403877397723665, 1.539...  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "64d44e08-f2e9-44c5-88f4-af823f8342aa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['mutinfo.distributions.base.LogGammaExponential',\n",
       "       'mutinfo.distributions.base.CorrelatedUniform',\n",
       "       'mutinfo.distributions.base.CorrelatedNormal',\n",
       "       'mutinfo.distributions.base.SmoothedUniform'], dtype=object)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[\"distribution._target_\"].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "6d02c221-895b-40a3-915b-1d818b75ee61",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['distribution._target_', 'distribution.dimensionality',\n",
       "       'distribution.mutual_information._args_',\n",
       "       'distribution.mutual_information._target_',\n",
       "       'distribution.randomize_interactions', 'estimator._target_',\n",
       "       'estimator.estimator._target_', 'estimator.projection_dim',\n",
       "       'metaparams.dimensionality', 'metaparams.mutual_information',\n",
       "       'n_parameters', 'n_runs', 'n_samples',\n",
       "       'mutual_information.half_interquartile_range',\n",
       "       'mutual_information.lower_quartile', 'mutual_information.mean',\n",
       "       'mutual_information.median', 'mutual_information.std',\n",
       "       'mutual_information.upper_quartile', 'mutual_information.values'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "7ca1cb57-eeee-4a01-b6b4-c8e758c3e56f",
   "metadata": {},
   "outputs": [],
   "source": [
    "data.to_csv(\"./data.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "fcaf5c37-4d11-4943-80f7-7146ef89afaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "saturated_data = data.groupby(\n",
    "    [\n",
    "        \"distribution._target_\",\n",
    "        \"distribution.dimensionality\",\n",
    "        \"estimator.projection_dim\"\n",
    "    ]\n",
    ").max(\"mutual_information.mean\").reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "ca7c4f8b-cb89-4420-b8b5-c1e3d6c8a3b0",
   "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>index</th>\n",
       "      <th>distribution._target_</th>\n",
       "      <th>distribution.dimensionality</th>\n",
       "      <th>estimator.projection_dim</th>\n",
       "      <th>distribution.randomize_interactions</th>\n",
       "      <th>metaparams.dimensionality</th>\n",
       "      <th>metaparams.mutual_information</th>\n",
       "      <th>n_parameters</th>\n",
       "      <th>n_runs</th>\n",
       "      <th>n_samples</th>\n",
       "      <th>mutual_information.half_interquartile_range</th>\n",
       "      <th>mutual_information.lower_quartile</th>\n",
       "      <th>mutual_information.mean</th>\n",
       "      <th>mutual_information.median</th>\n",
       "      <th>mutual_information.std</th>\n",
       "      <th>mutual_information.upper_quartile</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>mutinfo.distributions.base.CorrelatedNormal</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>2</td>\n",
       "      <td>18.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.163460</td>\n",
       "      <td>0.618604</td>\n",
       "      <td>0.678609</td>\n",
       "      <td>0.677802</td>\n",
       "      <td>0.085006</td>\n",
       "      <td>0.757080</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>mutinfo.distributions.base.CorrelatedNormal</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>3</td>\n",
       "      <td>18.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.025755</td>\n",
       "      <td>0.302578</td>\n",
       "      <td>0.313052</td>\n",
       "      <td>0.316141</td>\n",
       "      <td>0.018217</td>\n",
       "      <td>0.328161</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>mutinfo.distributions.base.CorrelatedNormal</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>3</td>\n",
       "      <td>18.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.073933</td>\n",
       "      <td>3.505820</td>\n",
       "      <td>3.543183</td>\n",
       "      <td>3.540481</td>\n",
       "      <td>0.044679</td>\n",
       "      <td>3.577591</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>mutinfo.distributions.base.CorrelatedNormal</td>\n",
       "      <td>4.0</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>18.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.017996</td>\n",
       "      <td>0.170506</td>\n",
       "      <td>0.182155</td>\n",
       "      <td>0.178388</td>\n",
       "      <td>0.019566</td>\n",
       "      <td>0.187962</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>mutinfo.distributions.base.CorrelatedNormal</td>\n",
       "      <td>4.0</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>18.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.099018</td>\n",
       "      <td>1.397434</td>\n",
       "      <td>1.432004</td>\n",
       "      <td>1.438041</td>\n",
       "      <td>0.093515</td>\n",
       "      <td>1.496436</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>103</th>\n",
       "      <td>103</td>\n",
       "      <td>mutinfo.distributions.base.SmoothedUniform</td>\n",
       "      <td>32.0</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>32</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.003728</td>\n",
       "      <td>0.072572</td>\n",
       "      <td>0.072582</td>\n",
       "      <td>0.073855</td>\n",
       "      <td>0.006377</td>\n",
       "      <td>0.075183</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>104</th>\n",
       "      <td>104</td>\n",
       "      <td>mutinfo.distributions.base.SmoothedUniform</td>\n",
       "      <td>32.0</td>\n",
       "      <td>3</td>\n",
       "      <td>False</td>\n",
       "      <td>32</td>\n",
       "      <td>12.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.006655</td>\n",
       "      <td>0.163044</td>\n",
       "      <td>0.166856</td>\n",
       "      <td>0.165293</td>\n",
       "      <td>0.005204</td>\n",
       "      <td>0.169487</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>105</th>\n",
       "      <td>105</td>\n",
       "      <td>mutinfo.distributions.base.SmoothedUniform</td>\n",
       "      <td>64.0</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>64</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.002611</td>\n",
       "      <td>0.011808</td>\n",
       "      <td>0.012512</td>\n",
       "      <td>0.012618</td>\n",
       "      <td>0.001633</td>\n",
       "      <td>0.013220</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>106</th>\n",
       "      <td>106</td>\n",
       "      <td>mutinfo.distributions.base.SmoothedUniform</td>\n",
       "      <td>64.0</td>\n",
       "      <td>2</td>\n",
       "      <td>False</td>\n",
       "      <td>64</td>\n",
       "      <td>20.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.002617</td>\n",
       "      <td>0.032819</td>\n",
       "      <td>0.033490</td>\n",
       "      <td>0.033594</td>\n",
       "      <td>0.002068</td>\n",
       "      <td>0.034566</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>107</th>\n",
       "      <td>107</td>\n",
       "      <td>mutinfo.distributions.base.SmoothedUniform</td>\n",
       "      <td>64.0</td>\n",
       "      <td>3</td>\n",
       "      <td>False</td>\n",
       "      <td>64</td>\n",
       "      <td>12.0</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>10000</td>\n",
       "      <td>0.007606</td>\n",
       "      <td>0.073003</td>\n",
       "      <td>0.075130</td>\n",
       "      <td>0.074496</td>\n",
       "      <td>0.003828</td>\n",
       "      <td>0.078095</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>108 rows × 16 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     index                        distribution._target_  \\\n",
       "0        0  mutinfo.distributions.base.CorrelatedNormal   \n",
       "1        1  mutinfo.distributions.base.CorrelatedNormal   \n",
       "2        2  mutinfo.distributions.base.CorrelatedNormal   \n",
       "3        3  mutinfo.distributions.base.CorrelatedNormal   \n",
       "4        4  mutinfo.distributions.base.CorrelatedNormal   \n",
       "..     ...                                          ...   \n",
       "103    103   mutinfo.distributions.base.SmoothedUniform   \n",
       "104    104   mutinfo.distributions.base.SmoothedUniform   \n",
       "105    105   mutinfo.distributions.base.SmoothedUniform   \n",
       "106    106   mutinfo.distributions.base.SmoothedUniform   \n",
       "107    107   mutinfo.distributions.base.SmoothedUniform   \n",
       "\n",
       "     distribution.dimensionality  estimator.projection_dim  \\\n",
       "0                            2.0                         1   \n",
       "1                            3.0                         1   \n",
       "2                            3.0                         2   \n",
       "3                            4.0                         1   \n",
       "4                            4.0                         2   \n",
       "..                           ...                       ...   \n",
       "103                         32.0                         2   \n",
       "104                         32.0                         3   \n",
       "105                         64.0                         1   \n",
       "106                         64.0                         2   \n",
       "107                         64.0                         3   \n",
       "\n",
       "     distribution.randomize_interactions  metaparams.dimensionality  \\\n",
       "0                                  False                          2   \n",
       "1                                  False                          3   \n",
       "2                                  False                          3   \n",
       "3                                  False                          4   \n",
       "4                                  False                          4   \n",
       "..                                   ...                        ...   \n",
       "103                                False                         32   \n",
       "104                                False                         32   \n",
       "105                                False                         64   \n",
       "106                                False                         64   \n",
       "107                                False                         64   \n",
       "\n",
       "     metaparams.mutual_information  n_parameters  n_runs  n_samples  \\\n",
       "0                             18.0             0      10      10000   \n",
       "1                             18.0             0      10      10000   \n",
       "2                             18.0             0      10      10000   \n",
       "3                             18.0             0      10      10000   \n",
       "4                             18.0             0      10      10000   \n",
       "..                             ...           ...     ...        ...   \n",
       "103                           20.0             0      10      10000   \n",
       "104                           12.0             0      10      10000   \n",
       "105                           20.0             0      10      10000   \n",
       "106                           20.0             0      10      10000   \n",
       "107                           12.0             0      10      10000   \n",
       "\n",
       "     mutual_information.half_interquartile_range  \\\n",
       "0                                       0.163460   \n",
       "1                                       0.025755   \n",
       "2                                       0.073933   \n",
       "3                                       0.017996   \n",
       "4                                       0.099018   \n",
       "..                                           ...   \n",
       "103                                     0.003728   \n",
       "104                                     0.006655   \n",
       "105                                     0.002611   \n",
       "106                                     0.002617   \n",
       "107                                     0.007606   \n",
       "\n",
       "     mutual_information.lower_quartile  mutual_information.mean  \\\n",
       "0                             0.618604                 0.678609   \n",
       "1                             0.302578                 0.313052   \n",
       "2                             3.505820                 3.543183   \n",
       "3                             0.170506                 0.182155   \n",
       "4                             1.397434                 1.432004   \n",
       "..                                 ...                      ...   \n",
       "103                           0.072572                 0.072582   \n",
       "104                           0.163044                 0.166856   \n",
       "105                           0.011808                 0.012512   \n",
       "106                           0.032819                 0.033490   \n",
       "107                           0.073003                 0.075130   \n",
       "\n",
       "     mutual_information.median  mutual_information.std  \\\n",
       "0                     0.677802                0.085006   \n",
       "1                     0.316141                0.018217   \n",
       "2                     3.540481                0.044679   \n",
       "3                     0.178388                0.019566   \n",
       "4                     1.438041                0.093515   \n",
       "..                         ...                     ...   \n",
       "103                   0.073855                0.006377   \n",
       "104                   0.165293                0.005204   \n",
       "105                   0.012618                0.001633   \n",
       "106                   0.033594                0.002068   \n",
       "107                   0.074496                0.003828   \n",
       "\n",
       "     mutual_information.upper_quartile  \n",
       "0                             0.757080  \n",
       "1                             0.328161  \n",
       "2                             3.577591  \n",
       "3                             0.187962  \n",
       "4                             1.496436  \n",
       "..                                 ...  \n",
       "103                           0.075183  \n",
       "104                           0.169487  \n",
       "105                           0.013220  \n",
       "106                           0.034566  \n",
       "107                           0.078095  \n",
       "\n",
       "[108 rows x 16 columns]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "saturated_data.reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "6be54f4e-6d2e-489c-934f-9cda65c95b4c",
   "metadata": {},
   "outputs": [],
   "source": [
    "saturated_data.to_csv(\"./saturated_data.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a666fc5-b01a-4b39-a92c-4a4511c6a4d0",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
