{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine\n",
    "import numpy as np\n",
    "import torch\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "from experiment import Experiment, MethodNest, Job\n",
    "from hyperbox import Hyperbox\n",
    "from relu_nets import ReLUNet\n",
    "from neural_nets import data_loaders as dl\n",
    "from neural_nets import train\n",
    "from lipMIP import LipProblem\n",
    "from other_methods import CLEVER, FastLip, LipLP, LipSDP, NaiveUB, RandomLB, SeqLip\n",
    "from other_methods import LOCAL_METHODS, GLOBAL_METHODS, OTHER_METHODS\n",
    "from utilities import Factory, DoEvery\n",
    "import utilities as utils\n",
    "import os\n",
    "import glob"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'2DTRAIN_REGfgsm_EPOCH0000_GLOBAL.result'"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filenames = sorted(glob.glob('../jobs/completed/2DTRAIN*_GLOBAL*'))\n",
    "os.path.basename(filenames[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "def get_series_dicts(fxn):\n",
    "    series = {}\n",
    "    for filename in filenames:\n",
    "        with open(filename, 'rb') as f:\n",
    "            basename = os.path.basename(filename)\n",
    "            series_name = (basename.split('_')[1][3:])\n",
    "            series[series_name] = series.get(series_name, []) + [fxn(pickle.load(f))]\n",
    "    return series\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "20.236103057861328"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "obj = series['vanilla'][4]\n",
    "utils.filename_to_epoch(test_el['Job'].name)\n",
    "\n",
    "float(obj['do_unit_hypercube_eval'].values('RandomLB'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_value(k):\n",
    "    def fxn(obj, k=k):\n",
    "        return utils.filename_to_epoch(obj['Job'].name), obj['do_unit_hypercube_eval'].values(k=k)\n",
    "    return fxn\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['fgsm', 'l1LipReg', 'l1Penalty', 'l2LipReg', 'l2Penalty', 'vanilla'])"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "answers = get_series_dicts(get_value(None))\n",
    "answers.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "def collect_series(all_series, series_name):\n",
    "    series = all_series[series_name]\n",
    "    output = {}\n",
    "    \n",
    "    for epoch, vals in series:\n",
    "        correct = vals['LipProblem']\n",
    "        for k, v in vals.items():\n",
    "            output[k] = output.get(k,[]) + [(epoch, v / correct)]\n",
    "    return output\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for v in answers.values():\n",
    "    plt.scatter(*zip(*v))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LipProblem\n",
      "FastLip\n",
      "LipLP\n",
      "SeqLip\n",
      "LipSDP\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "cs = 'rgbmy'\n",
    "for i, (k, pairs) in enumerate(collect_series(answers, 'l2Penalty').items()):\n",
    "    if k in ['NaiveUB', 'RandomLB']:\n",
    "        continue\n",
    "    print(k)\n",
    "    plt.scatter(*zip(*pairs[8:]),c=cs[i])"
   ]
  },
  {
   "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
}
