{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "sns.set()\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def scale_dim(method, val, dim=2):\n",
    "    if method == 'LipSDP':\n",
    "        return val * (dim**0.5)\n",
    "    return val\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "set([os.path.basename(_).split('_')[1][3:] for _ in glob.glob('../jobs/completed/l1_2DTRAINv2_*')])\n",
    "files = sorted(glob.glob('../jobs/completed/l1_2DTRAINv2_REGvanilla*'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0000_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0025_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0050_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0075_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0100_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0125_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0150_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0175_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0200_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0225_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0250_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0275_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0300_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0325_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0350_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0375_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0400_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0425_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0450_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0475_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0500_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0525_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0550_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0575_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0600_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0625_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0650_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0675_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0700_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0725_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0750_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0775_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0800_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0825_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0850_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0875_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0900_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0925_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0950_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH0975_GLOBAL.result',\n",
       " '../jobs/completed/l1_2DTRAINv2_REGvanilla_EPOCH1000_GLOBAL.result']"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "files"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "def get_series_by_method(filenames, fxn=None):\n",
    "    if fxn is None:\n",
    "        fxn = lambda x: x\n",
    "    reg_series = {}\n",
    "    for filename in filenames:\n",
    "        with open(filename, 'rb') as f:\n",
    "            obj = pickle.load(f)\n",
    "            basename = os.path.basename(filename)\n",
    "            epoch = utils.filename_to_epoch(filename)\n",
    "            for k, v in obj['do_unit_hypercube_eval'].values().items():\n",
    "                if k not in reg_series:\n",
    "                    reg_series[k] = []\n",
    "                reg_series[k].append((epoch, float(scale_dim(k, v))))\n",
    "    return reg_series\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['LipProblem', 'FastLip', 'LipLP', 'SeqLip', 'LipSDP', 'NaiveUB', 'RandomLB', 'CLEVER'])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Lipschitz Estimators During Training')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x439.2 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = get_series_by_method(files)\n",
    "print(data.keys())\n",
    "def plt_series(data, series, c):\n",
    "    plt.scatter(*zip(*data[series]), c=c,)\n",
    "markers = \".*+1\"\n",
    "\n",
    "long = 10\n",
    "fig = plt.figure(figsize=(long,long * 0.61))\n",
    "ax = fig.add_subplot()\n",
    "sns.set(font_scale=1.5)\n",
    "def namer(k):\n",
    "    if k == 'LipProblem':\n",
    "        return 'LipMIP (ours)'\n",
    "    elif k == 'LipLP':\n",
    "        return 'LipLP (ours)'\n",
    "    else:\n",
    "        return k\n",
    "for i, series in enumerate(['LipProblem', 'LipLP', 'LipSDP', 'FastLip',]):\n",
    "    ax.scatter(*zip(*data[series]), label=namer(series), marker=markers[i], s=120)\n",
    "ax.legend()\n",
    "ax.set_xlabel('Training Epoch')\n",
    "ax.set_ylabel('Reported Lispchitz Value')\n",
    "ax.set_title('Lipschitz Estimators During Training')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QEREIhySgyAiIufHAEFERGa5xQODlEqFU53HVXC87suTxgpwvHK9XiEIZh5dRkREHo9LTEREZBYDBBERmcUAQUREZjFAEBGRWQwQRERkFgMEERGZxQBBRERmMUAQEZFZDBBERGQWAwQREZnl0QFCq9Xitddew8iRI3Httdfivvvuw969ex19WTYrKSnB//3f/yEzMxOJiYkYM2YM5s+fj7Nnz5ocW1xcjGnTpuG6667DLbfcgpdffhkXL140Oc7VfierVq1CXFwcJkyYYNLnLmMuKSnBnDlzcMMNNyApKQn33HMP8vPzjY7ZtWsXsrKyMHz4cIwZMwbLli1Da2urybnq6urw/PPP46abbkJiYiJmzpyJ0tLS7hqKqF9//RW5ubkYNWoUEhMTkZmZibfffhtardboOFd7XysqKpCXl4fs7GwkJSUhLi4O+/fvN3usHO+jrec0x+uFF154weaRupkFCxYgPz8f9913H8aPH4+TJ0/i3XffRWpqKvr06ePoy7PqH//4B7777jvcdtttyMrKwqBBg1BYWIi1a9fijjvuQGhoKACgtLQUM2bMQK9evfDwww8jJiYGH374IY4fP45x48YZndOVfidqtRrz5s2Dj48PevXqhWnTphn63GXMe/bswaxZs9CnTx9MmzYNo0aNQs+ePaHVapGSkmI45tFHH8VVV12Fhx56CL169cK7776L2tpajB492nAunU6HnJwc7Nu3Dw888ADGjh2LAwcOYO3atUhPT0evXr0cNUxcuHABWVlZqKmpwfTp05GWlobW1lasXr0av//+O+68804Arvm+Hj16FM8//zy8vb3Rv39/lJeXIysrC/369TM6To730dZzWiR4qCNHjghDhw4V3n//fUNbc3OzkJaWJkyfPt1xF9YJhw4dEjQajVHbmTNnhGuuuUZ4+umnDW0PPfSQcOuttwoNDQ2Gto8//lgYOnSo8P333xvaXO138vTTTwvZ2dnCjBkzhHvuuceozx3GXFdXJ6SmpgovvfSS6HGZmZlCVlaW0Nraamh7/fXXhfj4eOHMmTOGtm3btglDhw4VvvjiC0NbVVWVcP311wsLFiyQ/Po7Y+XKlcLQoUOFU6dOGbU//vjjwtVXXy1otVpBEFzzfa2vrxeqq6sFQRCEL774Qhg6dKiwb98+k+PkeB9tPaclHrvEVFhYCB8fH0yZMsXQ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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_run(run_name, methods):\n",
    "    cs = 'rgbcymB'\n",
    "    files = sorted(glob.glob('../jobs/completed/2DTRAINv2_REG%s*.result' % run_name))\n",
    "    data = get_series_by_method(files)\n",
    "    for i, series in enumerate(methods):\n",
    "        plt_series(data, series, c=cs[i])\n",
    "    \n",
    "plot_run('fgsm', ['LipProblem', 'LipLP', 'SeqLip', 'LipSDP'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "xs = [_[0] for _ in data['LipProblem']]\n",
    "ys = [_[1] for _ in data['LipProblem']]\n",
    "sns.scatterplot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "tips = sns.load_dataset('tips')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "tips.__class__"
   ]
  },
  {
   "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
}
