{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import numpy as np \n",
    "import torch\n",
    "from hyperbox import Hyperbox\n",
    "from interval_analysis import HBoxIA\n",
    "from relu_nets import ReLUNet\n",
    "from lipMIP import LipProblem\n",
    "from other_methods import CLEVER, FastLip, LipLP, LipSDP, NaiveUB, RandomLB, SeqLip\n",
    "from neural_nets import train\n",
    "from neural_nets import data_loaders as dl\n",
    "from experiment import Experiment, InstanceGroup, Result, ResultList, MethodNest\n",
    "from utilities import Factory\n",
    "import math\n",
    "import neural_nets.data_loaders as dl \n",
    "import neural_nets.train as train\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "sns.set()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/matt/grad/lipMIP/scripts\r\n"
     ]
    }
   ],
   "source": [
    "!pwd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('l1_exp_random_10-3.pkl', 'rb') as f:\n",
    "    output = pickle.load(f)\n",
    "    \n",
    "with open('exp_random_10-3.pkl', 'rb') as f:\n",
    "    linf_output = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "values = [_.values('LipProblem') for _ in output]\n",
    "linf_values = [_.values('LipProblem') for _ in linf_output]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'Rectangle' object has no property 'c'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-18-3ee5268a1676>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbins\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m50\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlinf_values\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbins\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m50\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mc\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'r'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/configs/env/lib/python3.6/site-packages/matplotlib/pyplot.py\u001b[0m in \u001b[0;36mhist\u001b[0;34m(x, bins, range, density, weights, cumulative, bottom, histtype, align, orientation, rwidth, log, color, label, stacked, normed, data, **kwargs)\u001b[0m\n\u001b[1;32m   2640\u001b[0m         \u001b[0malign\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0malign\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0morientation\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0morientation\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrwidth\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mrwidth\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2641\u001b[0m         \u001b[0mcolor\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcolor\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlabel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstacked\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstacked\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnormed\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mnormed\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2642\u001b[0;31m         **({\"data\": data} if data is not None else {}), **kwargs)\n\u001b[0m\u001b[1;32m   2643\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2644\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/configs/env/lib/python3.6/site-packages/matplotlib/__init__.py\u001b[0m in \u001b[0;36minner\u001b[0;34m(ax, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1599\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0minner\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\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[1;32m   1600\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1601\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msanitize_sequence\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\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   1602\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1603\u001b[0m         \u001b[0mbound\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnew_sig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbind\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/configs/env/lib/python3.6/site-packages/matplotlib/axes/_axes.py\u001b[0m in \u001b[0;36mhist\u001b[0;34m(self, x, bins, range, density, weights, cumulative, bottom, histtype, align, orientation, rwidth, log, color, label, stacked, normed, **kwargs)\u001b[0m\n\u001b[1;32m   6955\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mpatch\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   6956\u001b[0m                 \u001b[0mp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpatch\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 6957\u001b[0;31m                 \u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkwargs\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   6958\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0mlbl\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   6959\u001b[0m                     \u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_label\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlbl\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/configs/env/lib/python3.6/site-packages/matplotlib/artist.py\u001b[0m in \u001b[0;36mupdate\u001b[0;34m(self, props)\u001b[0m\n\u001b[1;32m    972\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    973\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mcbook\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setattr_cm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0meventson\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\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;32m--> 974\u001b[0;31m             \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0m_update_property\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\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;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mprops\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[0m\n\u001b[0m\u001b[1;32m    975\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    976\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mret\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;32m~/configs/env/lib/python3.6/site-packages/matplotlib/artist.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m    972\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    973\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mcbook\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setattr_cm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0meventson\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\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;32m--> 974\u001b[0;31m             \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0m_update_property\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\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;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mprops\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[0m\n\u001b[0m\u001b[1;32m    975\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    976\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mret\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;32m~/configs/env/lib/python3.6/site-packages/matplotlib/artist.py\u001b[0m in \u001b[0;36m_update_property\u001b[0;34m(self, k, v)\u001b[0m\n\u001b[1;32m    968\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0mcallable\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfunc\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[1;32m    969\u001b[0m                     raise AttributeError('{!r} object has no property {!r}'\n\u001b[0;32m--> 970\u001b[0;31m                                          .format(type(self).__name__, k))\n\u001b[0m\u001b[1;32m    971\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    972\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'Rectangle' object has no property 'c'"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(np.array(values),bins=50)\n",
    "plt.hist(np.array(linf_values), bins=50, c='r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fec29b2b6a0>"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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wz333INAIIBdu3bh2WefDV9/0KBB4Wvs2rULV1xxBTp16gSn04kNGzbg//2//4fS0lLcfffdEa+nofekR48eePTRR/H000/jqquuwlVXXQUAMBqNMamnGTNmoHfv3hHX79GjR6PejwudPHkSACJai1atWoWKigpcf/31aNeuHc6dO4f33nsPd9xxB5YsWYIhQ4bUON/hcGDmzJnIz8/HQw89hFOnTmHJkiW47777sHbtWqhUKgDBrpvbbrsNhYWFuPnmm9GjRw/s3LkTs2fPhsvliijfvHnz8Prrr2PAgAH47W9/C5vNhnfffRe33347/vnPf2LMmDE1zt+3bx+++OIL3HTTTZg6dSrWr1+P+fPnQ6vV4sMPP0THjh3xwAMP4MSJE3j77bfx8MMPY/HixY2ur969e2Py5MlYs2YN7rrrLvTu3bve83//+99j3bp1mDBhAqZPnw6Px4M1a9bgzjvvxIIFCzBu3LgGPzMjRozA6tWr4XK5oNPpAABbt26FKIrYuXMn/H5/uH63bduGnj17onXr1gCa9/fvmWeegc/nw0033QSj0Yhu3brV+tp++OEH/PKXv0RGRgZWrFgRbvH69a9/jV27duHmm29GXl4eXC4XCgoKsGPHDsyZM6fRdU0Kk6lF2bZtm2yxWOTXX3+9Uee9//77EccGDhwonz17Nnzc7XbLP/vZz+S+ffuGj2/cuFG2WCzyunXr6r3Pq6++KlssFnn+/PkRj/n9/vDvX3rpJdlisci//OUv5UAgED6+e/du2WKxyM8991yN51osFvnhhx9u8Fht3G63fOutt8r9+/eXv/3223rPXbJkiWyxWOQ33nijweuGPP/887LFYpGXLl1a4/jSpUtli8Uiv/DCC+Fj77//vmyxWOSpU6fKbrc7fLywsFC++OKL5Yceeih87G9/+5tssVjk8+fP13v/hx9+WLZYLLU+ZrfbI475/X555syZ8qBBg2SPxxM+3pT35OTJk7LFYpFfeumlestWXVPqqanXD32WFyxYIJeUlMglJSXygQMH5D//+c+yxWKRb7jhhojn1FY3xcXF8rBhw+Q5c+bUOD5z5kzZYrHIr776ao3jr732mmyxWOQvv/wyfGz+/PmyxWKRV65cWePcp556SrZYLPLMmTPDxwoKCuS8vDz55ptvjvg8DB48WL7yyitln88XPm6xWOS8vDz5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GHjS0Jo1a1BYWBj+s8fjweLFi6FSqcLTg8vLyyNaAzIyMsIzf9xuN4DgeKCKiopax0zE+n/BBoOh1qb6EydO4P7770e7du2wcOHCGmMjGqLRaPCb3/wGdrsdDz30UK3jldxuN55//vnwY6HxCxdO9X733XdRWlra7IURS0tLI451794dWq0WFRUV4WOhsSgX1kWopebCei8qKqp1WnpThO5ZvRwNiVc9NeS+++6DSqXCSy+9FD4Wagm5sG62bNmC3bt3R3W/cePG4fz58/jwww9rHH/ttdcizh07diwEQcCiRYvg9XrDx4uKivDBBx+gY8eO6Nu3b1TliYZer8eDDz6I48eP49133414/Prrr0cgEMDzzz9f6/OrTx1v6DMzfPhwCIKAl19+GV6vNxx4LBYLcnJysHDhQsiyXGP8DhCfz5XJZMKiRYuQn5+P3/zmN/jkk0/CjzmdzohQrFKpwkteNOXvBCmLXVot1NatW8Oho7rs7Gzccsst9T63W7duuPHGG3HzzTfDaDRi7dq12Lt3L+677z60b98eAPDhhx/irbfewvjx49GlSxeo1Wrs3LkTW7ZswTXXXBNuIp49eza++OILvPzyy9i7dy9Gjx4NjUaDw4cP4+jRo02aHtuQgQMHYuvWrXj11VfRoUMHCIKAa6+9FnPnzkV5eTluueUWfPnllxHPq74wXW1uuOEGFBYWYuHChbj66qtrrLRcUFCADRs2oLS0FL/85S8BAHPmzMGGDRvwxBNPYN++fejTpw/279+PlStXolu3bs2epvqnP/0JhYWFGD16NDp06ACXy4X169fDbrfXeA35+flYunRpeB0SSZIwYMAAdO7cGaNGjcLq1auh0+nQv39/nD59GitWrECnTp2aNa4jJDs7G126dMG6devQuXNntG7dGnq9vt61eOJVTw3p0qULJk2ahDVr1mDXrl0YMmQIBg8ejNzcXDzzzDM4ffo02rVrh/379+Ojjz6CxWLBwYMHm32/OXPmYO3atfjTn/6EH374AT179sSOHTvw3Xff1Rj8CgQD7F133YXXX38dM2fOxDXXXAO73Y53330XDocDzz33XL1dWIlwww034M0338TevXsjHps4cWJ4ja0ffvgBV155JbKzs1FYWIjvvvsOx48fx2effQag4c9MVlYWevfujf3796Njx441WmaGDx+Ojz/+GJIk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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",
    "sns.set(font_scale=1.5)\n",
    "sns.distplot(np.array(values), ax=ax)\n",
    "sns.distplot(np.array(linf_values), ax=ax)\n",
    "ax.set_title('Lipschitz Constant of Random Networks')\n",
    "ax.set_xlabel('True Lipschitz Value')\n",
    "ax.set_yticklabels('')\n",
    "ax.legend(['$L^1(f)$', '$L^{\\infty}(f)$'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
