{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matlab.engine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "from hyperbox import Hyperbox\n",
    "from interval_analysis import HBoxIA\n",
    "from relu_nets import ReLUNet\n",
    "from lipMIP import LipProblem\n",
    "from other_methods import CLEVER, FastLip, LipLP, LipSDP, NaiveUB, RandomLB, SeqLip\n",
    "from neural_nets import train\n",
    "from neural_nets import data_loaders as dl\n",
    "from experiment import Experiment, InstanceGroup, Result\n",
    "from utilities import Factory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Basic test file to demonstrate that everything works \n",
    "# 1) Build dataset and display it \n",
    "# 2) Build neural net and train it \n",
    "# 3) Run single evaluations for a particular hyperbox and multiple types of results\n",
    "# 4) Run some simple experimental series\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 1) Build a dataset and display it \n",
    "dataset_params = dl.RandomKParameters(256, 30, radius=0.02)\n",
    "dataset = dl.Random2DBinaryDataset(dataset_params, random_seed=420)\n",
    "train_data, val_data = dataset.split_train_val(1.0)\n",
    "dataset.plot_2d()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00 | Accuracy: 42.58\n",
      "Epoch 100 | Accuracy: 75.78\n",
      "Epoch 200 | Accuracy: 75.00\n",
      "Epoch 300 | Accuracy: 92.19\n",
      "Epoch 400 | Accuracy: 96.88\n",
      "Epoch 500 | Accuracy: 97.27\n",
      "Epoch 600 | Accuracy: 97.27\n",
      "Epoch 700 | Accuracy: 97.66\n",
      "Epoch 800 | Accuracy: 98.05\n",
      "Epoch 900 | Accuracy: 98.05\n"
     ]
    }
   ],
   "source": [
    "# 2) Build neural net and train it \n",
    "test_net = ReLUNet(layer_sizes=[2, 16, 32, 64, 16, 2])\n",
    "train_params = train.TrainParameters(train_data, train_data, 1000, test_after_epoch=100)\n",
    "train.training_loop(test_net, train_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 3) Run single evaluations for a particular hyperbox and multiple types of results\n",
    "hbox1 = Hyperbox.build_linf_ball(np.array([0.5, 0.5]), 0.2)\n",
    "c_vec = torch.Tensor([1.0, -1.0])\n",
    "local_args = {'network': test_net, 'domain': hbox1, 'c_vector': c_vec, 'primal_norm': 'linf'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Changed value of parameter Threads to 4\n",
      "   Prev: 0  Min: 0  Max: 1024  Default: 0\n",
      "Gurobi Optimizer version 9.0.0 build v9.0.0rc2 (linux64)\n",
      "Optimize a model with 1046 rows, 614 columns and 9280 nonzeros\n",
      "Model fingerprint: 0x824aee9f\n",
      "Variable types: 522 continuous, 92 integer (92 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [3e-05, 6e+03]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-08, 3e+03]\n",
      "  RHS range        [1e-08, 6e+03]\n",
      "Presolve removed 359 rows and 181 columns\n",
      "Presolve time: 0.07s\n",
      "Presolved: 687 rows, 433 columns, 7136 nonzeros\n",
      "Variable types: 356 continuous, 77 integer (77 binary)\n",
      "\n",
      "Root relaxation: objective 2.790220e+03, 575 iterations, 0.02 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 2770.91588    0   54          - 2770.91588      -     -    0s\n",
      "     0     0 2750.69610    0   61          - 2750.69610      -     -    0s\n",
      "H    0     0                     354.7120463 2750.69610   675%     -    0s\n",
      "     0     0 2743.99212    0   62  354.71205 2743.99212   674%     -    0s\n",
      "     0     0 2743.86404    0   61  354.71205 2743.86404   674%     -    0s\n",
      "     0     0 2743.86403    0   61  354.71205 2743.86403   674%     -    0s\n",
      "     0     0 2717.41618    0   67  354.71205 2717.41618   666%     -    0s\n",
      "     0     0 2717.41618    0   64  354.71205 2717.41618   666%     -    0s\n",
      "     0     0 2717.41618    0   65  354.71205 2717.41618   666%     -    0s\n",
      "     0     0 1575.92249    0   64  354.71205 1575.92249   344%     -    0s\n",
      "     0     0 1575.92249    0   64  354.71205 1575.92249   344%     -    0s\n",
      "     0     2 1575.92249    0   64  354.71205 1575.92249   344%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 3\n",
      "  Gomory: 3\n",
      "  Cover: 9\n",
      "  Implied bound: 33\n",
      "  Clique: 6\n",
      "  MIR: 173\n",
      "  Flow cover: 11\n",
      "  RLT: 92\n",
      "  Relax-and-lift: 35\n",
      "  BQP: 3\n",
      "\n",
      "Explored 143 nodes (9702 simplex iterations) in 0.71 seconds\n",
      "Thread count was 4 (of 8 available processors)\n",
      "\n",
      "Solution count 1: 354.712 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 3.547120462943e+02, best bound 3.547120462943e+02, gap 0.0000%\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "LipMIP Result: \n",
       "\tValue 354.712\n",
       "\tRuntime 0.786"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 3.1) lipMIP\n",
    "lip_prob = LipProblem(test_net, hbox1, c_vec, verbose=True, num_threads=4)\n",
    "lip_prob.compute_max_lipschitz()\n",
    "lip_prob.result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "354.7120666503906"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 3.2) CLEVER\n",
    "clever = CLEVER(**local_args)\n",
    "clever.compute()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4680.738"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 3.3) FastLip\n",
    "fastlip = FastLip(**local_args)\n",
    "fastlip.compute()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4418.351108605412"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 3.4) LipLP\n",
    "liplp = LipLP(**local_args)\n",
    "liplp.compute()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1941.1770552806809\n"
     ]
    }
   ],
   "source": [
    "# 3.5) LipSDP\n",
    "lipsdp = LipSDP(test_net, c_vec)\n",
    "lipsdp.compute()\n",
    "print(lipsdp.l1_value())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L1 norms of matrices: 32390.244\n",
      "L2 norms of matrices, scaled by sqrt(2) 27052.201210369218\n"
     ]
    }
   ],
   "source": [
    "# 3.6) Naive UB\n",
    "naiveub = NaiveUB(test_net, c_vec, 'linf')\n",
    "print(\"L1 norms of matrices:\", naiveub.compute())\n",
    "naiveub2 = NaiveUB(test_net, c_vec, 'l2')\n",
    "print(\"L2 norms of matrices, scaled by sqrt(2)\", naiveub2.compute() * 2**0.5)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(354.7120)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 3.7) Random LB\n",
    "randomlb = RandomLB(**local_args)\n",
    "randomlb.compute()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "../other_methods/seq_lip.py:31: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  c_vec = torch.tensor(self.c_vector).view(1, -1)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "3162.988943009787"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 3.8) SeqLip\n",
    "seqlip = SeqLip(**local_args)\n",
    "seqlip.compute() * 2 **0.5 \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 4) Run some simple experimental series\n",
    "exp_1 = Experiment([RandomLB, FastLip, LipProblem], network=test_net, c_vector=c_vec, \n",
    "                   primal_norm='linf', verbose=False, num_threads=4)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 4.1) Evaluate over the unit hypercube\n",
    "hypercube_result = exp_1.do_unit_hypercube_eval()\n",
    "print(hypercube_result.values())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 4.2) Evaluate over random Linf balls of radius 0.2\n",
    "ball_factory = Factory(Hyperbox.build_linf_ball, radius=0.2, global_lo=np.array([0,0]), global_hi=np.array([1.0, 1.0]))\n",
    "center_domain = Hyperbox.build_linf_ball(x=np.array([0.5, 0.5]), radius=0.5)\n",
    "random_results = exp_1.do_random_evals(10, center_domain, ball_factory)\n",
    "random_results.average_stdevs('value')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 4.3) Evaluate over random data points \n",
    "data_results = exp_1.do_data_evals(train_data[0][0], ball_factory, num_random=10)\n",
    "data_results.average_stdevs('value')"
   ]
  },
  {
   "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
}
