{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import experiment_1 as exp1\n",
    "import pickle\n",
    "from experiment import ResultList\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('exp_1_random.pkl', 'rb') as f:\n",
    "    rand_results = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<experiment.ResultList at 0x7f4f0857db70>"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results = []\n",
    "def scrub_results(results):\n",
    "    output = []\n",
    "    for _ in results.results:\n",
    "        if (_.values('CLEVER')) < 10000:\n",
    "            output.append(_)\n",
    "    new_results = ResultList(output)\n",
    "    return new_results\n",
    "synthetic_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "    times = results.average_stdevs('time')\n",
    "    values = results.average_stdevs('value')\n",
    "    rel_errs = results.get_rel_err(dim)\n",
    "    keys = sorted(list(times.keys()))\n",
    "    max_len_k = max(len(_) for _ in keys + ['method'])\n",
    "    rows = []\n",
    "    pad = lambda s: s + ' ' * (max_len_k - len(s))\n",
    "    def dim_scale(k, val):\n",
    "        if k not in ['SeqLip', 'LipSDP']:\n",
    "            return val\n",
    "        else:\n",
    "            return math.sqrt(dim) *val\n",
    "    header_pad = lambda s: '|' + ' ' * (10 - len(s)) + s\n",
    "    row1 = ['Method', 'Time', 'Time STD', 'Value', 'Value STD', 'Err', 'ErrSTD']\n",
    "    rows.append(row1)\n",
    "    header = pad('Method') +' '+ ' '.join(header_pad(_) for _ in ['Time', 'Time STD', 'Value', 'Value STD', 'Err', 'ErrSTD'])\n",
    "    print(header + '\\n' + '-' * len(header))\n",
    "    key_order = [_[0] for _ in sorted([(k, dim_scale(k, values[k][0])) for k in keys], key=lambda p: p[1])]\n",
    "    for k in key_order:\n",
    "        elements = [pad(k),  \n",
    "                    '${:10.3f} \\pm {:10.3f}$'.format(times[k][0], times[k][1]),\n",
    "                    '${:10.3f} \\pm {:10.3f}$'.format(dim_scale(k, values[k][0]), dim_scale(k, values[k][1])),\n",
    "                    '${:10.2f}\\% \\pm {:10.2f}\\%$'.format(rel_errs[k][0] * 100, rel_errs[k][1] * 100)]\n",
    "        rows.append(elements)\n",
    "        print(' '.join(elements))\n",
    "    return rows\n",
    "    with open(csvfile, 'w', newline='') as f:\n",
    "        csvwriter = csv.writer(f, delimiter=',',\n",
    "                                quotechar='|', quoting=csv.QUOTE_MINIMAL)\n",
    "        for row in rows:\n",
    "            csvwriter.writerow(row)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "exp_1_MNIST_bin.pkl\t      exp_2_random_radius01.pkl\r\n",
      "exp_1_MNIST_data.pkl\t      exp_2_synthetic_radius01.pkl\r\n",
      "exp_1_random.pkl\t      experiment_multiclass_rad01.pkl\r\n",
      "exp_1_synthetic.pkl\t      experiment_multiclass_rad02.pkl\r\n",
      "exp_2_MNIST_bin_radius01.pkl  exp_random_10-3.pkl\r\n"
     ]
    }
   ],
   "source": [
    "!ls *.pkl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "synthetic_file = 'exp_1_synthetic.pkl'\n",
    "with open(synthetic_file, 'rb') as f:\n",
    "    synthetic_results = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method     |      Time |  Time STD |     Value | Value STD |       Err |    ErrSTD\n",
      "----------------------------------------------------------------------------------\n",
      "RandomLB   $     0.297 \\pm      0.004$ $   282.296 \\pm    119.711$ $     67.32\\% \\pm      10.25\\%$\n",
      "LipProblem $    38.844 \\pm     34.906$ $   432.448 \\pm    198.834$ $    100.00\\% \\pm       0.00\\%$\n",
      "CLEVER     $     1.849 \\pm      0.054$ $   528.870 \\pm    221.114$ $    128.45\\% \\pm      48.44\\%$\n",
      "LipSDP     $     2.704 \\pm      0.019$ $   605.006 \\pm    288.065$ $    139.07\\% \\pm      10.14\\%$\n",
      "SeqLip     $     0.016 \\pm      0.002$ $   846.551 \\pm    366.126$ $    198.98\\% \\pm      22.26\\%$\n",
      "LipLP      $     0.030 \\pm      0.002$ $  1863.143 \\pm    679.332$ $    462.43\\% \\pm     108.28\\%$\n",
      "FastLip    $     0.001 \\pm      0.000$ $  1977.247 \\pm    722.151$ $    488.14\\% \\pm     106.99\\%$\n",
      "NaiveUB    $     0.000 \\pm      0.000$ $  4546.686 \\pm   2036.963$ $   1096.96\\% \\pm     303.35\\%$\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[['Method', 'Time', 'Time STD', 'Value', 'Value STD', 'Err', 'ErrSTD'],\n",
       " ['RandomLB  ',\n",
       "  '$     0.297 \\\\pm      0.004$',\n",
       "  '$   282.296 \\\\pm    119.711$',\n",
       "  '$     67.32\\\\% \\\\pm      10.25\\\\%$'],\n",
       " ['LipProblem',\n",
       "  '$    38.844 \\\\pm     34.906$',\n",
       "  '$   432.448 \\\\pm    198.834$',\n",
       "  '$    100.00\\\\% \\\\pm       0.00\\\\%$'],\n",
       " ['CLEVER    ',\n",
       "  '$     1.849 \\\\pm      0.054$',\n",
       "  '$   528.870 \\\\pm    221.114$',\n",
       "  '$    128.45\\\\% \\\\pm      48.44\\\\%$'],\n",
       " ['LipSDP    ',\n",
       "  '$     2.704 \\\\pm      0.019$',\n",
       "  '$   605.006 \\\\pm    288.065$',\n",
       "  '$    139.07\\\\% \\\\pm      10.14\\\\%$'],\n",
       " ['SeqLip    ',\n",
       "  '$     0.016 \\\\pm      0.002$',\n",
       "  '$   846.551 \\\\pm    366.126$',\n",
       "  '$    198.98\\\\% \\\\pm      22.26\\\\%$'],\n",
       " ['LipLP     ',\n",
       "  '$     0.030 \\\\pm      0.002$',\n",
       "  '$  1863.143 \\\\pm    679.332$',\n",
       "  '$    462.43\\\\% \\\\pm     108.28\\\\%$'],\n",
       " ['FastLip   ',\n",
       "  '$     0.001 \\\\pm      0.000$',\n",
       "  '$  1977.247 \\\\pm    722.151$',\n",
       "  '$    488.14\\\\% \\\\pm     106.99\\\\%$'],\n",
       " ['NaiveUB   ',\n",
       "  '$     0.000 \\\\pm      0.000$',\n",
       "  '$  4546.686 \\\\pm   2036.963$',\n",
       "  '$   1096.96\\\\% \\\\pm     303.35\\\\%$']]"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "csv_parser(scrub_results(synthetic_results), 10, None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method     |      Time |  Time STD |     Value | Value STD |       Err |    ErrSTD\n",
      "----------------------------------------------------------------------------------\n",
      "RandomLB   $     0.238 \\pm      0.004$ $     0.752 \\pm      0.207$ $     76.20\\% \\pm       8.94\\%$\n",
      "CLEVER     $     1.420 \\pm      0.061$ $     0.891 \\pm      0.252$ $     89.89\\% \\pm       8.46\\%$\n",
      "LipProblem $   325.337 \\pm    357.716$ $     0.984 \\pm      0.238$ $    100.00\\% \\pm       0.00\\%$\n",
      "LipSDP     $     2.635 \\pm      0.025$ $     1.414 \\pm      0.289$ $    145.67\\% \\pm      16.62\\%$\n",
      "SeqLip     $     0.008 \\pm      0.001$ $     1.823 \\pm      0.376$ $    189.17\\% \\pm      35.40\\%$\n",
      "LipLP      $     0.019 \\pm      0.009$ $     5.342 \\pm      0.991$ $    555.45\\% \\pm      93.58\\%$\n",
      "FastLip    $     0.001 \\pm      0.000$ $     5.637 \\pm      1.053$ $    585.49\\% \\pm      95.01\\%$\n",
      "NaiveUB    $     0.000 \\pm      0.000$ $    13.496 \\pm      1.900$ $   1439.31\\% \\pm     374.21\\%$\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[['Method', 'Time', 'Time STD', 'Value', 'Value STD', 'Err', 'ErrSTD'],\n",
       " ['RandomLB  ',\n",
       "  '$     0.238 \\\\pm      0.004$',\n",
       "  '$     0.752 \\\\pm      0.207$',\n",
       "  '$     76.20\\\\% \\\\pm       8.94\\\\%$'],\n",
       " ['CLEVER    ',\n",
       "  '$     1.420 \\\\pm      0.061$',\n",
       "  '$     0.891 \\\\pm      0.252$',\n",
       "  '$     89.89\\\\% \\\\pm       8.46\\\\%$'],\n",
       " ['LipProblem',\n",
       "  '$   325.337 \\\\pm    357.716$',\n",
       "  '$     0.984 \\\\pm      0.238$',\n",
       "  '$    100.00\\\\% \\\\pm       0.00\\\\%$'],\n",
       " ['LipSDP    ',\n",
       "  '$     2.635 \\\\pm      0.025$',\n",
       "  '$     1.414 \\\\pm      0.289$',\n",
       "  '$    145.67\\\\% \\\\pm      16.62\\\\%$'],\n",
       " ['SeqLip    ',\n",
       "  '$     0.008 \\\\pm      0.001$',\n",
       "  '$     1.823 \\\\pm      0.376$',\n",
       "  '$    189.17\\\\% \\\\pm      35.40\\\\%$'],\n",
       " ['LipLP     ',\n",
       "  '$     0.019 \\\\pm      0.009$',\n",
       "  '$     5.342 \\\\pm      0.991$',\n",
       "  '$    555.45\\\\% \\\\pm      93.58\\\\%$'],\n",
       " ['FastLip   ',\n",
       "  '$     0.001 \\\\pm      0.000$',\n",
       "  '$     5.637 \\\\pm      1.053$',\n",
       "  '$    585.49\\\\% \\\\pm      95.01\\\\%$'],\n",
       " ['NaiveUB   ',\n",
       "  '$     0.000 \\\\pm      0.000$',\n",
       "  '$    13.496 \\\\pm      1.900$',\n",
       "  '$   1439.31\\\\% \\\\pm     374.21\\\\%$']]"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "csv_parser(new_rand_results, 16, 'exp1RANDOMCSV.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
