{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Experiment 4\n",
    "# ==================================\n",
    "\n",
    "# estimate the number of encountered polytopes when varying the neural\n",
    "# network architecture / capacity. Again, classifier trained on random\n",
    "# data in R^2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/justin/Programs/anaconda3/envs/DeepL/lib/python3.6/site-packages/matplotlib/cbook/deprecation.py:107: MatplotlibDeprecationWarning: Adding an axes using the same arguments as a previous axes currently reuses the earlier instance.  In a future version, a new instance will always be created and returned.  Meanwhile, this warning can be suppressed, and the future behavior ensured, by passing a unique label to each axes instance.\n",
      "  warnings.warn(message, mplDeprecation, stacklevel=1)\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from plnn import PLNN\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.autograd import Variable\n",
    "import utilities as utils\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============Generating Training Points============\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# ==================================\n",
    "# Generate Training Points\n",
    "# ==================================\n",
    "\n",
    "print('===============Generating Training Points============')\n",
    "# random points at least 2r apart\n",
    "m = 12\n",
    "np.random.seed(3)\n",
    "x = [np.random.uniform(size=(2))]\n",
    "r = 0.16\n",
    "while(len(x) < m):\n",
    "    p = np.random.uniform(size=(2))\n",
    "    if min(np.abs(p-a).sum() for a in x) > 2*r:\n",
    "        x.append(p)\n",
    "# r = 0.145\n",
    "epsilon = r/2\n",
    "\n",
    "X = torch.Tensor(np.array(x))\n",
    "torch.manual_seed(1)\n",
    "y = (torch.rand(m)+0.5).long()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============Initializing Network============\n",
      "Sequential(\n",
      "  (1): Linear(in_features=2, out_features=6, bias=True)\n",
      "  (2): ReLU()\n",
      "  (3): Linear(in_features=6, out_features=6, bias=True)\n",
      "  (4): ReLU()\n",
      "  (5): Linear(in_features=6, out_features=6, bias=True)\n",
      "  (6): ReLU()\n",
      "  (7): Linear(in_features=6, out_features=6, bias=True)\n",
      "  (8): ReLU()\n",
      "  (9): Linear(in_features=6, out_features=2, bias=True)\n",
      ")\n",
      "===============Training Network============\n",
      "error:  tensor(0.2500)\n",
      "===============Gathering Polytopes============\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/justin/Programs/anaconda3/envs/DeepL/lib/python3.6/site-packages/torch/tensor.py:255: UserWarning: non-inplace resize is deprecated\n",
      "  warnings.warn(\"non-inplace resize is deprecated\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of polytopes: 26\n",
      "===============Initializing Network============\n",
      "Sequential(\n",
      "  (1): Linear(in_features=2, out_features=100, bias=True)\n",
      "  (2): ReLU()\n",
      "  (3): Linear(in_features=100, out_features=100, bias=True)\n",
      "  (4): ReLU()\n",
      "  (5): Linear(in_features=100, out_features=100, bias=True)\n",
      "  (6): ReLU()\n",
      "  (7): Linear(in_features=100, out_features=100, bias=True)\n",
      "  (8): ReLU()\n",
      "  (9): Linear(in_features=100, out_features=2, bias=True)\n",
      ")\n",
      "===============Training Network============\n",
      "error:  tensor(0.)\n",
      "===============Gathering Polytopes============\n",
      "number of polytopes: 4430\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAecAAAHWCAYAAABNK0FcAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvhp/UCwAAIABJREFUeJzt3XlwnHed5/HPtw9JtmzLh3zf8ZHECTlFCIQZEhJ2EpaKdwaYSnaoGSiWZIdhtnagWJgixVAMuzUwxVJDVWqIZ5biqBrOP8BQYUIRwjGAgx1yOzE4dhzLR3zIp6yru7/7hyQj62g9krr7+T3P835VucpSP1a+efz4eev3dPcjc3cBAIBw5OIeAAAAXIo4AwAQGOIMAEBgiDMAAIEhzgAABIY4AwAQmEnjbGZfNLNjZvbcBI+bmX3ezPaa2TNmdkPtxwQAIDuirJy/JOnOKo/fJWnT0K/7JP3zzMcCACC7Jo2zu/9MUleVTbZK+ooP2iFpvpktr9WAAABkTS2ec14p6eCIjzuHPgcAAKahUIOvYeN8btx7gprZfRq89K3W1tYbr7jiiksef/V0DaYBACBmS+eP/dwTTzxxwt0XR/nztYhzp6TVIz5eJenweBu6+zZJ2ySpo6PDd+3adcnj//e73OcbAJB8H9w6dt1qZgei/vlaXNbeLunPh161fbOkM+5+pAZfFwCATJp05WxmX5N0q6R2M+uU9HeSipLk7l+Q9LCkt0raK+mCpPfUa1gAALJg0ji7+72TPO6S/qpmEwEAkHHcIQwAgMAQZwAAAkOcAQAIDHEGACAwxBkAgMAQZwAAAkOcAQAIDHEGACAwxBkAgMAQZwAAAkOcAQAIDHEGACAwxBkAgMAQZwAAAkOcAQAIDHEGACAwxBkAgMAQZyCiSrmi3p5+lUuVuEcBkHKFuAcAQtfb06/du17Wwb3H5JLkruXrFunq165X69xZcY8HIIWIM1BF74V+/fg7v1Ff74C84hc/f2j/CR3rPKVbt16vuW2zY5wQQBpxWRuo4rlf71NfT/8lYZYkuTTQX9aTP/9dPIMBSDXiDEygXCqrc/8JuU+8Tdfxc+rp7mvcUAAygTgDE+jrHZBZ9W1yedOF88QZQG0RZ2ACxabC2MvZo3jZ1dxSbNBEALKCOAMTKDYVtHjl/KrbtM5r0Zw2XrENoLaIM1DFa27aoEIxP+5j+UJO192yqcETAcgC4gxUMW/BbL3pbddqfvsc5fI5FYp55Qs5zWmbpVv+6Gq1L2uLe0QAKcT7nIFJtC2aozf/lxt0/myPes73qXlWUfMWtMY9FoAUI85ARHPmzdKceTy/DKD+uKwNAEBgiDMAAIEhzgAABIY4AwAQGOIMAEBgiDMAAIHhrVQAgGBUKq6jB0+q86XjKpXKWrx8vtZuXqqm5mzdw544AwCC0HuhXz/7/tPq7elXaaAsSTp+6LR2P/Gybr5ji5auWhjzhI1DnCUdPnBCe556RWdOdstypuVrFuny69aobSF3gQKARnB3/ce/P6vucz2X/Az1crkiSdrxo9264+03qnVuNm4ElPnnnJ/Z8ZJ2PvaiTh0/r0rFVS5V1Ln/uH6y/UkdO3Qq7vEAIBO6jp1T99lLwzxSpeLa+9yhxg4Vo0zH+cTRM9r/4hGVS5VLH3CpXKpox492X/yuDQBQP8cOdY09F4/gFdeRV7oaONH03X/0gRl/jUzH+XfPHKx6MMilw/tPNG4gAMioiVbMl25U9zFmrBZhljL+nPOZru6qj5dKZZ3p6tbqBs0DAFm1ZMV8/e7ZzgkXTGbS0tULGjxVdLWK8rBMr5wLxXzVxy1nKjZn+vsXAGiIRcvaNHtOs8zGfzyXz2nT1asaO1REtQ6zlPE4r7tiufL5iXeBmWnV+vYGTgQA2WRmuuXO16iltVmFwu8XTrm8KZ/P6bW3Xak5beG9UrseYZYyfll77aal+u3TB1Xp6R/zfEc+n9OKde1q5ef3AkBDzJ7Toj9652t16OUTOrj3mMqlihavaNO6y5erZXZT3OONUa8wSxmPc7GpoNu2Xq8dP9qts13dkg1+91apVLR60xJd94aNcY8IAJmSy+e0esMSrd6wJO5RJlTPKA/LdJwlaVZrs27ber3OnupW1/FzyudyWrJqgZpbsnWrOADA5BoRZok4XzRvQavmLeCOYACA8TUqzBJxBgCgqkZGeVimX60NAEA1cYRZIs4AAIwrrjBLxBkAgDHiDLPEc84AAFwUd5SHsXIGAEDhhFkizgAABBVmiTgDADIutDBLPOcMAMioEKM8jJUzACBzQg6zRJwBABkTepgl4gwAyJAkhFniOWcAQAYkJcrDWDkDAFItaWGWiDMAIMWSGGaJy9oAgBRKapSHsXIGAKRK0sMsEWcAQIqkIcwScQYApERawizxnDMAIOHSFOVhrJwBAImVxjBLxBkAkFBpDbNEnAEACZTmMEs85wwASJC0R3kYK2cAQCJkJcwScQYAJECWwixxWRsAELCsRXkYK2cAQJCyGmaJOAMAApTlMEtc1gYABCTrUR4WKc5mdqekf5KUl/Sv7v4Pox5fI+nLkuYPbfNRd3+4xrMCQFWNPLE/tOxTDftvZQVh/r1J42xmeUkPSnqLpE5JO81su7vvHrHZA5K+6e7/bGZbJD0saV0d5gWQAUk4SU80I9GeniT8nTdSlJXzTZL2uvs+STKzr0vaKmlknF3SvKHft0k6XMshAaRPWk/Gw/9fRDq6tB4LMxElzislHRzxcaek143a5hOSfmhmfy2pVdIdNZkOQOJl9cQ78v+bUE8sq8fHZKLE2cb5nI/6+F5JX3L3z5rZ6yV91cyudvfKJV/I7D5J90nSmjVrpjMvgEBxkp0YoR4fx8zEosS5U9LqER+v0tjL1u+VdKckufuvzKxFUrukYyM3cvdtkrZJUkdHx+jAA0gATqgzQ6gHcRxVFyXOOyVtMrP1kg5JukfSfx21zSuSbpf0JTO7UlKLpOO1HBRAY3HyrL+shppja3KTxtndS2b2AUmPaPBtUl909+fN7JOSdrn7dkkfkvQvZvY3Grzk/W53Z2UMJAQny/hlJdQca9FEep/z0HuWHx71uY+P+P1uSbfUdjQA9cRJMlxpDTXHXHTcIQzIGE6QyTL67ytNscbEiDOQAQQ5PZK6quYYnBriDKQYJ8R0S0qoOQ6njjgDKcTJMHtCDTXH4vQQZyAlOAliWCih5picPuIMJBwnQFTDvb6TKRf3AACm5/6jDxBmRNboY4Vjc2aIM5BAnPgwHY06bjg+Z444AwnCahkzVe/jh+OzNogzkBCc9BA6jtHaIc5AAnDSQ+g4RmuLOAOB46SHWqv1McUxWnvEGQgYJz0gm4gzECjCjHqq1fHFcVofxBkIECc8JAHHaf0QZyAwnPCQBByn9UWcgYBwwkMjTfd44zitP+IMBIITHpKA47QxiDMAZBixDRNxBgLACRJJwHHaOPzISCBmnPAQOo7RxmPlDAAZVy2+hDkexBmIESc+hIzjMz7EGYgJJz4AEyHOAIAx3yzyzWO8eEEYEANOfAgRx2U4WDkDDcYJEMBkiDMAAIEhzkADsWoGEAVxBhqEMAOIiheEAZi2cn9JRx8/oMP/sU+l7n7NWjJHq2/frIVblsnM4h4PSCziDDRAGlfN/ef79ORnf6y+M72q9JclSX2ne3T25S61v2aFrvyLm2Q5Ag1MB5e1gTpLY5gl6cWv7FRv14WLYR5W6S/rxLOHdeSX+2OaDEg+4gxgyvpO9+j0b4/Jyz7u45X+sl754YsNngpID+IM1FFaV83nDp6SFaqfPnpPXVBloFx1GwDjI84ApixXyEfYymR5TjHAdPAvB6iTtK6aJaltQ7tUGf+S9rD5m9p5QRgwTcQZqIM0h1mS8k15rb7jcuWaxl9B54p5rX/bVQ2eCkgP4gxgWtbedaVW3LJeVsjJioOnklxzQbmmvK58901qu6w95gmB5OJ9zkCNpX3VPMzMtPHt12n17Zfr2JOdGjjfp9lL5mrx9SuVb+LUAswE/4KAGspKmEdqnj9Lq2/bFPcYQKpwWRsAgMAQZ6BGsrhqBlAfxBkAgMAQZ6AGWDUDqCXiDABAYIgzMEOsmgHUGnEGACAwxBmYAVbNAOqBOAMAEBjiDEwTq2YA9UKcAQAIDHEGpoFVM4B6Is4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAPT8NCyT8U9AoAUI84AAASGOAMAEBjiDEwTl7YB1AtxBgAgMMQZAIDAEGdgBri0DaAeiDMAAIEhzgAABIY4AzPEpW0AtUacgRog0ABqiTgDABAY4gzUCKtnALUSVJzvP/rAxV9AEhFoALUQVJxHItJIKgINYKaCjfMwIo0kemjZp4g0gGkLPs7DiDSSiEADmI7ExHkYkUbSEGgAU1WIe4DpGhloTn4I3fAxyjeWAKJI3Mp5PKymkRR8IwkgikhxNrM7zWyPme01s49OsM2fmtluM3vezP6ttmNGQ6SRBLxYDMBkJr2sbWZ5SQ9KeoukTkk7zWy7u+8esc0mSX8r6RZ3P2VmS+o1cBTDgeYEiJBxqRvARKKsnG+StNfd97l7v6SvS9o6apv3SXrQ3U9Jkrsfq+2Y08NKGknAN5EARosS55WSDo74uHPocyNtlrTZzH5hZjvM7M5aDVgLRBqh41I3gJGixNnG+ZyP+rggaZOkWyXdK+lfzWz+mC9kdp+Z7TKzXcePH5/qrDNGpBE6Ag1AivZWqk5Jq0d8vErS4XG22eHuA5L2m9keDcZ658iN3H2bpG2S1NHRMTrwDcPbsBAynosGEGXlvFPSJjNbb2ZNku6RtH3UNt+RdJskmVm7Bi9z76vloPXCahqh4lI3kF2TxtndS5I+IOkRSS9I+qa7P29mnzSzu4c2e0TSSTPbLekxSR9295P1GroeiDRCRaCB7DH3eK4ud3R0+K5duy75XPdDH4tllvFwQkSI+AYSSIbW+//3mM+Z2RPu3hHlz6fiDmH1wEoaIeJSN5ANxHkSRBohItBAuhHniIg0QsMqGkgv4jxFRBqhIdJA+hDnaSLSCA2RBtKDOM8QgUZohiNNqIHkinKHMEzi/qMPcCJEkEYfl3wzCSQDca4RfkwlkmDk8UmogXBxWbvGOOEhKbj8DYSLONcBgUbSEGogLMS5Tgg0kopQA/HjOec64nloJB3PUQPxYOXcAJzUkAasqIHGIc4NQqCRJoQaqC8uazcQl7mRRlz6xrCBC/06f/C0LG+au3ah8sV83CMlFnGOATctQVoR6mwq95X022/8Rsd/0ykrDF2QdWnVmzdp3V1bZDmLd8AEIs4xIdBIO0KdDZVyRU99/qc6f+iMvFSRSpWLjx189LfqP9ury++9McYJk4nnnGPECQtZwXPU6XXy2SO6cOTsYJhHqfSX9erjB9Rz/HwMkyUbK+eY8Tw0soYVdboc+vlLKveXJ3zc3XX01we0/j9f1cCpko+VcyA4SSGLWE0nX//Z3qqPe9nVf6b6NhiLOAeEQCOruOydXLOXzK36eK6Y0+yl1bfBWMQ5MPcffYBII9OIdLKsum2jck0Tv2XKXVr6urUNnCgdiHOgCDSyjkgnQ9uGdi25YdW4gc4V89r49mvVNKc5hsmSjTgHjEADRDp0ZqbL/6xDG//kWjUvmCXLmyxnmrNqvq76bzdr5R9siHvEROLV2oHj/dDAoOF/B3zTGh4z04o3Xqblt6xXubcky5nyzeRlJth7CcDbrYDf461Y4TIzFWYV4x4jFbisnSCciIBLcckbaUWcE4ZAA2MRaaQNcU6gtAXa3VWpjL31HzBVRBppwXPOCZWG56G7z/bohd8cUOe+46pUXM0tRW24aoU2vWa18gW+b8T08eIxJB1xTrikvpr7TFe3fvq9p1QqlSUf/Fxf74BefOqgDh84qTe97VrlC/wsWMzM6H8btYg1L0hDIxDnFEhioHc+9oJKA2Nvll8pV3T21AXtfe6QLr9uTQyTIc1q/e+kHvEHJJ5zTo0k3fbzzMnz6j438Y3wK+WK9j5/qIETAbWRtG+SES7inDJJCPT5sz0ys6rb9PUMqFLxBk0E1A6BRi0Q5xQKPdDFCHcOyuVzmqTfQLB41ThmijinVMiBbl82X5arUl6TVm1YPOnqGggdgcZ0EecUCzXQuZzpmtddpnx+/MOvUMjryut5MRjSgUBjOohzyoUa6LWbl+m6Wzaq2FxQoZhXoZhXvpDTvAWtuvXu69Q6d1bcIwI1Q6AxVbyVKgNCfavV2s3LtHrjUp08ekb9/SXNmTdLbQtb4x4LAGLHyjkjQl1B53KmxSvma+W6dsIMAEOIc4aEGmggC0K8eoVwEeeMIdAAED7inEEEGgDCRpwzikADQLiIMwAAgSHOGcbqGQDCRJwzjkADQHiIMwg0AASGOEMSgQaAkBBnXESgASAMxBmXINAAED/ijDEINADEizgDABAY4oxxsXoGgPgQZ0yIQANAPIgzqiLQANB4xBmTItAA0FjEGQCAwBBnRMLqGZi5h5Z9Ku4RkBDEGZERaABoDOKMKSHQAFB/xBlTRqABoL6IMwAAgSHOmBZWzwBQP8QZ00agAaA+iDNmhEADQO0V4h6gmv5zfTr46G915Ff7Ve4dUFPbLK26daNW/MEG5Yv5uMfDkPuPPsD7NwGghoKNc++pC3riM4+q1DMgL1UkSX1dF7T/e8/r2K6Duu5/3qp8E4EGAKRPsJe1X/zqTg10918M87DKQFnnj5zRgUdeiGkyjIfL2wBQO0HGuffUBZ3Zd1Kq+LiP+0BFh3/2knyCxxEPAg1MjqeAEEWQcb7w6jnlitVHK/eXVeodaNBEiIpAA8DMBRnnQktRqkyykbtyvCgsSAQaAGYmyDjPXbNAuUle7DX/8iW8YjtgBBoApi/IOFvOtOGPr5lwZZxryuuyu69u8FQAADRGkHGWpGU3rdWmd16nfEtB+ZaCck155ZsLampr0TXvf6Pmrl4Q94iYBKtnAJieYN/nLEnL37BeS1+7Rl0vvqqB8/1qWTRb8zculuUs7tEQETcoAYCpC3blPCxXzKv9NSu0/PXrtGDzEsKcQKygAWBqgo8z0oFAA0B0keJsZnea2R4z22tmH62y3TvMzM2so3YjIi0INABEM2mczSwv6UFJd0naIuleM9syznZzJf0PSY/XekikB4EGgMlFWTnfJGmvu+9z935JX5e0dZzt/l7SZyT11nA+AEgdXiSJyUSJ80pJB0d83Dn0uYvM7HpJq939+zWcDSnF6hkAqosS5/FeHn3xJ06YWU7S5yR9aNIvZHafme0ys13Hjx+PPiVSh0ADwMSixLlT0uoRH6+SdHjEx3MlXS3pJ2b2sqSbJW0f70Vh7r7N3TvcvWPx4sXTnxqpQKABYHxR4rxT0iYzW29mTZLukbR9+EF3P+Pu7e6+zt3XSdoh6W5331WXiZEqBBoAxpo0zu5ekvQBSY9IekHSN939eTP7pJndXe8BkX4EGgAuFen2ne7+sKSHR33u4xNse+vMx0LWcJtPAPg97hCGYLCCBoBBxBlBIdAAQJwRIAINIOuIM4JEoAFkGXFGsAg0gKwizggagQaQRcQZwSPQSCPeOohqiDMSgUADyBLijMQg0ACygjgjUQg0gCwgzkic+48+QKQBpBpxRmIRaABpRZyRaAQaQBoRZyQegQaQNsQZqUCgAaQJcUZqEGgAaUGckSoEGkAaEGekDoEGkHTEGalEoAEkGXFGahFoAElFnJFqBBpAEhFnpB6BBpA0xBmZQKABJAlxRmYQaABJQZyRKQQaQBIQZwAAAkOckTmsngGEjjgjkwg0gJARZ2QWgQYQKuKMTCPQAEJEnJF5BBpAaIgzIAINICzEGQCAwBBnYAirZwChIM7ACAQaQAiIMzAKgQYQN+IMjINAA4gTcQYmQKABxIU4A1UQaABxIM7AJAg0gEYjzkAEBBpAIxFnICICjVrieEI1xBmYAk6oABqhEPcAQNLcf/QBPbTsU3GPgSk6feK8XnjygF492CV317wFrbri+jVasa5dZhb3eMAlWDkD08AKOlmOvHJSP/3eUzpy4KQqFZe7dKarW7t+ukfP7Hgp7vGAMYgzME33H32ASCdAqVTWr3/8gsrlypjHyqWKXt5zVCeOnolhMmBixBmYIQIdtkP7jld9vFyq6HfPdjZomkEcM5gMcQZqgJNtuM6cuqByaeyqeaSzXd0NmgaIhjgDNUKgw9TUlJflqr/gq9jMa2MRFuIM1BCBDs+qy5ZUfTV2vpDTusuXNXAiYHLEGagxAh2WOW2ztHJ9u/KFsac7M6m5pag1G5c2bB6OD0RBnIE64AQclhv/8HKt3bxUuXxOhWJehWJeuXxOi5a26da7r1ehmI97ROASPNEC1Ak3KwlHLme67g2btOXGdTp++LTK5YoWLp6nOW2z4h4NGBcrZ6COWEGHpam5qJXrF2vNxqWxhJnjAVERZ6DOuFkJgKkizkCDEGgAURFnoIEINIAoiDPQYAQ6m/h7x1QQZyAGnKgBVEOcgZgQ6Ozg7xpTRZyBGHHSBjAe4gzEjEADGI04AwEg0OnF3y2mgzgDgeAkDoSn/1yfLrx6TqW+UkP/u9xbGwjIcKC5J3c68A1Xcp090KW9335a5w6eUi6fk5crar9+pTb+ybVqmttS9/8+K2cgQJzUgficfumEnvqnn+rs/pPyUkXlvpIqpYqOPdGpXZ9+VP3n++o+A3EGAkWgk42/v2Ryd7341Z2q9JfHPlhxDZzr04F/f6HucxBnIGD80Ixk4u8suc53nlb/2d4JH/dyRUd+uV/uXtc5iDOQAJzsgcboO9Ujy1nVbSoDFVUGKnWdgzgDCUGgk4G/p2RramuRJlkV5wo55Yr1zSdxBhKEE3/Y+PtJvrlrFqjQ2jzh45Y3Lbt5rcyqr65nijgDCcPz0ED9mJmu+LMblSvmxz6Ykwqzm7T2ri11n4M4AwlFoMPC30d6LLh8qa75qzeqdWWbcsW88i0FWSGnRVctV8dH7lDzvPq/z5mbkDSIu9f9Mgiy5/6jD3DDkgAQ5vSZv3GxXvu3b1FvV7cGuvvVsmC2inMmvtxda8S5jvrP9eqVH+7RkV+9rHLvgIqtTVrxBxu0+vbNKswqxj0eUoJAx4cop1/Lwla1LGxt+H+XONdJ3+kePfGZRzXQ3S8vD77kfqC7X6/8aI+OPXFQN/6v2wk0aobbfjYeYUY98Zxznez52hPqP997MczDvFRRb1e39m1/NqbJkGYEozHYz6g34lwH/ed6dWrPMWmC96h72XX08QOqDIxzezhghghHfbF/0QiR4mxmd5rZHjPba2YfHefxD5rZbjN7xsweNbO1tR81OXpOdCtXmHzX9p+r/83TkU283ao+2KdolEkLYmZ5SQ9KukvSFkn3mtnoN3k9KanD3a+R9G1Jn6n1oElSmFWUV6rfYcbLrnwLT/mjvohJ7bAv0UhRVs43Sdrr7vvcvV/S1yVtHbmBuz/m7heGPtwhaVVtx0yW2UvnqmmS98HNW79QxdlNDZoIWUZUZo59iEaLEueVkg6O+Lhz6HMTea+kH8xkqKQzM21653Xj32FGUq6Y14Y/vqbBUyHLiMv0se8QhyhxHu/OGeNeszWzd0nqkPSPEzx+n5ntMrNdx48fjz5lAi26arm2vOd1Ks5pVr65cPFX84JZuub9b9S8tQvjHhEZw/PQU8f+QlyiPOnZKWn1iI9XSTo8eiMzu0PSxyS9yd3HfaWTu2+TtE2SOjo66vvDMAPQfs0KLbp6uU7vPa7+s31qWThL89Yv4k5hiBU3LYmGMCNOUVbOOyVtMrP1ZtYk6R5J20duYGbXS3pI0t3ufqz2YyaX5UwLNi/R0o7VarusnTAjCISnOvYP4jbpytndS2b2AUmPSMpL+qK7P29mn5S0y923a/Ay9hxJ3xqKzyvufncd5wYwQ9xVbCyijFBEei+Puz8s6eFRn/v4iN/fUeO5ADQIl7kHEWaEhDuEAch0mHihHEJEnAFIymaksvb/i+QgzgAukYVgZfEbESQL948EMEZaXyxGkJEUxBnAhNISaaKMpCHOACaV1EgTZSQVcQYQ2cjYhRxqooykI84ApiWU1TQhRhoRZyAA5f6Syr0lFVqblMsn600UjV5NE2NkAXEGYtR99Kz2ffdZde0+Onjf9Zxp2c3rtP5tVyXy533XMtREGFlGnIGYnOs8rac+9xOV+0qSJB/6SaxHfrFPXc8f1Y0fuT2RgR5GXIHpS9b1MyBFXvzyry+GeSQvu/pO9+jAD16IYSoAISDOQAy6j5xVz8nuCR/3ckVHfrlfXkn9jz0HMA7iDMSgt6tblqv+s70rA2WVB8oNmghASIgzEIPinGZpslVxzpQv5hszEICgEGcgBnPXLFCh2ou9TFpyw+pJV9cA0ok4AzEwM22+9wblxlsZm1RoKWr927Y0fjAAQSDOQEwWXbVcV7/v9WpZNFu5przyLUXlijm1rV+kGz78ZrUsbI17RAAx4X3OQIwWblmm133iLnUfOauB832a1T5HLQtnxz0WgJgRZyBmZqY5K9riHgNAQLisDQBAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAACBIc4AAASGOAMAEBjiDABAYIgzAEBecZX7SvKKxz0KJBXiHgAAEJ/+s716+Qe7dfTxA/JSRVbIadnr1mndW69U09yWuMfLLOIMABnVd7pHuz79I5Uu9MvLgytm7y/ryC/36cTTh3TjR25Xc9usmKfMJi5rA0BG/e5bT2qgu+9imId52dV/vk97v/10TJOBOANABg1c6NegzUAnAAAFI0lEQVTJ549KlQk2qLhOPHtYpZ6Bhs6FQZHibGZ3mtkeM9trZh8d5/FmM/vG0OOPm9m6Wg8KAKidvlM9yhWqJyCXz6nvTE+DJsJIk8bZzPKSHpR0l6Qtku41sy2jNnuvpFPuvlHS5yR9utaDAgBqp9jaJC9NtGweVClXVJjd1KCJMFKUlfNNkva6+z5375f0dUlbR22zVdKXh37/bUm3m5nVbkwAQC01z5+l1hVtVbeZs3K+mufxiu04RInzSkkHR3zcOfS5cbdx95KkM5IW1WJAAEB9bHzHdco15cd9LFfMa9M7r23wRBgW5a1U462AR79LPco2MrP7JN039OF5M9szzp9rl3QiwlyYOvZt/bBv64d9Wz8T79uSpH94oaHDpMp//z/j7du1Uf94lDh3Slo94uNVkg5PsE2nmRUktUnqGv2F3H2bpG3V/mNmtsvdOyLMhSli39YP+7Z+2Lf1w76tn5nu2yiXtXdK2mRm682sSdI9kraP2ma7pL8Y+v07JP3Y3bkHHAAA0zDpytndS2b2AUmPSMpL+qK7P29mn5S0y923S/p/kr5qZns1uGK+p55DAwCQZpFu3+nuD0t6eNTnPj7i972S3lmjmape9saMsG/rh31bP+zb+mHf1s+M9q1x9RkAgLBw+04AAAITW5y5JWh9RNivHzSz3Wb2jJk9amaRX9qPyffviO3eYWZuZrwSNoIo+9XM/nTo2H3ezP6t0TMmVYRzwhoze8zMnhw6L7w1jjmTyMy+aGbHzOy5CR43M/v80L5/xsxuiPzF3b3hvzT4wrKXJF0mqUnS05K2jNrm/ZK+MPT7eyR9I45Zk/Qr4n69TdLsod//Jfu1tvt3aLu5kn4maYekjrjnDv1XxON2k6QnJS0Y+nhJ3HMn4VfEfbtN0l8O/X6LpJfjnjspvyT9oaQbJD03weNvlfQDDd4L5GZJj0f92nGtnLklaH1Mul/d/TF3vzD04Q4Nvm8d0UQ5biXp7yV9RlJvI4dLsCj79X2SHnT3U5Lk7scaPGNSRdm3Lmne0O/bNPY+FpiAu/9M49zTY4Stkr7ig3ZImm9my6N87bjizC1B6yPKfh3pvRr8rg7RTLp/zex6Savd/fuNHCzhohy3myVtNrNfmNkOM7uzYdMlW5R9+wlJ7zKzTg2+K+evGzNaJkz1nHxRpLdS1UHNbgmKS0TeZ2b2Lkkdkt5U14nSper+NbOcBn8q27sbNVBKRDluCxq8tH2rBq/2/NzMrnb303WeLemi7Nt7JX3J3T9rZq/X4D0rrnb36j+yClFMu2NxrZyncktQVbslKC4RZb/KzO6Q9DFJd7t7X4NmS4PJ9u9cSVdL+omZvazB55i286KwSUU9H3zX3Qfcfb+kPRqMNaqLsm/fK+mbkuTuv5LUosF7bmPmIp2TxxNXnLklaH1Mul+HLrs+pMEw87zd1FTdv+5+xt3b3X2du6/T4HP6d7v7rnjGTYwo54PvaPDFjDKzdg1e5t7X0CmTKcq+fUXS7ZJkZldqMM7HGzplem2X9OdDr9q+WdIZdz8S5Q/GclnbuSVoXUTcr/8oaY6kbw29vu4Vd787tqETJOL+xRRF3K+PSPpPZrZbUlnSh939ZHxTJ0PEffshSf9iZn+jwUuu72YhFI2ZfU2DT7W0Dz1n/3eSipLk7l/Q4HP4b5W0V9IFSe+J/LX5OwAAICzcIQwAgMAQZwAAAkOcAQAIDHEGACAwxBkAgMAQZwAAAkOcAQAIDHEGACAw/x8c6H/sPc2dHgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ===========================================\n",
    "# Estimate Polytope Density as Net Width Increases \n",
    "# ===========================================\n",
    "widths = [int(elem) for elem in np.linspace(6, 100, 15)]\n",
    "errs = []\n",
    "unique_polytopes = []\n",
    "\n",
    "for width in widths:\n",
    "    layer_sizes = [2] + [width for _ in range(0, 4)] + [2]\n",
    "\n",
    "    # ==================================\n",
    "    # Initialize Network\n",
    "    # ==================================\n",
    "    \n",
    "    print('===============Initializing Network============')\n",
    "    network = PLNN(layer_sizes)\n",
    "    net = network.net\n",
    "    \n",
    "    # ==================================\n",
    "    # Train Network\n",
    "    # ==================================\n",
    "    \n",
    "    print('===============Training Network============')\n",
    "    opt = optim.Adam(net.parameters(), lr=1e-3)\n",
    "    for i in range(1000):\n",
    "        out = net(Variable(X))\n",
    "        l = nn.CrossEntropyLoss()(out, Variable(y))\n",
    "        err = (out.max(1)[1].data != y).float().mean()\n",
    "        opt.zero_grad()\n",
    "        (l).backward()\n",
    "        opt.step()\n",
    "    errs.append(err)\n",
    "    print('error: ', err)\n",
    "    \n",
    "    # ==================================\n",
    "    # Visualize: baseline classifier boundary\n",
    "    # ==================================\n",
    "\n",
    "    XX, YY = np.meshgrid(np.linspace(0, 1, 100), np.linspace(0, 1, 100))\n",
    "    X0 = Variable(torch.Tensor(np.stack([np.ravel(XX), np.ravel(YY)]).T))\n",
    "    y0 = network(X0)\n",
    "    ZZ = (y0[:,0] - y0[:,1]).resize(100, 100).data.numpy()\n",
    "\n",
    "    _, ax = plt.subplots(figsize=(8,8))\n",
    "    ax.contourf(XX,YY,-ZZ, cmap=\"coolwarm\", levels=np.linspace(-1000,1000,3))\n",
    "    ax.scatter(X.numpy()[:,0], X.numpy()[:,1], c=y.numpy(), cmap=\"coolwarm\", s=70)\n",
    "    ax.axis(\"equal\")\n",
    "    ax.axis([0, 1, 0, 1])\n",
    "    \n",
    "    # ==================================\n",
    "    # Gather Polytopes\n",
    "    # ==================================\n",
    "    print('===============Gathering Polytopes============')\n",
    "    num_pts = 350\n",
    "    xylim = 1.0\n",
    "    \n",
    "    unique_relu_configs_list, unique_bin_acts, _, _ = utils.get_unique_relu_configs(network, xylim, num_pts)\n",
    "    unique_polytopes.append(len(unique_bin_acts))\n",
    "    print('number of polytopes:', len(unique_bin_acts))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ==================================\n",
    "# Plot Results\n",
    "# ==================================\n",
    "\n",
    "xs = widths\n",
    "ys = unique_polytopes\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(xs,ys)\n",
    "plt.plot(np.unique(xs), np.poly1d(np.polyfit(xs, ys, 1))(np.unique(xs)))\n",
    "plt.xlabel('Network Width')\n",
    "plt.ylabel('Num Unique Polytopes')\n",
    "\n",
    "import os\n",
    "cwd = os.getcwd()\n",
    "plot_dir = cwd + '/plots/'\n",
    "filename = plot_dir + 'width_experiment' + '.svg'\n",
    "plt.savefig(filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(xs,errs[0:-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (DeepL)",
   "language": "python",
   "name": "deepl"
  },
  "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
