{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# imports\n",
    "from tueplots import bundles\n",
    "import wandb\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import MultipleLocator, FormatStrFormatter\n",
    "from tueplots  import figsizes\n",
    "\n",
    "import sys\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "sys.path.insert(0, '.')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "from analysis import sweep2df, format_violin, RED, BLUE"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/Cellar/python@3.9/3.9.6/Frameworks/Python.framework/Versions/3.9/lib/python3.9/_collections_abc.py:940: MatplotlibDeprecationWarning: Support for setting the 'text.latex.preamble' or 'pgf.preamble' rcParam to a list of strings is deprecated since 3.3 and will be removed two minor releases later; set it to a single string instead.\n",
      "  self[key] = other[key]\n"
     ]
    }
   ],
   "source": [
    "plt.rcParams.update(bundles.neurips2022(usetex=True))\n",
    "plt.rcParams.update({\n",
    "    'text.latex.preamble': [r'\\usepackage{amsfonts}', # mathbb\n",
    "                            r'\\usepackage{amsmath}'] # boldsymbol\n",
    "})"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# Constants\n",
    "ENTITY = \"ima-vae\"\n",
    "PROJECT = \"priors\"\n",
    "\n",
    "# W&B API\n",
    "api = wandb.Api(timeout=200)\n",
    "runs = api.runs(ENTITY + \"/\" + PROJECT)"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Data loading"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading sweep with SWEEP_ID='2y77igd1'\n",
      "\t Loading moebius_sweep_2y77igd1.csv...\n",
      "Loading sweep with SWEEP_ID='vtyztyfn'\n",
      "\t Loading moebius_lin_map_sweep_vtyztyfn.csv...\n",
      "Loading sweep with SWEEP_ID='uac6296c'\n",
      "\t Loading moebius_lin_map_sweep_uac6296c.csv...\n",
      "Loading sweep with SWEEP_ID='afkhqbu9'\n",
      "\t Loading ar_flow_sweep_afkhqbu9.csv...\n"
     ]
    }
   ],
   "source": [
    "\"\"\"Moebius gamma ablation\"\"\"\n",
    "SWEEP_ID = \"2y77igd1\"\n",
    "sweep = api.sweep(f\"{ENTITY}/{PROJECT}/{SWEEP_ID}\")\n",
    "filename = f\"moebius_sweep_{SWEEP_ID}.csv\"\n",
    "print(f\"Loading sweep with {SWEEP_ID=}\")\n",
    "moebius_df = sweep2df(sweep.runs, filename, save=True, load=True)\n",
    "\n",
    "moebius_df = moebius_df[moebius_df.gamma_square <= 1e5]\n",
    "\n",
    "\"\"\"Moebius + linear map (20 seeds)\"\"\"\n",
    "SWEEP_ID = \"vtyztyfn\"\n",
    "api = wandb.Api(timeout=200)\n",
    "runs = api.runs(ENTITY + \"/\" + PROJECT)\n",
    "sweep = api.sweep(f\"{ENTITY}/{PROJECT}/{SWEEP_ID}\")\n",
    "print(f\"Loading sweep with {SWEEP_ID=}\")\n",
    "filename = f\"moebius_lin_map_sweep_{SWEEP_ID}.csv\"\n",
    "runs_df1 = sweep2df(sweep.runs, filename, save=True,load=True)\n",
    "\n",
    "\"\"\"Moebius + linear map (80 seeds)\"\"\"\n",
    "SWEEP_ID = \"uac6296c\"\n",
    "sweep = api.sweep(f\"{ENTITY}/{PROJECT}/{SWEEP_ID}\")\n",
    "filename = f\"moebius_lin_map_sweep_{SWEEP_ID}.csv\"\n",
    "print(f\"Loading sweep with {SWEEP_ID=}\")\n",
    "runs_df2 = sweep2df(sweep.runs, filename, save=True,load=True)\n",
    "\n",
    "moebius_lin_map_df = pd.concat([runs_df1, runs_df2]).reset_index(drop=True)\n",
    "\n",
    "\"\"\"AR flow (100 seeds)\"\"\"\n",
    "SWEEP_ID = \"afkhqbu9\"\n",
    "sweep = api.sweep(f\"{ENTITY}/{PROJECT}/{SWEEP_ID}\")\n",
    "filename = f\"ar_flow_sweep_{SWEEP_ID}.csv\"\n",
    "print(f\"Loading sweep with {SWEEP_ID=}\")\n",
    "flow_df = sweep2df(sweep.runs, filename, save=True, load=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Data inspection"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "$$ \\sigma_k^2 (x) = \\left(-n''(\\mu_k^\\phi(x)) + \\gamma^2 \\left\\Vert \\left[ J_f(g(x))\\right]_{:k}\\right\\Vert^2\\right)^{-1} $$"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Moebius $\\gamma$ ablation"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "outputs": [
    {
     "data": {
      "text/plain": "             cima4min_neg_elbo                                          \\\n                         count      mean       std       min       25%   \ngamma_square                                                             \n10.0                      20.0  1.335482  0.564094  0.611589  0.792626   \n100.0                     20.0  1.236132  0.559228  0.450587  0.768593   \n1000.0                    19.0  0.068911  0.139163  0.002055  0.002738   \n10000.0                   18.0  0.001694  0.001008  0.000548  0.000933   \n100000.0                  20.0  0.004486  0.003369  0.000571  0.002154   \n\n                                            \n                   50%       75%       max  \ngamma_square                                \n10.0          1.350295  1.737893  2.397702  \n100.0         1.049250  1.718161  2.334175  \n1000.0        0.004156  0.007729  0.444581  \n10000.0       0.001556  0.002046  0.003893  \n100000.0      0.003660  0.005736  0.012824  ",
      "text/html": "<div>\n<style scoped>\n    .dataframe tbody tr th:only-of-type {\n        vertical-align: middle;\n    }\n\n    .dataframe tbody tr th {\n        vertical-align: top;\n    }\n\n    .dataframe thead tr th {\n        text-align: left;\n    }\n\n    .dataframe thead tr:last-of-type th {\n        text-align: right;\n    }\n</style>\n<table border=\"1\" class=\"dataframe\">\n  <thead>\n    <tr>\n      <th></th>\n      <th colspan=\"8\" halign=\"left\">cima4min_neg_elbo</th>\n    </tr>\n    <tr>\n      <th></th>\n      <th>count</th>\n      <th>mean</th>\n      <th>std</th>\n      <th>min</th>\n      <th>25%</th>\n      <th>50%</th>\n      <th>75%</th>\n      <th>max</th>\n    </tr>\n    <tr>\n      <th>gamma_square</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>10.0</th>\n      <td>20.0</td>\n      <td>1.335482</td>\n      <td>0.564094</td>\n      <td>0.611589</td>\n      <td>0.792626</td>\n      <td>1.350295</td>\n      <td>1.737893</td>\n      <td>2.397702</td>\n    </tr>\n    <tr>\n      <th>100.0</th>\n      <td>20.0</td>\n      <td>1.236132</td>\n      <td>0.559228</td>\n      <td>0.450587</td>\n      <td>0.768593</td>\n      <td>1.049250</td>\n      <td>1.718161</td>\n      <td>2.334175</td>\n    </tr>\n    <tr>\n      <th>1000.0</th>\n      <td>19.0</td>\n      <td>0.068911</td>\n      <td>0.139163</td>\n      <td>0.002055</td>\n      <td>0.002738</td>\n      <td>0.004156</td>\n      <td>0.007729</td>\n      <td>0.444581</td>\n    </tr>\n    <tr>\n      <th>10000.0</th>\n      <td>18.0</td>\n      <td>0.001694</td>\n      <td>0.001008</td>\n      <td>0.000548</td>\n      <td>0.000933</td>\n      <td>0.001556</td>\n      <td>0.002046</td>\n      <td>0.003893</td>\n    </tr>\n    <tr>\n      <th>100000.0</th>\n      <td>20.0</td>\n      <td>0.004486</td>\n      <td>0.003369</td>\n      <td>0.000571</td>\n      <td>0.002154</td>\n      <td>0.003660</td>\n      <td>0.005736</td>\n      <td>0.012824</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 147,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "moebius_df[[\"cima4min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "outputs": [
    {
     "data": {
      "text/plain": "             mcc4min_neg_elbo                                          \\\n                        count      mean       std       min       25%   \ngamma_square                                                            \n10.0                     20.0  0.152054  0.002594  0.145711  0.150620   \n100.0                    20.0  0.150781  0.003009  0.144056  0.149297   \n1000.0                   19.0  0.711884  0.095085  0.529063  0.738003   \n10000.0                  18.0  0.960569  0.008208  0.945257  0.954324   \n100000.0                 20.0  0.960279  0.008393  0.945410  0.954748   \n\n                                            \n                   50%       75%       max  \ngamma_square                                \n10.0          0.151827  0.153587  0.156768  \n100.0         0.150826  0.152549  0.156737  \n1000.0        0.758195  0.764575  0.773091  \n10000.0       0.960455  0.967798  0.972966  \n100000.0      0.960646  0.965914  0.977027  ",
      "text/html": "<div>\n<style scoped>\n    .dataframe tbody tr th:only-of-type {\n        vertical-align: middle;\n    }\n\n    .dataframe tbody tr th {\n        vertical-align: top;\n    }\n\n    .dataframe thead tr th {\n        text-align: left;\n    }\n\n    .dataframe thead tr:last-of-type th {\n        text-align: right;\n    }\n</style>\n<table border=\"1\" class=\"dataframe\">\n  <thead>\n    <tr>\n      <th></th>\n      <th colspan=\"8\" halign=\"left\">mcc4min_neg_elbo</th>\n    </tr>\n    <tr>\n      <th></th>\n      <th>count</th>\n      <th>mean</th>\n      <th>std</th>\n      <th>min</th>\n      <th>25%</th>\n      <th>50%</th>\n      <th>75%</th>\n      <th>max</th>\n    </tr>\n    <tr>\n      <th>gamma_square</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>10.0</th>\n      <td>20.0</td>\n      <td>0.152054</td>\n      <td>0.002594</td>\n      <td>0.145711</td>\n      <td>0.150620</td>\n      <td>0.151827</td>\n      <td>0.153587</td>\n      <td>0.156768</td>\n    </tr>\n    <tr>\n      <th>100.0</th>\n      <td>20.0</td>\n      <td>0.150781</td>\n      <td>0.003009</td>\n      <td>0.144056</td>\n      <td>0.149297</td>\n      <td>0.150826</td>\n      <td>0.152549</td>\n      <td>0.156737</td>\n    </tr>\n    <tr>\n      <th>1000.0</th>\n      <td>19.0</td>\n      <td>0.711884</td>\n      <td>0.095085</td>\n      <td>0.529063</td>\n      <td>0.738003</td>\n      <td>0.758195</td>\n      <td>0.764575</td>\n      <td>0.773091</td>\n    </tr>\n    <tr>\n      <th>10000.0</th>\n      <td>18.0</td>\n      <td>0.960569</td>\n      <td>0.008208</td>\n      <td>0.945257</td>\n      <td>0.954324</td>\n      <td>0.960455</td>\n      <td>0.967798</td>\n      <td>0.972966</td>\n    </tr>\n    <tr>\n      <th>100000.0</th>\n      <td>20.0</td>\n      <td>0.960279</td>\n      <td>0.008393</td>\n      <td>0.945410</td>\n      <td>0.954748</td>\n      <td>0.960646</td>\n      <td>0.965914</td>\n      <td>0.977027</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "moebius_df[[\"mcc4min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "outputs": [
    {
     "data": {
      "text/plain": "             min_neg_elbo                                                    \\\n                    count      mean       std       min       25%       50%   \ngamma_square                                                                  \n10.0                 20.0 -0.631330  0.001146 -0.633572 -0.632227 -0.631218   \n100.0                20.0 -3.733695  0.001176 -3.736262 -3.734592 -3.733493   \n1000.0               19.0 -4.696911  0.014440 -4.711015 -4.707474 -4.705772   \n10000.0              18.0 -4.745679  0.116238 -4.889962 -4.827169 -4.769033   \n100000.0             20.0 -3.961198  0.287607 -4.266053 -4.183210 -4.077030   \n\n                                  \n                   75%       max  \ngamma_square                      \n10.0         -0.630326 -0.629624  \n100.0        -3.732953 -3.731812  \n1000.0       -4.687442 -4.660370  \n10000.0      -4.670219 -4.476871  \n100000.0     -3.825058 -3.312922  ",
      "text/html": "<div>\n<style scoped>\n    .dataframe tbody tr th:only-of-type {\n        vertical-align: middle;\n    }\n\n    .dataframe tbody tr th {\n        vertical-align: top;\n    }\n\n    .dataframe thead tr th {\n        text-align: left;\n    }\n\n    .dataframe thead tr:last-of-type th {\n        text-align: right;\n    }\n</style>\n<table border=\"1\" class=\"dataframe\">\n  <thead>\n    <tr>\n      <th></th>\n      <th colspan=\"8\" halign=\"left\">min_neg_elbo</th>\n    </tr>\n    <tr>\n      <th></th>\n      <th>count</th>\n      <th>mean</th>\n      <th>std</th>\n      <th>min</th>\n      <th>25%</th>\n      <th>50%</th>\n      <th>75%</th>\n      <th>max</th>\n    </tr>\n    <tr>\n      <th>gamma_square</th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n      <th></th>\n    </tr>\n  </thead>\n  <tbody>\n    <tr>\n      <th>10.0</th>\n      <td>20.0</td>\n      <td>-0.631330</td>\n      <td>0.001146</td>\n      <td>-0.633572</td>\n      <td>-0.632227</td>\n      <td>-0.631218</td>\n      <td>-0.630326</td>\n      <td>-0.629624</td>\n    </tr>\n    <tr>\n      <th>100.0</th>\n      <td>20.0</td>\n      <td>-3.733695</td>\n      <td>0.001176</td>\n      <td>-3.736262</td>\n      <td>-3.734592</td>\n      <td>-3.733493</td>\n      <td>-3.732953</td>\n      <td>-3.731812</td>\n    </tr>\n    <tr>\n      <th>1000.0</th>\n      <td>19.0</td>\n      <td>-4.696911</td>\n      <td>0.014440</td>\n      <td>-4.711015</td>\n      <td>-4.707474</td>\n      <td>-4.705772</td>\n      <td>-4.687442</td>\n      <td>-4.660370</td>\n    </tr>\n    <tr>\n      <th>10000.0</th>\n      <td>18.0</td>\n      <td>-4.745679</td>\n      <td>0.116238</td>\n      <td>-4.889962</td>\n      <td>-4.827169</td>\n      <td>-4.769033</td>\n      <td>-4.670219</td>\n      <td>-4.476871</td>\n    </tr>\n    <tr>\n      <th>100000.0</th>\n      <td>20.0</td>\n      <td>-3.961198</td>\n      <td>0.287607</td>\n      <td>-4.266053</td>\n      <td>-4.183210</td>\n      <td>-4.077030</td>\n      <td>-3.825058</td>\n      <td>-3.312922</td>\n    </tr>\n  </tbody>\n</table>\n</div>"
     },
     "execution_count": 149,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "moebius_df[[\"min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Moebius + linear map and AR Flows"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [
    {
     "data": {
      "text/plain": "(<AxesSubplot:>, <AxesSubplot:>)"
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 396x244.741 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "moebius_lin_map_df.mixing_linear_map_cima.hist(), flow_df.mixing_cima.hist()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Data pre-processing"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Moebius $\\gamma$ ablation"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [],
   "source": [
    "# if we need to filter outliers, use this\n",
    "# \"max\" means no filtering is done\n",
    "elbo_filter = moebius_df[[\"neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\").describe()['neg_elbo']['max']\n",
    "groups = [g for _, g in moebius_df[[\"neg_elbo\", \"mcc4min_neg_elbo\", \"cima4min_neg_elbo\", \"gamma_square\"]].groupby(\"gamma_square\")]\n",
    "\n",
    "# filter metrics based on ELBO threshold (if applicabble)\n",
    "gg_mcc = [g[g.neg_elbo <= threshold].mcc4min_neg_elbo  for g, threshold in zip(groups, elbo_filter)]\n",
    "gg_cima = [g[g.neg_elbo <= threshold].cima4min_neg_elbo  for g, threshold in zip(groups, elbo_filter)]\n",
    "gg_gamma = [g[g.neg_elbo <= threshold].gamma_square  for g, threshold in zip(groups, elbo_filter)]"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Moebius + linear map and AR Flows"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [],
   "source": [
    "\"\"\"Data for Mobius with linear maps\"\"\"\n",
    "# get quartiles\n",
    "quartile_bins = moebius_lin_map_df.mixing_linear_map_cima.describe()[[\"min\", \"25%\", \"50%\", \"75%\", \"max\"]].tolist()\n",
    "\n",
    "NUM_BINS = 6 #len(quartile_bins)\n",
    "\n",
    "# create a log set of bins\n",
    "bins = np.logspace( np.log10(moebius_lin_map_df.mixing_linear_map_cima.min()-1e-8), np.log10(moebius_lin_map_df.mixing_linear_map_cima.max()+1e-8), NUM_BINS)\n",
    "logbins = sorted(np.log10(bins))\n",
    "binned_cima = pd.cut(moebius_lin_map_df.mixing_linear_map_cima, bins=bins, labels=list(range(NUM_BINS-1)), retbins=False, right=True, include_lowest=True)\n",
    "moebius_lin_map_groups = [moebius_lin_map_df.mcc4min_neg_elbo[binned_cima==label] for label in list(range(NUM_BINS-1))]"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Plot"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Moebius"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 243,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/rb/d8k1n6bj4lg801y0yxz4jtbh0000gn/T/ipykernel_75992/4083792918.py:40: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([0] + sorted(np.log10(moebius_df[\"gamma_square\"]).astype(int).unique()))\n",
      "/var/folders/rb/d8k1n6bj4lg801y0yxz4jtbh0000gn/T/ipykernel_75992/4083792918.py:59: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels( xticklabels)\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 396x122.371 with 4 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# to make the grid behind both plots: https://stackoverflow.com/a/55618417/16912032\n",
    "\n",
    "LABELPAD = 2\n",
    "TICK_PADDING = 2\n",
    "\n",
    "fig = plt.figure(figsize=figsizes.neurips2022(nrows=1, ncols=2)['figure.figsize'])\n",
    "\n",
    "\n",
    "\"\"\"MCC vs CIMA over different gamma\"\"\"\n",
    "ax = fig.add_subplot(121)\n",
    "ax.grid(True, which=\"both\", ls=\"-.\")\n",
    "\n",
    "# create double y-axis\n",
    "ax_cima = ax.twinx()\n",
    "ax_mcc = ax.twinx()\n",
    "\n",
    "# Link the respective y-axes for grid and plot\n",
    "ax.get_shared_y_axes().join(ax, ax_mcc)\n",
    "\n",
    "# Remove ticks and labels and set which side to label\n",
    "ticksoff = dict(labelleft=False, labelright=False, left=False, right=False)\n",
    "ax.tick_params(axis=\"y\", **ticksoff)\n",
    "ax_mcc.tick_params(axis=\"y\", labelleft=True, labelright=False, left=True, right=False)\n",
    "ax_cima.tick_params(axis=\"y\", labelleft=False, labelright=True, left=False, right=True)\n",
    "\n",
    "\n",
    "# MCC\n",
    "vp= ax_mcc.violinplot(gg_mcc, showmedians=True)\n",
    "format_violin(vp,BLUE)\n",
    "# CIMA\n",
    "# ax2.set_axisbelow(True)\n",
    "vp2= ax_cima.violinplot([np.log10(g) for g in gg_cima], showmedians=True)\n",
    "format_violin(vp2, RED)\n",
    "\n",
    "\n",
    "ax_cima.set_ylabel(\"$\\log_{10}c_{\\mathrm{IMA}}$\", labelpad=LABELPAD)\n",
    "ax.set_ylabel(\"$\\mathrm{MCC}$\", labelpad=LABELPAD+17)\n",
    "\n",
    "ax.set_xlabel(\"$\\log_{10}\\gamma^2$\", labelpad=LABELPAD)\n",
    "ax.set_xticklabels([0] + sorted(np.log10(moebius_df[\"gamma_square\"]).astype(int).unique()))\n",
    "\n",
    "\n",
    "\n",
    "plt.legend([vp['bodies'][0], vp2['bodies'][0]], [\"$\\mathrm{MCC}$\", \"$\\log_{10}c_{\\mathrm{IMA}}$\"], loc='center left')\n",
    "\n",
    "\n",
    "\"\"\"MCC vs the mixing lin map's CIMA\"\"\"\n",
    "ax = fig.add_subplot(122)\n",
    "ax.grid(True, which=\"both\", ls=\"-.\")\n",
    "ax.set_axisbelow(True)\n",
    "\n",
    "vp = plt.violinplot(moebius_lin_map_groups, showmedians=True)\n",
    "format_violin(vp)\n",
    "\n",
    "ax.set_ylabel(\"$\\mathrm{MCC}$\", labelpad=LABELPAD)\n",
    "ax.set_xlabel(\"$\\log_{10}c_{\\mathrm{IMA}}$\", labelpad=LABELPAD)\n",
    "\n",
    "xticklabels = [0]+ [f\"$[{logbins[0]:.2f};{logbins[1]:.2f})$\"]+ [f\"$<{logbins[i]:.2f}$\" for i in range(2,NUM_BINS-1)] +[f\"$[{logbins[-2]:.2f};{logbins[-1]:.2f}]$\"]\n",
    "ax.set_xticklabels( xticklabels)\n",
    "# plt.legend()\n",
    "ax.tick_params(axis='both', which='major', pad=TICK_PADDING)\n",
    "plt.legend([vp['bodies'][0],], [\"$\\mathrm{MCC}$\"], loc='lower left')\n",
    "\n",
    "plt.savefig(\"moebius_mcc_cima.svg\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "set_size_inches() missing 1 required positional argument: 'w'",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mTypeError\u001B[0m                                 Traceback (most recent call last)",
      "\u001B[0;32m/var/folders/rb/d8k1n6bj4lg801y0yxz4jtbh0000gn/T/ipykernel_75992/1593343479.py\u001B[0m in \u001B[0;36m<module>\u001B[0;34m\u001B[0m\n\u001B[0;32m----> 1\u001B[0;31m \u001B[0max\u001B[0m\u001B[0;34m.\u001B[0m\u001B[0mfigure\u001B[0m\u001B[0;34m.\u001B[0m\u001B[0mset_size_inches\u001B[0m\u001B[0;34m(\u001B[0m\u001B[0;34m)\u001B[0m\u001B[0;34m\u001B[0m\u001B[0;34m\u001B[0m\u001B[0m\n\u001B[0m",
      "\u001B[0;31mTypeError\u001B[0m: set_size_inches() missing 1 required positional argument: 'w'"
     ]
    }
   ],
   "source": [],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 396x244.741 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "quartile_bins = flow_df.mixing_cima.describe()[[\"min\", \"25%\", \"50%\", \"75%\", \"max\"]].tolist()\n",
    "NUM_BINS = 10#len(quartile_bins)\n",
    "bins = np.logspace( np.log10(flow_df.mixing_cima.min()-1e-8), np.log10(flow_df.mixing_cima.max()+1e-8), NUM_BINS, base=5)\n",
    "binned_cima = pd.cut(flow_df.mixing_cima, bins=bins, labels=list(range(NUM_BINS-1)), retbins=False, right=True, include_lowest=True)\n",
    "\n",
    "groups = [flow_df.mcc4min_neg_elbo[binned_cima==label] for label in list(range(NUM_BINS-1)) if len(flow_df.mcc4min_neg_elbo[binned_cima==label])>0]\n",
    "vp = plt.violinplot(groups, showmedians=True)\n",
    "format_violin(vp)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## ELBO, IMA, log-likelihood"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### Triangular MLP"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [],
   "source": [
    "elbo= np.load(\"elbo_gap_data_full_seeds.npy\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "outputs": [],
   "source": [
    "log_gamma_sq = np.array([1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0])\n",
    "LOG_LIKELIHOOD = 14.851245309530446\n",
    "IMA_REG_LOG_LIKELIHOOD = 7.779079986965633\n",
    "GLOBAL_CIMA = LOG_LIKELIHOOD-IMA_REG_LOG_LIKELIHOOD"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [
    {
     "data": {
      "text/plain": "7.072165322564813"
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "GLOBAL_CIMA"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [],
   "source": [
    "import tueplots\n",
    "plt.rcParams.update( tueplots.fontsizes.neurips2022())"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 257,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/rb/d8k1n6bj4lg801y0yxz4jtbh0000gn/T/ipykernel_75992/2850137678.py:28: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels(range(log_gamma_sq[0].astype(int),log_gamma_sq[-1].astype(int)))\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 396x143.966 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "LABELPAD = 1\n",
    "TICK_PADDING = 2\n",
    "STD_FACTOR = 3\n",
    "# plt.rcParams.update(figsizes.neurips2022(nrows=1, ncols=1))\n",
    "fig = plt.figure(figsize=figsizes.neurips2022(nrows=1, ncols=1.7, rel_width=1)['figure.figsize'])\n",
    "\n",
    "\"\"\"MCC vs CIMA over different gamma\"\"\"\n",
    "ax = fig.add_subplot(121)\n",
    "ax.grid(True, which=\"major\", ls=\"-.\")\n",
    "ax.set_axisbelow(True)\n",
    "\n",
    "ima_elbo = IMA_REG_LOG_LIKELIHOOD - elbo\n",
    "log_likelihood_elbo = LOG_LIKELIHOOD - elbo\n",
    "for i in range(0,len(log_gamma_sq),2):\n",
    "    l = ax.vlines(log_gamma_sq[i], ima_elbo.mean(0)[i], log_likelihood_elbo.mean(0)[i], colors=\"black\", linestyle=\"--\", label=None if i != 0 else r\"$C_{\\mathrm{IMA}}$\")\n",
    "\n",
    "# L_IMA - ELBO\n",
    "ax.plot(log_gamma_sq, ima_elbo.mean(0),  label=r\"$\\mathbb{E}_{p(\\boldsymbol{x})}[\\mathcal{L}_{\\mathrm{IMA}}-\\mathrm{ELBO}^*]$\", c=BLUE)\n",
    "# Log-likelihood - ELBO\n",
    "ax.plot(log_gamma_sq, log_likelihood_elbo.mean(0),  label=r\"$\\mathbb{E}_{p(\\boldsymbol{x})}[\\log p_{\\boldsymbol{\\theta}}(\\boldsymbol{x})-\\mathrm{ELBO}^*]$\", c=RED)\n",
    "\n",
    "# ax.plot(log_gamma_sq, GLOBAL_CIMA * np.ones_like(log_gamma_sq), label=r\"$C_{\\mathrm{IMA}}$\", c=\"black\", linestyle=\"--\")\n",
    "\n",
    "ax.set_ylabel(r\"$\\mathrm{ELBO}^*\\ \\mathrm{Gap}$\", labelpad=LABELPAD)\n",
    "ax.set_xlabel(r\"$\\log_{10}\\gamma^2$\", labelpad=LABELPAD)\n",
    "plt.legend()\n",
    "\n",
    "ax.set_xticklabels(range(log_gamma_sq[0].astype(int),log_gamma_sq[-1].astype(int)))\n",
    "\n",
    "\n",
    "# Make a plot with major ticks that are multiples of 20 and minor ticks that\n",
    "# are multiples of 5.  Label major ticks with '%d' formatting but don't label\n",
    "# minor ticks.\n",
    "ax.xaxis.set_major_locator(MultipleLocator(1))\n",
    "ax.xaxis.set_major_formatter(FormatStrFormatter('%d'))\n",
    "# For the minor ticks, use no labels; default NullFormatter.\n",
    "ax.xaxis.set_minor_locator(MultipleLocator(0.5))\n",
    "\n",
    "\n",
    "plt.savefig(\"ima_elbo_likelihood.svg\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 226,
   "outputs": [
    {
     "data": {
      "text/plain": "(array([4.18749310e-05, 2.62954786e-04, 6.60705750e-04, 1.72489779e-03,\n        2.20550174e-03, 3.34985192e-03, 2.23306660e-02, 2.03566935e-02,\n        2.14185868e-02]),\n array([4.18749310e-05, 2.62954786e-04, 6.60705750e-04, 1.72489779e-03,\n        2.20550174e-03, 3.34985192e-03, 2.23306660e-02, 2.03566935e-02,\n        2.14185868e-02]))"
     },
     "execution_count": 226,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# error bars\n",
    "ima_elbo.std(0),log_likelihood_elbo.std(0)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "### IMA class"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [],
   "source": [
    "elbo= np.load(\"elbo_gap_ima_class.npy\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "outputs": [],
   "source": [
    "log_gamma_sq = np.array([1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0])\n",
    "LOG_LIKELIHOOD = 0.3921541939735914\n",
    "IMA_REG_LOG_LIKELIHOOD = 0.3921541939735914\n",
    "GLOBAL_CIMA = LOG_LIKELIHOOD-IMA_REG_LOG_LIKELIHOOD"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/rb/d8k1n6bj4lg801y0yxz4jtbh0000gn/T/ipykernel_69018/404887574.py:28: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels(range(log_gamma_sq[0].astype(int),log_gamma_sq[-1].astype(int)))\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 396x143.966 with 1 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAOIAAACYCAYAAAD5qTVwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAjJElEQVR4nO2de3iU1b3vPyv3OyEhBEgCZBAEwi1XiFBFmUipuO3uDtjWS9ttDbXtY92tJtp9nu7d9hwr2W7b2u1pEz2np0q7q4naVqWtjIhUi5ALd6JgJigBuSSTyf0+6/wxF2Ymk7kkk5k3w/t5nnlm3vWutd7vXH6z3vddv9/6CSklKioqwSUs2AJUVFRUQ1RRUQSqIaqoKADVEFVUFIBqiCoqCkA1RBUVBRARbAHeMmvWLLlw4cJx9w8NDREVFRU4QT6idH2gfI3TXV9DQ0OblDLN5U4p5bR45OfnS3e8/fbbbvcHG6Xrk1L5Gqe7PqBejvP7Vk9NVVQUwLQ5Nb1WGB4eprW1lYGBgYAfe8aMGTQ1NQX8uN4yHfXNnTuX5ORkj22nvSFKCd94RZITtYyNwRbjhtWrV3tVr7W1lcTERBYuXIgQYopVOTIyMkJEhHJ/EtNNX39/P+fPn/fKEP1yaiqESBZClFoeyU77yoQQWstrjRCiRghR5qmd98cG7Q/vJqv8gcm+jSmlu7vbq3oDAwOkpqYG3AgBRkdHva5bW1s7hUpc44s+f6DT6TAajV7Xd9YXExPD8PCwV239dY34mJSyFtABZU776oFku+37pZTVXrTzmrAli8nQH6W/d3CiXUw5MTExXtedKiOsrq6msrISnU7Hjh07xvzIwsK8/znY/8s3NjZSXV3Njh07/KTUNVZ9er2e/Px8dDodOp2OiooKW5ler7fVd65XXV1t21dbW2srt/6pGI1G2+cDoNVqqa+v91mfFV++R3+N8xq714vc1DMAGiGEBmj01M4ycpYBzJs3j3379jnsnzNnDtnZ2YzmZBP96iCvPlPLvKIMhzrFxcW0tLSQmZnJpUuXOHfunMP+jIwMMjMzaWlpYcmSJbz77rtjRG/YsIHTp0+TnZ1Na2sr58+fd9iflZVFeno6ra2tZGdnc+DAgTF9LFmyhOPHj7NkyRJaWlq4ePGiw/6FCxeSkpLC8PAwJpOJ3t7eMX0kJibS19dHbGwsAwMDjIyMOOyPiooiPDyckZERIiMj6evrc9i/bNkyBgcHuXjxIuXl5URFRTmM1NY7eEIITCYTERERY/oQQpCQkGC7hu3r6+ONN97goYceYt26dXR3dxMdHW3rIzw8nP7+fpd99Pb2Eh8fT29vLyaTyaFOTEwM0hIZJIRgYGAAKSUDAwOkpaUxf/58tFotr7/+Ojt27CA9PZ358+eTlpZme09ZWVnk5uZy4403cuTIEZqamuju7ubIkSNcuHCBLVu2EB8fz65du6itrWXdunXExMTQ19dn62N0dJTBwUHCwsKQUjI46PhnHx4eTlxcHL29vURGRtLT02PTDeYznK6uLgwGw5jv0x5/GaLe7nWzm3oFUkqd5Z+i1FM7y8hZDVBQUCA3btzostObvnYbF//nvxL3SScby+8as3/p0qUAJCQksGiR6/+J5cuXAzDeMaz7Fy9ezOLFi13WsR7HVR/79u2zlS9dutRW15nIyEjCwsL4j/cTOXXJVY04y3Osy/YAy9Mj+FGJ2XDtiY+PZ3BwkAsXLiCEIC4uzmF/d3c3UVFR6HQ6tFotcLUP60ij0Zj/O60j/K5du7jrrrtITExk1apVgHmErKqqoqKigoqKCmpqagDYtm0bzz77rG00/e53v0tVVRXx8fHjvhf7z6W7u9ump6enB51Ox4ULF9i6dSsAERERY95zZ2cnJ06coKuri/Xr15OYmMiBAwfIy8uzHfeGG26gqqqK0tJSHnzwQYf24eHhREdH27bHmyeMj4930GclJiaGpKQkkpKS3L4/fxlilRCi1PK6GkAIoZVS6gAtkCqE0AF6IUQeUGCpl+LcbiKkL5zF4bRsTAcPAd+c8Ju4FkhJSaG8vBwwG5fRaOTFF1+kpKSE2bNnM3/+fNspq06nQ6/X09DQQHJyMoWFhTZDtNLQ0EBZmeNVRV5eHosWLUKj0aDRaGxGXFhYaDPCxsZGkpOT0ev1Y/qEsdegWq2W8PBw23ZycrLtz6K2tpbS0lKH+tY/k5SUFPLy8gDzH0FpaSl5eXkOp7CNjY0UFhZ69flNFX4xRCmlHsfRDYsRIqWstCs2Wp4b7bYd2k2Uuju+zgemTD4vISzw9zn8zo9K/N9nfX09RqMRg8HAnj17KCkpQavVotPpSElJobOzE71eb/vhFhQU2Npu376dl156yaG/xkbz11hRUUFqaioajWaMQdx5550uDaW+vp7CwkKqqqrYuXPnGK3O9eHqDS+9Xo9er7ddy+3Zs8dmXDqdjsbGRtsfQH19ve2mS0mJ+UPVarW2a0QAg8Ew5s8k0Cj3XrCvbCpi30fL+PAKLJsdbDHKxP7HZh1NrKOfXq9n8+bNjI6OUl9fj0aj4aWXXqK52XzFYP3R2pOXl0dVVdWYcr1eT3Nzs80QrKNgc3MzRqMRvV5PSkoKpaWlVFVVjTsqjodGo6GhoWHMe7GWWbfty5xxZehBZTyXG6U9PLm4/eW9k3LjA43y97874bZesDhy5IhX9U6dOjXFShypqamRDQ0NUkope3t7bWXOdHR02OpJKWV5eXlgBNph1Rco9uzZI/fs2eN1fVf67L9P3Li4CTlN1qwpKCiQ7m4lm0yS/bMKaF+xjn/a/0wAlfmXpqYmli1bFmwZKn7C/vsUQjRIKQtc1QsZX9PDhxtpX7GWlBMHMZmU9+cy3imSknA1ZaIkQllfyBhifn4+0TcUkdJ5kY+Pn/PcIMDk5+cHW4JHvJlGCCahrC9kDPHAgQNkf7YIgA/fOBRkNWNxNcmvNHp6eoItwS2hrC9kDHFwcJCln1lKT+wMet5VniE6e2QoEV/uFwTD11Tp9zP27t3rk2+qPSFjiADh4WG88m81/GrzvwdbiiLx5GvqC8nJyWP8N/2FdZ5wvH3W+Utf+guEb+rNN9/sk2+qPaEzj2hBs2E5v38b2nshVdmXFB756Jaxc13J225n1gNfwdTXj37rPWP2p9y7nZSvbnfZX0FBAQaDAaPRSEVFhVfhOe4oKCiwGY3VOLRaLQaDgcbGRurq6rjzzjttDgJW17dt27ZhNBrHncvT6XSUlZXR2NhIfX09NTU1lJSUEBMTw4MPPkh1dbWtT2+wevhYnRd27NhhK7Ofv9RoNBQUFKDVamlsbGTPnj023QaDwaa3traW2tpatFrtpD9DKyE1IgIUzejiXl0lR/5wMNhSFMt4o40VV5P37kYpq59maWkp1dXVDr6q9gaj0Whsrml1dXUAVFZWUllZ6dB3SkqK7XVZWRl6vZ7S0lKsaxZpNBqfR3Oj0Whz2XPnPGD9EzEYDDa3N51O59AmLy+Puro6kpOTKSsrc3AgmCghMyJav/BV2THI96o4l9oPd60Nsqqr+PIPbuW6veNfh4XFxbrdPx7ufE0XLFjA6OioT76mzjQ3N7Njxw50Ot0Y/0370cNoNFJbW0tzczPJyckObmnWegaDwcHZ3Brvl5KSQn19vYMBuPJNtT9eIHxTnZ3ofcEvhmgJ6rV+KjoppdFuXxmgl+aoCw3m2EQtFqdvYCewR16NUZwQBoOBpKQkomOj+PS6XGIalXXDxqovmHjyNW1vb6e7u9trX1OrkVZUVNgMoaKiAqPRSF1dHYsWLcJoNNoMwvpjrq2tpaKiwhahUVVVZTumRqOxjciNjY02A62urmbVqlUsXrzYwR/WijuXtUD5pjqHpfnEeC43vjyAnZbnZKDcaV8eUGp5XWpXVoY5HjHZm2N4cnG7cuWK7fXL91bKhoj5squ9x22bQGKvzx2BdnHr6OiQO3fulDU1NXJoaEh2dHTY3LqqqqpkeXm5LC8vlzU1NbKqqsrWzp3rl7WetW8r9u50UkrZ0NAgq6qqHPq1b+/M0NCQ2/3BZmhoaMzn4q2LW0ADg6U5Gh/MI2ItToHC0hzFYcPbwODTp08zc+ZM2/7e7FmEm0b5wy9q2P7olxQRGHzdddcFPTDY2kdvby9xcXH09/fz2muvUVxczJo1a+jv7ycuLo62tjYGBwe57777bH0YjUbOnj1LT08PCQkJ7N69G61WS19f35glIrKysjh06BBtbW2sXr3aFjWxe/duvva1r9n6uP7668nLy6O3t9chQHndunUcOnSINWvWAI6BwU1NTaxbt84hqNiX4GJ7wsLCHPpwDuoFiI2NZXR01KvA4P379zMyMuLwXrwNDA7oiGjZ1mIZCQGtXZ1yd8fwZV3Tzstd8m/xy+UL3x/rvBwsvF2TM9Ajoj1dXV1BO7Y3TEd9gR4RvQ0MLgAqMMcg7gEanQKF/UJSWiKP/+w4cTFh3O2vTlVUppBABwbrLA9nfJuh9YKCBWH89jAMjUJUuOf6SqK/v5+YmJigrOSm4j98WXUuZKYvnNnQc5K8n32H48sqyb/d96mDYDF37lzOnz/v9TJ8/mRgYMCn1eYCzXTUZz8n6o6QMcTU1FSH7VWrZ3Pp0gecffOgIgzRWd94JCcn+81bw1eOHz+u6FjIUNYXMp41OTk5DttzNGlcmq1h9KAy5hOd9SkRpWsMZX0hY4hHjhwZU9a1uoj0U4cYHTWNbRBgXOlTGkrXGMr6vDZEIUS2EOIlIcSLQoiFEz7iFOHKhSxhw1oS+jv58L3TQVDkyERc3AKN0jWGsj5fRsRSzFMPj1peKwpXE/FLbl/HvpV3cPyiiwYBxpU+paF0jaGszxdDbJBStkgpW7BMQQghgus8aYcrP7/sVVk8/8/PsD/K9aragWRSfogBQukaQ1mfL3dNHxVCbAMEZrc0PZANbJ7w0acYIaAoU3Lm2AXkHRmo03IqSsUXQ9wppXzLvkAIscnPevzOliO/Z8H/eoSP//F9Fq7MDLYcFRWXeH1qam+EQog1zmVKRbPRnCD0wzfUQGEV5eLLXdMkIcQTQogXgalNhDcB7GPn7Fn6mevpjUmie39w5xPH06cklK4xlPX5cmpaBlThGPIE+BQY7FDP8uyyna9cunSJhISEMeURkeFcWlpA4tHgGuJ4+pSE0jWGsj5f7pq2YDbCUmCG0z5vMwY71/NLxmBw79Mn1hYx5+IZrnziISZsCvHW5zCYKF1jKOvzekSUUr4shMjGHNDrPCp6mzHYuV6K07YDvgQGJyUlcfTo0TEHLC4uRty4hp2G/+KzpzqYrz/msD9QgcHWtp4Cgy9dukRmZiYHDzpe0wohuOmmmzh69Cg5OTmcPn2ay5cvO9TRaDQkJiZiMBhIT08fs7RfREQEGzZsoLGxkTVr1nDy5Ena29tt+4eGhsjJySE6Opqenh5SUlLGLF0YHR1NcXExDQ0N5Ofnc/ToUTo6OhzqXH/99YSHhzMwMEBiYuKY7yU2Npa1a9fa+mhsbKSrq8uhzvLlyxkdHcVkMhEdHc2JEycYGhqyJQpNSEigoKDA1kd9ff2YBX5XrFhhy/YbHh7OqVOnHPYnJSWRl5dn6+PgwYNjshtbA5tjYmIYHR3lww8/dNg/c+ZMVq9eTUNDA2lpaXzwwQdjgofz8vImFxgMJFkflu0v2G9LHwODneu5a+f88CUw2JmBYSmzn5Dy371P7ON3vA0MDiZK1zjd9eEmMNjTqekO4DGujlzfB2oA54UzrYHB1kWhEEJYr/20QKHl+tC53ph2U0F0BGwK0zPw8h+n6hAqKpPC06lpo3ScorhfSnnYef5Q+pYxWO9me8rYcqyGBb//Jd2Pl5A4c+LL3qmoTAWeRkSHlXSklIddlU8HZt9SRIRphGO7/b4YgIrKpPFkiOPlElNcjrHZs93n6165tYBREcalt4Izse9JnxJQusZQ1ufp1LRaCPEm0Gx5XIfZv3TbhI84RSxZssTt/hlpiVzMXE5YXXDmEz3pUwJK1xjK+tyOiFLKTinlrZjn+QRQI6XcLKXsctcuGJw8edJjnf68ItKbjzI0GHgvfm/0BRulawxlfUIqPOeclYKCAjnRlFdWdv/tCg/uieGlHYnkZfhJmIqKlwghGqSULv3gQmapjHfeecdjncLcNPpjEjkUhMze3ugLNkrXGMr6QsYQvRnZ0xLgnpMvIJ76zwAocmQ6nHkoXWMo6wsZQ/SWwitHyPnzrxWxoJSKihW3hmhZMOonSlwsaqLEf6aIxD4jp/9+JthSVFRseBoRNZidsd1np5xGLN5SBID+L8pY71RFBTzcNRVCWMOdZLCnLDzdNe3v7yc2NtZjPyaT5G8p+VzJXU/p27/wp0S3eKsvmChd43TXN+G7plLKTszubHcKIX4phHjY1cptQohkIUSp5ZE8XrnluUYIUSWEKBNCaCzbk4pFBGhtbfWqXliY4GLeTbT1BXYlKW/1BROlawxlfR6vEYHnLJs6oBOosa5ZY8d4Ab7O5Xop5TbM6bqteaDvl5NM2w2Qnp7udd3enT/lx3c8TWvnZI/qPb7oCxZK1xjK+jxdI26SUm6XUj4rpXzZ8rwZcz5De8YLDHYol1JaPa410rwshjVjcKkla/CE8Rh4aUfRfPPzoU8CdzvcF33BQukaQ1mfJ1/T8UKUnMvtt5vdlVviD60GWSDNa9mAeQkO+5ApnyL029raOHv27BihxcXFY1J3myQ88f9+Sddb8zjzq28GJEJfSkl3d7eiI/R7enqIjIxUbIR+T0+P7TtWYoR+d3c3n3766ZRE6N8/TvkjTtvWtWxKgWTpmKLbubzc7rUGcwR/mbVsvMdkIvRd8Uru3fLPGTf71GYyKD26XErla5zu+phE6u6XLNEXDUA7V6MvHJZTlG4Cg12UVzq1gynIGOwJUVTE3Gd3cuVcB2lZMwN9eBUVB7yNvqjHHH2xR5qjL84GQtxUklFink88+bo6n6gSfLxycZPmGzX/IaV8eaoFTZQ5c+b4VD9n82qGw6No3xcYQ/RVXzBQusZQ1udp+iLXkg/xFsvrj4QQZ4QQt0z4iFNEdna2T/XjEmI4sOUb1M1aMzWCnPBVXzBQusZQ1udpRNQCTwC3AvlSyuuAQqBkwkecIk6f9j0Zac+/lPPfWbfTNzQFgpyYiL5Ao3SNoazPkyE2SvOCUT/BfMMGaZ7/07lrFAwmkr98bRYkGS/SePTKFChyROn530H5GkNZnydDnAE2V7eZzuVKYv/+/T63yUvq4TdPFnH5Vy9MgSJHJqIv0ChdYyjr8zR9USmEsE5VCCFEBea7p9nAKxM+qkJITkvgYuayoC0opaJixZMhbpNX1zK1YfFBDQn61xSS+ZcXGRoYJiomMthyVK5RPM0jOhihEGKhxeFb2WsW+EDyTWuJGe7n5Fsngi1F5RrGp6UyLBP5nZjzX4QEy243T+x/8qZ6eqoSPCa0nKIQ4p8CPbnvKTB4cHCQ6OjoCfX97ftfRxTm84uyuROV55HJ6AsUStc43fVNODBYCPGFcXZJp3reBgY7BAKP124itLS0TLht5B1bebt3LqYpPOGejL5AoXSNoazP06lppRDir06PNzEH9trjbWAwOAYC+y1jcGZm5oTb3pDYwbr9uzh95LznyhNkMvoChdI1hrK+id41zXUq8iowmKuBwBrMERfeZhr2yGTyl+fGdbDkT4/SnPMES3PvnoyMcVF6/ndQvsZQ1ufJEDcJIWZKKfcCWO6YLsLs+vaAXT1vA4OdA4HHa4fleD4FBp87N3YJb1eBwfZkZGQwb3kG9Qmz6H/vIPv2jf1X81dgcF9fn+IDg2NiYhQdGGz9/pQaGHz58uWpCwzmagrvGfbl0sfAYJwCgV21G+/h78BgZ2pvKJO6WWsn1Yc7lB7UKqXyNU53fUwiMNg6YpVYDKvCqdxqzN4GBhstz4122wHJGOyJqOJCZr3/Bp+cvMD8nHnBlqNyjeGtr+nLmIOCu+zLQ4mFm9cC0PS2OrGvEnh89TXdgUJ9TTMyJpdnbdnG5az9wXFKFs1ks5802TNZfYFA6RpDWZ+/7poGncne2o6IDGfp9TOnLGWb0m+9g/I1hrI+n3xNPZUHE39M9mqN9Xzpp/dypbXDc2UfUfpkNChfYyjrC5m0bP7Ir56TMkzR6b2cfGNymYldofT876B8jaGsL2QM0dXCwL6yYssahsMjaX/7oOfKPuIPfVON0jWGsr6QMUR/EJcYy6fZq4lqUCMxVAKLaohODOcXMe/sMXqM/Z4rq6j4CdUQnZh163o+yMrj2PGpX1BKRcWKp+mLa47VX7yJL1+4ie8BNwRbjMo1w4QCg4OBp8DgkZERIiL8879S8hzk732ez34mnfX3bSIyavL9+lPfVKF0jdNd34QDg6cT/lx89pENJm7a92tmfvs+/jb3Bl7d8TQX9ZM7VVX64rigfI2hrM8vhuhjhH6eEKLcVcT+ZPDncuy3Lg1De3YPhqefpStjEZrnKmldWsTT3/otBz+BiZxEKH25eFC+xlDW568R0dsI/TxpzhqsA7Zb6vgldbe/86tHRkVw87e28Plj/03c39/h43/4Crtjc/nCLrjnByd5/bHf0HmlO2j6pgKlawxlff464fY2dbc1N6IWqMUpYl9ezZcI+B4Y7BywC94FBnuTMXj4R9v5XWY2L7x/ib6nXiVrz69o+tnjnC7eTOaOf6TotkKPgcEDAwOKDwyOi4tTdGCw9TtWamBwW1ub/wODvX0AOy3PyUC5u3KuBgwnA1pLWZ59O1ePqQ4M9oXRUZNsfL1R1mofkoeiNPJIWIb8fd7X5KsnpBwcCb6+iaJ0jdNdH5MIDPaWKiFEqeV1NYAQQutcbimrwBwMvAdoFELkAQXWdtOBsDBB7m255N6Wy5VzP+DvT77EyfPwf/4IaX818djpX7Hu2//AghXKjhZQUQ5+MUTpfYS+DteZpAKeuttfpGXN5I6f7+B2Cbe0wO6Xm1j83BO0P/cEDXmbmP3AvRTfe1OwZaoonJCZvsjKygrq8cMEbNRA5SM5zDp6gLNf/jazPjxM4tfvYe+8z3Dko8SA5GGcDMH+DD0RyvpCxhDT09ODLcHG/JwMvvB8OWsvHuLKzmdoX7CMpz5dRfH/hl27TtLbpUw/ViV9hq4IZX0hY4hKvLUdHRuF9uE7+OKh5/jpLRdYMXOQjG/dQ92CDbz2yP+lr2cg2BIdUOJnaE8o6wsZQ1T6ZO/Wgjn89ivRxD/7DF1zFzL/qR9wcP4GXn/sefp7Bz13EACU/hmGsr6QMURXc3dKwqqvaHsxW0/U0vfCi/SkZZJV+X12PFrH747A8KgyNCoVf+nr7ern3JUhzhnxa76TyehTrgdtCBMWJij+8npMX7yBv79cj6GngEd2Q9OPq1ifO5NN5V/wi6P5tYDJJOkx9NJ2rh3j+Xa6Lxjov9jOhaWFnE/VYDrVxKpfP05Up4GYLgPxPe3EDvXxg3t+Q/2STRS0vs/XdT9hcMlyYlYuY87a5SzZsJSkWYFd2l/9toNIWJhgw7ZCXpOw94yJ7uffZO4fDrLvv57G9NC/sOl7nyciMjzYMoOGScL5ywN8vPsAhuPNGE59QO2PXiG8o52/F3+Jfcu3kqD/gJ/9vASAcMxeIsnAS3fs5J11GlYaoaCjjaHkFPoXLMKYmkr4rFTu3ZLN9ixo140iIyKYu+9PJPz5BQBagB8/tocZa5ZR1HWKxX0fs+CGZSxcPZ/w8Kk5iVQNUQEIAZuWhGE6Vcv+qjcZfuI/yfjX7/DW079AVlZy611FhImpO35vZz+tJ1sxnuuiv3eQ2PjA5iDs7xmgpaGFC4eb6T5xBtOZjzi6sJjfrbibiM5+XvzJPSQCs6Pi6E1IpX9GKjPDh1i/AOYsyODs8PeJnp1K3JxUEuelkJyRys+zZ5OQBEIsg8f/PP7Bc9fDI+sxmSStTRdoefcUHQ2nSF+ZzfE2yPzdy6x7r4oeoC4qnitZSxlcspy+//FDlmVGsTTVRGLs5I1TNUQFERYm2PjAZkbLSnjnmT9jevKn/Lguico+eDi3i815CRP+Rx7sH+LjY+e4cERPZ1MLw2f0/PHz36dpIImSV57mi/t/QTZw+qvQEzuDnhmz+c2//4nktERWnNrLvPNNxMydTUJmGjOy0pi1MI20hWlEhHv/D9F+wcjZQx9x+ehHXDAlsD9nKx+1SZ58eA1xgz2kAWlAW0oWafOWcncuXJc6k8G8V1lYsIhT+mNs2rgRgK22XpPg9m9O6DOxJyxMMD8ng/k5GUAJn7eU937pYc68dzsXDp6i71gTUR+eIr7+Pb6zNwqAR2oeZMWFw3RmL+PMjbeyrADSJ3BWGzKGeOONNwZbglt80RceHsYtD97G6Lc/x9AHgqf+Bs1fr+CvxmbiHv0eN+64lTAXQ+TI8Citp85z/kgLHaf0HFv9WZrC5zLrLy9zz67vEm4aZSYwE+iOSyZyw33ckJOE5iu3c+mzixnu6WPoUjujly4j2troj4zn409h4Rs6st9/3nYcE9AaEU3Rv31EShzcvfdJFn9ymJFZaYi0NCLS04hatpjzuTfzUTvkPP4dFhx7hxk9bUQA84COhWs5/+hWVswRfPyNx0idO4M5udehKVzE6hmxbLJ/Y7mFAMzKDPx3HD8jljWfW8Oaz62xlUkJh7rg5GUwdhXT+e4IifomTp7dwuDIxI4TMhH6x48fZ+XKlQFU5BuT0TdqgreefBV++hTpl1toXbCKyG/cj3HlWk5Hz6On7ig3P/0QqVc+JnL0qvtO5d3P0nbjFvK7myg4/DrxS7OZtSKb+Ws0pGXN9Eljt6GXy2ev0PFJG13nLtNj6OXDjdu40gua3zxFZsNe4oxXSOq6QuToEJdnZPDVhw+SHAMPvP04c4baiVpyHTNWLiYzfxELVs33+fpX6d9x3eETFKxZgRjnJMFdhL5fDNESDKy1bOqklEZX5Zbncbet7VzhyRCne351bxgeGuGtyleIePpnpLV/wi9v+xF/Xf/P5I1+wl1/+iEyO5vYJRpSV2jIys1mjma2y5FzKjWaTJKOi520f9JOyspFpMYx7g/TV6b7d+zOEAMaBuVp290xPIVBNTU1eQhSCS7+1DfYPyTr/lAvz55pkyOjfuv2mvoMpwJP+ghAGJS3qbtTPGw74GtgsHOwLfgvMNgfGYOHh4f9FhgctziWltbjtNh5VfkjMDgxMVHRgcHWz02pgcEdHR3KDwz2tO3uGEoKDJ4IStcnpfI1Tnd9KCUwGEjxsK2ick0S6MBgo4dtFZVrkmkzfSGEuAJ87KbKLKDNj4ecAXT6sT+l6wPla5zu+hZIKdNc7hnvnHW6PXBz/j3B/qqvJX3TQWMo6wuZMKgp4LVgC/CA0vWB8jUqRp9qiOMgpVTMl+QKpesD5WtUkr5QMkSl33VVuj5QvsaQ1TdtbtaoqIQyoTQiqqhMW0LCEIUQZRYHAsXhnAEr2HpcMR00AgghdgZbgyv8kdUsJAwRqMfsJqdEXGXAUhoGrjpWpLirGCwsqRmSg63DDZPKahYqhqhYpDktHZjDvVylGwg60k34mcIwBlvAOFizmpVaMpv5jGqIAcBy2mxNQ6c4hBClFmPUAaUeqgccO39kzUR/6FNMgeWsR88EP79QMUQtUKjE6xu7DFgVXA2CVhrWrFxaFDhFYDmr0KPcU1P9ZLOaqdMXKioKIFRGRBWVaY1qiCoTwn7KI9haQgHVEEMMIYRWCFEVgENpLDcoUOK1+XRDNcQQQ5oDsqd8LlBKqbPcwdRPo+kPxaIaosqEsNwl3AmUqCPi5AmZlb5VxmIxkO2Yb/1rpJTVllHMfhql3nqK6aafPOAxACnlNiGE1Vto29Qov/ZQDTG02QlUSCmNQoidFoOynrYaAKMnI7SQYjHAZKc+VPyEemoa2rgyGANmDxqd5XoSi5FqLK/zLDd8bA7M1nqWa0GtvLowmIqfUA0xxLCMWBrLaWkFsN3i3dNsGf2MmEfKx+xcx+rsurjTYmgGS1/OqKvuTQHqqWmIYTG2fMumkbEuV6WYIwWMlvAxZ9/N5KlVqOIK1RCvPfRAgRDC6oBuAArt9lVZRtAUu8gRwDyJD3hzTaniI6qvqYqKAlCvEVVUFIBqiCoqCkA1RBUVBaAaooqKAlANUUVFAaiGqKKiAP4/YGMXlbW39y8AAAAASUVORK5CYII=\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "LABELPAD = 1\n",
    "TICK_PADDING = 2\n",
    "\n",
    "fig = plt.figure(figsize=figsizes.neurips2022(nrows=1, ncols=1.7, rel_width=1)['figure.figsize'])\n",
    "\n",
    "\"\"\"MCC vs CIMA over different gamma\"\"\"\n",
    "ax = fig.add_subplot(121)\n",
    "ax.grid(True, which=\"major\", ls=\"-.\")\n",
    "ax.set_axisbelow(True)\n",
    "\n",
    "ima_elbo = IMA_REG_LOG_LIKELIHOOD - elbo\n",
    "log_likelihood_elbo = LOG_LIKELIHOOD - elbo\n",
    "\n",
    "# for i in range(0,len(log_gamma_sq),2):\n",
    "#     l = ax.vlines(log_gamma_sq[i], ima_elbo[i], log_likelihood_elbo[i], colors=\"black\", linestyle=\"--\", label=None if i != 0 else r\"$C_{\\mathrm{IMA}}$\")\n",
    "\n",
    "# L_IMA - ELBO\n",
    "ax.plot(log_gamma_sq, ima_elbo,  label=r\"$\\mathbb{E}_{p(\\boldsymbol{x})}[\\mathcal{L}_{\\mathrm{IMA}}-\\mathrm{ELBO}^*]$\", c=BLUE)\n",
    "# Log-likelihood - ELBO\n",
    "ax.plot(log_gamma_sq, log_likelihood_elbo,  label=r\"$\\mathbb{E}_{p(\\boldsymbol{x})}[\\log p_{\\boldsymbol{\\theta}}(\\boldsymbol{x})-\\mathrm{ELBO}^*]$\", c=RED, ls=\"--\")\n",
    "\n",
    "# ax.plot(log_gamma_sq, GLOBAL_CIMA * np.ones_like(log_gamma_sq), label=r\"$C_{\\mathrm{IMA}}$\", c=\"black\", linestyle=\"--\")\n",
    "\n",
    "ax.set_ylabel(r\"$\\mathrm{ELBO}^*\\ \\mathrm{Gap}$\", labelpad=LABELPAD)\n",
    "ax.set_xlabel(r\"$\\log_{10}\\gamma^2$\", labelpad=LABELPAD)\n",
    "plt.legend()\n",
    "\n",
    "ax.set_xticklabels(range(log_gamma_sq[0].astype(int),log_gamma_sq[-1].astype(int)))\n",
    "\n",
    "\n",
    "# Make a plot with major ticks that are multiples of 20 and minor ticks that\n",
    "# are multiples of 5.  Label major ticks with '%d' formatting but don't label\n",
    "# minor ticks.\n",
    "ax.xaxis.set_major_locator(MultipleLocator(1))\n",
    "ax.xaxis.set_major_formatter(FormatStrFormatter('%d'))\n",
    "# For the minor ticks, use no labels; default NullFormatter.\n",
    "ax.xaxis.set_minor_locator(MultipleLocator(0.5))\n",
    "\n",
    "\n",
    "plt.savefig(\"ima_elbo_likelihood_ima_class.svg\")"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 226,
   "outputs": [
    {
     "data": {
      "text/plain": "(array([4.18749310e-05, 2.62954786e-04, 6.60705750e-04, 1.72489779e-03,\n        2.20550174e-03, 3.34985192e-03, 2.23306660e-02, 2.03566935e-02,\n        2.14185868e-02]),\n array([4.18749310e-05, 2.62954786e-04, 6.60705750e-04, 1.72489779e-03,\n        2.20550174e-03, 3.34985192e-03, 2.23306660e-02, 2.03566935e-02,\n        2.14185868e-02]))"
     },
     "execution_count": 226,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# error bars\n",
    "ima_elbo.std(0),log_likelihood_elbo.std(0)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}