{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load results "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('results_summary.dict', 'rb') as f:\n",
    "    stats = pickle.load(f)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Main tables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_latex(df):\n",
    "    print(df.to_latex().replace('\\$', '$'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_results_table(results_dict, metrics, keep_methods):\n",
    "    d = {}\n",
    "    missing_methods = []\n",
    "    for method in keep_methods:\n",
    "        if method in results_dict:\n",
    "            d[method] = ['{:.3f} ({:.3f})'.format(*results_dict[method][metric]) if 'time' in metric else \\\n",
    "                         '{:.2f} ({:.2f})'.format(*results_dict[method][metric]) for metric in metrics]\n",
    "        else:\n",
    "            missing_methods.append(method)\n",
    "    df = pd.DataFrame.from_dict(d, orient='index')\n",
    "    df.columns = metrics\n",
    "    df.index.names = ['alg']\n",
    "    if len(missing_methods) > 0:\n",
    "        print('missing methods: {}'.format(missing_methods))\n",
    "    return df.loc[[x for x in keep_methods if x not in missing_methods]], missing_methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_full_results_table(results_dict, exper_type, num=5):\n",
    "    metrics = ['test_eval', \n",
    "               'test_eq_max', 'test_eq_mean', \n",
    "               'test_ineq_max', 'test_ineq_mean',\n",
    "               'test_time']\n",
    "    metrics_raw = [x.replace('test_', 'test_raw_') for x in metrics]\n",
    "    metrics_renaming = ['Obj. value', \n",
    "                        'Max eq viol.', 'Mean eq viol.', \n",
    "                        'Max ineq viol.', 'Mean ineq viol.',\n",
    "                        'Time']\n",
    "    \n",
    "    nn_methods = ['method', 'method_no_compl', 'method_no_corr', 'method_no_soft', \n",
    "               'baseline_nn', 'baseline_eq_nn']\n",
    "    opt_methods = dict([\n",
    "            ('simple', ['osqp', 'qpth']), ('nonconvex', ['ipopt']), ('acopf', ['pypower'])\n",
    "    ])\n",
    "    opt_methods_list = ['baseline_opt_{}'.format(x) for x in opt_methods[exper_type]]\n",
    "    methods_renaming_dict = dict((\n",
    "            ('method', 'DC3'),\n",
    "            ('method_no_compl', 'DC3, $\\neq$'),\n",
    "            ('method_no_corr', 'DC3, $\\not\\leq$ train'),\n",
    "            ('method_no_corr-noTestCorr', 'DC3, $\\not\\leq$ train/test'),\n",
    "            ('method_no_soft', 'DC3, no soft loss'),\n",
    "            ('baseline_nn-noTestCorr', 'NN'),\n",
    "            ('baseline_nn', 'NN, $\\leq$ test'),\n",
    "            ('baseline_eq_nn-noTestCorr', 'Eq.~NN'),\n",
    "            ('baseline_eq_nn', 'Eq.~NN, $\\leq$ test'),\n",
    "            ('baseline_opt_osqp', 'Optimizer (OSQP)'),\n",
    "            ('baseline_opt_qpth', 'Optimizer (qpth)'),\n",
    "            ('baseline_opt_ipopt', 'Optimizer (IPOPT)'),\n",
    "            ('baseline_opt_pypower', 'Optimizer (PYPOWER)')\n",
    "        ))\n",
    "    \n",
    "    df1, missing_methods = get_results_table(results_dict, metrics, nn_methods + opt_methods_list)\n",
    "    \n",
    "    df2, missing_methods_2 = get_results_table(results_dict, metrics_raw, nn_methods)\n",
    "    df2.columns = metrics\n",
    "    df2.index =  ['{}-noTestCorr'.format(x) for x in df2.index]\n",
    "    \n",
    "    missing_methods = missing_methods + ['{}-noTestCorr'.format(x) for x in missing_methods_2]\n",
    "        \n",
    "    all_results = pd.concat([df1, df2])\n",
    "    results_ordering = opt_methods_list + ['method', 'method_no_compl', 'method_no_corr', 'method_no_corr-noTestCorr',\n",
    "                       'method_no_soft', 'baseline_nn-noTestCorr', 'baseline_nn', 'baseline_eq_nn-noTestCorr', \n",
    "                       'baseline_eq_nn']\n",
    "    all_results = all_results.loc[[x for x in results_ordering if x not in missing_methods]]\n",
    "    all_results.index = [methods_renaming_dict[x] for x in all_results.index]\n",
    "    all_results.columns = metrics_renaming\n",
    "    \n",
    "    return all_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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>Obj. value</th>\n",
       "      <th>Max eq viol.</th>\n",
       "      <th>Mean eq viol.</th>\n",
       "      <th>Max ineq viol.</th>\n",
       "      <th>Mean ineq viol.</th>\n",
       "      <th>Time</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Optimizer (OSQP)</th>\n",
       "      <td>-15.05 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.002 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Optimizer (qpth)</th>\n",
       "      <td>-15.05 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>1.335 (0.012)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3</th>\n",
       "      <td>-13.46 (0.01)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.017 (0.001)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\neq$</th>\n",
       "      <td>-12.58 (0.04)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.13 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.008 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\not\\leq$ train</th>\n",
       "      <td>-1.39 (0.97)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.02 (0.02)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.017 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\not\\leq$ train/test</th>\n",
       "      <td>-1.23 (1.21)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.09 (0.13)</td>\n",
       "      <td>0.01 (0.01)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, no soft loss</th>\n",
       "      <td>-21.84 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>23.83 (0.11)</td>\n",
       "      <td>4.04 (0.01)</td>\n",
       "      <td>0.017 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NN</th>\n",
       "      <td>-12.57 (0.01)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.13 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NN, $\\leq$ test</th>\n",
       "      <td>-12.57 (0.01)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.13 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.008 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Eq.~NN</th>\n",
       "      <td>-9.16 (0.75)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>8.83 (0.72)</td>\n",
       "      <td>0.91 (0.09)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Eq.~NN, $\\leq$ test</th>\n",
       "      <td>-14.68 (0.05)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.89 (0.05)</td>\n",
       "      <td>0.07 (0.01)</td>\n",
       "      <td>0.018 (0.001)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                               Obj. value Max eq viol. Mean eq viol.  \\\n",
       "Optimizer (OSQP)            -15.05 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "Optimizer (qpth)            -15.05 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3                         -13.46 (0.01)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, $\\neq$                 -12.58 (0.04)  0.35 (0.00)   0.13 (0.00)   \n",
       "DC3, $\\not\\leq$ train        -1.39 (0.97)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test   -1.23 (1.21)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, no soft loss           -21.84 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "NN                          -12.57 (0.01)  0.35 (0.00)   0.13 (0.00)   \n",
       "NN, $\\leq$ test             -12.57 (0.01)  0.35 (0.00)   0.13 (0.00)   \n",
       "Eq.~NN                       -9.16 (0.75)  0.00 (0.00)   0.00 (0.00)   \n",
       "Eq.~NN, $\\leq$ test         -14.68 (0.05)  0.00 (0.00)   0.00 (0.00)   \n",
       "\n",
       "                           Max ineq viol. Mean ineq viol.           Time  \n",
       "Optimizer (OSQP)              0.00 (0.00)     0.00 (0.00)  0.002 (0.000)  \n",
       "Optimizer (qpth)              0.00 (0.00)     0.00 (0.00)  1.335 (0.012)  \n",
       "DC3                           0.00 (0.00)     0.00 (0.00)  0.017 (0.001)  \n",
       "DC3, $\\neq$                   0.00 (0.00)     0.00 (0.00)  0.008 (0.000)  \n",
       "DC3, $\\not\\leq$ train         0.02 (0.02)     0.00 (0.00)  0.017 (0.000)  \n",
       "DC3, $\\not\\leq$ train/test    0.09 (0.13)     0.01 (0.01)  0.001 (0.000)  \n",
       "DC3, no soft loss            23.83 (0.11)     4.04 (0.01)  0.017 (0.000)  \n",
       "NN                            0.00 (0.00)     0.00 (0.00)  0.001 (0.000)  \n",
       "NN, $\\leq$ test               0.00 (0.00)     0.00 (0.00)  0.008 (0.000)  \n",
       "Eq.~NN                        8.83 (0.72)     0.91 (0.09)  0.001 (0.000)  \n",
       "Eq.~NN, $\\leq$ test           0.89 (0.05)     0.07 (0.01)  0.018 (0.001)  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_simple_5050 = get_full_results_table(stats['simple_ineq50_eq50'], exper_type='simple')\n",
    "df_simple_5050"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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>Obj. value</th>\n",
       "      <th>Max eq viol.</th>\n",
       "      <th>Mean eq viol.</th>\n",
       "      <th>Max ineq viol.</th>\n",
       "      <th>Mean ineq viol.</th>\n",
       "      <th>Time</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Optimizer (IPOPT)</th>\n",
       "      <td>-11.59 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.121 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3</th>\n",
       "      <td>-10.66 (0.03)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.013 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\neq$</th>\n",
       "      <td>-10.04 (0.02)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.13 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.009 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\not\\leq$ train</th>\n",
       "      <td>-0.29 (0.67)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.01 (0.01)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.010 (0.004)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\not\\leq$ train/test</th>\n",
       "      <td>-0.27 (0.67)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.03 (0.03)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, no soft loss</th>\n",
       "      <td>-13.81 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>15.21 (0.04)</td>\n",
       "      <td>2.33 (0.01)</td>\n",
       "      <td>0.013 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NN</th>\n",
       "      <td>-10.02 (0.01)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.13 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NN, $\\leq$ test</th>\n",
       "      <td>-10.02 (0.01)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.13 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.009 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Eq.~NN</th>\n",
       "      <td>-3.88 (0.56)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>6.87 (0.43)</td>\n",
       "      <td>0.72 (0.05)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Eq.~NN, $\\leq$ test</th>\n",
       "      <td>-10.99 (0.03)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.87 (0.04)</td>\n",
       "      <td>0.06 (0.00)</td>\n",
       "      <td>0.013 (0.000)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                               Obj. value Max eq viol. Mean eq viol.  \\\n",
       "Optimizer (IPOPT)           -11.59 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3                         -10.66 (0.03)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, $\\neq$                 -10.04 (0.02)  0.35 (0.00)   0.13 (0.00)   \n",
       "DC3, $\\not\\leq$ train        -0.29 (0.67)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test   -0.27 (0.67)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, no soft loss           -13.81 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "NN                          -10.02 (0.01)  0.35 (0.00)   0.13 (0.00)   \n",
       "NN, $\\leq$ test             -10.02 (0.01)  0.35 (0.00)   0.13 (0.00)   \n",
       "Eq.~NN                       -3.88 (0.56)  0.00 (0.00)   0.00 (0.00)   \n",
       "Eq.~NN, $\\leq$ test         -10.99 (0.03)  0.00 (0.00)   0.00 (0.00)   \n",
       "\n",
       "                           Max ineq viol. Mean ineq viol.           Time  \n",
       "Optimizer (IPOPT)             0.00 (0.00)     0.00 (0.00)  0.121 (0.000)  \n",
       "DC3                           0.00 (0.00)     0.00 (0.00)  0.013 (0.000)  \n",
       "DC3, $\\neq$                   0.00 (0.00)     0.00 (0.00)  0.009 (0.000)  \n",
       "DC3, $\\not\\leq$ train         0.01 (0.01)     0.00 (0.00)  0.010 (0.004)  \n",
       "DC3, $\\not\\leq$ train/test    0.03 (0.03)     0.00 (0.00)  0.001 (0.000)  \n",
       "DC3, no soft loss            15.21 (0.04)     2.33 (0.01)  0.013 (0.000)  \n",
       "NN                            0.00 (0.00)     0.00 (0.00)  0.001 (0.000)  \n",
       "NN, $\\leq$ test               0.00 (0.00)     0.00 (0.00)  0.009 (0.000)  \n",
       "Eq.~NN                        6.87 (0.43)     0.72 (0.05)  0.001 (0.000)  \n",
       "Eq.~NN, $\\leq$ test           0.87 (0.04)     0.06 (0.00)  0.013 (0.000)  "
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_nonconvex = get_full_results_table(stats['nonconvex'], exper_type='nonconvex')\n",
    "df_nonconvex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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>Obj. value</th>\n",
       "      <th>Max eq viol.</th>\n",
       "      <th>Mean eq viol.</th>\n",
       "      <th>Max ineq viol.</th>\n",
       "      <th>Mean ineq viol.</th>\n",
       "      <th>Time</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Optimizer (PYPOWER)</th>\n",
       "      <td>3.81 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.949 (0.002)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3</th>\n",
       "      <td>3.82 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.089 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\neq$</th>\n",
       "      <td>3.67 (0.01)</td>\n",
       "      <td>0.14 (0.01)</td>\n",
       "      <td>0.02 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.040 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\not\\leq$ train</th>\n",
       "      <td>3.82 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.089 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, $\\not\\leq$ train/test</th>\n",
       "      <td>3.82 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.01 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.039 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>DC3, no soft loss</th>\n",
       "      <td>3.11 (0.05)</td>\n",
       "      <td>2.60 (0.35)</td>\n",
       "      <td>0.07 (0.00)</td>\n",
       "      <td>2.33 (0.33)</td>\n",
       "      <td>0.03 (0.01)</td>\n",
       "      <td>0.088 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NN</th>\n",
       "      <td>3.69 (0.02)</td>\n",
       "      <td>0.19 (0.01)</td>\n",
       "      <td>0.03 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.001 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>NN, $\\leq$ test</th>\n",
       "      <td>3.69 (0.02)</td>\n",
       "      <td>0.16 (0.00)</td>\n",
       "      <td>0.02 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.040 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Eq.~NN</th>\n",
       "      <td>3.81 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.15 (0.01)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.039 (0.000)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Eq.~NN, $\\leq$ test</th>\n",
       "      <td>3.81 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.15 (0.01)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.078 (0.000)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             Obj. value Max eq viol. Mean eq viol.  \\\n",
       "Optimizer (PYPOWER)         3.81 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3                         3.82 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, $\\neq$                 3.67 (0.01)  0.14 (0.01)   0.02 (0.00)   \n",
       "DC3, $\\not\\leq$ train       3.82 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test  3.82 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "DC3, no soft loss           3.11 (0.05)  2.60 (0.35)   0.07 (0.00)   \n",
       "NN                          3.69 (0.02)  0.19 (0.01)   0.03 (0.00)   \n",
       "NN, $\\leq$ test             3.69 (0.02)  0.16 (0.00)   0.02 (0.00)   \n",
       "Eq.~NN                      3.81 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "Eq.~NN, $\\leq$ test         3.81 (0.00)  0.00 (0.00)   0.00 (0.00)   \n",
       "\n",
       "                           Max ineq viol. Mean ineq viol.           Time  \n",
       "Optimizer (PYPOWER)           0.00 (0.00)     0.00 (0.00)  0.949 (0.002)  \n",
       "DC3                           0.00 (0.00)     0.00 (0.00)  0.089 (0.000)  \n",
       "DC3, $\\neq$                   0.00 (0.00)     0.00 (0.00)  0.040 (0.000)  \n",
       "DC3, $\\not\\leq$ train         0.00 (0.00)     0.00 (0.00)  0.089 (0.000)  \n",
       "DC3, $\\not\\leq$ train/test    0.01 (0.00)     0.00 (0.00)  0.039 (0.000)  \n",
       "DC3, no soft loss             2.33 (0.33)     0.03 (0.01)  0.088 (0.000)  \n",
       "NN                            0.00 (0.00)     0.00 (0.00)  0.001 (0.000)  \n",
       "NN, $\\leq$ test               0.00 (0.00)     0.00 (0.00)  0.040 (0.000)  \n",
       "Eq.~NN                        0.15 (0.01)     0.00 (0.00)  0.039 (0.000)  \n",
       "Eq.~NN, $\\leq$ test           0.15 (0.01)     0.00 (0.00)  0.078 (0.000)  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_acopf = get_full_results_table(stats['acopf'], exper_type='acopf')\n",
    "df_acopf"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Appendix tables (simple problem)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_comparison_table(all_stats, experiments, metrics, keep_methods):\n",
    "    d = {}\n",
    "    for method in keep_methods:\n",
    "        for metric in metrics:\n",
    "            d[(method, metric)] = {}\n",
    "            for experiment in experiments:\n",
    "                d[(method, metric)][experiment] = '{:.2f} ({:.2f})'.format(*all_stats[experiment][method][metric])\n",
    "        df = pd.DataFrame.from_dict(d, orient='index')           \n",
    "    df.index.names = ['Alg', 'Metric']\n",
    "    return df.iloc[df.index.isin(keep_methods, 'Alg')]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_simple_comparison_table(all_stats, vary_across):\n",
    "    assert vary_across in ['ineq', 'eq'], 'vary_across should be in [ineq, eq]'\n",
    "    \n",
    "    if vary_across == 'ineq':\n",
    "        experiments = ['simple_ineq10_eq50', 'simple_ineq30_eq50', 'simple_ineq50_eq50', 'simple_ineq70_eq50',\n",
    "                       'simple_ineq90_eq50']\n",
    "        experiments_renaming = ['10', '30', '50', '70', '90']\n",
    "    else:\n",
    "        experiments = ['simple_ineq50_eq10', 'simple_ineq50_eq30', 'simple_ineq50_eq50', 'simple_ineq50_eq70',\n",
    "                       'simple_ineq50_eq90']\n",
    "        experiments_renaming = ['10', '30', '50', '70', '90']\n",
    "    \n",
    "    methods = ['method', 'method_no_compl', 'method_no_corr', 'method_no_soft', \n",
    "               'baseline_nn', 'baseline_eq_nn', 'baseline_opt_osqp']\n",
    "    methods_renaming_dict = dict((\n",
    "            ('method', 'DC3'),\n",
    "            ('method_no_compl', 'DC3, $\\neq$'),\n",
    "            ('method_no_corr', 'DC3, $\\not\\leq$ train'),\n",
    "            ('method_no_corr-noTestCorr', 'DC3, $\\not\\leq$ train/test'),\n",
    "            ('method_no_soft', 'DC3, no soft loss'),\n",
    "            ('baseline_nn-noTestCorr', 'NN'),\n",
    "            ('baseline_nn', 'NN, $\\leq$ test'),\n",
    "            ('baseline_eq_nn-noTestCorr', 'Eq.~NN'),\n",
    "            ('baseline_eq_nn', 'Eq.~NN, $\\leq$ test'),\n",
    "            ('baseline_opt_osqp', 'Optimizers (OSQP, qpth)')\n",
    "        ))\n",
    "    \n",
    "    metrics = ['test_eval', 'test_eq_max', 'test_ineq_max']\n",
    "    metrics_renaming_dict = dict((('test_eval', 'Obj. val.'), ('test_eq_max', 'Max eq.'), ('test_ineq_max', 'Max ineq.')  ))\n",
    "    clean_metrics = [metrics_renaming_dict[x] for x in metrics]\n",
    "    metrics_raw = [x.replace('test_', 'test_raw_') if 'time' not in x else x for x in metrics]\n",
    "    \n",
    "    df1 = get_comparison_table(all_stats, experiments, metrics, methods)\n",
    "    df1 = df1.reset_index()\n",
    "    df1['Metric'] = df1['Metric'].str.replace('_obj_val', '_eval') # make naming consistent\n",
    "    df1 = df1.set_index(['Alg', 'Metric'])\n",
    "    \n",
    "    df2 = get_comparison_table(all_stats, experiments, metrics_raw, methods[:-1])\n",
    "    df2.columns = experiments\n",
    "    df2 = df2.reset_index()\n",
    "    df2['Alg'] = ['{}-noTestCorr'.format(x) for x in df2['Alg']]\n",
    "    df2['Metric'] = df2['Metric'].str.replace('raw_', '')  # make naming consistent\n",
    "    df2 = df2.set_index(['Alg', 'Metric'])\n",
    "    \n",
    "    all_results = pd.concat([df1, df2])\n",
    "    results_ordering = ['baseline_opt_osqp', 'method', 'method_no_compl', 'method_no_corr', 'method_no_corr-noTestCorr',\n",
    "                       'method_no_soft', 'baseline_nn-noTestCorr', 'baseline_nn', 'baseline_eq_nn-noTestCorr', \n",
    "                       'baseline_eq_nn']\n",
    "    clean_results_ordering = [methods_renaming_dict[x] for x in results_ordering]\n",
    "    all_results = all_results.iloc[all_results.index.isin(results_ordering, 'Alg')]\n",
    "    all_results = all_results.reindex(pd.MultiIndex.from_product([results_ordering, metrics], names=['Alg', 'Metric']))\n",
    "    all_results = all_results.reset_index()\n",
    "    all_results['Alg'] = [methods_renaming_dict[x] for x in all_results['Alg']]\n",
    "    all_results['Metric'] = [metrics_renaming_dict[x] for x in all_results['Metric']]\n",
    "    all_results = all_results.set_index(['Alg', 'Metric'])\n",
    "    all_results.columns = experiments_renaming\n",
    "    all_results = all_results.reindex(pd.MultiIndex.from_product([clean_results_ordering, clean_metrics])) # remove names\n",
    "    \n",
    "    return all_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>10</th>\n",
       "      <th>30</th>\n",
       "      <th>50</th>\n",
       "      <th>70</th>\n",
       "      <th>90</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">Optimizers (OSQP, qpth)</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-27.26 (0.00)</td>\n",
       "      <td>-23.13 (0.00)</td>\n",
       "      <td>-15.05 (0.00)</td>\n",
       "      <td>-14.80 (0.00)</td>\n",
       "      <td>-4.79 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-25.79 (0.02)</td>\n",
       "      <td>-20.29 (0.20)</td>\n",
       "      <td>-13.46 (0.01)</td>\n",
       "      <td>-13.73 (0.02)</td>\n",
       "      <td>-4.76 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, $\\neq$</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-22.59 (0.18)</td>\n",
       "      <td>-20.40 (0.03)</td>\n",
       "      <td>-12.58 (0.04)</td>\n",
       "      <td>-13.36 (0.02)</td>\n",
       "      <td>-5.27 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.12 (0.01)</td>\n",
       "      <td>0.24 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.47 (0.00)</td>\n",
       "      <td>0.59 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, $\\not\\leq$ train</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-25.75 (0.04)</td>\n",
       "      <td>-20.14 (0.15)</td>\n",
       "      <td>-1.39 (0.97)</td>\n",
       "      <td>-13.71 (0.04)</td>\n",
       "      <td>-4.75 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.02 (0.02)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, $\\not\\leq$ train/test</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-25.75 (0.04)</td>\n",
       "      <td>-20.14 (0.15)</td>\n",
       "      <td>-1.23 (1.21)</td>\n",
       "      <td>-13.71 (0.04)</td>\n",
       "      <td>-4.75 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.09 (0.13)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, no soft loss</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-66.79 (0.01)</td>\n",
       "      <td>-40.63 (0.02)</td>\n",
       "      <td>-21.84 (0.00)</td>\n",
       "      <td>-15.56 (0.02)</td>\n",
       "      <td>-4.76 (0.01)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>122.52 (0.22)</td>\n",
       "      <td>50.25 (0.14)</td>\n",
       "      <td>23.83 (0.11)</td>\n",
       "      <td>5.85 (0.18)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">NN</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-22.65 (0.12)</td>\n",
       "      <td>-20.43 (0.03)</td>\n",
       "      <td>-12.57 (0.01)</td>\n",
       "      <td>-13.35 (0.03)</td>\n",
       "      <td>-5.29 (0.02)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.11 (0.01)</td>\n",
       "      <td>0.24 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.47 (0.00)</td>\n",
       "      <td>0.59 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">NN, $\\leq$ test</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-22.65 (0.12)</td>\n",
       "      <td>-20.43 (0.03)</td>\n",
       "      <td>-12.57 (0.01)</td>\n",
       "      <td>-13.35 (0.03)</td>\n",
       "      <td>-5.29 (0.02)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.11 (0.01)</td>\n",
       "      <td>0.24 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.47 (0.00)</td>\n",
       "      <td>0.59 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">Eq.~NN</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-27.20 (0.02)</td>\n",
       "      <td>-22.74 (0.14)</td>\n",
       "      <td>-9.16 (0.75)</td>\n",
       "      <td>-14.64 (0.01)</td>\n",
       "      <td>-4.74 (0.01)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.43 (0.02)</td>\n",
       "      <td>1.37 (0.09)</td>\n",
       "      <td>8.83 (0.72)</td>\n",
       "      <td>0.86 (0.05)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">Eq.~NN, $\\leq$ test</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-27.20 (0.02)</td>\n",
       "      <td>-22.76 (0.13)</td>\n",
       "      <td>-14.68 (0.05)</td>\n",
       "      <td>-14.65 (0.01)</td>\n",
       "      <td>-4.74 (0.01)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.42 (0.02)</td>\n",
       "      <td>1.27 (0.09)</td>\n",
       "      <td>0.89 (0.05)</td>\n",
       "      <td>0.85 (0.05)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                 10             30  \\\n",
       "Optimizers (OSQP, qpth)    Obj. val.  -27.26 (0.00)  -23.13 (0.00)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3                        Obj. val.  -25.79 (0.02)  -20.29 (0.20)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\neq$                Obj. val.  -22.59 (0.18)  -20.40 (0.03)   \n",
       "                           Max eq.      0.12 (0.01)    0.24 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train      Obj. val.  -25.75 (0.04)  -20.14 (0.15)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test Obj. val.  -25.75 (0.04)  -20.14 (0.15)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, no soft loss          Obj. val.  -66.79 (0.01)  -40.63 (0.02)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.  122.52 (0.22)   50.25 (0.14)   \n",
       "NN                         Obj. val.  -22.65 (0.12)  -20.43 (0.03)   \n",
       "                           Max eq.      0.11 (0.01)    0.24 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "NN, $\\leq$ test            Obj. val.  -22.65 (0.12)  -20.43 (0.03)   \n",
       "                           Max eq.      0.11 (0.01)    0.24 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "Eq.~NN                     Obj. val.  -27.20 (0.02)  -22.74 (0.14)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.43 (0.02)    1.37 (0.09)   \n",
       "Eq.~NN, $\\leq$ test        Obj. val.  -27.20 (0.02)  -22.76 (0.13)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.42 (0.02)    1.27 (0.09)   \n",
       "\n",
       "                                                 50             70  \\\n",
       "Optimizers (OSQP, qpth)    Obj. val.  -15.05 (0.00)  -14.80 (0.00)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3                        Obj. val.  -13.46 (0.01)  -13.73 (0.02)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\neq$                Obj. val.  -12.58 (0.04)  -13.36 (0.02)   \n",
       "                           Max eq.      0.35 (0.00)    0.47 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train      Obj. val.   -1.39 (0.97)  -13.71 (0.04)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.02 (0.02)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test Obj. val.   -1.23 (1.21)  -13.71 (0.04)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.09 (0.13)    0.00 (0.00)   \n",
       "DC3, no soft loss          Obj. val.  -21.84 (0.00)  -15.56 (0.02)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.   23.83 (0.11)    5.85 (0.18)   \n",
       "NN                         Obj. val.  -12.57 (0.01)  -13.35 (0.03)   \n",
       "                           Max eq.      0.35 (0.00)    0.47 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "NN, $\\leq$ test            Obj. val.  -12.57 (0.01)  -13.35 (0.03)   \n",
       "                           Max eq.      0.35 (0.00)    0.47 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "Eq.~NN                     Obj. val.   -9.16 (0.75)  -14.64 (0.01)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    8.83 (0.72)    0.86 (0.05)   \n",
       "Eq.~NN, $\\leq$ test        Obj. val.  -14.68 (0.05)  -14.65 (0.01)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.89 (0.05)    0.85 (0.05)   \n",
       "\n",
       "                                                90  \n",
       "Optimizers (OSQP, qpth)    Obj. val.  -4.79 (0.00)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "DC3                        Obj. val.  -4.76 (0.00)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "DC3, $\\neq$                Obj. val.  -5.27 (0.00)  \n",
       "                           Max eq.     0.59 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "DC3, $\\not\\leq$ train      Obj. val.  -4.75 (0.00)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "DC3, $\\not\\leq$ train/test Obj. val.  -4.75 (0.00)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "DC3, no soft loss          Obj. val.  -4.76 (0.01)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "NN                         Obj. val.  -5.29 (0.02)  \n",
       "                           Max eq.     0.59 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "NN, $\\leq$ test            Obj. val.  -5.29 (0.02)  \n",
       "                           Max eq.     0.59 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "Eq.~NN                     Obj. val.  -4.74 (0.01)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  \n",
       "Eq.~NN, $\\leq$ test        Obj. val.  -4.74 (0.01)  \n",
       "                           Max eq.     0.00 (0.00)  \n",
       "                           Max ineq.   0.00 (0.00)  "
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_simple_varyeq = get_simple_comparison_table(stats, 'eq')\n",
    "df_simple_varyeq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>10</th>\n",
       "      <th>30</th>\n",
       "      <th>50</th>\n",
       "      <th>70</th>\n",
       "      <th>90</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">Optimizers (OSQP, qpth)</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-17.33 (0.00)</td>\n",
       "      <td>-16.33 (0.00)</td>\n",
       "      <td>-15.05 (0.00)</td>\n",
       "      <td>-14.61 (0.00)</td>\n",
       "      <td>-14.26 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-15.18 (0.31)</td>\n",
       "      <td>-13.90 (0.20)</td>\n",
       "      <td>-13.46 (0.01)</td>\n",
       "      <td>-10.52 (0.93)</td>\n",
       "      <td>-11.77 (0.07)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, $\\neq$</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-15.66 (0.05)</td>\n",
       "      <td>-14.10 (0.04)</td>\n",
       "      <td>-12.58 (0.04)</td>\n",
       "      <td>-12.10 (0.03)</td>\n",
       "      <td>-11.72 (0.03)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, $\\not\\leq$ train</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-15.60 (0.30)</td>\n",
       "      <td>-13.83 (0.15)</td>\n",
       "      <td>-1.39 (0.97)</td>\n",
       "      <td>-11.14 (0.05)</td>\n",
       "      <td>-11.76 (0.06)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.02 (0.02)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, $\\not\\leq$ train/test</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-15.60 (0.30)</td>\n",
       "      <td>-13.83 (0.15)</td>\n",
       "      <td>-1.23 (1.21)</td>\n",
       "      <td>-11.14 (0.05)</td>\n",
       "      <td>-11.76 (0.06)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.09 (0.13)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">DC3, no soft loss</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-21.78 (0.01)</td>\n",
       "      <td>-21.72 (0.03)</td>\n",
       "      <td>-21.84 (0.00)</td>\n",
       "      <td>-21.82 (0.01)</td>\n",
       "      <td>-21.83 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>23.85 (0.52)</td>\n",
       "      <td>23.54 (0.23)</td>\n",
       "      <td>23.83 (0.11)</td>\n",
       "      <td>23.73 (0.09)</td>\n",
       "      <td>23.69 (0.06)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">NN</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-15.66 (0.03)</td>\n",
       "      <td>-14.10 (0.05)</td>\n",
       "      <td>-12.57 (0.01)</td>\n",
       "      <td>-12.12 (0.03)</td>\n",
       "      <td>-11.70 (0.02)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">NN, $\\leq$ test</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-15.66 (0.03)</td>\n",
       "      <td>-14.10 (0.05)</td>\n",
       "      <td>-12.57 (0.01)</td>\n",
       "      <td>-12.12 (0.03)</td>\n",
       "      <td>-11.70 (0.02)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "      <td>0.35 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">Eq.~NN</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-17.07 (0.20)</td>\n",
       "      <td>-15.45 (0.09)</td>\n",
       "      <td>-9.16 (0.75)</td>\n",
       "      <td>-14.20 (0.06)</td>\n",
       "      <td>-14.10 (0.10)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>1.65 (0.22)</td>\n",
       "      <td>1.79 (0.10)</td>\n",
       "      <td>8.83 (0.72)</td>\n",
       "      <td>2.26 (0.04)</td>\n",
       "      <td>1.28 (0.05)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">Eq.~NN, $\\leq$ test</th>\n",
       "      <th>Obj. val.</th>\n",
       "      <td>-17.06 (0.20)</td>\n",
       "      <td>-15.65 (0.09)</td>\n",
       "      <td>-14.68 (0.05)</td>\n",
       "      <td>-14.31 (0.06)</td>\n",
       "      <td>-14.10 (0.10)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max eq.</th>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "      <td>0.00 (0.00)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Max ineq.</th>\n",
       "      <td>1.53 (0.19)</td>\n",
       "      <td>1.58 (0.08)</td>\n",
       "      <td>0.89 (0.05)</td>\n",
       "      <td>1.92 (0.04)</td>\n",
       "      <td>1.25 (0.04)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                 10             30  \\\n",
       "Optimizers (OSQP, qpth)    Obj. val.  -17.33 (0.00)  -16.33 (0.00)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3                        Obj. val.  -15.18 (0.31)  -13.90 (0.20)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\neq$                Obj. val.  -15.66 (0.05)  -14.10 (0.04)   \n",
       "                           Max eq.      0.35 (0.00)    0.35 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train      Obj. val.  -15.60 (0.30)  -13.83 (0.15)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test Obj. val.  -15.60 (0.30)  -13.83 (0.15)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, no soft loss          Obj. val.  -21.78 (0.01)  -21.72 (0.03)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.   23.85 (0.52)   23.54 (0.23)   \n",
       "NN                         Obj. val.  -15.66 (0.03)  -14.10 (0.05)   \n",
       "                           Max eq.      0.35 (0.00)    0.35 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "NN, $\\leq$ test            Obj. val.  -15.66 (0.03)  -14.10 (0.05)   \n",
       "                           Max eq.      0.35 (0.00)    0.35 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "Eq.~NN                     Obj. val.  -17.07 (0.20)  -15.45 (0.09)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    1.65 (0.22)    1.79 (0.10)   \n",
       "Eq.~NN, $\\leq$ test        Obj. val.  -17.06 (0.20)  -15.65 (0.09)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    1.53 (0.19)    1.58 (0.08)   \n",
       "\n",
       "                                                 50             70  \\\n",
       "Optimizers (OSQP, qpth)    Obj. val.  -15.05 (0.00)  -14.61 (0.00)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3                        Obj. val.  -13.46 (0.01)  -10.52 (0.93)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\neq$                Obj. val.  -12.58 (0.04)  -12.10 (0.03)   \n",
       "                           Max eq.      0.35 (0.00)    0.35 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train      Obj. val.   -1.39 (0.97)  -11.14 (0.05)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.02 (0.02)    0.00 (0.00)   \n",
       "DC3, $\\not\\leq$ train/test Obj. val.   -1.23 (1.21)  -11.14 (0.05)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.09 (0.13)    0.00 (0.00)   \n",
       "DC3, no soft loss          Obj. val.  -21.84 (0.00)  -21.82 (0.01)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.   23.83 (0.11)   23.73 (0.09)   \n",
       "NN                         Obj. val.  -12.57 (0.01)  -12.12 (0.03)   \n",
       "                           Max eq.      0.35 (0.00)    0.35 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "NN, $\\leq$ test            Obj. val.  -12.57 (0.01)  -12.12 (0.03)   \n",
       "                           Max eq.      0.35 (0.00)    0.35 (0.00)   \n",
       "                           Max ineq.    0.00 (0.00)    0.00 (0.00)   \n",
       "Eq.~NN                     Obj. val.   -9.16 (0.75)  -14.20 (0.06)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    8.83 (0.72)    2.26 (0.04)   \n",
       "Eq.~NN, $\\leq$ test        Obj. val.  -14.68 (0.05)  -14.31 (0.06)   \n",
       "                           Max eq.      0.00 (0.00)    0.00 (0.00)   \n",
       "                           Max ineq.    0.89 (0.05)    1.92 (0.04)   \n",
       "\n",
       "                                                 90  \n",
       "Optimizers (OSQP, qpth)    Obj. val.  -14.26 (0.00)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "DC3                        Obj. val.  -11.77 (0.07)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "DC3, $\\neq$                Obj. val.  -11.72 (0.03)  \n",
       "                           Max eq.      0.35 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "DC3, $\\not\\leq$ train      Obj. val.  -11.76 (0.06)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "DC3, $\\not\\leq$ train/test Obj. val.  -11.76 (0.06)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "DC3, no soft loss          Obj. val.  -21.83 (0.00)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.   23.69 (0.06)  \n",
       "NN                         Obj. val.  -11.70 (0.02)  \n",
       "                           Max eq.      0.35 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "NN, $\\leq$ test            Obj. val.  -11.70 (0.02)  \n",
       "                           Max eq.      0.35 (0.00)  \n",
       "                           Max ineq.    0.00 (0.00)  \n",
       "Eq.~NN                     Obj. val.  -14.10 (0.10)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.    1.28 (0.05)  \n",
       "Eq.~NN, $\\leq$ test        Obj. val.  -14.10 (0.10)  \n",
       "                           Max eq.      0.00 (0.00)  \n",
       "                           Max ineq.    1.25 (0.04)  "
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_simple_varyineq = get_simple_comparison_table(stats, 'ineq')\n",
    "df_simple_varyineq"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## LaTeX "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "get_latex(df_simple_5050)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "get_latex(df_nonconvex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "get_latex(df_acopf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "get_latex(df_simple_varyeq)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "get_latex(df_simple_varyineq)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
