{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Simple test to do lipMIP for a very easy MNIST network \n",
    "import sys \n",
    "sys.path.append('..')\n",
    "import lipMIP as lm\n",
    "import neural_nets.data_loaders as dl \n",
    "import neural_nets.train as train \n",
    "from relu_nets import ReLUNet\n",
    "import utilities as utils\n",
    "from hyperbox import Hyperbox\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# First build and train a simple MNIST network \n",
    "oneseven_train = dl.load_mnist_data('train', digits=[1, 7])\n",
    "oneseven_val = dl.load_mnist_data('val', digits=[1, 7])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training network: 2layer_2class_mnist.pkl\n",
      "Epoch 00 | Accuracy: 99.45\n",
      "Epoch 01 | Accuracy: 99.58\n",
      "Epoch 02 | Accuracy: 99.65\n",
      "Epoch 03 | Accuracy: 99.69\n",
      "Epoch 04 | Accuracy: 99.72\n",
      "Epoch 05 | Accuracy: 99.73\n",
      "Epoch 06 | Accuracy: 99.75\n",
      "Epoch 07 | Accuracy: 99.78\n",
      "Epoch 08 | Accuracy: 99.80\n",
      "Epoch 09 | Accuracy: 99.86\n"
     ]
    }
   ],
   "source": [
    "# And do training loop: \n",
    "network = ReLUNet(layer_sizes=[784, 20, 20, 2])\n",
    "saved_name = '2layer_2class_mnist.pkl'\n",
    "trained_net = train.train_cacher(saved_name, network=network, trainset=oneseven_train, valset=oneseven_val, \n",
    "                                 num_epochs=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAOcAAADnCAYAAADl9EEgAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAEr0lEQVR4nO3dMU5UWxzAYS+RFdjZSOES3AREY4w7IBS6BAujhQuwdgsWJsTG0tBKY2tHYUWhhaVzX/0Cc/ENzNzfPL+vnH9mzknIj5NwcodhHMdbQM/O3BsALidOiBInRIkTosQJUbenhsMw+FMurNk4jsNlrzs5IUqcECVOiBInRIkTosQJUeKEKHFClDghSpwQJU6IEidEiROixAlR4oQocUKUOCFKnBAlTogSJ0SJE6LECVHihChxQpQ4IUqcECVOiBInRIkTosQJUeKEKHFClDghSpwQJU6IEidEiROixAlRt+feAJu1v78/Of/48ePa1n716tXk/M2bN2tbexs5OSFKnBAlTogSJ0SJE6LECVHihKhhHMflw2FYPmQrXXXPeXx8vKGdXLS7uzvb2nMax3G47HUnJ0SJE6LECVHihChxQpQ4IcojY3+Zu3fvzrb29+/fZ1t7Gzk5IUqcECVOiBInRIkTosQJUeKEKI+M/WV+//49OV8sFmtb++HDh5PzT58+rW3tMo+MwZYRJ0SJE6LECVHihChxQpQ4IcrznFvm8ePHk/Ojo6MN7eSiq75W8/T0dEM7+X9wckKUOCFKnBAlTogSJ0SJE6LECVHuObfMvXv3JucHBweT852d1X8ff/v2bXL+9OnTlT+bi5ycECVOiBInRIkTosQJUeKEKHFClHvOLTP1PcO3bl3/e2en3n/V2twsJydEiROixAlR4oQocUKUOCFKnBAlTogSJ0SJE6LECVHihChxQpQ4IcojY/yxq/7FHzfLyQlR4oQocUKUOCFKnBAlTogSJ0S55+SPvXv3bu4t/FWcnBAlTogSJ0SJE6LECVHihChxQpR7zpj79+9Pzt++fXutz9/Z8ft4W/hJQZQ4IUqcECVOiBInRIkTosQJUe45Y549ezY5XywWa13//fv3S2fn5+drXZt/c3JClDghSpwQJU6IEidEiROihnEclw+HYfmQlb18+XLp7MWLF5Pv3d3dvdbaJycnk/MnT54snf38+fNaa3O5cRyHy153ckKUOCFKnBAlTogSJ0SJE6LECVEeGZvBnTt3ls6ue495lV+/fk3O3WV2ODkhSpwQJU6IEidEiROixAlR4oQo95xr8ODBg8n5o0ePNrSTi16/fj3b2vw3Tk6IEidEiROixAlR4oQocUKUOCHKPeca7O/vT8739vbWtvaXL18m56enp2tbm5vl5IQocUKUOCFKnBAlTogSJ0S5SlnB8+fPJ+dXPZa1WCxWXvvz58+T88PDw5U/mxYnJ0SJE6LECVHihChxQpQ4IUqcEOWecwUHBwezrf3169fJ+dnZ2YZ2wro5OSFKnBAlTogSJ0SJE6LECVHihCj3nDE/fvyYnJ+cnGxoJ8zNyQlR4oQocUKUOCFKnBAlTogSJ0S554w5Pz+fnH/48GFDO2FuTk6IEidEiROixAlR4oQocUKUOCFqGMdx+XAYlg+BGzGO43DZ605OiBInRIkTosQJUeKEKHFClDghSpwQJU6IEidEiROixAlR4oQocUKUOCFKnBAlTogSJ0SJE6LECVHihChxQtTkV2MC83FyQpQ4IUqcECVOiBInRIkTov4BpdaUKii72z0AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# And now try a small local lipschitz-y thing on a single example \n",
    "EXAMPLE_NUM = 42\n",
    "example = next(iter(oneseven_val))[0][EXAMPLE_NUM:EXAMPLE_NUM+1]\n",
    "utils.display_images(example, figsize=(4, 4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimize a model with 4302 rows, 3338 columns and 41566 nonzeros\n",
      "Variable types: 2514 continuous, 824 integer (824 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [4e-06, 7e+01]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-08, 7e+01]\n",
      "  RHS range        [1e-08, 7e+01]\n",
      "Presolve removed 122 rows and 42 columns\n",
      "Presolve time: 0.12s\n",
      "Presolved: 4180 rows, 3296 columns, 41324 nonzeros\n",
      "Variable types: 2472 continuous, 824 integer (824 binary)\n",
      "\n",
      "Root relaxation: objective 4.129003e+02, 3197 iterations, 0.50 seconds\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0  412.90032    0  804          -  412.90032      -     -    1s\n",
      "     0     0  383.55093    0  798          -  383.55093      -     -    1s\n",
      "     0     0  382.19754    0  791          -  382.19754      -     -    1s\n",
      "     0     0  382.00859    0  789          -  382.00859      -     -    1s\n",
      "     0     0  381.76027    0  787          -  381.76027      -     -    1s\n",
      "     0     0  381.70144    0  786          -  381.70144      -     -    1s\n",
      "     0     0  381.59716    0  785          -  381.59716      -     -    1s\n",
      "     0     0  381.56727    0  800          -  381.56727      -     -    1s\n",
      "     0     0  381.38400    0  802          -  381.38400      -     -    1s\n",
      "     0     0  381.30695    0  801          -  381.30695      -     -    1s\n",
      "     0     0  381.19495    0  801          -  381.19495      -     -    1s\n",
      "     0     0  381.11477    0  801          -  381.11477      -     -    1s\n",
      "     0     0  381.05730    0  801          -  381.05730      -     -    1s\n",
      "     0     0  380.98328    0  801          -  380.98328      -     -    1s\n",
      "     0     0  380.88883    0  801          -  380.88883      -     -    2s\n",
      "     0     0  380.78764    0  801          -  380.78764      -     -    2s\n",
      "     0     0  380.71829    0  801          -  380.71829      -     -    2s\n",
      "     0     0  380.62865    0  801          -  380.62865      -     -    2s\n",
      "     0     0  380.59884    0  804          -  380.59884      -     -    2s\n",
      "     0     0  380.54881    0  804          -  380.54881      -     -    2s\n",
      "     0     0  380.50055    0  804          -  380.50055      -     -    2s\n",
      "     0     0  380.43507    0  804          -  380.43507      -     -    2s\n",
      "     0     0  380.35885    0  804          -  380.35885      -     -    2s\n",
      "     0     0  380.29655    0  804          -  380.29655      -     -    2s\n",
      "     0     0  380.24488    0  804          -  380.24488      -     -    2s\n",
      "     0     0  380.19660    0  804          -  380.19660      -     -    2s\n",
      "     0     0  380.15836    0  807          -  380.15836      -     -    2s\n",
      "     0     0  380.11772    0  807          -  380.11772      -     -    2s\n",
      "     0     0  380.08722    0  808          -  380.08722      -     -    2s\n",
      "     0     0  380.03631    0  809          -  380.03631      -     -    2s\n",
      "     0     0  379.99831    0  809          -  379.99831      -     -    2s\n",
      "     0     0  379.98331    0  809          -  379.98331      -     -    2s\n",
      "     0     0  379.97531    0  810          -  379.97531      -     -    2s\n",
      "     0     0  370.38988    0  803          -  370.38988      -     -    2s\n",
      "     0     0  370.07916    0  806          -  370.07916      -     -    4s\n",
      "     0     0  369.73947    0  807          -  369.73947      -     -    4s\n",
      "     0     0  369.67726    0  808          -  369.67726      -     -    4s\n",
      "     0     0  369.64270    0  807          -  369.64270      -     -    4s\n",
      "     0     0  369.61489    0  808          -  369.61489      -     -    4s\n",
      "     0     0  369.24586    0  809          -  369.24586      -     -    4s\n",
      "     0     0  369.16382    0  807          -  369.16382      -     -    4s\n",
      "     0     0  369.09410    0  810          -  369.09410      -     -    4s\n",
      "     0     0  369.08438    0  813          -  369.08438      -     -    5s\n",
      "     0     0  368.95847    0  808          -  368.95847      -     -    5s\n",
      "H    0     0                     113.8697794  368.95847   224%     -    5s\n",
      "     0     0  368.95847    0  808  113.86978  368.95847   224%     -    5s\n",
      "     0     2  368.95847    0  808  113.86978  368.95847   224%     -    6s\n",
      "   616   607  329.37642  226  569  113.86978  368.61168   224%  29.7   10s\n",
      "  1838  1745  304.97814  530  266  113.86978  368.61168   224%  42.1   15s\n",
      "H 2629  2361                     289.3760794  368.55394  27.4%  50.5   20s\n",
      "H 3113  2395                     304.8931728  368.43258  20.8%  52.8   22s\n",
      "  3277  2502  308.15210  643  808  304.89317  368.43258  20.8%  52.0   26s\n",
      "  3279  2503  342.19086  165  804  304.89317  368.43258  20.8%  51.9   30s\n",
      "  3303  2519  308.46504  479  788  304.89317  352.04359  15.5%  51.5   36s\n",
      "  3319  2530  335.62231  319  796  304.89317  349.97549  14.8%  51.3   40s\n",
      "H 3327  2407                     328.9954291  349.65711  6.28%  51.2   44s\n",
      "H 3330  2288                     332.2127702  349.62941  5.24%  51.1   44s\n",
      "  3333  2290  332.21277  625  801  332.21277  349.61012  5.24%  51.1   45s\n",
      "  3341  2296  341.95176  196  799  332.21277  349.42880  5.18%  51.0   50s\n",
      "H 3353  2187                     332.2430172  349.30069  5.13%  50.8   54s\n",
      "  3356  2189  332.24302  654  799  332.24302  349.28349  5.13%  50.7   55s\n",
      "  3364  2194  347.33502   92  801  332.24302  349.20657  5.11%  50.6   61s\n",
      "  3370  2198  349.18738   18  801  332.24302  349.18738  5.10%  50.5   65s\n",
      "  3375  2203  349.18738   52  763  332.24302  349.18738  5.10%  53.5   70s\n",
      "  3390  2213  332.24302  369  795  332.24302  348.54604  4.91%  53.3   76s\n",
      "  3400  2220  342.57862  174  786  332.24302  347.88284  4.71%  53.1   80s\n",
      "  3413  2228  341.18951   22  790  332.24302  347.75424  4.67%  52.9   85s\n",
      "  3423  2235  336.83400  293  792  332.24302  347.65093  4.64%  52.7   90s\n",
      "  3427  2238  332.24302  245  791  332.24302  347.63322  4.63%  52.7   96s\n",
      "  3430  2241  347.58555   27  784  332.24302  347.58555  4.62%  55.0  114s\n",
      "  3432  2240  347.54797   28  784  332.24302  347.54797  4.61%  55.0  115s\n",
      "  3436  2239  347.37799   30  779  332.24302  347.37799  4.56%  55.0  120s\n",
      "  3440  2237  347.31272   32  772  332.24302  347.31272  4.54%  55.0  125s\n",
      "  3489  2233  346.66070   44  776  332.24302  346.66070  4.34%  55.4  130s\n",
      "  3800  2376     cutoff   84       332.24302  346.48145  4.29%  55.5  135s\n",
      "  4107  2512     cutoff   62       332.24302  346.04938  4.16%  53.3  141s\n",
      "  4811  2874  335.82363  190  611  332.24302  345.64214  4.03%  50.6  152s\n",
      "  4845  2869  343.92083   69  744  332.24302  345.41380  3.96%  51.6  155s\n",
      "  5888  3423     cutoff  181       332.24302  345.17690  3.89%  45.9  161s\n",
      "  6459  3735  333.03552  289  339  332.24302  344.94601  3.82%  45.7  165s\n",
      "  6825  3899  343.13479   61  750  332.24302  344.71264  3.75%  46.6  170s\n",
      "  7408  4087  340.02614  135  673  332.24302  344.53193  3.70%  46.3  175s\n",
      "  8026  4287  338.34761  167  639  332.24302  344.46187  3.68%  46.5  180s\n",
      "  8459  4348  334.47699  276  483  332.24302  344.46187  3.68%  46.0  185s\n",
      "  8771  4490  341.54851  113  705  332.24302  344.36943  3.65%  47.5  190s\n",
      "  9480  4806  335.43404   98  695  332.24302  344.15334  3.58%  47.4  195s\n",
      "  9787  4945  339.53964  119  690  332.24302  344.14501  3.58%  49.2  200s\n",
      " 10106  5064     cutoff   78       332.24302  344.10813  3.57%  49.8  206s\n",
      " 10567  5280     cutoff  115       332.24302  343.95575  3.53%  51.5  212s\n",
      " 10777  5414  341.45041  110  708  332.24302  343.92228  3.52%  52.1  216s\n",
      " 11289  5833  341.97992  102  720  332.24302  343.80494  3.48%  52.2  220s\n",
      " 12239  6631  332.88768  322  130  332.24302  343.61757  3.42%  51.9  225s\n",
      " 12588  6913  337.31525  167  644  332.24302  343.56154  3.41%  52.4  230s\n",
      " 12941  7099  334.06264  270  495  332.24302  343.53145  3.40%  53.5  236s\n",
      " 13483  7362  340.56448   91  715  332.24302  343.47033  3.38%  54.1  240s\n",
      " 13776  7530     cutoff  173       332.24302  343.39134  3.36%  55.5  246s\n",
      " 14394  7935     cutoff   81       332.24302  343.27820  3.32%  56.4  252s\n",
      " 14481  7967  341.90059   75  735  332.24302  343.22960  3.31%  56.5  256s\n",
      " 14863  8192  335.09496  197  606  332.24302  343.22960  3.31%  56.2  260s\n",
      " 15393  8583  335.32546   93  689  332.24302  343.12901  3.28%  57.1  267s\n",
      " 15730  8731  336.75853  165  647  332.24302  343.11126  3.27%  57.5  270s\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " 16150  8995  341.78465   90  723  332.24302  343.00986  3.24%  57.3  275s\n",
      " 16186  8998     cutoff   95       332.24302  342.98238  3.23%  57.9  284s\n",
      " 16191  8985     cutoff   96       332.24302  342.98238  3.23%  58.0  288s\n",
      " 16245  8991  340.75131  102  708  332.24302  342.98238  3.23%  58.6  291s\n",
      " 17159  9652  332.96451  165  553  332.24302  342.91981  3.21%  58.2  297s\n",
      " 17625  9997     cutoff   95       332.24302  342.84403  3.19%  58.0  300s\n",
      " 18017 10218  337.25057   89  727  332.24302  342.76432  3.17%  59.1  305s\n",
      " 18552 10628  332.38591  104  681  332.24302  342.71577  3.15%  59.8  312s\n",
      " 19258 11152  339.17967  128  681  332.24302  342.63350  3.13%  60.4  319s\n",
      " 19443 11287  342.11960   94  725  332.24302  342.63350  3.13%  60.7  322s\n",
      " 19753 11505     cutoff  260       332.24302  342.61747  3.12%  61.0  325s\n",
      " 20054 11690  335.68640   92  706  332.24302  342.58093  3.11%  62.4  332s\n",
      " 20168 11741  338.83293  101  713  332.24302  342.56376  3.11%  62.6  335s\n",
      " 20485 11971  334.96283  133  808  332.24302  342.49646  3.09%  62.9  406s\n",
      " 20492 11976  337.68417   80  769  332.24302  342.49646  3.09%  62.9  410s\n",
      " 20511 11988  338.03871  147  801  332.24302  341.63633  2.83%  62.9  415s\n",
      " 20517 11992  334.50043  259  800  332.24302  340.92229  2.61%  62.8  420s\n",
      " 20526 11998  338.71354  152  803  332.24302  340.80252  2.58%  62.8  425s\n",
      " 20533 12003  334.95938  247  801  332.24302  340.73103  2.55%  62.8  432s\n",
      " 20535 12004  334.75530  224  799  332.24302  340.71315  2.55%  62.8  435s\n",
      " 20541 12008  336.80883  177  805  332.24302  340.69383  2.54%  62.8  440s\n",
      " 20543 12010  334.11521  277  804  332.24302  340.68744  2.54%  62.8  445s\n",
      " 20547 12012  340.65069  109  800  332.24302  340.65069  2.53%  62.7  451s\n",
      " 20551 12015  338.78789  120  793  332.24302  340.60883  2.52%  62.7  456s\n",
      " 20560 12021  340.50002  126  804  332.24302  340.50002  2.49%  62.7  461s\n",
      " 20564 12024  335.15758  312  803  332.24302  340.48920  2.48%  62.7  465s\n",
      " 20569 12027  338.07256  106  807  332.24302  340.47896  2.48%  62.7  472s\n",
      " 20571 12028  338.18105  109  805  332.24302  340.47740  2.48%  62.7  477s\n",
      " 20574 12030  340.47060  107  804  332.24302  340.47060  2.48%  62.7  482s\n",
      " 20575 12031  338.91795  144  805  332.24302  340.46869  2.48%  62.7  485s\n",
      " 20578 12033  339.74036  140  805  332.24302  340.46435  2.47%  62.7  491s\n",
      " 20580 12034  337.28922  123  804  332.24302  340.46274  2.47%  62.6  496s\n",
      " 20583 12036  334.82941  216  803  332.24302  340.45924  2.47%  62.6  501s\n",
      " 20586 12038  334.49427  177  805  332.24302  340.45794  2.47%  62.6  506s\n",
      " 20589 12040  332.87865  115  805  332.24302  340.45710  2.47%  62.6  513s\n",
      " 20591 12042  334.58080  224  807  332.24302  340.45643  2.47%  62.6  515s\n",
      " 20595 12044  338.07953  173  801  332.24302  340.45397  2.47%  62.6  521s\n",
      " 20597 12046  338.08362  115  804  332.24302  340.45342  2.47%  62.6  525s\n",
      " 20599 12047  334.85832  122  803  332.24302  340.45085  2.47%  62.6  532s\n",
      " 20601 12048  339.89237   70  801  332.24302  340.44855  2.47%  62.6  537s\n",
      " 20603 12050  333.49188  293  805  332.24302  340.44567  2.47%  62.6  540s\n",
      " 20606 12052  337.48266  163  806  332.24302  340.44460  2.47%  62.6  545s\n",
      " 20608 12053  339.03000  114  805  332.24302  340.44441  2.47%  62.6  550s\n",
      " 20611 12055  338.03871  147  804  332.24302  340.44151  2.47%  62.6  555s\n",
      " 20613 12056  338.22063  164  805  332.24302  340.44074  2.47%  62.5  560s\n",
      " 20616 12058  338.71117   83  804  332.24302  340.43664  2.47%  62.5  565s\n",
      " 20619 12060  340.43514  103  806  332.24302  340.43514  2.47%  62.5  572s\n",
      " 20621 12062  340.21070   91  807  332.24302  340.43463  2.47%  62.5  575s\n",
      " 20624 12064  340.43367   95  806  332.24302  340.43367  2.47%  62.5  580s\n",
      " 20627 12066  338.48765  157  804  332.24302  340.43251  2.46%  62.5  587s\n",
      " 20628 12066  336.84434  150  805  332.24302  340.43239  2.46%  62.5  590s\n",
      " 20630 12068  340.43212  102  805  332.24302  340.43212  2.46%  62.5  596s\n",
      " 20633 12070  334.95938  247  806  332.24302  340.43160  2.46%  62.5  600s\n",
      " 20635 12071  334.75530  224  806  332.24302  340.43155  2.46%  62.5  605s\n",
      " 20638 12073  334.85819  217  802  332.24302  340.43133  2.46%  62.5  610s\n",
      " 20641 12075  336.80883  177  804  332.24302  340.43107  2.46%  62.5  615s\n",
      " 20644 12077  340.33415   99  807  332.24302  340.43035  2.46%  62.5  621s\n",
      " 20647 12079  340.42915  109  803  332.24302  340.42915  2.46%  62.4  627s\n",
      " 20649 12080  340.42525   73  803  332.24302  340.42525  2.46%  62.4  631s\n",
      " 20652 12082  333.35251  162  804  332.24302  340.42074  2.46%  62.4  635s\n",
      " 20655 12084  335.12580  217  806  332.24302  340.41883  2.46%  62.4  640s\n",
      " 20657 12086  336.71083  122  805  332.24302  340.41673  2.46%  62.4  645s\n",
      "H20659 11479                     332.2430219  340.41638  2.46%  62.4  650s\n",
      "H20662 10904                     332.3068584  340.41299  2.44%  62.4  654s\n",
      " 20663 10905  335.13972  169  806  332.30686  340.41255  2.44%  62.4  655s\n",
      " 20665 10906  334.48391  162  806  332.30686  340.41154  2.44%  62.4  661s\n",
      " 20667 10907  339.98892  131  805  332.30686  340.41124  2.44%  62.4  665s\n",
      " 20670 10909  339.13616  124  805  332.30686  340.40973  2.44%  62.4  670s\n",
      " 20673 10911  339.28509   93  807  332.30686  340.40925  2.44%  62.4  675s\n",
      "H20675 10364                     332.3097903  340.40921  2.44%  62.4  679s\n",
      " 20676 10364  332.30979  222  806  332.30979  340.40921  2.44%  62.4  680s\n",
      " 20680 10367  337.28922  123  806  332.30979  340.40920  2.44%  62.3  686s\n",
      " 20683 10369  334.82941  216  806  332.30979  340.40920  2.44%  62.3  690s\n",
      " 20686 10371  334.49427  177  806  332.30979  340.40920  2.44%  62.3  697s\n",
      " 20688 10372  338.13221  154  806  332.30979  340.40919  2.44%  62.3  700s\n",
      " 20692 10375  337.68417   80  806  332.30979  340.40919  2.44%  62.3  706s\n",
      " 20695 10377  338.07953  173  806  332.30979  340.40919  2.44%  62.3  710s\n",
      " 20698 10379  340.34508  121  806  332.30979  340.40919  2.44%  62.3  716s\n",
      " 20701 10381  339.89237   70  806  332.30979  340.40919  2.44%  62.3  720s\n",
      " 20704 10383  332.46671  306  806  332.30979  340.40919  2.44%  62.3  725s\n",
      " 20708 10386  339.03000  114  806  332.30979  340.40918  2.44%  62.3  732s\n",
      " 20711 10388  338.03871  147  806  332.30979  340.40918  2.44%  62.2  736s\n",
      " 20714 10390  335.87957  179  806  332.30979  340.40918  2.44%  62.2  741s\n",
      " 20717 10392  334.50043  259  806  332.30979  340.40918  2.44%  62.2  745s\n",
      " 20720 10394  340.19405  118  806  332.30979  340.40918  2.44%  62.2  750s\n",
      " 20724 10396  340.40918   95  806  332.30979  340.40918  2.44%  62.2  756s\n",
      " 20726 10398  338.71354  152  806  332.30979  340.40918  2.44%  62.2  760s\n",
      " 20730 10400  340.40918  102  806  332.30979  340.40918  2.44%  62.2  766s\n",
      " 20733 10402  334.95938  247  806  332.30979  340.40918  2.44%  62.2  770s\n",
      " 20736 10404  335.76455  157  806  332.30979  340.40917  2.44%  62.2  793s\n",
      " 20737 10405  336.51118  189  806  332.30979  340.40917  2.44%  62.2  799s\n",
      " 20738 10408  336.20615   42  776  332.30979  340.40917  2.44%  64.3  850s\n",
      " 20740 10406     cutoff   43       332.30979  340.38786  2.43%  64.4  866s\n",
      " 20743 10405     cutoff   44       332.30979  340.34046  2.42%  64.5  880s\n",
      " 20747 10405  334.55078   46  773  332.30979  340.30132  2.40%  64.6  889s\n",
      " 20749 10403     cutoff   47       332.30979  340.25168  2.39%  64.6  891s\n",
      " 20752 10403  340.19453   48  783  332.30979  340.22813  2.38%  64.6  942s\n",
      " 20763 10403  339.99606   52  783  332.30979  340.13001  2.35%  64.8  946s\n",
      " 20793 10396     cutoff   58       332.30979  340.07700  2.34%  65.0  951s\n",
      " 20841 10394     cutoff   57       332.30979  339.95668  2.30%  64.9  956s\n",
      " 20912 10378     cutoff   71       332.30979  339.88734  2.28%  64.9  961s\n",
      " 20946 10386     cutoff   78       332.30979  339.85603  2.27%  64.9  965s\n",
      " 21070 10431     cutoff   96       332.30979  339.85603  2.27%  64.7  970s\n",
      " 21384 10539  335.31660   86  724  332.30979  339.83758  2.27%  64.1  976s\n",
      " 21565 10605  339.29273   65  773  332.30979  339.45934  2.15%  63.9  981s\n",
      " 21822 10709  335.93125  147  647  332.30979  339.31614  2.11%  63.6  985s\n",
      " 22215 10899  333.03262   69  645  332.30979  339.15660  2.06%  63.0  991s\n",
      " 22320 10918  337.54648   78  750  332.30979  339.00449  2.01%  63.0  996s\n",
      " 22602 11028  337.14482   86  745  332.30979  338.88120  1.98%  63.0 1000s\n",
      " 23069 11172  336.53700   97  705  332.30979  338.83767  1.96%  62.2 1005s\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " 23146 11175  335.65212  112  687  332.30979  338.77145  1.94%  62.3 1012s\n",
      " 23438 11317  338.14586  112  724  332.30979  338.72446  1.93%  62.1 1015s\n",
      " 24021 11455  334.93004  298  534  332.30979  338.72446  1.93%  61.4 1021s\n",
      " 24250 11520  337.85868  129  709  332.30979  338.37507  1.83%  61.4 1026s\n",
      " 24656 11673  334.84215  269  560  332.30979  338.36719  1.82%  61.0 1032s\n",
      " 25067 11772  332.34985  416   18  332.30979  338.35657  1.82%  60.4 1036s\n",
      " 25245 11840  338.17959  113  721  332.30979  338.21702  1.78%  60.3 1040s\n",
      " 25328 11864  337.60333  150  684  332.30979  338.20094  1.77%  60.4 1045s\n",
      " 25405 11866  336.97868  177  656  332.30979  338.16776  1.76%  60.4 1053s\n",
      " 25608 11943  335.50309  257  574  332.30979  338.16776  1.76%  60.3 1056s\n",
      " 25801 12015  334.52708  309  521  332.30979  338.14731  1.76%  60.2 1073s\n",
      " 25835 12003  334.27817  317  510  332.30979  338.09635  1.74%  60.3 1076s\n",
      " 26355 12160     cutoff  114       332.30979  337.97661  1.71%  59.8 1081s\n",
      " 26993 12310  336.12208  155  620  332.30979  337.79009  1.65%  59.3 1088s\n",
      " 27253 12362  334.49824  100  699  332.30979  337.65969  1.61%  59.1 1091s\n",
      " 27651 12402     cutoff  146       332.30979  337.52882  1.57%  59.1 1098s\n",
      " 27766 12311  336.57692  157  674  332.30979  337.48125  1.56%  59.3 1101s\n",
      " 28304 12386     cutoff  145       332.30979  337.29002  1.50%  59.1 1108s\n",
      " 28564 12374  333.50171  262  183  332.30979  337.22500  1.48%  58.9 1112s\n",
      " 28732 12381  336.54205  171  663  332.30979  337.17256  1.46%  59.0 1118s\n",
      " 29287 12617     cutoff  144       332.30979  337.15307  1.46%  58.3 1121s\n",
      " 29913 12707     cutoff  156       332.30979  336.99052  1.41%  58.0 1129s\n",
      " 30085 12598     cutoff  160       332.30979  336.84889  1.37%  58.2 1133s\n",
      " 30322 12471     cutoff  182       332.30979  336.80171  1.35%  58.3 1137s\n",
      " 30606 12474     cutoff  170       332.30979  336.72690  1.33%  58.3 1144s\n",
      " 30975 12447     cutoff  217       332.30979  336.71764  1.33%  58.1 1150s\n",
      " 31297 12292  335.04829  136  696  332.30979  336.69672  1.32%  58.0 1155s\n",
      " 31848 12347  335.55403  120  711  332.30979  336.56590  1.28%  57.7 1161s\n",
      " 32030 12300     cutoff  110       332.30979  336.53492  1.27%  57.6 1166s\n",
      " 32114 12213  332.74620  208  155  332.30979  336.48124  1.26%  57.8 1173s\n",
      " 32216 12128     cutoff  150       332.30979  336.45288  1.25%  58.0 1180s\n",
      " 32329 12036     cutoff  186       332.30979  336.37556  1.22%  58.2 1185s\n",
      " 32455 11992     cutoff  208       332.30979  336.30838  1.20%  58.3 1193s\n",
      " 32559 11921  335.93167  106  730  332.30979  336.28103  1.20%  58.5 1201s\n",
      " 32759 11878     cutoff   95       332.30979  336.22762  1.18%  58.4 1206s\n",
      " 32904 11770     cutoff  130       332.30979  336.17545  1.16%  58.6 1210s\n",
      " 33400 11720     cutoff  196       332.30979  336.05168  1.13%  58.4 1220s\n",
      " 33445 11653  335.29972  214  601  332.30979  336.05045  1.13%  58.4 1226s\n",
      " 33753 11520     cutoff  121       332.30979  336.02989  1.12%  58.5 1230s\n",
      " 33900 11463  335.29054  231  599  332.30979  335.92786  1.09%  58.5 1238s\n",
      " 34180 11449     cutoff  204       332.30979  335.90280  1.08%  58.4 1243s\n",
      " 34354 11377     cutoff  200       332.30979  335.85319  1.07%  58.6 1248s\n",
      " 34569 11336     cutoff  180       332.30979  335.81320  1.05%  58.6 1253s\n",
      " 34851 11324     cutoff  126       332.30979  335.77064  1.04%  58.5 1257s\n",
      " 34981 11208  335.10187  109  722  332.30979  335.71874  1.03%  58.6 1266s\n",
      " 35120 11119     cutoff  242       332.30979  335.66209  1.01%  58.7 1275s\n",
      " 35291 11044  333.07105  238  179  332.30979  335.62785  1.00%  58.7 1280s\n",
      " 35408 10959  333.72999  253  567  332.30979  335.57422  0.98%  58.9 1287s\n",
      " 35584 10898  334.89699  205  613  332.30979  335.53984  0.97%  59.0 1293s\n",
      " 35955 10899     cutoff  114       332.30979  335.48074  0.95%  58.9 1297s\n",
      " 36166 10834     cutoff  150       332.30979  335.44114  0.94%  58.8 1300s\n",
      " 36315 10758     cutoff  238       332.30979  335.41252  0.93%  58.9 1306s\n",
      " 36543 10714     cutoff   85       332.30979  335.36691  0.92%  58.9 1312s\n",
      " 36723 10605     cutoff  264       332.30979  335.33573  0.91%  59.0 1318s\n",
      " 36972 10595     cutoff  200       332.30979  335.29106  0.90%  59.0 1326s\n",
      " 37194 10495  332.63600  351  141  332.30979  335.26678  0.89%  58.9 1334s\n",
      " 37506 10441  335.13716  241  461  332.30979  335.22083  0.88%  58.9 1344s\n",
      " 37659 10349     cutoff  269       332.30979  335.21854  0.88%  58.9 1350s\n",
      " 37864 10320     cutoff  243       332.30979  335.19568  0.87%  59.0 1357s\n",
      " 37996 10213     cutoff  161       332.30979  335.18150  0.86%  59.0 1361s\n",
      " 38359 10246     cutoff  130       332.30979  335.14026  0.85%  59.0 1367s\n",
      " 38612 10221  332.84675  459   45  332.30979  335.09591  0.84%  58.8 1370s\n",
      " 38879 10019     cutoff  112       332.30979  335.02317  0.82%  58.9 1378s\n",
      " 39056  9946     cutoff  246       332.30979  335.00094  0.81%  59.0 1382s\n",
      " 39251  9903     cutoff  282       332.30979  334.95682  0.80%  58.9 1389s\n",
      " 39418  9845     cutoff  238       332.30979  334.94348  0.79%  59.1 1395s\n",
      " 39617  9813     cutoff  249       332.30979  334.91313  0.78%  59.0 1401s\n",
      " 39846  9627     cutoff  267       332.30979  334.83364  0.76%  59.2 1410s\n",
      " 39944  9509     cutoff  292       332.30979  334.83049  0.76%  59.3 1416s\n",
      " 40224  9249  334.35119  161  672  332.30979  334.75158  0.73%  59.2 1421s\n",
      " 40313  9160     cutoff  136       332.30979  334.72487  0.73%  59.3 1429s\n",
      " 40577  9137     cutoff  308       332.30979  334.71546  0.72%  59.2 1432s\n",
      " 40935  9006     cutoff  234       332.30979  334.64086  0.70%  59.0 1437s\n",
      " 41124  8777     cutoff  166       332.30979  334.58256  0.68%  59.1 1441s\n",
      " 41228  8673     cutoff  168       332.30979  334.55185  0.67%  59.1 1445s\n",
      " 41437  8445     cutoff  241       332.30979  334.49243  0.66%  59.3 1455s\n",
      " 41757  8267     cutoff  324       332.30979  334.43592  0.64%  59.3 1461s\n",
      " 41860  8160     cutoff  333       332.30979  334.40661  0.63%  59.4 1469s\n",
      " 42117  8112     cutoff  329       332.30979  334.38139  0.62%  59.3 1473s\n",
      " 42311  7882     cutoff  208       332.30979  334.32459  0.61%  59.4 1476s\n",
      " 42479  7658     cutoff  322       332.30979  334.27230  0.59%  59.4 1480s\n",
      " 42663  7428  333.62240  344  448  332.30979  334.21918  0.57%  59.5 1486s\n",
      " 42852  7197     cutoff  142       332.30979  334.16424  0.56%  59.6 1494s\n",
      " 42977  7085     cutoff  335       332.30979  334.13878  0.55%  59.7 1495s\n",
      " 43163  6855     cutoff  146       332.30979  334.08164  0.53%  59.8 1503s\n",
      " 43345  6626     cutoff  199       332.30979  334.03252  0.52%  59.7 1506s\n",
      " 43442  6524     cutoff  321       332.30979  334.00085  0.51%  59.8 1514s\n",
      " 43532  6414  333.69899  350  481  332.30979  333.98698  0.50%  59.7 1517s\n",
      " 43684  6337     cutoff  120       332.30979  333.94767  0.49%  59.7 1522s\n",
      " 43964  5993     cutoff  356       332.30979  333.86266  0.47%  59.7 1526s\n",
      " 44050  5880     cutoff  272       332.30979  333.83329  0.46%  59.6 1532s\n",
      " 44352  5554     cutoff  190       332.30979  333.73800  0.43%  59.4 1540s\n",
      " 44797  4994     cutoff   67       332.30979  333.60447  0.39%  59.4 1545s\n",
      " 45230  4430     cutoff  146       332.30979  333.45242  0.34%  59.1 1552s\n",
      " 45434  4200     cutoff  432       332.30979  333.38088  0.32%  59.1 1555s\n",
      " 45867  3635     cutoff  263       332.30979  333.21583  0.27%  58.9 1561s\n",
      " 46235  3181     cutoff  127       332.30979  333.07972  0.23%  58.6 1565s\n",
      " 46768  2499     cutoff  109       332.30979  332.84856  0.16%  58.2 1570s\n",
      " 47374  1709     cutoff  345       332.30979  332.54200  0.07%  57.7 1575s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 540\n",
      "  Cover: 72\n",
      "  Implied bound: 16\n",
      "  MIR: 225\n",
      "  Flow cover: 354\n",
      "\n",
      "Explored 47628 nodes (2741150 simplex iterations) in 1576.45 seconds\n",
      "Thread count was 8 (of 8 available processors)\n",
      "\n",
      "Solution count 9: 332.31 332.307 332.243 ... 113.87\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 3.323097902548e+02, best bound 3.323302925953e+02, gap 0.0062%\n"
     ]
    }
   ],
   "source": [
    "# LipMIP stuff\n",
    "small_rad = Hyperbox.build_linf_ball(example, 1.0, global_lo=0.0, global_hi=1.0)\n",
    "lipmip_out = lm.compute_max_lipschitz(trained_net, small_rad, 'l_inf', torch.Tensor([1.0, -1.0]), verbose=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(672.2600, grad_fn=<SumBackward0>)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trained_net.fcs[0].weight.abs().sum()"
   ]
  },
  {
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
