{
 "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": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "def csv_parser(results, dim, csvfile, no_err=False):\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",
    "        if not no_err:\n",
    "            elements.append(\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": 49,
   "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$\n",
      "LipProblem $    38.844 \\pm     34.906$ $   432.448 \\pm    198.834$\n",
      "CLEVER     $     1.849 \\pm      0.054$ $   528.870 \\pm    221.114$\n",
      "LipSDP     $     2.704 \\pm      0.019$ $   605.006 \\pm    288.065$\n",
      "SeqLip     $     0.016 \\pm      0.002$ $   846.551 \\pm    366.126$\n",
      "LipLP      $     0.030 \\pm      0.002$ $  1863.143 \\pm    679.332$\n",
      "FastLip    $     0.001 \\pm      0.000$ $  1977.247 \\pm    722.151$\n",
      "NaiveUB    $     0.000 \\pm      0.000$ $  4546.686 \\pm   2036.963$\n"
     ]
    }
   ],
   "source": [
    "synthetic_rows = csv_parser(scrub_results(synthetic_results), 10, None, no_err=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "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$\n",
      "CLEVER     $     1.420 \\pm      0.061$ $     0.891 \\pm      0.252$\n",
      "LipProblem $   325.337 \\pm    357.716$ $     0.984 \\pm      0.238$\n",
      "LipSDP     $     2.635 \\pm      0.025$ $     1.414 \\pm      0.289$\n",
      "SeqLip     $     0.008 \\pm      0.001$ $     1.823 \\pm      0.376$\n",
      "LipLP      $     0.019 \\pm      0.009$ $     5.342 \\pm      0.991$\n",
      "FastLip    $     0.001 \\pm      0.000$ $     5.637 \\pm      1.053$\n",
      "NaiveUB    $     0.000 \\pm      0.000$ $    13.496 \\pm      1.900$\n"
     ]
    }
   ],
   "source": [
    "random_rows = csv_parser(new_rand_results, 16, None, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method     |      Time |  Time STD |     Value | Value STD |       Err |    ErrSTD\n",
      "----------------------------------------------------------------------------------\n",
      "RandomLB   $     0.297 \\pm      0.007$ $   115.579 \\pm      2.839$\n",
      "CLEVER     $     4.517 \\pm      0.076$ $   117.087 \\pm      2.716$\n",
      "LipProblem $     4.163 \\pm      0.817$ $   117.505 \\pm      2.963$\n",
      "LipLP      $     0.263 \\pm      0.020$ $   119.447 \\pm      3.075$\n",
      "FastLip    $     0.001 \\pm      0.000$ $   122.228 \\pm      3.323$\n",
      "NaiveUB    $     0.000 \\pm      0.000$ $   227.903 \\pm     35.661$\n",
      "LipSDP     $    31.700 \\pm      2.376$ $   256.955 \\pm      5.535$\n",
      "SeqLip     $     0.015 \\pm      0.003$ $   257.910 \\pm      5.502$\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "['RandomLB  ', '$     0.297 \\\\pm      0.007$', '$   115.579 \\\\pm      2.839$']"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('exp_1_MNIST_bin.pkl', 'rb') as f:\n",
    "    mnist_results = scrub_results(pickle.load(f))\n",
    "mnist_rows = csv_parser(mnist_results, 784, None, True)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9, 9, 9)"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(random_rows), len(synthetic_rows), len(mnist_rows)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_rows = []\n",
    "for i in range(1, 9):\n",
    "   all_rows.append(random_rows[i] + synthetic_rows[i][1:] + mnist_rows[i][1:]) \n",
    "\n",
    "\n",
    "rand_synth_rows = []\n",
    "for i in range(1, 9):\n",
    "    rand_synth_rows.append(random_rows[i] + synthetic_rows[i][1:])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('experiment_1_randSynth.csv', 'w', newline='') as f:\n",
    "    csvwriter = csv.writer(f, delimiter=',',\n",
    "                                quotechar='|', quoting=csv.QUOTE_MINIMAL)\n",
    "    for row in rand_synth_rows:\n",
    "        csvwriter.writerow(row)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('experiment_1_MNIST.csv', 'w', newline='') as f:\n",
    "    csvwriter = csv.writer(f, delimiter=',',\n",
    "                                quotechar='|', quoting=csv.QUOTE_MINIMAL)\n",
    "    for row in mnist_rows:\n",
    "        csvwriter.writerow(row)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
