{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Experiment 1\n",
    "# ==================================\n",
    "\n",
    "# demonstration to find the maximal l_p ball at a point x_0, within which,\n",
    "# the class label of a random classifier is equal to C(x_0)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/jordanm/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/figure.py:98: MatplotlibDeprecationWarning: \n",
      "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",
      "  \"Adding an axes using the same arguments as a previous axes \"\n"
     ]
    }
   ],
   "source": [
    "# =====================\n",
    "# Imports\n",
    "# =====================\n",
    "\n",
    "from geocert import compute_boundary_batch, batch_GeoCert, incremental_GeoCert\n",
    "from plnn import PLNN\n",
    "from _polytope_ import Polytope, from_polytope_dict\n",
    "import utilities as utils\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.autograd import Variable\n",
    "from torchvision import datasets, transforms\n",
    "# from convex_adversarial import robust_loss\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============Initializing Network============\n",
      "Sequential(\n",
      "  (1): Linear(in_features=2, out_features=8, bias=True)\n",
      "  (2): ReLU()\n",
      "  (3): Linear(in_features=8, out_features=8, bias=True)\n",
      "  (4): ReLU()\n",
      "  (5): Linear(in_features=8, out_features=2, bias=True)\n",
      ")\n",
      "===============Finding Projection============\n",
      "lp_norm:  l_2\n",
      "from point: \n",
      "tensor([[0.],\n",
      "        [0.]])\n",
      "/Users/jordanm/grad/geometric-certificates\n",
      "---Initial Polytope---\n",
      "num facets:  4\n",
      "---Opening New Polytope---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/jordanm/.virtualenvs/myvenv/lib/python3.7/site-packages/scipy/optimize/_linprog_ip.py:1262: OptimizeWarning: Solving system with option 'sym_pos':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'sym_pos' to False.\n",
      "  OptimizeWarning)\n",
      "/Users/jordanm/.virtualenvs/myvenv/lib/python3.7/site-packages/scipy/optimize/_linprog_ip.py:1274: OptimizeWarning: Solving system with option 'sym_pos':False failed. This may happen occasionally, especially as the solution is approached. However, if you see this frequently, your problem may be numerically challenging. If you cannot improve the formulation, consider setting 'lstsq' to True. Consider also setting `presolve` to True, if it is not already.\n",
      "  OptimizeWarning)\n",
      "/Users/jordanm/.virtualenvs/myvenv/lib/python3.7/site-packages/scipy/optimize/_linprog_ip.py:1048: RuntimeWarning: internal gelsd driver lwork query error, required iwork dimension not returned. This is likely the result of LAPACK bug 0038, fixed in LAPACK 3.2.2 (released July 21, 2010). Falling back to 'gelss' driver.\n",
      "  return sp.linalg.lstsq(M, r)[0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num facets:  4\n"
     ]
    },
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: '/Users/jordanm/grad/geometric-certificates/plots/incremental_geocert/0.png'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-4-cc0388dbec6d>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     29\u001b[0m \u001b[0mplot_dir\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcwd\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;34m'/plots/incremental_geocert/'\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     30\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 31\u001b[0;31m \u001b[0mt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mincremental_GeoCert\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlp_norm\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnetwork\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx_0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mplot_dir\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~/grad/geometric-certificates/geocert.py\u001b[0m in \u001b[0;36mincremental_GeoCert\u001b[0;34m(lp_norm, net, x, ax, plot_dir, n_colors)\u001b[0m\n\u001b[1;32m    183\u001b[0m         \u001b[0;32mif\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;36m1\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[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    184\u001b[0m             geocert_plot_step(lp_norm, seen_to_polytope_map, pq, pop_el.lp_dist,\n\u001b[0;32m--> 185\u001b[0;31m                               x, plot_dir, n_colors, iter=index)\n\u001b[0m\u001b[1;32m    186\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mindex\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    187\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/grad/geometric-certificates/geocert.py\u001b[0m in \u001b[0;36mgeocert_plot_step\u001b[0;34m(lp_norm, seen_to_polytope_map, facet_heap_elems, t, x, plot_dir, n_colors, ax, iter)\u001b[0m\n\u001b[1;32m    276\u001b[0m         \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mylim\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mxylim\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mxylim\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    277\u001b[0m     \u001b[0mfilename\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mplot_dir\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mstr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0miter\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;34m'.png'\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 278\u001b[0;31m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msavefig\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfilename\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    279\u001b[0m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclose\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    280\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/pyplot.py\u001b[0m in \u001b[0;36msavefig\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    686\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0msavefig\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[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    687\u001b[0m     \u001b[0mfig\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgcf\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--> 688\u001b[0;31m     \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msavefig\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[0m\u001b[1;32m    689\u001b[0m     \u001b[0mfig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcanvas\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdraw_idle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m   \u001b[0;31m# need this if 'transparent=True' to reset colors\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    690\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mres\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/figure.py\u001b[0m in \u001b[0;36msavefig\u001b[0;34m(self, fname, frameon, transparent, **kwargs)\u001b[0m\n\u001b[1;32m   2095\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_frameon\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mframeon\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2096\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2097\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcanvas\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprint_figure\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfname\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   2098\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2099\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mframeon\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/backend_bases.py\u001b[0m in \u001b[0;36mprint_figure\u001b[0;34m(self, filename, dpi, facecolor, edgecolor, orientation, format, bbox_inches, **kwargs)\u001b[0m\n\u001b[1;32m   2073\u001b[0m                     \u001b[0morientation\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0morientation\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2074\u001b[0m                     \u001b[0mbbox_inches_restore\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0m_bbox_inches_restore\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2075\u001b[0;31m                     **kwargs)\n\u001b[0m\u001b[1;32m   2076\u001b[0m             \u001b[0;32mfinally\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2077\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0mbbox_inches\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mrestore_bbox\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/backends/backend_agg.py\u001b[0m in \u001b[0;36mprint_png\u001b[0;34m(self, filename_or_obj, *args, **kwargs)\u001b[0m\n\u001b[1;32m    519\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    520\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[0mrenderer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdpi\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfigure\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdpi\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 521\u001b[0;31m                 \u001b[0mcbook\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mopen_file_cm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfilename_or_obj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"wb\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mfh\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    522\u001b[0m             _png.write_png(renderer._renderer, fh,\n\u001b[1;32m    523\u001b[0m                             self.figure.dpi, metadata=metadata)\n",
      "\u001b[0;32m/usr/local/Cellar/python/3.7.2_2/Frameworks/Python.framework/Versions/3.7/lib/python3.7/contextlib.py\u001b[0m in \u001b[0;36m__enter__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    110\u001b[0m         \u001b[0;32mdel\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkwds\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    111\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 112\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mnext\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgen\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    113\u001b[0m         \u001b[0;32mexcept\u001b[0m \u001b[0mStopIteration\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    114\u001b[0m             \u001b[0;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"generator didn't yield\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/cbook/__init__.py\u001b[0m in \u001b[0;36mopen_file_cm\u001b[0;34m(path_or_file, mode, encoding)\u001b[0m\n\u001b[1;32m    405\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mopen_file_cm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpath_or_file\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"r\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencoding\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\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    406\u001b[0m     \u001b[0;34mr\"\"\"Pass through file objects and context-manage `.PathLike`\\s.\"\"\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 407\u001b[0;31m     \u001b[0mfh\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mopened\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mto_filehandle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpath_or_file\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencoding\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    408\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mopened\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    409\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mfh\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.virtualenvs/myvenv/lib/python3.7/site-packages/matplotlib/cbook/__init__.py\u001b[0m in \u001b[0;36mto_filehandle\u001b[0;34m(fname, flag, return_opened, encoding)\u001b[0m\n\u001b[1;32m    390\u001b[0m             \u001b[0mfh\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mbz2\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mBZ2File\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfname\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mflag\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    391\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 392\u001b[0;31m             \u001b[0mfh\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfname\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mflag\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencoding\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mencoding\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    393\u001b[0m         \u001b[0mopened\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    394\u001b[0m     \u001b[0;32melif\u001b[0m \u001b[0mhasattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfname\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'seek'\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;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: '/Users/jordanm/grad/geometric-certificates/plots/incremental_geocert/0.png'"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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pEmTtLGDBw9i9+7dypf20el0MBgMSEtL85i5vli+iIiICOPHj0daWhquvvpqbay8vBxpaWno6OhQmKxXfX09cnNzVcewC5YvIiIiAgCMHDkS3333HR566CFtzJWWIjKbzeju7kZra6vqKMPC8kVEREQaHx8f/O1vf8Nbb72FESNG4N///vdx6yyqUl9fjzfeeANxcXF4++23VccZFpYvIiIiOo4QAo8++igOHz6MG264AcuXL8dZZ52lNFNzczPy8/Nx7Ngxt59yguWLiIiIBvTDE5ARERF49dVXcdFFF6Gqqgp79+51+s3vMTEx2gz9VqsVRUVFTn1/e2L5IiIiolPy9/fH9ddfjz179qCoqAjp6elOvR/Mx8cHkZGR2rY7n/1i+SIiIqJB+eyzz7QnH2tqamAymdDc3Oy09+9/7xnLFxEREXm8pUuXYvHixdp2S0sLTCYTjh075pT3j42N1S49ms1ml5qJfyhYvoiIiGhQhBB47rnn8NVXX8Hf3x8A0NXVhfT0dBQXFzv8/X19fbX70ABg1apVDn9PR2D5IiIioiG54447kJqaqi16LaXEnj17kJub6/AlifpfekxKSnLoezkKyxcREREN2fnnn4+MjAyce+652lhBQQGsViu6u7sd9r6xsbHa6+3bt6O6utph7+UoLF9ERER0WhISEmA0GvGLX/xCG6uqqkJNTY3D3tPf3x8jR44E0LsI+OrVqx32Xo7C8kVERESnLTg4GMnJyXj88ccBAA899BDGjh3r0Pf84dJjYmLicdNPuAvh6GuzpysxMVFarVbVMYiIiGiQtmzZgiuvvBIlJSVYtGgRjh496pD36ezsRE9PD/77v/8bt99+u0PeY6iEEDullImD2ZdnvoiIiMgu5s6dCyEEEhISsHz5ckyZMgWdnZ04cuSIXW/E9/X1hb+/P8xms92+pzOxfBEREZHdhYWF4YUXXsDhw4exb98+ZGVlwWaz2fU98vPzHXZ2zZFYvoiIiMgh3n//fRw+fBgAUFZWBovFos2Qby9paWkA4PS1JoeD5YuIiIgc4ve//z0efPBBbbuurg5GoxGNjY12+f5NTU147bXXMHXqVHz11Vd2+Z7OwPJFREREDuHj44P33nsPy5cv15YFamtrg9lstsvlwoqKCqSlpWH//v1utdYjyxcRERE5jBACCxcuxDfffIPg4GAAQHd3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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Fun incremental 'GeoCert' from the point [0,0]. Network is simple ReLu net with\n",
    "# Gaussian random weights. Finds maximal l_p ball within which the class label\n",
    "# remains the same.\n",
    "\n",
    "\n",
    "# ==================================\n",
    "# Initialize Network\n",
    "# ==================================\n",
    "\n",
    "print('===============Initializing Network============')\n",
    "layer_sizes = [2, 8, 8, 2]\n",
    "network = PLNN(layer_sizes)\n",
    "\n",
    "# ==================================\n",
    "# Find Projection\n",
    "# ==================================\n",
    "\n",
    "lp_norm = 'l_2'\n",
    "\n",
    "print('===============Finding Projection============')\n",
    "print('lp_norm: ', lp_norm)\n",
    "x_0 = torch.Tensor([[0.0], [0.0]])\n",
    "print('from point: ')\n",
    "print(x_0)\n",
    "\n",
    "ax = plt.axes()\n",
    "cwd = os.getcwd()\n",
    "print(cwd)\n",
    "plot_dir = cwd + '/plots/incremental_geocert/'\n",
    "\n",
    "t = incremental_GeoCert(lp_norm, network, x_0, ax, plot_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print('plots can be found at:', plot_dir)\n",
    "print('the final projection value:', t)"
   ]
  },
  {
   "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.7.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
