{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Experiment 3\n",
    "# ==================================\n",
    "\n",
    "# estimate the reduction in the number of encountered polytopes\n",
    "#when l_1 regularizaiton is utilized. Again, classifier trained on\n",
    "# random data in R^2."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\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": [
    "import numpy as np\n",
    "from plnn import PLNN\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.autograd import Variable\n",
    "import utilities as utils\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============Generating Training Points============\n"
     ]
    }
   ],
   "source": [
    "# ==================================\n",
    "# Generate Training Points\n",
    "# ==================================\n",
    "print('===============Generating Training Points============')\n",
    "# random points at least 2r apart\n",
    "m = 12\n",
    "# np.random.seed(3)\n",
    "x = [np.random.uniform(size=(2))]\n",
    "r = 0.16\n",
    "while(len(x) < m):\n",
    "    p = np.random.uniform(size=(2))\n",
    "    if min(np.abs(p-a).sum() for a in x) > 2*r:\n",
    "        x.append(p)\n",
    "# r = 0.145\n",
    "epsilon = r/2\n",
    "\n",
    "X = torch.Tensor(np.array(x))\n",
    "torch.manual_seed(1)\n",
    "y = (torch.rand(m)+0.5).long()\n",
    "\n",
    "layer_sizes = [2,50,50,50,2]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Define L1-reg loss\n",
    "# ==================================\n",
    "def l1_loss(net):\n",
    "\n",
    "    return sum([_.norm(p=1) for _ in net.parameters() if _.dim() > 1])"
   ]
  },
  {
   "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=50, bias=True)\n",
      "  (2): ReLU()\n",
      "  (3): Linear(in_features=50, out_features=50, bias=True)\n",
      "  (4): ReLU()\n",
      "  (5): Linear(in_features=50, out_features=50, bias=True)\n",
      "  (6): ReLU()\n",
      "  (7): Linear(in_features=50, out_features=2, bias=True)\n",
      ")\n",
      "===============Training Network============\n",
      "tensor(0.7138)\n",
      "error:  tensor(0.5833)\n",
      "tensor(0.7071)\n",
      "error:  tensor(0.5833)\n",
      "tensor(0.7009)\n",
      "error:  tensor(0.5833)\n",
      "tensor(0.6956)\n",
      "error:  tensor(0.5833)\n",
      "tensor(0.6909)\n",
      "error:  tensor(0.5833)\n",
      "tensor(0.6866)\n",
      "error:  tensor(0.5833)\n",
      "tensor(0.6824)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6783)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.6743)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.6704)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.6665)\n",
      "error:  tensor(0.2500)\n",
      "tensor(0.6626)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6587)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6552)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6516)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6482)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6447)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6411)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6374)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6337)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6299)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6260)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6221)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6182)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6143)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6104)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6063)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.6020)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.5975)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.5928)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.5880)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.5829)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.5775)\n",
      "error:  tensor(0.4167)\n",
      "tensor(0.5720)\n",
      "error:  tensor(0.3333)\n",
      "tensor(0.5661)\n",
      "error:  tensor(0.3333)\n",
      "tensor(0.5601)\n",
      "error:  tensor(0.3333)\n",
      "tensor(0.5538)\n",
      "error:  tensor(0.3333)\n",
      "tensor(0.5473)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.5406)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.5336)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.5264)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.5190)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.5116)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.5039)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4962)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4886)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4808)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4728)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4647)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4566)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4487)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4409)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4333)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.4258)\n",
      "error:  tensor(0.2500)\n",
      "tensor(0.4183)\n",
      "error:  tensor(0.2500)\n",
      "tensor(0.4110)\n",
      "error:  tensor(0.2500)\n",
      "tensor(0.4039)\n",
      "error:  tensor(0.2500)\n",
      "tensor(0.3972)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3906)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3844)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3785)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3729)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3677)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3629)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3584)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3540)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3499)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3460)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3423)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3389)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3356)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3326)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3299)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3273)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3249)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3227)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3206)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3188)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3172)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3156)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3140)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3126)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3115)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3104)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3091)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3080)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3069)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3057)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3047)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3034)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3023)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.3011)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2999)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2986)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2974)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2963)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2952)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2941)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2929)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2919)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2911)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2901)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2891)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2882)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2873)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2863)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2852)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2842)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2832)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2823)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2812)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2801)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2790)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2780)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2768)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2756)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2744)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2733)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2721)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2709)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2696)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2684)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2671)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2660)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2647)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2634)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2621)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2608)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2594)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2580)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2565)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2551)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2536)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2522)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2508)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2494)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2480)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2465)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2448)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2432)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2419)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2404)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2384)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2369)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2353)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2337)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2320)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2300)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2285)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2268)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2249)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2231)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2215)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2196)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2177)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2158)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2139)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2121)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2099)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2080)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2061)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2040)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.2019)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.1999)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.1979)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.1957)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.1933)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.1914)\n",
      "error:  tensor(0.1667)\n",
      "tensor(0.1894)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1870)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1847)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1826)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1804)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1780)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1756)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1731)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1708)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1686)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1659)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1636)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1615)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1593)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1569)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1546)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1521)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1497)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1473)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1451)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1429)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1408)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1387)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1363)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1335)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1309)\n",
      "error:  tensor(0.0833)\n",
      "tensor(0.1284)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1258)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1234)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1213)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1192)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1169)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1148)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1128)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1106)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1083)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1064)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1045)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.1004)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "error:  tensor(0.)\n",
      "tensor(0.0985)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0966)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0945)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0925)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0907)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0888)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0868)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0853)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0838)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0819)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0800)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0784)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0769)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0752)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0734)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0718)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0703)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0689)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0673)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0658)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0642)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0630)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0617)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0603)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0590)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0575)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0562)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0550)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0537)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0526)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0514)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0502)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0491)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0480)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0469)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0459)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0450)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0440)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0430)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0420)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0412)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0403)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0394)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0385)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0376)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0368)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0360)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0352)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0344)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0336)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0330)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0323)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0315)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0308)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0301)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0295)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0289)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0284)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0278)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0271)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0266)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0261)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0255)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0250)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0245)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0241)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0235)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0230)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0227)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0223)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0218)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0213)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0209)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0205)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0201)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0198)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0194)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0190)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0187)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0184)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0180)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0176)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0173)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0170)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0167)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0164)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0161)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0159)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0156)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0154)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0151)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0148)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0146)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0144)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0141)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0139)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0136)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0134)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0132)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0130)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0128)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0126)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0124)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0122)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0120)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0118)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0117)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0115)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0113)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0111)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0109)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0108)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0106)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0105)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0103)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0102)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0100)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0099)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0098)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0096)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0095)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0094)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0092)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0091)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0090)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0089)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0088)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0087)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0086)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0084)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0083)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0082)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0081)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0080)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0079)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0078)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0077)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0076)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0075)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0074)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0074)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0073)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0072)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0071)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0070)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0069)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0068)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0068)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0067)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0066)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0065)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0065)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0064)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0063)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0062)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0062)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0061)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0061)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0060)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0059)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0059)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0058)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0057)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0057)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0056)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0056)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0055)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0054)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0054)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0053)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0053)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0052)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0052)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0051)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0051)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0050)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0050)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0049)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0049)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0048)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0048)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0047)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0047)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0047)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0046)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0046)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0045)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0045)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0044)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0044)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0044)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0043)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0043)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0042)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0042)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0042)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0041)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0041)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0041)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0040)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0040)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0039)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0039)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0039)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0038)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0038)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0038)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0038)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0037)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0037)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0037)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0036)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0036)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0036)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0035)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0035)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0035)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0035)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0034)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0034)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0034)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0033)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0033)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0033)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0033)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0032)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0032)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0032)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0032)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0031)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0031)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0031)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0031)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0031)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0030)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0030)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0030)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0030)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0029)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0029)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0029)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0029)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0028)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0028)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0028)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0028)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "error:  tensor(0.)\n",
      "tensor(0.0027)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0027)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0027)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0027)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0027)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0026)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0026)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0026)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0026)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0026)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0025)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0025)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0025)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0025)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0025)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0024)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0024)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0024)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0024)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0024)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0024)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0023)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0023)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0023)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0023)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0023)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0023)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0022)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0021)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0020)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0019)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0018)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0017)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0016)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0015)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0014)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0013)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0012)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0011)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0010)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0009)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0008)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0007)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0006)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0005)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0004)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "tensor(0.0003)\n",
      "error:  tensor(0.)\n",
      "===============Gathering Polytopes============\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "ERROR:root:Internal Python error in the inspect module.\n",
      "Below is the traceback from this internal error.\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\site-packages\\IPython\\core\\interactiveshell.py\", line 3267, in run_code\n",
      "    exec(code_obj, self.user_global_ns, self.user_ns)\n",
      "  File \"<ipython-input-4-f58054fb2082>\", line 49, in <module>\n",
      "    unique_relu_configs_list, unique_bin_acts, _, _ = utils.get_unique_relu_configs(network, xylim, num_pts)\n",
      "  File \"C:\\Users\\justin\\Projects\\geometric-certificates\\utilities.py\", line 373, in get_unique_relu_configs\n",
      "    relu_configs = network.relu_config(pt_0, False)\n",
      "  File \"C:\\Users\\justin\\Projects\\geometric-certificates\\plnn.py\", line 75, in relu_config\n",
      "    pre_relus = self.forward_by_layer(x)\n",
      "  File \"C:\\Users\\justin\\Projects\\geometric-certificates\\plnn.py\", line 179, in forward_by_layer\n",
      "    pre_relus.append(x.clone())\n",
      "KeyboardInterrupt\n",
      "\n",
      "During handling of the above exception, another exception occurred:\n",
      "\n",
      "Traceback (most recent call last):\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\site-packages\\IPython\\core\\interactiveshell.py\", line 2018, in showtraceback\n",
      "    stb = value._render_traceback_()\n",
      "AttributeError: 'KeyboardInterrupt' object has no attribute '_render_traceback_'\n",
      "\n",
      "During handling of the above exception, another exception occurred:\n",
      "\n",
      "Traceback (most recent call last):\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\site-packages\\IPython\\core\\ultratb.py\", line 1095, in get_records\n",
      "    return _fixed_getinnerframes(etb, number_of_lines_of_context, tb_offset)\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\site-packages\\IPython\\core\\ultratb.py\", line 313, in wrapped\n",
      "    return f(*args, **kwargs)\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\site-packages\\IPython\\core\\ultratb.py\", line 347, in _fixed_getinnerframes\n",
      "    records = fix_frame_records_filenames(inspect.getinnerframes(etb, context))\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\inspect.py\", line 1490, in getinnerframes\n",
      "    frameinfo = (tb.tb_frame,) + getframeinfo(tb, context)\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\inspect.py\", line 1448, in getframeinfo\n",
      "    filename = getsourcefile(frame) or getfile(frame)\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\inspect.py\", line 696, in getsourcefile\n",
      "    if getattr(getmodule(object, filename), '__loader__', None) is not None:\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\inspect.py\", line 739, in getmodule\n",
      "    f = getabsfile(module)\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\inspect.py\", line 708, in getabsfile\n",
      "    _filename = getsourcefile(object) or getfile(object)\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\inspect.py\", line 693, in getsourcefile\n",
      "    if os.path.exists(filename):\n",
      "  File \"C:\\Users\\justin\\Anaconda3\\envs\\DeepL\\lib\\genericpath.py\", line 19, in exists\n",
      "    os.stat(path)\n",
      "KeyboardInterrupt\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m"
     ]
    }
   ],
   "source": [
    "# ==================================\n",
    "# Estimate Polytope Density as Regularization is Increased\n",
    "# ==================================\n",
    "\n",
    "# The number of unique polytopes generated is compared in the normal\n",
    "# and regularized classifier cases. Results are displayed \n",
    "\n",
    "unique_polytopes = []\n",
    "unique_polytopes_reg = []\n",
    "\n",
    "errs = []\n",
    "errs_reg = []\n",
    "\n",
    "reg_coeffs = [1e-6, 1e-5, 1e-4, 5e-4, 1e-3, 5e-3, 1e-2, 1.0]\n",
    "\n",
    "for reg_coeff in reg_coeffs:\n",
    "    # ==================================\n",
    "    # Initialize Network\n",
    "    # ==================================\n",
    "\n",
    "    print('===============Initializing Network============')\n",
    "    network = PLNN(layer_sizes)\n",
    "    net = network.net\n",
    "\n",
    "    # ==================================\n",
    "    # Train Network\n",
    "    # ==================================\n",
    "\n",
    "    print('===============Training Network============')\n",
    "    opt = optim.Adam(net.parameters(), lr=1e-3)\n",
    "    for i in range(1000):\n",
    "        out = net(Variable(X))\n",
    "        l = nn.CrossEntropyLoss()(out, Variable(y))\n",
    "        err = (out.max(1)[1].data != y).float().mean()\n",
    "        opt.zero_grad()\n",
    "        (l).backward()\n",
    "        opt.step()\n",
    "        print('error: ', err)\n",
    "        errs.append(err)\n",
    "\n",
    "    # ==================================\n",
    "    # Gather Polytopes\n",
    "    # ==================================\n",
    "    print('===============Gathering Polytopes============')\n",
    "    num_pts = 200\n",
    "    xylim = 1.0\n",
    "\n",
    "    unique_relu_configs_list, unique_bin_acts, _, _ = utils.get_unique_relu_configs(network, xylim, num_pts)\n",
    "    print('number of polytopes:', len(unique_bin_acts))\n",
    "    unique_polytopes.append(len(unique_bin_acts))\n",
    "    \n",
    "    \n",
    "    #--------------------------------------------------------------------------------------------\n",
    "\n",
    "    # ==================================\n",
    "    # Initialize Network\n",
    "    # ==================================\n",
    "\n",
    "    print('===============Initializing Network============')\n",
    "    network = PLNN(layer_sizes)\n",
    "    net = network.net\n",
    "\n",
    "    # ==================================\n",
    "    # Train Network\n",
    "    # ==================================\n",
    "\n",
    "    print('===============Training Network with Regularization============')\n",
    "    opt = optim.Adam(net.parameters(), lr=1e-3)\n",
    "    for i in range(1000):\n",
    "        out = net(Variable(X))\n",
    "        l = nn.CrossEntropyLoss()(out, Variable(y)).view([1])\n",
    "        \n",
    "#         l1_scale = 1 * 1e-3\n",
    "#         l1_loss = lambda l1_scale: l1_scale * sum([_.norm(p=1) for _ in net.parameters() if _.dim() > 1])\n",
    "\n",
    "        l1_scale = torch.Tensor([reg_coeff])\n",
    "        l +=  l1_scale*l1_loss(net).view([1])\n",
    "        \n",
    "        err = (out.max(1)[1].data != y).float().mean()\n",
    "        opt.zero_grad()\n",
    "        (l).backward()\n",
    "        opt.step()\n",
    "        \n",
    "\n",
    "    print('error: ', err)\n",
    "    errs_reg.append(err)\n",
    "\n",
    "    # ==================================\n",
    "    # Gather Polytopes\n",
    "    # ==================================\n",
    "    print('===============Gathering Polytopes============')\n",
    "    num_pts = 200\n",
    "    xylim = 1.0\n",
    "\n",
    "    unique_relu_configs_list_reg, unique_bin_acts, _, _ = utils.get_unique_relu_configs(network, xylim, num_pts)\n",
    "    print('number of polytopes:', len(unique_bin_acts))\n",
    "    unique_polytopes_reg.append(len(unique_bin_acts))\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Display Results\n",
    "# ==================================\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "avg = np.average(unique_polytopes)\n",
    "unique_polytopes = [avg for _ in range(0, len(unique_polytopes))]\n",
    "avg2 = np.average(errs)\n",
    "errs = [avg2 for _ in range(0, len(errs))]\n",
    "\n",
    "import os\n",
    "cwd = os.getcwd()\n",
    "plot_dir = cwd + '/plots/'\n",
    "filename = plot_dir + 'l1_reg' + '.svg'\n",
    "\n",
    "plt.figure()\n",
    "ax = plt.axes()\n",
    "plt.plot(reg_coeffs,unique_polytopes_reg, label='Regularized')\n",
    "plt.plot(reg_coeffs,unique_polytopes, label='Unregularized')\n",
    "ax.set_xscale('log')\n",
    "plt.xlabel('Reg. Coefficient')\n",
    "plt.ylabel('Num. Unique Polytopes')\n",
    "plt.legend()\n",
    "plt.savefig(filename)\n",
    "plt.show()\n",
    "\n",
    "plt.figure()\n",
    "ax = plt.axes()\n",
    "plt.plot(reg_coeffs,errs_reg)\n",
    "plt.plot(reg_coeffs,errs)\n",
    "ax.set_xscale('log')\n",
    "plt.ylabel('Error_rate')\n",
    "plt.xlabel('Reg. Coefficient')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Initialize Network\n",
    "# ==================================\n",
    "\n",
    "print('===============Initializing Network============')\n",
    "network = PLNN(layer_sizes)\n",
    "net = network.net\n",
    "\n",
    "# ==================================\n",
    "# Train Network\n",
    "# ==================================\n",
    "\n",
    "print('===============Training Network============')\n",
    "opt = optim.Adam(net.parameters(), lr=1e-3)\n",
    "for i in range(1000):\n",
    "    out = net(Variable(X))\n",
    "    l = nn.CrossEntropyLoss()(out, Variable(y))\n",
    "    err = (out.max(1)[1].data != y).float().mean()\n",
    "    opt.zero_grad()\n",
    "    (l).backward()\n",
    "    opt.step()\n",
    "\n",
    "print('error: ', err)\n",
    "\n",
    "# ==================================\n",
    "# Gather Polytopes\n",
    "# ==================================\n",
    "print('===============Gathering Polytopes============')\n",
    "num_pts = 200\n",
    "xylim = 1.0\n",
    "\n",
    "unique_relu_configs_list, unique_bin_acts, _, _ = utils.get_unique_relu_configs(network, xylim, num_pts)\n",
    "print('number of polytopes:', len(unique_bin_acts))\n",
    "\n",
    "# ==================================\n",
    "# Visualize: classifier boundary\n",
    "# ==================================\n",
    "\n",
    "XX, YY = np.meshgrid(np.linspace(0, 1, 100), np.linspace(0, 1, 100))\n",
    "X0 = Variable(torch.Tensor(np.stack([np.ravel(XX), np.ravel(YY)]).T))\n",
    "y0 = network(X0)\n",
    "ZZ = (y0[:,0] - y0[:,1]).resize(100, 100).data.numpy()\n",
    "\n",
    "_, ax = plt.subplots(figsize=(8,8))\n",
    "ax.contourf(XX,YY,-ZZ, cmap=\"coolwarm\", levels=np.linspace(-1000,1000,3))\n",
    "ax.scatter(X.numpy()[:,0], X.numpy()[:,1], c=y.numpy(), cmap=\"coolwarm\", s=70)\n",
    "ax.axis(\"equal\")\n",
    "ax.axis([0, 1, 0, 1])\n",
    "plt.show()\n",
    "\n",
    "# ------------------------------\n",
    "# Plot Polytopes\n",
    "# ------------------------------\n",
    "from _polytope_ import Polytope, from_polytope_dict\n",
    "\n",
    "polytope_list = []\n",
    "\n",
    "\n",
    "for relu_configs in unique_relu_configs_list:\n",
    "    polytope_dict = network.compute_polytope_config(relu_configs, True)\n",
    "    polytope = from_polytope_dict(polytope_dict)\n",
    "    polytope_list.append(polytope)\n",
    "\n",
    "ax = plt.axes()\n",
    "alpha = 0.6\n",
    "xylim = 1.0\n",
    "\n",
    "colors = utils.get_spaced_colors(len(polytope_list))\n",
    "utils.plot_polytopes_2d(polytope_list, colors, alpha, xylim, ax)\n",
    "plt.xlim(0.0, 1.0)\n",
    "plt.ylim(0.0, 1.0)\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ==================================\n",
    "# Initialize Network\n",
    "# ==================================\n",
    "\n",
    "print('===============Initializing Network============')\n",
    "network = PLNN(layer_sizes)\n",
    "net = network.net\n",
    "\n",
    "# ==================================\n",
    "# Train Network\n",
    "# ==================================\n",
    "\n",
    "print('===============Training Network with Regularization============')\n",
    "opt = optim.Adam(net.parameters(), lr=1e-3)\n",
    "for i in range(1000):\n",
    "    out = net(Variable(X))\n",
    "    l = nn.CrossEntropyLoss()(out, Variable(y)).view([1])\n",
    "\n",
    "    l1_scale = torch.Tensor([0.001])\n",
    "    l +=  l1_scale*l1_loss(net).view([1])\n",
    "\n",
    "    err = (out.max(1)[1].data != y).float().mean()\n",
    "    opt.zero_grad()\n",
    "    (l).backward()\n",
    "    opt.step()\n",
    "\n",
    "\n",
    "print('error: ', err)\n",
    "\n",
    "# ==================================\n",
    "# Gather Polytopes\n",
    "# ==================================\n",
    "print('===============Gathering Polytopes============')\n",
    "num_pts = 200\n",
    "xylim = 1.0\n",
    "\n",
    "unique_relu_configs_list_reg, unique_bin_acts, _, _ = utils.get_unique_relu_configs(network, xylim, num_pts)\n",
    "print('number of polytopes:', len(unique_bin_acts))\n",
    "\n",
    "# ==================================\n",
    "# Visualize: classifier boundary\n",
    "# ==================================\n",
    "\n",
    "XX, YY = np.meshgrid(np.linspace(0, 1, 100), np.linspace(0, 1, 100))\n",
    "X0 = Variable(torch.Tensor(np.stack([np.ravel(XX), np.ravel(YY)]).T))\n",
    "y0 = network(X0)\n",
    "ZZ = (y0[:,0] - y0[:,1]).resize(100, 100).data.numpy()\n",
    "\n",
    "_, ax = plt.subplots(figsize=(8,8))\n",
    "ax.contourf(XX,YY,-ZZ, cmap=\"coolwarm\", levels=np.linspace(-1000,1000,3))\n",
    "ax.scatter(X.numpy()[:,0], X.numpy()[:,1], c=y.numpy(), cmap=\"coolwarm\", s=70)\n",
    "ax.axis(\"equal\")\n",
    "ax.axis([0, 1, 0, 1])\n",
    "plt.show()\n",
    "\n",
    "# ------------------------------\n",
    "# Plot Polytopes Regularized\n",
    "# ------------------------------\n",
    "from _polytope_ import Polytope, from_polytope_dict\n",
    "\n",
    "polytope_list = []\n",
    "\n",
    "\n",
    "for relu_configs in unique_relu_configs_list_reg:\n",
    "    polytope_dict = network.compute_polytope_config(relu_configs, True)\n",
    "    polytope = from_polytope_dict(polytope_dict)\n",
    "    polytope_list.append(polytope)\n",
    "\n",
    "ax = plt.axes()\n",
    "alpha = 0.6\n",
    "xylim = 1.0\n",
    "\n",
    "colors = utils.get_spaced_colors(len(polytope_list))\n",
    "utils.plot_polytopes_2d(polytope_list, colors, alpha, xylim, ax)\n",
    "plt.xlim(0.0, 1.0)\n",
    "plt.ylim(0.0, 1.0)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (DeepL)",
   "language": "python",
   "name": "deepl"
  },
  "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
}
