{
 "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 seaborn as sns\n",
    "sns.set()"
   ]
  },
  {
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "width_files = sorted(glob.glob('../jobs/completed/width2Dv2*_GLOBAL*'))\n",
    "width_files\n",
    "\n",
    "width_to_int = lambda s: int(s[5:])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "def get_mid_params(filenames, fxn=None):\n",
    "    if fxn is None:\n",
    "        fxn = lambda x: x\n",
    "    series = {}\n",
    "    for filename in filenames:\n",
    "        with open(filename, 'rb') as f:\n",
    "            basename = os.path.basename(filename)\n",
    "            param_name = (basename.split('_')[1])\n",
    "            series[param_name] = fxn(pickle.load(f))\n",
    "    return series\n",
    "\n",
    "width_objs = get_mid_params(width_files)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'WIDTH0020': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312d7588>,\n",
       "  'Job': <experiment.Job at 0x7fd8312dda90>},\n",
       " 'WIDTH0040': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312d7550>,\n",
       "  'Job': <experiment.Job at 0x7fd8312dda58>},\n",
       " 'WIDTH0060': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312d7cc0>,\n",
       "  'Job': <experiment.Job at 0x7fd8312ea470>},\n",
       " 'WIDTH0080': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312d7630>,\n",
       "  'Job': <experiment.Job at 0x7fd8312eae80>},\n",
       " 'WIDTH0100': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312ea160>,\n",
       "  'Job': <experiment.Job at 0x7fd8312798d0>},\n",
       " 'WIDTH0120': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312d77f0>,\n",
       "  'Job': <experiment.Job at 0x7fd83128d320>},\n",
       " 'WIDTH0140': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312eab70>,\n",
       "  'Job': <experiment.Job at 0x7fd8312d76d8>},\n",
       " 'WIDTH0160': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd8312ea7f0>,\n",
       "  'Job': <experiment.Job at 0x7fd83129ff28>},\n",
       " 'WIDTH0180': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd83128d6d8>,\n",
       "  'Job': <experiment.Job at 0x7fd8312d7b00>},\n",
       " 'WIDTH0200': {'do_unit_hypercube_eval': <experiment.Result at 0x7fd83128d5f8>,\n",
       "  'Job': <experiment.Job at 0x7fd8312acbe0>}}"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "width_objs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "width_dict = {}\n",
    "for k,v in width_objs.items():\n",
    "    width = width_to_int(k)\n",
    "    for method, val in v['do_unit_hypercube_eval'].values().items():\n",
    "        width_dict[method] = width_dict.get(method,[]) + [(width, scale_dim(method, val, dim=2))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Lipschitz Constants Under Changing Width')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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AOORvvWiKJ7W1rn66ksr3M/MzGTu3A8BeP31N8nIOKB82+mnn8H555/F669PKU/kPvlkCZmZjfj73x8hJSWl0vHbtm3HUUcdzdSpr9KrV9+QW+FC8fPPe5gy5XXS0jIA6NSpM/fddw/vvTeXk0/+v7CdR0REJN4pkYuSeLu+3g033ELbtu3K7/snY74krqysjN27d1NaWsoRRxzNhx/OL9+ncePG/PzzT3zyyRL69TsueoEDI0acQmZmJiUlpQAMH/5rHnnk7yxZskiJnIiINChK5KKkurV1YpHIde9+eJWTHRYuXMDkyc+xcuUKiop+idm/23Lo0OH8619vceONf6BFi5b07NmbQYNOZMCAQRGfadquXfsK91NTU8nNbcPmzZsiel4REZF4o0QuSurL2jpLl37GLbfcwDHHHMv1199M8+Y5pKam8q9/vcn7779Xvt8BBxzA448/w9Kln7FkyUd8/PFi5sx5m759+3P//f8gOVlrTYuIiESaErkoqS9r67z//n844IADePDBRyos/zFr1puV9k1JSaFXrz706tWHq66CF154jqeeepwvv/ycY445NmItcxs2rK9wv6SkhC1bNtO///EROZ+IiEi8UrNJlNSX6+slJ6eQlJRMaWlpednGjRtYuPCDCvv9+GN+4EPp2rUbQHl37AEHZAJQULA7rDHOnv0v9u7dU35/zpy3+emnn8onYoiIxLNPtizlto8mcMV7N3HbRxP4ZMvSWIck9Zha5KKkvqyt07//AKZOfZXrr7+KIUOG8cMPeUyf/gbt23dgzZpV5fs9++yTfPPN1/Trdxy5uW3YufMHZsyYSuvWuRxxxJGAS+xSUlJ46aXn2bXrR9LS0ujZsw/Z2W6Zk7y8HUya9EylGDp37lJpzTp/jRplcumlv+fkk0ewffs2pk59lV/9qhuDB58c5toQEQmvT7YsZcqyaRSXFgOwszCfKcvcdUh75/aIZWhSTymRi6L6sLZO7959uemmW5ky5QUefvhBDjqoLVdc8QfWr19XIZE7/vgT2LZtK2+/PZMff8wnO7sZRx/dg9///lIaNToQgJycFtxwwy288MLz3HffPezbt4/HHnuG7Gy3FMmOHdt55pmJlWIYPHhotYncBRdcwnfffcULLzxHYeFejjvueK699iatIScicW/myjnlSZxPcWkxM1fOSZhE7pMtS5m5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pTjV1sLgmi4OMB51aEsiS54j09NMkidPnsnwOEs+6tBERESaghK5Gnqgu4sz6dkjVmfSKR7o7ooooqU1uHuE5/PTPM40PyT4+Xxea62JiIjUixK5GjrVmlpQedxorTUREZFoKZGroZUdKxZUHjeV1lTTWmsiIiL1oUSuhq7ruYa29Ow11drSbVzXc01EES0trbUmIiISLS0/UkNb124B4Dsj/8gLk6dY2bGC63qumSmPO621JiIiEi0lcjW2de2WxCRu5WitNRERkegokauxx769hwNPjDORXs6y6ZfY8gudvOE3ro46LBEREUkA3SNXQ499ew/7hnNMtJwHqRQTLeexbzjHY9/eE3VoIiIikgBK5GrowBPjZTeVP/BEMhYEFhERkWgpkauhifTyBZWLiIiILIQSuRrqmH5pQeUiIiIiC6FEroYm86dJT0/NKktPTzGZPx1RRCIiIpIkSuRqaH/rKl6cOEH71GnI52mfOs2LEyfY37oq6tBEREQkAbT8SA1lujr4MWvCo2loXQaty7SFlYiIiCwJjcjVkLawEhERkVrSiFwNaQsrERERqSUlcjWmLaxERESkVnRpVURERCSmlMiJiIiIxJQSOREREZGYivU9cma2CbgTyABZ4CPufjjaqERERETqI+4jcrcDt7n7JuA24I6I4xERERGpm9gmcma2BtgC3BsW3QtsMbPV0UUlIiIiUj+pfD4fdQyLYmZvBu5y996isp8AN7j7gTmevgF4qobhiYiIiCy1jcCR4oJY3yN3rrLZcaanGzuRXb36Ak6c+HnUYTQctcvZ1CblqV3OpjYpT+1SntrlbPVuk3Q6RSbTWb6ublEsvaPAxWbWAhD+XBeWi4iIiCRebEfk3P15MzsIXA/cHf581N1PzOPpLRBkuHEQlzjrTe1yNrVJeWqXs6lNylO7lKd2OVs926TovVpK62J7jxyAmW0mWH5kJfACwfIjPo+n7gD21DI2ERERkSV2NfBwcUGsE7lz0AFcATwLvBxxLCIiIiLVtAAXAfuByeKKZk3kRERERGIvzpMdRERERJqaEjkRERGRmFIiJyIiIhJTSuREREREYkqJnIiIiEhMKZETERERiSklciIiIiIxFdstupLGzDLAN4EeIAccBn7X3U+YWR74MTAdPvzD7v7jaCKtLzM7AkyE/wA+5e4PmNmVwB3AcuAIcIO7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\n",
      "text/plain": [
       "<Figure size 720x439.2 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "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'\n",
    "    else:\n",
    "        return k\n",
    "for i, (k, v) in enumerate(width_dict.items()):\n",
    "    if k not in ['LipProblem', 'FastLip', 'LipSDP', 'SeqLip', 'LipLP']:\n",
    "        continue\n",
    "    ax.scatter(*zip(*v), label=namer(k))\n",
    "ax.legend()\n",
    "ax.set_xlabel('Width of Hidden Units')\n",
    "ax.set_ylabel('Estimated Lipschitz Value')\n",
    "ax.set_title('Lipschitz Constants Under Changing Width')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plot_dict' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-9-bb5ed33ce204>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mcs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m'rgbmyc'\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mv\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mplot_dict\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitems\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mk\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m'NaiveUB'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m         \u001b[0;32mcontinue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m     \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plot_dict' is not defined"
     ]
    }
   ],
   "source": [
    "cs = 'rgbmyc'\n",
    "for i, (k, v) in enumerate(plot_dict.items()):\n",
    "    if k == 'NaiveUB':\n",
    "        continue\n",
    "    print(k, cs[i])\n",
    "    plt.scatter(*zip(*v), c=cs[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# DEPTH SERIES \n",
    "import math\n",
    "depth_files = sorted(glob.glob('../jobs/completed/depth2Dv2*_GLOBAL*'))\n",
    "#print(depth_files)\n",
    "depth_objs = get_mid_params(depth_files)\n",
    "depth_to_int = lambda s: int(s[-4:])\n",
    "\n",
    "depth_dict = {}\n",
    "for k,v in depth_objs.items():\n",
    "\n",
    "    depth = depth_to_int(k)\n",
    "    for method, val in v['do_unit_hypercube_eval'].values().items():\n",
    "        depth_dict[method] = depth_dict.get(method,[]) + [(depth, math.log(scale_dim(method, val, dim=2)))]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x439.2 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "long = 10\n",
    "fig = plt.figure(figsize=(long,long * 0.61))\n",
    "ax = fig.add_subplot()\n",
    "\n",
    "def namer(k):\n",
    "    if k == 'LipProblem':\n",
    "        return 'LipMIP'\n",
    "    else:\n",
    "        return k\n",
    "for i, (k, v) in enumerate(depth_dict.items()):\n",
    "    if k not in ['LipProblem', 'NaiveUB', 'FastLip', 'LipSDP', 'SeqLip']:\n",
    "        continue\n",
    "    ax.scatter(*zip(*v), label=namer(k))\n",
    "ax.legend()\n",
    "ax.set_xlabel('# of Hidden Units')\n",
    "ax.set_ylabel('Log of Estimated Lipschitz Value')\n",
    "ax.set_title('Lipschitz Constants Under Changing Depth')\n",
    "\n",
    "\n",
    "def plot_estimator(estimator):\n",
    "    for i, (reg, series) in enumerate(data[estimator].items()):\n",
    "        print(reg, cs[i])\n",
    "        plot_single_series(series[:40], c=cs[i])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "depth_dict.keys()"
   ]
  },
  {
   "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
}
