{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "from experiment import Experiment, MethodNest, Job\n",
    "from hyperbox import Hyperbox\n",
    "from relu_nets import ReLUNet\n",
    "from neural_nets import data_loaders as dl\n",
    "from neural_nets import train\n",
    "from lipMIP import LipProblem\n",
    "from other_methods import CLEVER, FastLip, LipLP, LipSDP, NaiveUB, RandomLB, SeqLip\n",
    "from other_methods import LOCAL_METHODS, GLOBAL_METHODS, OTHER_METHODS\n",
    "from utilities import Factory, DoEvery\n",
    "import utilities as utils\n",
    "import os\n",
    "import time\n",
    "import pickle "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def build_network(layers, train_params, data_seed=None):\n",
    "    network = ReLUNet(layers)\n",
    "    train.training_loop(network, train_params)\n",
    "    return network\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_eij(i,j, num_classes):\n",
    "    output = np.zeros(num_classes)\n",
    "    output[i] = 1.0\n",
    "    output[j] = -1.0\n",
    "    return output\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def naive_multiclass(network, box):\n",
    "    timer = utils.Timer()\n",
    "    lip_vals = {}\n",
    "    num_classes = network.layer_sizes[-1]\n",
    "    i = network.classify_np(box.get_center())\n",
    "    for j in range(num_classes):\n",
    "        if j == i:\n",
    "            continue\n",
    "        cvec = make_eij(i,j, num_classes)\n",
    "        lip_prob = LipProblem(network, box, c_vector=cvec, primal_norm='linf', verbose=False, num_threads=2)\n",
    "        ij_result = lip_prob.compute_max_lipschitz()\n",
    "        print((i,j), ij_result.compute_time)\n",
    "        lip_vals[(i,j)] = ij_result.value\n",
    "    return (timer.stop(), min(lip_vals.values()))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "def do_data_box(network, datum, radius):\n",
    "    style_outputs = {}\n",
    "    box = Hyperbox.build_linf_ball(datum, radius)\n",
    "\n",
    "    for style in ['targetCrossLipschitz', 'trueTargetCrossLipschitz']:\n",
    "        xlip = LipProblem(network, box, style, primal_norm='linf', verbose=True, num_threads=2)\n",
    "        xlip_result = xlip.compute_max_lipschitz()\n",
    "        xlip_tv = xlip_result.compute_time, xlip_result.value\n",
    "        style_outputs[style] = xlip_tv\n",
    "    style_outputs['naive'] = naive_multiclass(network, box)\n",
    "    print('-' * 100)\n",
    "    print(style_outputs)\n",
    "    \n",
    "    return style_outputs\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00 | Accuracy: 2.45\n",
      "Epoch 20 | Accuracy: 4.40\n",
      "Epoch 40 | Accuracy: 6.50\n",
      "Epoch 60 | Accuracy: 7.15\n",
      "Epoch 80 | Accuracy: 9.20\n",
      "Epoch 100 | Accuracy: 9.45\n",
      "Epoch 120 | Accuracy: 11.75\n",
      "Epoch 140 | Accuracy: 13.40\n",
      "Epoch 160 | Accuracy: 14.30\n",
      "Epoch 180 | Accuracy: 14.25\n",
      "Epoch 200 | Accuracy: 14.85\n",
      "Epoch 220 | Accuracy: 16.55\n",
      "Epoch 240 | Accuracy: 19.50\n",
      "Epoch 260 | Accuracy: 21.95\n",
      "Epoch 280 | Accuracy: 23.95\n",
      "Epoch 300 | Accuracy: 25.40\n",
      "Epoch 320 | Accuracy: 26.70\n",
      "Epoch 340 | Accuracy: 27.95\n",
      "Epoch 360 | Accuracy: 28.80\n",
      "Epoch 380 | Accuracy: 30.00\n",
      "Epoch 400 | Accuracy: 30.75\n",
      "Epoch 420 | Accuracy: 31.30\n",
      "Epoch 440 | Accuracy: 32.50\n",
      "Epoch 460 | Accuracy: 33.45\n",
      "Epoch 480 | Accuracy: 33.95\n",
      "Epoch 500 | Accuracy: 35.05\n",
      "Epoch 520 | Accuracy: 35.55\n",
      "Epoch 540 | Accuracy: 36.70\n",
      "Epoch 560 | Accuracy: 37.40\n",
      "Epoch 580 | Accuracy: 38.00\n",
      "Epoch 600 | Accuracy: 38.55\n",
      "Epoch 620 | Accuracy: 38.85\n",
      "Epoch 640 | Accuracy: 39.75\n",
      "Epoch 660 | Accuracy: 40.30\n",
      "Epoch 680 | Accuracy: 40.95\n",
      "Epoch 700 | Accuracy: 41.20\n",
      "Epoch 720 | Accuracy: 41.55\n",
      "Epoch 740 | Accuracy: 42.40\n",
      "Epoch 760 | Accuracy: 43.00\n",
      "Epoch 780 | Accuracy: 43.50\n",
      "Epoch 800 | Accuracy: 43.85\n",
      "Epoch 820 | Accuracy: 44.40\n",
      "Epoch 840 | Accuracy: 44.80\n",
      "Epoch 860 | Accuracy: 44.45\n",
      "Epoch 880 | Accuracy: 45.20\n",
      "Epoch 900 | Accuracy: 45.55\n",
      "Epoch 920 | Accuracy: 45.50\n",
      "Epoch 940 | Accuracy: 45.35\n",
      "Epoch 960 | Accuracy: 45.85\n",
      "Epoch 980 | Accuracy: 45.90\n",
      "Epoch 1000 | Accuracy: 46.65\n",
      "Epoch 1020 | Accuracy: 47.15\n",
      "Epoch 1040 | Accuracy: 47.50\n",
      "Epoch 1060 | Accuracy: 48.10\n",
      "Epoch 1080 | Accuracy: 48.20\n",
      "Epoch 1100 | Accuracy: 48.40\n",
      "Epoch 1120 | Accuracy: 48.70\n",
      "Epoch 1140 | Accuracy: 48.95\n",
      "Epoch 1160 | Accuracy: 49.25\n",
      "Epoch 1180 | Accuracy: 49.60\n",
      "Epoch 1200 | Accuracy: 49.80\n",
      "Epoch 1220 | Accuracy: 50.25\n",
      "Epoch 1240 | Accuracy: 50.35\n",
      "Epoch 1260 | Accuracy: 51.05\n",
      "Epoch 1280 | Accuracy: 51.45\n",
      "Epoch 1300 | Accuracy: 51.75\n",
      "Epoch 1320 | Accuracy: 52.10\n",
      "Epoch 1340 | Accuracy: 52.15\n",
      "Epoch 1360 | Accuracy: 52.45\n",
      "Epoch 1380 | Accuracy: 52.85\n",
      "Epoch 1400 | Accuracy: 53.00\n",
      "Epoch 1420 | Accuracy: 53.20\n",
      "Epoch 1440 | Accuracy: 54.00\n",
      "Epoch 1460 | Accuracy: 54.20\n",
      "Epoch 1480 | Accuracy: 54.15\n",
      "Epoch 1500 | Accuracy: 54.35\n",
      "Epoch 1520 | Accuracy: 54.90\n",
      "Epoch 1540 | Accuracy: 54.95\n",
      "Epoch 1560 | Accuracy: 55.50\n",
      "Epoch 1580 | Accuracy: 55.90\n",
      "Epoch 1600 | Accuracy: 56.30\n",
      "Epoch 1620 | Accuracy: 56.55\n",
      "Epoch 1640 | Accuracy: 56.85\n",
      "Epoch 1660 | Accuracy: 57.00\n",
      "Epoch 1680 | Accuracy: 57.25\n",
      "Epoch 1700 | Accuracy: 57.25\n",
      "Epoch 1720 | Accuracy: 57.10\n",
      "Epoch 1740 | Accuracy: 57.10\n",
      "Epoch 1760 | Accuracy: 57.15\n",
      "Epoch 1780 | Accuracy: 57.45\n",
      "Epoch 1800 | Accuracy: 57.55\n",
      "Epoch 1820 | Accuracy: 57.65\n",
      "Epoch 1840 | Accuracy: 58.00\n",
      "Epoch 1860 | Accuracy: 57.85\n",
      "Epoch 1880 | Accuracy: 58.00\n",
      "Epoch 1900 | Accuracy: 58.30\n",
      "Epoch 1920 | Accuracy: 58.15\n",
      "Epoch 1940 | Accuracy: 58.50\n",
      "Epoch 1960 | Accuracy: 58.90\n",
      "Epoch 1980 | Accuracy: 58.95\n"
     ]
    }
   ],
   "source": [
    "DIMENSION = 8\n",
    "NUM_CLASSES = 100\n",
    "LAYERS = [DIMENSION, 40, 40, 40, NUM_CLASSES]\n",
    "NUM_SAMPLES = 100\n",
    "RANDOM_SEED = 420\n",
    "data_params = dl.RandomKParameters(2000, 200, radius=0.01, dimension=DIMENSION,\n",
    "                                   num_classes=NUM_CLASSES)\n",
    "dataset = dl.RandomDataset(data_params, random_seed=420)\n",
    "trainset, _ = dataset.split_train_val(1.0)\n",
    "train_batch = trainset[0][0]\n",
    "xentropy = train.XEntropyReg()\n",
    "l1_reg = train.LpWeightReg(scalar=5e-4)\n",
    "loss = train.LossFunctional(regularizers=[xentropy, l1_reg])\n",
    "train_params = train.TrainParameters(trainset, trainset, 2000, loss_functional=loss, \n",
    "                                     test_after_epoch=20)\n",
    "net = build_network(LAYERS, train_params, 420)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(85, 0) 0.2063589096069336\n",
      "(85, 1) 0.21882390975952148\n",
      "(85, 2) 0.5076403617858887\n",
      "(85, 3) 0.4966452121734619\n",
      "(85, 4) 0.7312166690826416\n",
      "(85, 5) 0.694495439529419\n",
      "(85, 6) 1.2182700634002686\n",
      "(85, 7) 0.4368710517883301\n",
      "(85, 8) 0.15004420280456543\n",
      "(85, 9) 0.15554094314575195\n",
      "(85, 10) 0.7056424617767334\n",
      "(85, 11) 0.3778553009033203\n",
      "(85, 12) 0.48939943313598633\n",
      "(85, 13) 0.6811318397521973\n"
     ]
    },
    {
     "ename": "AttributeError",
     "evalue": "b\"Unable to retrieve attribute 'X'\"",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-22-6a054902dfc8>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mradius\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0.1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mbox\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mHyperbox\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbuild_linf_ball\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdatum\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mradius\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m \u001b[0mnaive_multiclass\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnet\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbox\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<ipython-input-8-28664acb34dd>\u001b[0m in \u001b[0;36mnaive_multiclass\u001b[0;34m(network, box)\u001b[0m\n\u001b[1;32m      9\u001b[0m         \u001b[0mcvec\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmake_eij\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnum_classes\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     10\u001b[0m         \u001b[0mlip_prob\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mLipProblem\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnetwork\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbox\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mc_vector\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcvec\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mprimal_norm\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'linf'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mverbose\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnum_threads\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 11\u001b[0;31m         \u001b[0mij_result\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlip_prob\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute_max_lipschitz\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     12\u001b[0m         \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mij_result\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute_time\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     13\u001b[0m         \u001b[0mlip_vals\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mij_result\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/grad/lipMIP/lipMIP.py\u001b[0m in \u001b[0;36mcompute_max_lipschitz\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    130\u001b[0m         \u001b[0mx_vars\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msquire\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_vars\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'x'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    131\u001b[0m         \u001b[0mvalue\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mObjBound\u001b[0m \u001b[0;31m#model.getObjective().getValue()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 132\u001b[0;31m         \u001b[0mbest_x\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[0;34m[\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mX\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mx_vars\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    133\u001b[0m         \u001b[0mbest_sign_config\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msquire\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_sign_configs\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    134\u001b[0m         result = LipResult(self.network, self.c_vector, value=value,\n",
      "\u001b[0;32m~/grad/lipMIP/lipMIP.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m    130\u001b[0m         \u001b[0mx_vars\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msquire\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_vars\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'x'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    131\u001b[0m         \u001b[0mvalue\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mObjBound\u001b[0m \u001b[0;31m#model.getObjective().getValue()\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 132\u001b[0;31m         \u001b[0mbest_x\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[0;34m[\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mX\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mx_vars\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    133\u001b[0m         \u001b[0mbest_sign_config\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msquire\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_sign_configs\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    134\u001b[0m         result = LipResult(self.network, self.c_vector, value=value,\n",
      "\u001b[0;32mvar.pxi\u001b[0m in \u001b[0;36mgurobipy.Var.__getattr__ (../../src/python/gurobipy.c:15232)\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32mvar.pxi\u001b[0m in \u001b[0;36mgurobipy.Var.getAttr (../../src/python/gurobipy.c:16032)\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: b\"Unable to retrieve attribute 'X'\""
     ]
    }
   ],
   "source": [
    "datum = np.ones(8) * 0.5\n",
    "radius = 0.1\n",
    "box = Hyperbox.build_linf_ball(datum, radius)\n",
    "naive_multiclass(net, box)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Changed value of parameter Threads to 2\n",
      "   Prev: 0  Min: 0  Max: 1024  Default: 0\n",
      "Optimize a model with 654 rows, 738 columns and 16170 nonzeros\n",
      "Variable types: 705 continuous, 33 integer (33 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [5e-10, 8e+04]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-06, 4e+04]\n",
      "  RHS range        [1e-06, 8e+04]\n",
      "Warning: Model contains large matrix coefficient range\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 315 rows and 410 columns\n",
      "Presolve time: 0.03s\n",
      "Presolved: 339 rows, 328 columns, 4549 nonzeros\n",
      "Variable types: 295 continuous, 33 integer (33 binary)\n",
      "\n",
      "Root relaxation: objective 2.284624e+04, 293 iterations, 0.01 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 7587.15095    0   22          - 7587.15095      -     -    0s\n",
      "     0     0 7469.80383    0   22          - 7469.80383      -     -    0s\n",
      "     0     0 7316.07000    0   20          - 7316.07000      -     -    0s\n",
      "     0     0 7284.39387    0   19          - 7284.39387      -     -    0s\n",
      "     0     0 7284.13108    0   19          - 7284.13108      -     -    0s\n",
      "     0     0 7207.37814    0   21          - 7207.37814      -     -    0s\n",
      "     0     0 7183.07262    0   20          - 7183.07262      -     -    0s\n",
      "     0     0 7178.64109    0   21          - 7178.64109      -     -    0s\n",
      "     0     0 7178.40225    0   21          - 7178.40225      -     -    0s\n",
      "     0     0 7120.50707    0   20          - 7120.50707      -     -    0s\n",
      "     0     0 7119.16339    0   20          - 7119.16339      -     -    0s\n",
      "     0     0 7097.54668    0   20          - 7097.54668      -     -    0s\n",
      "     0     0 7096.74383    0   20          - 7096.74383      -     -    0s\n",
      "     0     0 7094.77478    0   20          - 7094.77478      -     -    0s\n",
      "     0     0 7075.70909    0   21          - 7075.70909      -     -    0s\n",
      "     0     0 7074.12000    0   20          - 7074.12000      -     -    0s\n",
      "     0     0 7058.73158    0   20          - 7058.73158      -     -    0s\n",
      "     0     0 7057.59277    0   20          - 7057.59277      -     -    0s\n",
      "     0     0 7057.52571    0   20          - 7057.52571      -     -    0s\n",
      "     0     0 7053.74350    0   20          - 7053.74350      -     -    0s\n",
      "     0     0 7051.82455    0   21          - 7051.82455      -     -    0s\n",
      "     0     0 7051.72801    0   21          - 7051.72801      -     -    0s\n",
      "     0     0 7049.20599    0   20          - 7049.20599      -     -    0s\n",
      "     0     0 7049.20599    0   20          - 7049.20599      -     -    0s\n",
      "H    0     0                      99.3422268 7049.20599  6996%     -    0s\n",
      "     0     2 7049.20599    0   20   99.34223 7049.20599  6996%     -    0s\n",
      "*   83    52              26     133.1278944 5135.84196  3758%  28.6    0s\n",
      "*   84    52              26     142.4173605 5135.84196  3506%  28.3    0s\n",
      "*   91    53              28     237.6725543 5135.84196  2061%  26.9    0s\n",
      "*  346   191              21     290.6095827 4170.99115  1335%  32.0    0s\n",
      "H  466   248                     318.5519277 3505.53313  1000%  31.1    0s\n",
      "*  703   331              23     320.6667417 2763.15498   762%  29.0    0s\n",
      "*  707   331              23     322.0052456 2763.15498   758%  28.8    0s\n",
      "* 2005   583              19     323.4832888 1505.87704   366%  24.6    1s\n",
      "* 2886   514              17     325.6985016 1313.53041   303%  23.2    1s\n",
      "* 4366   159              16     328.2920064  519.64594  58.3%  21.3    2s\n",
      "* 4505   163              18     330.7614834  478.59122  44.7%  21.1    2s\n",
      "* 4641   123              18     333.8716924  472.15600  41.4%  20.9    2s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 1\n",
      "  Gomory: 10\n",
      "  Cover: 34\n",
      "  Implied bound: 27\n",
      "  MIR: 49\n",
      "  Flow cover: 9\n",
      "  Inf proof: 2\n",
      "\n",
      "Explored 5169 nodes (104441 simplex iterations) in 2.68 seconds\n",
      "Thread count was 2 (of 8 available processors)\n",
      "\n",
      "Solution count 10: 333.872 330.761 328.292 ... 237.673\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 3.338716923918e+02, best bound 3.338716923918e+02, gap 0.0000%\n",
      "Changed value of parameter Threads to 2\n",
      "   Prev: 0  Min: 0  Max: 1024  Default: 0\n",
      "Optimize a model with 753 rows, 837 columns and 16368 nonzeros\n",
      "Variable types: 705 continuous, 132 integer (132 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [5e-10, 8e+04]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-06, 4e+04]\n",
      "  RHS range        [1e-06, 8e+04]\n",
      "Warning: Model contains large matrix coefficient range\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 414 rows and 509 columns\n",
      "Presolve time: 0.11s\n",
      "Presolved: 339 rows, 328 columns, 4549 nonzeros\n",
      "Variable types: 196 continuous, 132 integer (132 binary)\n",
      "\n",
      "Root relaxation: objective 2.284624e+04, 304 iterations, 0.01 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 7587.15095    0   15          - 7587.15095      -     -    0s\n",
      "     0     0 7518.54189    0   31          - 7518.54189      -     -    0s\n",
      "     0     0 7442.30296    0   34          - 7442.30296      -     -    0s\n",
      "     0     0 7435.13079    0   27          - 7435.13079      -     -    0s\n",
      "     0     0 7434.54311    0   32          - 7434.54311      -     -    0s\n",
      "     0     0 7434.54224    0   32          - 7434.54224      -     -    0s\n",
      "     0     0 7353.41889    0   26          - 7353.41889      -     -    0s\n",
      "     0     0 7346.96691    0   27          - 7346.96691      -     -    0s\n",
      "     0     0 7344.41889    0   25          - 7344.41889      -     -    0s\n",
      "     0     0 7344.41889    0   25          - 7344.41889      -     -    0s\n",
      "     0     0 7330.18020    0   24          - 7330.18020      -     -    0s\n",
      "     0     0 7329.86706    0   24          - 7329.86706      -     -    0s\n",
      "     0     0 7329.82442    0   27          - 7329.82442      -     -    0s\n",
      "     0     0 7326.41498    0   27          - 7326.41498      -     -    0s\n",
      "     0     0 7325.94776    0   28          - 7325.94776      -     -    0s\n",
      "     0     0 7325.38834    0   28          - 7325.38834      -     -    0s\n",
      "     0     0 7325.33646    0   29          - 7325.33646      -     -    0s\n",
      "     0     0 7307.83152    0   28          - 7307.83152      -     -    0s\n",
      "     0     0 7306.95960    0   28          - 7306.95960      -     -    0s\n",
      "     0     0 7306.94288    0   28          - 7306.94288      -     -    0s\n",
      "     0     0 7305.64022    0   27          - 7305.64022      -     -    0s\n",
      "     0     0 7305.20360    0   30          - 7305.20360      -     -    0s\n",
      "     0     0 7305.08150    0   31          - 7305.08150      -     -    0s\n",
      "     0     0 7304.57726    0   29          - 7304.57726      -     -    0s\n",
      "     0     0 7304.57726    0   29          - 7304.57726      -     -    0s\n",
      "H    0     0                      54.3850151 7304.57726      -     -    0s\n",
      "     0     2 7304.57726    0   29   54.38502 7304.57726      -     -    0s\n",
      "*  107    62              34     133.1789245 5945.46849  4364%  36.4    0s\n",
      "*  289   173              31     144.1113678 5080.34602  3425%  26.9    0s\n",
      "*  999   425              13     177.4006788 3459.79851  1850%  21.8    1s\n",
      "* 1142   460              21     209.0589168 3356.92429  1506%  22.1    1s\n",
      "* 1207   465              16     221.6829028 3312.54942  1394%  22.4    1s\n",
      "* 1209   461              16     224.9515356 3312.54942  1373%  22.4    1s\n",
      "H 1312   450                     288.1826442 3294.73834  1043%  23.0    1s\n",
      "* 1317   442              19     296.9206730 3294.73834  1010%  22.9    1s\n",
      "* 1446   467              20     315.0730827 3243.28813   929%  22.5    1s\n",
      "* 2868   310              30     332.1113361 1421.57787   328%  20.2    3s\n",
      "* 4055   232              28     333.8716924  480.40249  43.9%  18.2    3s\n",
      "\n",
      "Explored 4898 nodes (83196 simplex iterations) in 4.61 seconds\n",
      "Thread count was 2 (of 8 available processors)\n",
      "\n",
      "Solution count 10: 333.872 332.111 315.073 ... 144.111\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 3.338716923918e+02, best bound 3.338716923918e+02, gap 0.0000%\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(85, 0) 0.6862578392028809\n",
      "(85, 1) 0.4026784896850586\n",
      "(85, 2) 0.750737190246582\n",
      "(85, 3) 0.6678311824798584\n",
      "(85, 4) 0.9511158466339111\n",
      "(85, 5) 0.3203597068786621\n",
      "(85, 6) 0.5642180442810059\n",
      "(85, 7) 0.5781347751617432\n",
      "(85, 8) 1.0737190246582031\n",
      "(85, 9) 0.46069812774658203\n",
      "(85, 10) 0.9285140037536621\n",
      "(85, 11) 0.4491450786590576\n",
      "(85, 12) 0.5101864337921143\n",
      "(85, 13) 0.5945682525634766\n",
      "(85, 14) 1.096900463104248\n",
      "(85, 15) 0.8653953075408936\n",
      "(85, 16) 0.8418629169464111\n",
      "(85, 17) 0.691784143447876\n",
      "(85, 18) 0.4613962173461914\n",
      "(85, 19) 0.6755936145782471\n",
      "(85, 20) 0.6780133247375488\n",
      "(85, 21) 0.5989234447479248\n",
      "(85, 22) 0.9149072170257568\n",
      "(85, 23) 0.8561372756958008\n",
      "(85, 24) 1.4167821407318115\n",
      "(85, 25) 0.41436767578125\n",
      "(85, 26) 0.8518726825714111\n",
      "(85, 27) 0.8534295558929443\n",
      "(85, 28) 0.3768181800842285\n",
      "(85, 29) 0.563971757888794\n",
      "(85, 30) 0.3696765899658203\n",
      "(85, 31) 0.7938730716705322\n",
      "(85, 32) 0.7155666351318359\n",
      "(85, 33) 0.8975846767425537\n",
      "(85, 34) 0.46189045906066895\n",
      "(85, 35) 0.8411269187927246\n",
      "(85, 36) 1.231309175491333\n",
      "(85, 37) 0.6162915229797363\n",
      "(85, 38) 0.4892146587371826\n",
      "(85, 39) 0.35770750045776367\n",
      "(85, 40) 0.5220317840576172\n",
      "(85, 41) 0.3224189281463623\n",
      "(85, 42) 1.1892011165618896\n",
      "(85, 43) 0.6656925678253174\n",
      "(85, 44) 0.8341798782348633\n",
      "(85, 45) 0.6289710998535156\n",
      "(85, 46) 0.4755406379699707\n",
      "(85, 47) 0.3270092010498047\n",
      "(85, 48) 0.6805558204650879\n",
      "(85, 49) 0.6418740749359131\n",
      "(85, 50) 0.8186464309692383\n",
      "(85, 51) 1.138775110244751\n",
      "(85, 52) 0.9086093902587891\n",
      "(85, 53) 0.46093297004699707\n",
      "(85, 54) 0.5511448383331299\n",
      "(85, 55) 0.6214509010314941\n",
      "(85, 56) 0.4812510013580322\n",
      "(85, 57) 0.8166556358337402\n",
      "(85, 58) 1.0386168956756592\n",
      "(85, 59) 0.828538179397583\n",
      "(85, 60) 0.5124495029449463\n",
      "(85, 61) 0.9719521999359131\n",
      "(85, 62) 0.8672468662261963\n",
      "(85, 63) 1.207460641860962\n",
      "(85, 64) 0.7161257266998291\n",
      "(85, 65) 0.8854796886444092\n",
      "(85, 66) 0.398052453994751\n",
      "(85, 67) 0.8832852840423584\n",
      "(85, 68) 0.39250969886779785\n",
      "(85, 69) 0.795626163482666\n",
      "(85, 70) 0.35914111137390137\n",
      "(85, 71) 0.376237154006958\n",
      "(85, 72) 0.5015702247619629\n",
      "(85, 73) 0.9973952770233154\n",
      "(85, 74) 1.0165066719055176\n",
      "(85, 75) 0.42343664169311523\n",
      "(85, 76) 0.5246210098266602\n",
      "(85, 77) 0.9387550354003906\n",
      "(85, 78) 0.718137264251709\n",
      "(85, 79) 0.8530521392822266\n",
      "(85, 80) 0.5209863185882568\n",
      "(85, 81) 0.47702860832214355\n",
      "(85, 82) 0.8306803703308105\n",
      "(85, 83) 0.8609342575073242\n",
      "(85, 84) 0.8259978294372559\n",
      "(85, 86) 0.43952083587646484\n",
      "(85, 87) 0.9033405780792236\n",
      "(85, 88) 0.7326145172119141\n",
      "(85, 89) 1.1383893489837646\n",
      "(85, 90) 0.9850456714630127\n",
      "(85, 91) 0.47526097297668457\n",
      "(85, 92) 0.9134688377380371\n",
      "(85, 93) 0.9654688835144043\n",
      "(85, 94) 0.8589906692504883\n",
      "(85, 95) 0.5870635509490967\n",
      "(85, 96) 0.35985827445983887\n",
      "(85, 97) 0.6800069808959961\n",
      "(85, 98) 0.45369434356689453\n",
      "(85, 99) 0.7281923294067383\n",
      "----------------------------------------------------------------------------------------------------\n",
      "{'targetCrossLipschitz': (2.736213207244873, 333.87169239179565), 'trueTargetCrossLipschitz': (4.66519570350647, 333.871692391795), 'naive': (70.04203152656555, 80.55886271053177)}\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'targetCrossLipschitz': (2.736213207244873, 333.87169239179565),\n",
       " 'trueTargetCrossLipschitz': (4.66519570350647, 333.871692391795),\n",
       " 'naive': (70.04203152656555, 80.55886271053177)}"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "do_data_box(net, datum, 0.1)"
   ]
  },
  {
   "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
}
