{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import numpy as np \n",
    "\n",
    "\n",
    "import neural_nets.data_loaders as dl\n",
    "from relu_nets import ReLUNet\n",
    "from neural_nets import train\n",
    "from hyperbox import Hyperbox\n",
    "from lipMIP import LipProblem\n",
    "from interval_analysis import HBoxIA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": [
    "params = dl.RandomKParameters(00, k=20, radius=0.02, dimension=2, num_classes=4)\n",
    "dataset = dl.RandomDataset(params, random_seed=420)\n",
    "dataset.plot_2d()\n",
    "dataset.base_data[1]\n",
    "dataset.split_train_val(1.0)\n",
    "trainset = dataset.train_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 00 | Accuracy: 34.50\n",
      "Epoch 50 | Accuracy: 52.00\n",
      "Epoch 100 | Accuracy: 55.00\n",
      "Epoch 150 | Accuracy: 61.50\n",
      "Epoch 200 | Accuracy: 64.50\n",
      "Epoch 250 | Accuracy: 66.00\n",
      "Epoch 300 | Accuracy: 68.50\n",
      "Epoch 350 | Accuracy: 70.50\n",
      "Epoch 400 | Accuracy: 72.50\n",
      "Epoch 450 | Accuracy: 74.50\n",
      "Epoch 500 | Accuracy: 78.00\n",
      "Epoch 550 | Accuracy: 81.00\n",
      "Epoch 600 | Accuracy: 83.00\n",
      "Epoch 650 | Accuracy: 85.00\n",
      "Epoch 700 | Accuracy: 85.50\n",
      "Epoch 750 | Accuracy: 86.50\n",
      "Epoch 800 | Accuracy: 86.50\n",
      "Epoch 850 | Accuracy: 87.00\n",
      "Epoch 900 | Accuracy: 88.50\n",
      "Epoch 950 | Accuracy: 89.00\n"
     ]
    }
   ],
   "source": [
    "test_net = ReLUNet(layer_sizes=[2, 40, 40, 4])\n",
    "train_params = train.TrainParameters(trainset, trainset, 1000, test_after_epoch=50)\n",
    "train.training_loop(test_net, train_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "input_domain = Hyperbox.build_linf_ball(np.array([0.5, 0.5]), 0.5)\n",
    "backprop_domain = Hyperbox.build_linf_ball(np.zeros(4), 1.0)\n",
    "ia_obj = HBoxIA(test_net, input_domain, backprop_domain)\n",
    "ia_obj.compute_forward()\n",
    "ia_obj.compute_backward()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "LipMIP Result: \n",
       "\tValue 171.336\n",
       "\tRuntime 0.486"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "c_vec = np.array([1.0, -1.0, 0.0, 0.0])\n",
    "prob = LipProblem(test_net, input_domain, 'crossLipschitz', num_threads=4)\n",
    "prob.compute_max_lipschitz()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Get all results\n",
    "c_vecs = []\n",
    "for i in range(4):\n",
    "    for j in range(i + 1, 4):\n",
    "        z = np.zeros(4)\n",
    "        z[i] = 1\n",
    "        z[j] = -1\n",
    "        c_vecs.append(z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LipMIP Result: \n",
      "\tValue 153.495\n",
      "\tRuntime 0.374\n",
      "LipMIP Result: \n",
      "\tValue 88.296\n",
      "\tRuntime 0.474\n",
      "LipMIP Result: \n",
      "\tValue 109.175\n",
      "\tRuntime 0.345\n",
      "LipMIP Result: \n",
      "\tValue 171.336\n",
      "\tRuntime 0.431\n",
      "LipMIP Result: \n",
      "\tValue 72.800\n",
      "\tRuntime 0.336\n",
      "LipMIP Result: \n",
      "\tValue 140.389\n",
      "\tRuntime 0.246\n"
     ]
    }
   ],
   "source": [
    "for c_vec in c_vecs:\n",
    "    prob = LipProblem(test_net, input_domain, c_vec, num_threads=4)\n",
    "    print(prob.compute_max_lipschitz())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ia_obj.gradient_range.as_twocol()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "vals =[]\n",
    "for i in range(1000):\n",
    "    p = input_domain.random_point(1).squeeze()\n",
    "    c_vec = backprop_domain.random_point(1).squeeze()\n",
    "    vals.append(ia_obj.gradient_range.contains(test_net.get_grad_at_point(p, c_vec)))\n",
    "all(vals)"
   ]
  },
  {
   "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
}
