{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "30653fb7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd  \n",
    "from sklearn.datasets import load_boston\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ab26fdbe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "col_names: Index(['CRIM', 'ZN', 'INDUS', 'CHAS', 'NOX', 'RM', 'AGE', 'DIS', 'RAD', 'TAX',\n",
      "       'PTRATIO', 'B', 'LSTAT'],\n",
      "      dtype='object')\n"
     ]
    }
   ],
   "source": [
    "boston_dataset = load_boston()\n",
    "boston = pd.DataFrame(boston_dataset.data, columns=boston_dataset.feature_names)\n",
    "col_names = boston.columns\n",
    "print('col_names:',col_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bbe401aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(506, 13)\n",
      "[24.  21.6 34.7 33.4 36.2 28.7 22.9 27.1 16.5 18.9]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([ 21.,  55.,  82., 154.,  84.,  41.,  30.,   8.,  10.,  21.]),\n",
       " array([ 5. ,  9.5, 14. , 18.5, 23. , 27.5, 32. , 36.5, 41. , 45.5, 50. ]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAD6CAYAAABamQdMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAQ00lEQVR4nO3df6zddX3H8edrVPy9Fei1w5bu1lk1aPxBrgSDWxA2rUosfxiCcbNzJM025nC6ILg/yJYs0W0RNdtMOumoCUMbRGkM2+wqji2RsltA+T069EqbQmsQf8wEV33vj/tlHG4vvfeec8895XOfj+TkfL+f7/d7vu/7Sc+rn3zO+X5PqgpJUlt+YdQFSJIWn+EuSQ0y3CWpQYa7JDXIcJekBhnuktSgOcM9ybYkh5LcPaP9A0nuT3JPkr/sab8iyb4kDyR52zCKliQd24p57HMN8DfA555sSPIWYBPwuqp6IslLuvbTgYuAVwMvBf41ySuq6mfHOsGqVatqfHy8rz9AkparvXv3fq+qxmbbNme4V9UtScZnNP8+8LGqeqLb51DXvgn4fNf+7ST7gDOBbxzrHOPj40xOTs5ViiSpR5KpZ9rW75z7K4BfS7Inyb8leWPXvgZ4uGe//V2bJGkJzWda5pmOOxk4C3gjsCPJyxbyAkm2AFsA1q1b12cZkqTZ9Dty3w/cUNNuA34OrAIOAKf17Le2aztKVW2tqomqmhgbm3XKSJLUp37D/cvAWwCSvAI4EfgesBO4KMlzk6wHNgC3LUKdkqQFmHNaJsl1wDnAqiT7gSuBbcC27uuRPwU21/TtJe9JsgO4FzgCXDLXN2UkSYsvx8MtfycmJspvy0jSwiTZW1UTs23zClVJapDhLkkNMtwlqUGGuxZkfHycJEv+8PYU0sL0exGTlqmpqSlG8SF8kiU/p/Rs5shdkhpkuEtSgwx3SWqQ4S5JDTLcJalBhrskNchwl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQXOGe5JtSQ51v5c6c9uHk1SSVd16knw6yb4k30pyxjCKliQd23xG7tcAG2c2JjkNeCvw3Z7mtwMbuscW4DODlyhJWqg5w72qbgEem2XTVcBlQO/NvTcBn6tptwIrk5y6KJVKkuatrzn3JJuAA1X1zRmb1gAP96zv79okSUtowb/ElOQFwEeZnpLpW5ItTE/dsG7dukFeSpI0Qz8j918F1gPfTPIdYC1we5JfBg4Ap/Xsu7ZrO0pVba2qiaqaGBsb66MMSdIzWXC4V9VdVfWSqhqvqnGmp17OqKpHgJ3A+7pvzZwF/KCqDi5uyZKkucznq5DXAd8AXplkf5KLj7H7TcBDwD7g74E/WJQqJUkLMuece1W9Z47t4z3LBVwyeFmSpEF4haokNchwl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQYa7JDXIcJekBhnuktQgw12SGmS4S1KDDHdJapDhLkkNMtwlqUGGuyQ1yHCXpAbN5zdUtyU5lOTunra/SnJ/km8l+VKSlT3brkiyL8kDSd42pLolSccwn5H7NcDGGW27gNdU1WuB/wKuAEhyOnAR8OrumL9LcsKiVStJmpc5w72qbgEem9H21ao60q3eCqztljcBn6+qJ6rq28A+4MxFrFeSNA+LMef+u8A/dctrgId7tu3v2o6SZEuSySSThw8fXoQyJElPGijck/wpcAS4dqHHVtXWqpqoqomxsbFBypAkzbCi3wOT/A5wPnBeVVXXfAA4rWe3tV2bJGkJ9TVyT7IRuAx4V1X9pGfTTuCiJM9Nsh7YANw2eJmSpIWYc+Se5DrgHGBVkv3AlUx/O+a5wK4kALdW1e9V1T1JdgD3Mj1dc0lV/WxYxUuSZpenZlRGZ2JioiYnJ0ddhuYhCaP4NzOq80rHsyR7q2pitm1eoSpJDTLcJalBhrskNchwl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQYa7JDXIcJekBhnuktQgw12SGmS4S1KDDHdJapDhLkkNMtwlqUFzhnuSbUkOJbm7p+3kJLuSPNg9n9S1J8mnk+xL8q0kZwyzeEnS7OYzcr8G2Dij7XJgd1VtAHZ36wBvBzZ0jy3AZxanTEnSQswZ7lV1C/DYjOZNwPZueTtwQU/752rarcDKJKcuUq2SpHnqd859dVUd7JYfAVZ3y2uAh3v229+1HSXJliSTSSYPHz7cZxmSpNkM/IFqVRVQfRy3taomqmpibGxs0DIkST36DfdHn5xu6Z4Pde0HgNN69lvbtUmSllC/4b4T2NwtbwZu7Gl/X/etmbOAH/RM30iSlsiKuXZIch1wDrAqyX7gSuBjwI4kFwNTwIXd7jcB7wD2AT8B3j+EmiVJc5gz3KvqPc+w6bxZ9i3gkkGLkiQNxitUJalBhrskNchwl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQYa7JDXIcJekBhnuktQgw12SGmS4S1KDDHdJapDhLkkNMtz1rJFkJI/x8fFR/+nSgs35S0zS8WL6h76WXpKRnFcaxEAj9yR/nOSeJHcnuS7J85KsT7Inyb4kX0hy4mIVK0man77DPcka4I+Aiap6DXACcBHwceCqqno58H3g4sUoVE8ZHx8f2RSFpGeHQefcVwDPT7ICeAFwEDgXuL7bvh24YMBzaIapqSmqaiQPSc8OfYd7VR0A/hr4LtOh/gNgL/B4VR3pdtsPrJnt+CRbkkwmmTx8+HC/ZUiSZjHItMxJwCZgPfBS4IXAxvkeX1Vbq2qiqibGxsb6LUOSNItBpmV+A/h2VR2uqv8FbgDOBlZ20zQAa4EDA9YoSVqgQcL9u8BZSV6Q6U/azgPuBW4G3t3tsxm4cbASJUkLNcic+x6mPzi9Hbire62twEeADyXZB5wCXL0IdUqSFmCgi5iq6krgyhnNDwFnDvK6kqTBePsBSWqQ4S5JDTLcJalBhrskNchwl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQYa7JDXIcJekBhnuktQgw12SGmS4S1KDDHdJapDhLkkNGijck6xMcn2S+5Pcl+RNSU5OsivJg93zSYtVrCRpfgYduX8K+OeqehXwOuA+4HJgd1VtAHZ365KkJdR3uCf5JeDXgasBquqnVfU4sAnY3u22HbhgsBIlSQs1yMh9PXAY+IckdyT5bJIXAqur6mC3zyPA6tkOTrIlyWSSycOHDw9QhiRppkHCfQVwBvCZqnoD8D/MmIKpqgJqtoOramtVTVTVxNjY2ABlSJJmGiTc9wP7q2pPt34902H/aJJTAbrnQ4OVKElaqL7DvaoeAR5O8squ6TzgXmAnsLlr2wzcOFCFkqQFWzHg8R8Ark1yIvAQ8H6m/8PYkeRiYAq4cMBzSJIWaKBwr6o7gYlZNp03yOtKkgbjFaqS1CDDfQDj4+MkWfKHJM1l0Dn3ZW1qaorpb3suLQNe0lwcuUtSgwx3SWqQ4S5JDTLcJalBhrskNchwl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQYa7JDXIcJekBhnuktSggcM9yQlJ7kjylW59fZI9SfYl+UL3+6qSpCW0GCP3S4H7etY/DlxVVS8Hvg9cvAjnkCQtwEDhnmQt8E7gs916gHOB67tdtgMXDHIO6Xgwip9THB8fH/WfrWexQX9m75PAZcCLu/VTgMer6ki3vh9YM9uBSbYAWwDWrVs3YBnScPlzinq26XvknuR84FBV7e3n+KraWlUTVTUxNjbWbxmSpFkMMnI/G3hXkncAzwN+EfgUsDLJim70vhY4MHiZkqSF6HvkXlVXVNXaqhoHLgK+VlXvBW4G3t3tthm4ceAqJUkLMozvuX8E+FCSfUzPwV89hHNIko5h0A9UAaiqrwNf75YfAs5cjNeVJPXHK1QlqUGGuyQ1yHCXpAYZ7pLUIMNdkhpkuEtSgwx3SWqQ4S4dx7wbpfq1KBcxSRoO70apfjlyl6QGGe6S1CDDXZIaZLhLUoMMd0lqkOEuSQ0y3CWpQYa7JDWo73BPclqSm5Pcm+SeJJd27Scn2ZXkwe75pMUrV5I0H4OM3I8AH66q04GzgEuSnA5cDuyuqg3A7m5dkrSE+g73qjpYVbd3yz8C7gPWAJuA7d1u24ELBqxRkrRAizLnnmQceAOwB1hdVQe7TY8AqxfjHM9kfHx8JDdX8v4bUjtGmSPDulHbwDcOS/Ii4IvAB6vqh72hV1WVZNY7HyXZAmwBWLduXd/nn5qaGsnNlcAbLEmtaDFHBhq5J3kO08F+bVXd0DU/muTUbvupwKHZjq2qrVU1UVUTY2Njg5QhSZphkG/LBLgauK+qPtGzaSewuVveDNzYf3mSpH4MMi1zNvDbwF1J7uzaPgp8DNiR5GJgCrhwoAolSQvWd7hX1X8AzzRZdF6/rytJGpxXqEpSgwx3SWqQ4S5JDTLcJalBhrskNchwl6QGGe6S1CDDXZIaZLhLOm6M6u6MLRr4rpCStFhGdXfGFgPekbskNciRu6SjtDiSXW4Md0lHae2HK5Yjp2UkqUGGuyQ1yHCXpAYZ7pLUIMNdkho0tHBPsjHJA0n2Jbl8WOeRJB1tKOGe5ATgb4G3A6cD70ly+jDOJUk62rBG7mcC+6rqoar6KfB5YNOQziVJmmFY4b4GeLhnfX/XJklaAiO7QjXJFmBLt/rjJA8M8FqLU9Rg514FfG8E511y8zz3ovfHs+BvPpa++mNUf/OQz3vMvmj0bz6WVUn6fa/8yjNtGFa4HwBO61lf27X9v6raCmwd0vmXXJLJqpoYdR3HC/vj6eyPp9gXTzes/hjWtMx/AhuSrE9yInARsHNI55IkzTCUkXtVHUnyh8C/ACcA26rqnmGcS5J0tKHNuVfVTcBNw3r941AzU0yLxP54OvvjKfbF0w2lPzKqW3tKkobH2w9IUoMM9z4k2ZbkUJK7e9pOTrIryYPd80mjrHGpJDktyc1J7k1yT5JLu/bl2h/PS3Jbkm92/fFnXfv6JHu623F8ofuiwbKQ5IQkdyT5Sre+nPviO0nuSnJnksmubSjvFcO9P9cAG2e0XQ7srqoNwO5ufTk4Any4qk4HzgIu6W41sVz74wng3Kp6HfB6YGOSs4CPA1dV1cuB7wMXj67EJXcpcF/P+nLuC4C3VNXre77+OJT3iuHeh6q6BXhsRvMmYHu3vB24YClrGpWqOlhVt3fLP2L6TbyG5dsfVVU/7laf0z0KOBe4vmtfNv2RZC3wTuCz3XpYpn1xDEN5rxjui2d1VR3slh8BVo+ymFFIMg68AdjDMu6PbhriTuAQsAv4b+DxqjrS7bKcbsfxSeAy4Ofd+iks376A6f/ov5pkb3eVPgzpveIPZA9BVVWSZfU1pCQvAr4IfLCqfth7Kfdy64+q+hnw+iQrgS8BrxptRaOR5HzgUFXtTXLOiMs5Xry5qg4keQmwK8n9vRsX873iyH3xPJrkVIDu+dCI61kySZ7DdLBfW1U3dM3Ltj+eVFWPAzcDbwJWJnlyMHXU7TgadTbwriTfYfrOsOcCn2J59gUAVXWgez7E9H/8ZzKk94rhvnh2Apu75c3AjSOsZcl0c6hXA/dV1Sd6Ni3X/hjrRuwkeT7wm0x/DnEz8O5ut2XRH1V1RVWtrapxpm9B8rWqei/LsC8AkrwwyYufXAbeCtzNkN4rXsTUhyTXAecwfXe7R4ErgS8DO4B1wBRwYVXN/NC1OUneDPw7cBdPzat+lOl59+XYH69l+kOxE5gePO2oqj9P8jKmR68nA3cAv1VVT4yu0qXVTcv8SVWdv1z7ovu7v9StrgD+sar+IskpDOG9YrhLUoOclpGkBhnuktQgw12SGmS4S1KDDHdJapDhLkkNMtwlqUGGuyQ16P8AP2LTwWB84ScAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = boston.to_numpy()\n",
    "Y = boston_dataset.target\n",
    "print(X.shape)\n",
    "print(Y[:10])\n",
    "import matplotlib.pyplot as plt\n",
    "plt.figure()\n",
    "plt.hist(Y, fill=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2ab15def",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "max: 88.976, min: 0.006->  (1.0  , 0.0  )\n",
      "max: 100.0, min: 0.0  ->  (1.0  , 0.0  )\n",
      "max: 27.74, min: 0.46 ->  (1.0  , 0.0  )\n",
      "max: 1.0  , min: 0.0  ->  (1.0  , 0.0  )\n",
      "max: 0.871, min: 0.385->  (1.0  , 0.0  )\n",
      "max: 8.78 , min: 3.561->  (1.0  , 0.0  )\n",
      "max: 100.0, min: 2.9  ->  (1.0  , 0.0  )\n",
      "max: 12.126, min: 1.13 ->  (1.0  , 0.0  )\n",
      "max: 24.0 , min: 1.0  ->  (1.0  , 0.0  )\n",
      "max: 711.0, min: 187.0->  (1.0  , 0.0  )\n",
      "max: 22.0 , min: 12.6 ->  (1.0  , 0.0  )\n",
      "max: 396.9, min: 0.32 ->  (1.0  , 0.0  )\n",
      "max: 37.97, min: 1.73 ->  (1.0  , 0.0  )\n"
     ]
    }
   ],
   "source": [
    "for j in range(len(col_names)):\n",
    "    x_max, x_min = np.max(X[:,j]), np.min(X[:,j])\n",
    "    print('max: %-5s, min: %-5s'%(np.round(x_max,3), np.round(x_min,3)), end = '->')\n",
    "    X[:,j] = (X[:,j]-x_min)/(x_max-x_min)\n",
    "    x_max, x_min = np.max(X[:,j]), np.min(X[:,j])\n",
    "    print('  (%-5s, %-5s)'%(np.round(x_max,3), np.round(x_min,3)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "41e9d60a",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_train = 100 # int(len(X)/2)\n",
    "X_train, Y_train = X[:n_train,:], Y[:n_train]\n",
    "X_test, Y_test = X[n_train:,:], Y[n_train:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "347bf08f",
   "metadata": {},
   "outputs": [],
   "source": [
    "MSE = {}\n",
    "def compute_mse(y_pred,y0):\n",
    "    return np.mean((y_pred-y0)**2)**0.5\n",
    "# compute_mse(np.array([1,2,3]),np.array([0,2,5]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0e812255",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "linear models...\n",
      "\n",
      "Support vector models...\n",
      "\n",
      "Decision Tree models...\n",
      "\n",
      "KNeighbors models...\n",
      "7.8006 n:2\n",
      "7.5622 n:3\n",
      "7.4997 n:4\n",
      "7.3933 n:5\n",
      "\n",
      "MLP models...\n"
     ]
    }
   ],
   "source": [
    "from sklearn.linear_model import LinearRegression, Ridge,  Lasso\n",
    "def do_regress(regression, X_train, Y_train, MSE, name):\n",
    "    model = regression.fit(X_train, Y_train)\n",
    "    Y_pred = model.predict(X_test)\n",
    "    if name is not None:\n",
    "        MSE[name] = compute_mse(Y_pred,Y_test)\n",
    "    return MSE\n",
    "\n",
    "print('linear models...')\n",
    "MSE = do_regress( LinearRegression(), X_train, Y_train, MSE, 'linear')\n",
    "MSE = do_regress(Ridge(), X_train, Y_train, MSE,'Ridge')\n",
    "MSE = do_regress(Lasso(), X_train, Y_train, MSE, 'Lasso')\n",
    "\n",
    "print('\\nSupport vector models...')\n",
    "from sklearn.svm import LinearSVR, NuSVR, SVR\n",
    "MSE = do_regress(LinearSVR(), X_train, Y_train, MSE,'LinSVR')\n",
    "MSE = do_regress(NuSVR(), X_train, Y_train, MSE,'NuSVR')\n",
    "MSE = do_regress(SVR(), X_train, Y_train, MSE,'SVR')\n",
    "\n",
    "print('\\nDecision Tree models...')\n",
    "from sklearn.tree import DecisionTreeRegressor\n",
    "MSE = do_regress(DecisionTreeRegressor(random_state=0), X_train, Y_train, MSE,'DecTree')\n",
    "\n",
    "print('\\nKNeighbors models...')\n",
    "from sklearn.neighbors import KNeighborsRegressor\n",
    "min_mse,n_min = np.inf,-1\n",
    "for n in range(2,16+1):\n",
    "    temp_name = 'KNeighborsRegressor(n_neighbors=%s)'%(str(n))\n",
    "    dummy = do_regress(KNeighborsRegressor(n_neighbors=n), X_train, Y_train, {}, temp_name)\n",
    "    this_mse = dummy[temp_name]\n",
    "    if this_mse<min_mse:\n",
    "        print(np.round(this_mse,4), 'n:%s'%(str(n)))\n",
    "        min_mse = this_mse\n",
    "        n_min = n\n",
    "MSE['kneigh'] = min_mse\n",
    "\n",
    "print('\\nMLP models...')\n",
    "from sklearn.neural_network import MLPRegressor\n",
    "MSE = do_regress(MLPRegressor(hidden_layer_sizes=(64,64),random_state=1, max_iter=12000), X_train, Y_train, MSE, 'MLP')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "aeeb7ca6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Exiting layer_k_sample_collection() because all data have been used.\n",
      "Final positions of indices in the layers:\n",
      "  [1] [0, 3, 7, 12, 14, 16, 32, 39, 48, 54, 57, 60, 78, 93]\n",
      "  [2] [1, 4, 6, 9, 13, 17, 30, 37, 40, 42, 47, 50, 56, 59, 75, 43, 77]\n",
      "  [3] [15, 21, 25, 44, 51, 55, 63, 70, 79, 85, 92, 98, 8, 35, 10, 58, 27, 72, 73]\n",
      "  [4] [31, 33, 69, 76, 81, 87, 94, 97, 19, 49, 65, 71, 64, 38, 66]\n",
      "  [5] [84, 89, 18, 34, 62, 29, 52, 11, 95, 99, 2, 53, 86, 90, 74, 45]\n",
      "  [6] [23, 88, 46, 83, 36, 28, 41, 5, 22]\n",
      "  [7] [80, 82, 67, 61, 91, 68]\n",
      "  [8] [24, 96, 20]\n",
      "  [9] [26]\n",
      " i     Layer     |y-y0|                           abs error\n",
      "[0]    L=1         |(24.0 ) - (24.0 ))|                 0.0      HIT\n",
      "[1]    L=2         |(21.6 ) - (21.6 ))|                 0.0      HIT\n",
      "[2]    L=5         |(34.7 ) - (34.7 ))|                 0.0      HIT\n",
      "[3]    L=1         |(33.4 ) - (33.4 ))|                 0.0      HIT\n",
      "[4]    L=2         |(36.2 ) - (36.2 ))|                 0.0      HIT\n",
      "[5]    L=6         |(28.7 ) - (28.7 ))|                 0.0      HIT\n",
      "[6]    L=2         |(22.9 ) - (22.9 ))|                 0.0      HIT\n",
      "[7]    L=1         |(27.1 ) - (27.1 ))|                 0.0      HIT\n",
      "[8]    L=3         |(16.5 ) - (16.5 ))|                 0.0      HIT\n",
      "[9]    L=2         |(18.9 ) - (18.9 ))|                 0.0      HIT\n",
      "[10]   L=3         |(15.0 ) - (15.0 ))|                 0.0      HIT\n",
      "[11]   L=5         |(18.9 ) - (18.9 ))|                 0.0      HIT\n",
      "[12]   L=1         |(21.7 ) - (21.7 ))|                 0.0      HIT\n",
      "[13]   L=2         |(20.4 ) - (20.4 ))|                 0.0      HIT\n",
      "[14]   L=1         |(18.2 ) - (18.2 ))|                 0.0      HIT\n",
      "[15]   L=3         |(19.9 ) - (19.9 ))|                 0.0      HIT\n",
      "[16]   L=1         |(23.1 ) - (23.1 ))|                 0.0      HIT\n",
      "[17]   L=2         |(17.5 ) - (17.5 ))|                 0.0      HIT\n",
      "[18]   L=5         |(20.2 ) - (20.2 ))|                 0.0      HIT\n",
      "[19]   L=4         |(18.2 ) - (18.2 ))|                 0.0      HIT\n",
      "[20]   L=8         |(13.6 ) - (13.6 ))|                 0.0      HIT\n",
      "[21]   L=3         |(19.6 ) - (19.6 ))|                 0.0      HIT\n",
      "[22]   L=6         |(15.2 ) - (15.2 ))|                 0.0      HIT\n",
      "[23]   L=6         |(14.5 ) - (14.5 ))|                 0.0      HIT\n",
      "[24]   L=8         |(15.6 ) - (15.6 ))|                 0.0      HIT\n",
      "[25]   L=3         |(13.9 ) - (13.9 ))|                 0.0      HIT\n",
      "[26]   L=9         |(16.6 ) - (16.6 ))|                 0.0      HIT\n",
      "[27]   L=3         |(14.8 ) - (14.8 ))|                 0.0      HIT\n",
      "[28]   L=6         |(18.4 ) - (18.4 ))|                 0.0      HIT\n",
      "[29]   L=5         |(21.0 ) - (21.0 ))|                 0.0      HIT\n",
      "[30]   L=2         |(12.7 ) - (12.7 ))|                 0.0      HIT\n",
      "[31]   L=4         |(14.5 ) - (14.5 ))|                 0.0      HIT\n",
      "[32]   L=1         |(13.2 ) - (13.2 ))|                 0.0      HIT\n",
      "[33]   L=4         |(13.1 ) - (13.1 ))|                 0.0      HIT\n",
      "[34]   L=5         |(13.5 ) - (13.5 ))|                 0.0      HIT\n",
      "[35]   L=3         |(18.9 ) - (18.9 ))|                 0.0      HIT\n",
      "[36]   L=6         |(20.0 ) - (20.0 ))|                 0.0      HIT\n",
      "[37]   L=2         |(21.0 ) - (21.0 ))|                 0.0      HIT\n",
      "[38]   L=4         |(24.7 ) - (24.7 ))|                 0.0      HIT\n",
      "[39]   L=1         |(30.8 ) - (30.8 ))|                 0.0      HIT\n",
      "[40]   L=2         |(34.9 ) - (34.9 ))|                 0.0      HIT\n",
      "[41]   L=6         |(26.6 ) - (26.6 ))|                 0.0      HIT\n",
      "[42]   L=2         |(25.3 ) - (25.3 ))|                 0.0      HIT\n",
      "[43]   L=2         |(24.7 ) - (24.7 ))|                 0.0      HIT\n",
      "[44]   L=3         |(21.2 ) - (21.2 ))|                 0.0      HIT\n",
      "[45]   L=5         |(19.3 ) - (19.3 ))|                 0.0      HIT\n",
      "[46]   L=6         |(20.0 ) - (20.0 ))|                 0.0      HIT\n",
      "[47]   L=2         |(16.6 ) - (16.6 ))|                 0.0      HIT\n",
      "[48]   L=1         |(14.4 ) - (14.4 ))|                 0.0      HIT\n",
      "[49]   L=4         |(19.4 ) - (19.4 ))|                 0.0      HIT\n",
      "[50]   L=2         |(19.7 ) - (19.7 ))|                 0.0      HIT\n",
      "[51]   L=3         |(20.5 ) - (20.5 ))|                 0.0      HIT\n",
      "[52]   L=5         |(25.0 ) - (25.0 ))|                 0.0      HIT\n",
      "[53]   L=5         |(23.4 ) - (23.4 ))|                 0.0      HIT\n",
      "[54]   L=1         |(18.9 ) - (18.9 ))|                 0.0      HIT\n",
      "[55]   L=3         |(35.4 ) - (35.4 ))|                 0.0      HIT\n",
      "[56]   L=2         |(24.7 ) - (24.7 ))|                 0.0      HIT\n",
      "[57]   L=1         |(31.6 ) - (31.6 ))|                 0.0      HIT\n",
      "[58]   L=3         |(23.3 ) - (23.3 ))|                 0.0      HIT\n",
      "[59]   L=2         |(19.6 ) - (19.6 ))|                 0.0      HIT\n",
      "[60]   L=1         |(18.7 ) - (18.7 ))|                 0.0      HIT\n",
      "[61]   L=7         |(16.0 ) - (16.0 ))|                 0.0      HIT\n",
      "[62]   L=5         |(22.2 ) - (22.2 ))|                 0.0      HIT\n",
      "[63]   L=3         |(25.0 ) - (25.0 ))|                 0.0      HIT\n",
      "[64]   L=4         |(33.0 ) - (33.0 ))|                 0.0      HIT\n",
      "[65]   L=4         |(23.5 ) - (23.5 ))|                 0.0      HIT\n",
      "[66]   L=4         |(19.4 ) - (19.4 ))|                 0.0      HIT\n",
      "[67]   L=7         |(22.0 ) - (22.0 ))|                 0.0      HIT\n",
      "[68]   L=7         |(17.4 ) - (17.4 ))|                 0.0      HIT\n",
      "[69]   L=4         |(20.9 ) - (20.9 ))|                 0.0      HIT\n",
      "[70]   L=3         |(24.2 ) - (24.2 ))|                 0.0      HIT\n",
      "[71]   L=4         |(21.7 ) - (21.7 ))|                 0.0      HIT\n",
      "[72]   L=3         |(22.8 ) - (22.8 ))|                 0.0      HIT\n",
      "[73]   L=3         |(23.4 ) - (23.4 ))|                 0.0      HIT\n",
      "[74]   L=5         |(24.1 ) - (24.1 ))|                 0.0      HIT\n",
      "[75]   L=2         |(21.4 ) - (21.4 ))|                 0.0      HIT\n",
      "[76]   L=4         |(20.0 ) - (20.0 ))|                 0.0      HIT\n",
      "[77]   L=2         |(20.8 ) - (20.8 ))|                 0.0      HIT\n",
      "[78]   L=1         |(21.2 ) - (21.2 ))|                 0.0      HIT\n",
      "[79]   L=3         |(20.3 ) - (20.3 ))|                 0.0      HIT\n",
      "[80]   L=7         |(28.0 ) - (28.0 ))|                 0.0      HIT\n",
      "[81]   L=4         |(23.9 ) - (23.9 ))|                 0.0      HIT\n",
      "[82]   L=7         |(24.8 ) - (24.8 ))|                 0.0      HIT\n",
      "[83]   L=6         |(22.9 ) - (22.9 ))|                 0.0      HIT\n",
      "[84]   L=5         |(23.9 ) - (23.9 ))|                 0.0      HIT\n",
      "[85]   L=3         |(26.6 ) - (26.6 ))|                 0.0      HIT\n",
      "[86]   L=5         |(22.5 ) - (22.5 ))|                 0.0      HIT\n",
      "[87]   L=4         |(22.2 ) - (22.2 ))|                 0.0      HIT\n",
      "[88]   L=6         |(23.6 ) - (23.6 ))|                 0.0      HIT\n",
      "[89]   L=5         |(28.7 ) - (28.7 ))|                 0.0      HIT\n",
      "[90]   L=5         |(22.6 ) - (22.6 ))|                 0.0      HIT\n",
      "[91]   L=7         |(22.0 ) - (22.0 ))|                 0.0      HIT\n",
      "[92]   L=3         |(22.9 ) - (22.9 ))|                 0.0      HIT\n",
      "[93]   L=1         |(25.0 ) - (25.0 ))|                 0.0      HIT\n",
      "[94]   L=4         |(20.6 ) - (20.6 ))|                 0.0      HIT\n",
      "[95]   L=5         |(28.4 ) - (28.4 ))|                 0.0      HIT\n",
      "[96]   L=8         |(21.4 ) - (21.4 ))|                 0.0      HIT\n",
      "[97]   L=4         |(38.7 ) - (38.7 ))|                 0.0      HIT\n",
      "[98]   L=3         |(43.8 ) - (43.8 ))|                 0.0      HIT\n",
      "[99]   L=5         |(33.2 ) - (33.2 ))|                 0.0      HIT\n",
      "N_INTERPOLATED:0, N_large_error (>0.1):0\n",
      "avg error          :     0.0, avg_frac_error          :     0.0 \n",
      "avg exclusive error:     0.0, avg exclusive frac error:     0.0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'N_INTERPOLATED': 0,\n",
       " 'mean_error': 0.0,\n",
       " 'mean_frac_error': 0.0,\n",
       " 'mean_ex_error': 0.0,\n",
       " 'mean_ex_frac_error': 0.0}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from SQANN.model import SQANN, double_selective_activation\n",
    "from SQANN.utils import make_layer_setting, simple_evaluation, standard_evaluation\n",
    "\n",
    "a1 = 0.01\n",
    "a2 = 0.5\n",
    "t_admission = 0.2\n",
    "t_threshold = 0.9\n",
    "\n",
    "MAX_LAYER = 16\n",
    "layer_settings = {\n",
    "    # make_layer_setting(a1, a2,  admission_threshold, activation_threshold, max_n)\n",
    "    i: make_layer_setting(a1, a2,t_admission-0.01*i, t_threshold, ) for i in range(1,1+MAX_LAYER) # BEST NOW\n",
    "}\n",
    "\n",
    "net = SQANN(layer_settings, N=len(X_train))\n",
    "net.fit_data(X_train,Y_train,verbose=20)\n",
    "\n",
    "# Show zero errors on training dataset! (Theorem 2 in the paper)\n",
    "standard_evaluation(X_train, Y_train, net, get_interp_indices=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c10534b9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " i     Layer     |y-y0|                           abs error\n",
      "[0]    L=8         |(15.6 ) - (27.5 ))|                11.9      HIT\n",
      "[1]    L=[9, 6]    |(18.431) - (26.5 ))|              8.069      INTERPOLATE\n",
      "[2]    L=3         |(22.8 ) - (18.6 ))|                 4.2      HIT\n",
      "[3]    L=6         |(18.4 ) - (19.3 ))|                 0.9      HIT\n",
      "[4]    L=8         |(15.6 ) - (20.1 ))|                 4.5      HIT\n",
      "[5]    L=8         |(15.6 ) - (19.5 ))|                 3.9      HIT\n",
      "[6]    L=8         |(15.6 ) - (19.5 ))|                 3.9      HIT\n",
      "[7]    L=8         |(15.6 ) - (20.4 ))|                 4.8      HIT\n",
      "[8]    L=8         |(15.6 ) - (19.8 ))|                 4.2      HIT\n",
      "[9]    L=8         |(15.6 ) - (19.4 ))|                 3.8      HIT\n",
      "[10]   L=8         |(15.6 ) - (21.7 ))|                 6.1      HIT\n",
      "[11]   L=[5, 6]    |(19.462) - (22.8 ))|              3.338      INTERPOLATE\n",
      "[12]   L=4         |(20.6 ) - (18.8 ))|                 1.8      HIT\n",
      "[13]   L=4         |(20.6 ) - (18.7 ))|                 1.9      HIT\n",
      "[14]   L=[6, 5]    |(19.436) - (18.5 ))|              0.936      INTERPOLATE\n",
      "[15]   L=4         |(20.6 ) - (18.3 ))|                 2.3      HIT\n",
      "[16]   L=[4, 6]    |(20.0 ) - (21.2 ))|                 1.2      INTERPOLATE\n",
      "[17]   L=[5, 7]    |(20.573) - (19.2 ))|              1.373      INTERPOLATE\n",
      "[18]   L=[4, 6]    |(20.0 ) - (20.4 ))|                 0.4      INTERPOLATE\n",
      "[19]   L=[4, 6]    |(20.0 ) - (19.3 ))|                 0.7      INTERPOLATE\n",
      "[20]   L=3         |(22.8 ) - (22.0 ))|                 0.8      HIT\n",
      "[21]   L=3         |(22.8 ) - (20.3 ))|                 2.5      HIT\n",
      "[22]   L=3         |(22.8 ) - (20.5 ))|                 2.3      HIT\n",
      "[23]   L=3         |(22.8 ) - (17.3 ))|                 5.5      HIT\n",
      "[24]   L=3         |(22.8 ) - (18.8 ))|                 4.0      HIT\n",
      "[25]   L=3         |(22.8 ) - (21.4 ))|                 1.4      HIT\n",
      "[26]   L=3         |(22.8 ) - (15.7 ))|                 7.1      HIT\n",
      "[27]   L=3         |(22.8 ) - (16.2 ))|                 6.6      HIT\n",
      "[28]   L=3         |(22.8 ) - (18.0 ))|                 4.8      HIT\n",
      "[29]   L=3         |(22.8 ) - (14.3 ))|                 8.5      HIT\n",
      "[30]   L=3         |(22.8 ) - (19.2 ))|                 3.6      HIT\n",
      "[31]   L=3         |(22.8 ) - (19.6 ))|                 3.2      HIT\n",
      "[32]   L=3         |(22.8 ) - (23.0 ))|                 0.2      HIT\n",
      "[33]   L=3         |(22.8 ) - (18.4 ))|                 4.4      HIT\n",
      "[34]   L=3         |(22.8 ) - (15.6 ))|                 7.2      HIT\n",
      "[35]   L=3         |(22.8 ) - (18.1 ))|                 4.7      HIT\n",
      "[36]   L=3         |(22.8 ) - (17.4 ))|                 5.4      HIT\n",
      "[37]   L=3         |(22.8 ) - (17.1 ))|                 5.7      HIT\n",
      "[38]   L=3         |(22.8 ) - (13.3 ))|                 9.5      HIT\n",
      "[39]   L=3         |(22.8 ) - (17.8 ))|                 5.0      HIT\n",
      "[40]   L=3         |(22.8 ) - (14.0 ))|                 8.8      HIT\n",
      "[41]   L=3         |(22.8 ) - (14.4 ))|                 8.4      HIT\n",
      "[42]   L=3         |(22.8 ) - (13.4 ))|                 9.4      HIT\n",
      "[43]   L=3         |(22.8 ) - (15.6 ))|                 7.2      HIT\n",
      "[44]   L=3         |(22.8 ) - (11.8 ))|                11.0      HIT\n",
      "[45]   L=3         |(22.8 ) - (13.8 ))|                 9.0      HIT\n",
      "[46]   L=3         |(22.8 ) - (15.6 ))|                 7.2      HIT\n",
      "[47]   L=3         |(22.8 ) - (14.6 ))|                 8.2      HIT\n",
      "[48]   L=3         |(22.8 ) - (17.8 ))|                 5.0      HIT\n",
      "[49]   L=3         |(22.8 ) - (15.4 ))|                 7.4      HIT\n",
      "[50]   L=3         |(22.8 ) - (21.5 ))|                 1.3      HIT\n",
      "[51]   L=3         |(22.8 ) - (19.6 ))|                 3.2      HIT\n",
      "[52]   L=3         |(22.8 ) - (15.3 ))|                 7.5      HIT\n",
      "[53]   L=3         |(22.8 ) - (19.4 ))|                 3.4      HIT\n",
      "[54]   L=3         |(22.8 ) - (17.0 ))|                 5.8      HIT\n",
      "[55]   L=3         |(22.8 ) - (15.6 ))|                 7.2      HIT\n",
      "[56]   L=3         |(22.8 ) - (13.1 ))|                 9.7      HIT\n",
      "[57]   L=3         |(22.8 ) - (41.3 ))|                18.5      HIT\n",
      "[58]   L=3         |(22.8 ) - (24.3 ))|                 1.5      HIT\n",
      "[59]   L=3         |(22.8 ) - (23.3 ))|                 0.5      HIT\n",
      "[60]   L=3         |(22.8 ) - (27.0 ))|                 4.2      HIT\n",
      "[61]   L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[62]   L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[63]   L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[64]   L=3         |(22.8 ) - (22.7 ))|                 0.1      HIT\n",
      "[65]   L=3         |(22.8 ) - (25.0 ))|                 2.2      HIT\n",
      "[66]   L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[67]   L=3         |(22.8 ) - (23.8 ))|                 1.0      HIT\n",
      "[68]   L=3         |(22.8 ) - (23.8 ))|                 1.0      HIT\n",
      "[69]   L=3         |(22.8 ) - (22.3 ))|                 0.5      HIT\n",
      "[70]   L=3         |(22.8 ) - (17.4 ))|                 5.4      HIT\n",
      "[71]   L=3         |(22.8 ) - (19.1 ))|                 3.7      HIT\n",
      "[72]   L=[7, 3]    |(18.304) - (23.1 ))|              4.796      INTERPOLATE\n",
      "[73]   L=[4, 7]    |(21.215) - (23.6 ))|              2.385      INTERPOLATE\n",
      "[74]   L=[4, 6]    |(20.0 ) - (22.6 ))|                 2.6      INTERPOLATE\n",
      "[75]   L=[5, 5]    |(23.76) - (29.4 ))|                5.64      INTERPOLATE\n",
      "[76]   L=[1, 6]    |(20.744) - (23.2 ))|              2.456      INTERPOLATE\n",
      "[77]   L=[5, 7]    |(22.3 ) - (24.6 ))|                 2.3      INTERPOLATE\n",
      "[78]   L=7         |(22.0 ) - (29.9 ))|                 7.9      HIT\n",
      "[79]   L=5         |(22.6 ) - (37.2 ))|                14.6      HIT\n",
      "[80]   L=3         |(22.8 ) - (39.8 ))|                17.0      HIT\n",
      "[81]   L=[7, 6]    |(21.0 ) - (36.2 ))|                15.2      INTERPOLATE\n",
      "[82]   L=[3, 3]    |(23.088) - (37.9 ))|              14.812      INTERPOLATE\n",
      "[83]   L=5         |(23.4 ) - (32.5 ))|                 9.1      HIT\n",
      "[84]   L=5         |(20.2 ) - (26.4 ))|                 6.2      HIT\n",
      "[85]   L=7         |(22.0 ) - (29.6 ))|                 7.6      HIT\n",
      "[86]   L=[3, 4]    |(38.176) - (50.0 ))|              11.824      INTERPOLATE\n",
      "[87]   L=5         |(20.2 ) - (32.0 ))|                11.8      HIT\n",
      "[88]   L=3         |(22.8 ) - (29.8 ))|                 7.0      HIT\n",
      "[89]   L=[3, 3]    |(23.088) - (34.9 ))|              11.812      INTERPOLATE\n",
      "[90]   L=3         |(22.8 ) - (37.0 ))|                14.2      HIT\n",
      "[91]   L=3         |(22.8 ) - (30.5 ))|                 7.7      HIT\n",
      "[92]   L=3         |(22.8 ) - (36.4 ))|                13.6      HIT\n",
      "[93]   L=[7, 5]    |(20.358) - (31.1 ))|              10.742      INTERPOLATE\n",
      "[94]   L=[7, 2]    |(28.628) - (29.1 ))|              0.472      INTERPOLATE\n",
      "[95]   L=4         |(23.5 ) - (50.0 ))|                26.5      HIT\n",
      "[96]   L=[4, 4]    |(21.559) - (33.3 ))|              11.741      INTERPOLATE\n",
      "[97]   L=[7, 4]    |(22.776) - (30.3 ))|              7.524      INTERPOLATE\n",
      "[98]   L=[4, 4]    |(21.558) - (34.6 ))|              13.042      INTERPOLATE\n",
      "[99]   L=4         |(19.4 ) - (34.9 ))|                15.5      HIT\n",
      "[100]  L=4         |(19.4 ) - (32.9 ))|                13.5      HIT\n",
      "[101]  L=4         |(23.5 ) - (24.1 ))|                 0.6      HIT\n",
      "[102]  L=4         |(23.5 ) - (42.3 ))|                18.8      HIT\n",
      "[103]  L=4         |(23.5 ) - (48.5 ))|                25.0      HIT\n",
      "[104]  L=4         |(23.5 ) - (50.0 ))|                26.5      HIT\n",
      "[105]  L=[7, 4]    |(21.837) - (22.6 ))|              0.763      INTERPOLATE\n",
      "[106]  L=[5, 7]    |(22.161) - (24.4 ))|              2.239      INTERPOLATE\n",
      "[107]  L=[5, 6]    |(19.465) - (22.5 ))|              3.035      INTERPOLATE\n",
      "[108]  L=3         |(22.8 ) - (24.4 ))|                 1.6      HIT\n",
      "[109]  L=3         |(22.8 ) - (20.0 ))|                 2.8      HIT\n",
      "[110]  L=3         |(22.8 ) - (21.7 ))|                 1.1      HIT\n",
      "[111]  L=3         |(22.8 ) - (19.3 ))|                 3.5      HIT\n",
      "[112]  L=3         |(22.8 ) - (22.4 ))|                 0.4      HIT\n",
      "[113]  L=[4, 7]    |(21.055) - (28.1 ))|              7.045      INTERPOLATE\n",
      "[114]  L=3         |(22.8 ) - (23.7 ))|                 0.9      HIT\n",
      "[115]  L=[4, 4]    |(22.792) - (25.0 ))|              2.208      INTERPOLATE\n",
      "[116]  L=3         |(22.8 ) - (23.3 ))|                 0.5      HIT\n",
      "[117]  L=5         |(24.1 ) - (28.7 ))|                 4.6      HIT\n",
      "[118]  L=3         |(22.8 ) - (21.5 ))|                 1.3      HIT\n",
      "[119]  L=3         |(22.8 ) - (23.0 ))|                 0.2      HIT\n",
      "[120]  L=3         |(22.8 ) - (26.7 ))|                 3.9      HIT\n",
      "[121]  L=3         |(22.8 ) - (21.7 ))|                 1.1      HIT\n",
      "[122]  L=3         |(22.8 ) - (27.5 ))|                 4.7      HIT\n",
      "[123]  L=[5, 7]    |(22.296) - (30.1 ))|              7.804      INTERPOLATE\n",
      "[124]  L=3         |(22.8 ) - (44.8 ))|                22.0      HIT\n",
      "[125]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[126]  L=3         |(22.8 ) - (37.6 ))|                14.8      HIT\n",
      "[127]  L=5         |(23.4 ) - (31.6 ))|                 8.2      HIT\n",
      "[128]  L=3         |(24.2 ) - (46.7 ))|                22.5      HIT\n",
      "[129]  L=[2, 5]    |(22.443) - (31.5 ))|              9.057      INTERPOLATE\n",
      "[130]  L=[8, 5]    |(22.009) - (24.3 ))|              2.291      INTERPOLATE\n",
      "[131]  L=[5, 4]    |(20.405) - (31.7 ))|              11.295      INTERPOLATE\n",
      "[132]  L=3         |(23.4 ) - (41.7 ))|                18.3      HIT\n",
      "[133]  L=3         |(24.2 ) - (48.3 ))|                24.1      HIT\n",
      "[134]  L=3         |(22.8 ) - (29.0 ))|                 6.2      HIT\n",
      "[135]  L=[3, 7]    |(21.276) - (24.0 ))|              2.724      INTERPOLATE\n",
      "[136]  L=3         |(22.8 ) - (25.1 ))|                 2.3      HIT\n",
      "[137]  L=[5, 7]    |(20.728) - (31.5 ))|              10.772      INTERPOLATE\n",
      "[138]  L=5         |(24.1 ) - (23.7 ))|                 0.4      HIT\n",
      "[139]  L=[4, 3]    |(19.958) - (23.3 ))|              3.342      INTERPOLATE\n",
      "[140]  L=[7, 3]    |(21.134) - (22.0 ))|              0.866      INTERPOLATE\n",
      "[141]  L=3         |(20.5 ) - (20.1 ))|                 0.4      HIT\n",
      "[142]  L=[4, 3]    |(19.977) - (22.2 ))|              2.223      INTERPOLATE\n",
      "[143]  L=3         |(22.8 ) - (23.7 ))|                 0.9      HIT\n",
      "[144]  L=[5, 6]    |(22.57) - (17.6 ))|                4.97      INTERPOLATE\n",
      "[145]  L=6         |(22.9 ) - (18.5 ))|                 4.4      HIT\n",
      "[146]  L=5         |(22.2 ) - (24.3 ))|                 2.1      HIT\n",
      "[147]  L=[5, 6]    |(22.57) - (20.5 ))|                2.07      INTERPOLATE\n",
      "[148]  L=3         |(25.0 ) - (24.5 ))|                 0.5      HIT\n",
      "[149]  L=5         |(24.1 ) - (26.2 ))|                 2.1      HIT\n",
      "[150]  L=5         |(23.4 ) - (24.4 ))|                 1.0      HIT\n",
      "[151]  L=3         |(24.2 ) - (24.8 ))|                 0.6      HIT\n",
      "[152]  L=3         |(22.8 ) - (29.6 ))|                 6.8      HIT\n",
      "[153]  L=3         |(22.8 ) - (42.8 ))|                20.0      HIT\n",
      "[154]  L=4         |(23.5 ) - (21.9 ))|                 1.6      HIT\n",
      "[155]  L=4         |(23.5 ) - (20.9 ))|                 2.6      HIT\n",
      "[156]  L=4         |(19.4 ) - (44.0 ))|                24.6      HIT\n",
      "[157]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[158]  L=3         |(22.8 ) - (36.0 ))|                13.2      HIT\n",
      "[159]  L=3         |(22.8 ) - (30.1 ))|                 7.3      HIT\n",
      "[160]  L=4         |(20.6 ) - (33.8 ))|                13.2      HIT\n",
      "[161]  L=[5, 3]    |(23.425) - (43.1 ))|              19.675      INTERPOLATE\n",
      "[162]  L=3         |(22.8 ) - (48.8 ))|                26.0      HIT\n",
      "[163]  L=3         |(22.8 ) - (31.0 ))|                 8.2      HIT\n",
      "[164]  L=[3, 3]    |(23.088) - (36.5 ))|              13.412      INTERPOLATE\n",
      "[165]  L=[3, 4]    |(21.62) - (22.8 ))|                1.18      INTERPOLATE\n",
      "[166]  L=3         |(22.8 ) - (30.7 ))|                 7.9      HIT\n",
      "[167]  L=4         |(20.6 ) - (50.0 ))|                29.4      HIT\n",
      "[168]  L=[4, 6]    |(20.0 ) - (43.5 ))|                23.5      INTERPOLATE\n",
      "[169]  L=3         |(22.8 ) - (20.7 ))|                 2.1      HIT\n",
      "[170]  L=6         |(20.0 ) - (21.1 ))|                 1.1      HIT\n",
      "[171]  L=[3, 5]    |(23.451) - (25.2 ))|              1.749      INTERPOLATE\n",
      "[172]  L=[5, 4]    |(22.396) - (24.4 ))|              2.004      INTERPOLATE\n",
      "[173]  L=3         |(22.8 ) - (35.2 ))|                12.4      HIT\n",
      "[174]  L=3         |(22.8 ) - (32.4 ))|                 9.6      HIT\n",
      "[175]  L=[4, 6]    |(20.0 ) - (32.0 ))|                12.0      INTERPOLATE\n",
      "[176]  L=3         |(22.8 ) - (33.2 ))|                10.4      HIT\n",
      "[177]  L=3         |(22.8 ) - (33.1 ))|                10.3      HIT\n",
      "[178]  L=[4, 6]    |(20.0 ) - (29.1 ))|                 9.1      INTERPOLATE\n",
      "[179]  L=[5, 5]    |(21.677) - (35.1 ))|              13.423      INTERPOLATE\n",
      "[180]  L=[4, 6]    |(20.0 ) - (45.4 ))|                25.4      INTERPOLATE\n",
      "[181]  L=[5, 7]    |(20.677) - (35.4 ))|              14.723      INTERPOLATE\n",
      "[182]  L=3         |(22.8 ) - (46.0 ))|                23.2      HIT\n",
      "[183]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[184]  L=2         |(24.7 ) - (32.2 ))|                 7.5      HIT\n",
      "[185]  L=[6, 7]    |(21.028) - (22.0 ))|              0.972      INTERPOLATE\n",
      "[186]  L=[7, 5]    |(20.343) - (20.1 ))|              0.243      INTERPOLATE\n",
      "[187]  L=[7, 5]    |(20.294) - (23.2 ))|              2.906      INTERPOLATE\n",
      "[188]  L=[7, 5]    |(20.309) - (22.3 ))|              1.991      INTERPOLATE\n",
      "[189]  L=[7, 5]    |(20.329) - (24.8 ))|              4.471      INTERPOLATE\n",
      "[190]  L=7         |(22.0 ) - (28.5 ))|                 6.5      HIT\n",
      "[191]  L=[5, 7]    |(20.509) - (37.3 ))|              16.791      INTERPOLATE\n",
      "[192]  L=2         |(34.9 ) - (27.9 ))|                 7.0      HIT\n",
      "[193]  L=[4, 6]    |(20.0 ) - (23.9 ))|                 3.9      INTERPOLATE\n",
      "[194]  L=[4, 6]    |(20.0 ) - (21.7 ))|                 1.7      INTERPOLATE\n",
      "[195]  L=[4, 6]    |(20.0 ) - (28.6 ))|                 8.6      INTERPOLATE\n",
      "[196]  L=[3, 6]    |(21.432) - (27.1 ))|              5.668      INTERPOLATE\n",
      "[197]  L=[4, 6]    |(20.0 ) - (20.3 ))|                 0.3      INTERPOLATE\n",
      "[198]  L=4         |(23.5 ) - (22.5 ))|                 1.0      HIT\n",
      "[199]  L=[6, 5]    |(19.436) - (29.0 ))|              9.564      INTERPOLATE\n",
      "[200]  L=[4, 4]    |(21.589) - (24.8 ))|              3.211      INTERPOLATE\n",
      "[201]  L=[4, 3]    |(19.966) - (22.0 ))|              2.034      INTERPOLATE\n",
      "[202]  L=[5, 5]    |(21.686) - (26.4 ))|              4.714      INTERPOLATE\n",
      "[203]  L=3         |(22.8 ) - (33.1 ))|                10.3      HIT\n",
      "[204]  L=[7, 3]    |(33.792) - (36.1 ))|              2.308      INTERPOLATE\n",
      "[205]  L=[3, 7]    |(22.628) - (28.4 ))|              5.772      INTERPOLATE\n",
      "[206]  L=3         |(22.8 ) - (33.4 ))|                10.6      HIT\n",
      "[207]  L=5         |(23.4 ) - (28.2 ))|                 4.8      HIT\n",
      "[208]  L=[7, 5]    |(20.403) - (22.8 ))|              2.397      INTERPOLATE\n",
      "[209]  L=[5, 7]    |(20.822) - (20.3 ))|              0.522      INTERPOLATE\n",
      "[210]  L=[6, 4]    |(23.311) - (16.1 ))|              7.211      INTERPOLATE\n",
      "[211]  L=[7, 6]    |(20.883) - (22.1 ))|              1.217      INTERPOLATE\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[212]  L=[3, 5]    |(20.328) - (19.4 ))|              0.928      INTERPOLATE\n",
      "[213]  L=[7, 5]    |(20.449) - (21.6 ))|              1.151      INTERPOLATE\n",
      "[214]  L=[5, 7]    |(20.545) - (23.8 ))|              3.255      INTERPOLATE\n",
      "[215]  L=7         |(22.0 ) - (16.2 ))|                 5.8      HIT\n",
      "[216]  L=[5, 7]    |(20.686) - (17.8 ))|              2.886      INTERPOLATE\n",
      "[217]  L=[5, 7]    |(21.599) - (19.8 ))|              1.799      INTERPOLATE\n",
      "[218]  L=[7, 4]    |(19.97) - (23.1 ))|                3.13      INTERPOLATE\n",
      "[219]  L=[9, 6]    |(18.495) - (21.0 ))|              2.505      INTERPOLATE\n",
      "[220]  L=[4, 7]    |(22.87) - (23.8 ))|                0.93      INTERPOLATE\n",
      "[221]  L=[4, 6]    |(20.389) - (23.1 ))|              2.711      INTERPOLATE\n",
      "[222]  L=4         |(20.9 ) - (20.4 ))|                 0.5      HIT\n",
      "[223]  L=[1, 7]    |(20.13) - (18.5 ))|                1.63      INTERPOLATE\n",
      "[224]  L=[4, 6]    |(22.13) - (25.0 ))|                2.87      INTERPOLATE\n",
      "[225]  L=[4, 5]    |(20.39) - (24.6 ))|                4.21      INTERPOLATE\n",
      "[226]  L=5         |(22.5 ) - (23.0 ))|                 0.5      HIT\n",
      "[227]  L=4         |(24.7 ) - (22.2 ))|                 2.5      HIT\n",
      "[228]  L=[5, 7]    |(20.643) - (19.3 ))|              1.343      INTERPOLATE\n",
      "[229]  L=3         |(22.8 ) - (22.6 ))|                 0.2      HIT\n",
      "[230]  L=[4, 7]    |(20.748) - (19.8 ))|              0.948      INTERPOLATE\n",
      "[231]  L=[5, 7]    |(20.68) - (17.1 ))|                3.58      INTERPOLATE\n",
      "[232]  L=5         |(20.2 ) - (19.4 ))|                 0.8      HIT\n",
      "[233]  L=[1, 7]    |(27.002) - (22.2 ))|              4.802      INTERPOLATE\n",
      "[234]  L=[7, 6]    |(22.133) - (20.7 ))|              1.433      INTERPOLATE\n",
      "[235]  L=[1, 7]    |(22.507) - (21.1 ))|              1.407      INTERPOLATE\n",
      "[236]  L=4         |(20.9 ) - (19.5 ))|                 1.4      HIT\n",
      "[237]  L=[6, 7]    |(21.007) - (18.5 ))|              2.507      INTERPOLATE\n",
      "[238]  L=6         |(20.0 ) - (20.6 ))|                 0.6      HIT\n",
      "[239]  L=4         |(20.9 ) - (19.0 ))|                 1.9      HIT\n",
      "[240]  L=[9, 6]    |(18.4 ) - (18.7 ))|                 0.3      INTERPOLATE\n",
      "[241]  L=5         |(24.1 ) - (32.7 ))|                 8.6      HIT\n",
      "[242]  L=[4, 6]    |(20.0 ) - (16.5 ))|                 3.5      INTERPOLATE\n",
      "[243]  L=4         |(20.6 ) - (23.9 ))|                 3.3      HIT\n",
      "[244]  L=[7, 5]    |(20.346) - (31.2 ))|              10.854      INTERPOLATE\n",
      "[245]  L=5         |(22.2 ) - (17.5 ))|                 4.7      HIT\n",
      "[246]  L=5         |(22.2 ) - (17.2 ))|                 5.0      HIT\n",
      "[247]  L=4         |(23.5 ) - (23.1 ))|                 0.4      HIT\n",
      "[248]  L=[4, 4]    |(21.309) - (24.5 ))|              3.191      INTERPOLATE\n",
      "[249]  L=3         |(23.4 ) - (26.6 ))|                 3.2      HIT\n",
      "[250]  L=3         |(22.8 ) - (22.9 ))|                 0.1      HIT\n",
      "[251]  L=3         |(22.8 ) - (24.1 ))|                 1.3      HIT\n",
      "[252]  L=3         |(22.8 ) - (18.6 ))|                 4.2      HIT\n",
      "[253]  L=[7, 4]    |(22.757) - (30.1 ))|              7.343      INTERPOLATE\n",
      "[254]  L=[3, 3]    |(23.088) - (18.2 ))|              4.888      INTERPOLATE\n",
      "[255]  L=3         |(22.8 ) - (20.6 ))|                 2.2      HIT\n",
      "[256]  L=3         |(22.8 ) - (17.8 ))|                 5.0      HIT\n",
      "[257]  L=3         |(22.8 ) - (21.7 ))|                 1.1      HIT\n",
      "[258]  L=3         |(22.8 ) - (22.7 ))|                 0.1      HIT\n",
      "[259]  L=3         |(22.8 ) - (22.6 ))|                 0.2      HIT\n",
      "[260]  L=3         |(22.8 ) - (25.0 ))|                 2.2      HIT\n",
      "[261]  L=3         |(22.8 ) - (19.9 ))|                 2.9      HIT\n",
      "[262]  L=3         |(22.8 ) - (20.8 ))|                 2.0      HIT\n",
      "[263]  L=3         |(22.8 ) - (16.8 ))|                 6.0      HIT\n",
      "[264]  L=3         |(22.8 ) - (21.9 ))|                 0.9      HIT\n",
      "[265]  L=3         |(22.8 ) - (27.5 ))|                 4.7      HIT\n",
      "[266]  L=3         |(22.8 ) - (21.9 ))|                 0.9      HIT\n",
      "[267]  L=3         |(22.8 ) - (23.1 ))|                 0.3      HIT\n",
      "[268]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[269]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[270]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[271]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[272]  L=3         |(22.8 ) - (50.0 ))|                27.2      HIT\n",
      "[273]  L=3         |(22.8 ) - (13.8 ))|                 9.0      HIT\n",
      "[274]  L=3         |(22.8 ) - (13.8 ))|                 9.0      HIT\n",
      "[275]  L=3         |(22.8 ) - (15.0 ))|                 7.8      HIT\n",
      "[276]  L=3         |(22.8 ) - (13.9 ))|                 8.9      HIT\n",
      "[277]  L=3         |(22.8 ) - (13.3 ))|                 9.5      HIT\n",
      "[278]  L=3         |(22.8 ) - (13.1 ))|                 9.7      HIT\n",
      "[279]  L=3         |(22.8 ) - (10.2 ))|                12.6      HIT\n",
      "[280]  L=3         |(22.8 ) - (10.4 ))|                12.4      HIT\n",
      "[281]  L=3         |(22.8 ) - (10.9 ))|                11.9      HIT\n",
      "[282]  L=3         |(22.8 ) - (11.3 ))|                11.5      HIT\n",
      "[283]  L=3         |(22.8 ) - (12.3 ))|                10.5      HIT\n",
      "[284]  L=3         |(22.8 ) - (8.8  ))|                14.0      HIT\n",
      "[285]  L=3         |(22.8 ) - (7.2  ))|                15.6      HIT\n",
      "[286]  L=3         |(22.8 ) - (10.5 ))|                12.3      HIT\n",
      "[287]  L=3         |(22.8 ) - (7.4  ))|                15.4      HIT\n",
      "[288]  L=3         |(22.8 ) - (10.2 ))|                12.6      HIT\n",
      "[289]  L=3         |(22.8 ) - (11.5 ))|                11.3      HIT\n",
      "[290]  L=3         |(22.8 ) - (15.1 ))|                 7.7      HIT\n",
      "[291]  L=3         |(22.8 ) - (23.2 ))|                 0.4      HIT\n",
      "[292]  L=3         |(22.8 ) - (9.7  ))|                13.1      HIT\n",
      "[293]  L=3         |(22.8 ) - (13.8 ))|                 9.0      HIT\n",
      "[294]  L=3         |(22.8 ) - (12.7 ))|                10.1      HIT\n",
      "[295]  L=3         |(22.8 ) - (13.1 ))|                 9.7      HIT\n",
      "[296]  L=3         |(22.8 ) - (12.5 ))|                10.3      HIT\n",
      "[297]  L=3         |(22.8 ) - (8.5  ))|                14.3      HIT\n",
      "[298]  L=3         |(22.8 ) - (5.0  ))|                17.8      HIT\n",
      "[299]  L=3         |(22.8 ) - (6.3  ))|                16.5      HIT\n",
      "[300]  L=3         |(22.8 ) - (5.6  ))|                17.2      HIT\n",
      "[301]  L=3         |(22.8 ) - (7.2  ))|                15.6      HIT\n",
      "[302]  L=3         |(22.8 ) - (12.1 ))|                10.7      HIT\n",
      "[303]  L=3         |(22.8 ) - (8.3  ))|                14.5      HIT\n",
      "[304]  L=3         |(22.8 ) - (8.5  ))|                14.3      HIT\n",
      "[305]  L=3         |(22.8 ) - (5.0  ))|                17.8      HIT\n",
      "[306]  L=3         |(22.8 ) - (11.9 ))|                10.9      HIT\n",
      "[307]  L=3         |(22.8 ) - (27.9 ))|                 5.1      HIT\n",
      "[308]  L=3         |(22.8 ) - (17.2 ))|                 5.6      HIT\n",
      "[309]  L=3         |(22.8 ) - (27.5 ))|                 4.7      HIT\n",
      "[310]  L=3         |(22.8 ) - (15.0 ))|                 7.8      HIT\n",
      "[311]  L=3         |(22.8 ) - (17.2 ))|                 5.6      HIT\n",
      "[312]  L=3         |(22.8 ) - (17.9 ))|                 4.9      HIT\n",
      "[313]  L=3         |(22.8 ) - (16.3 ))|                 6.5      HIT\n",
      "[314]  L=3         |(22.8 ) - (7.0  ))|                15.8      HIT\n",
      "[315]  L=3         |(22.8 ) - (7.2  ))|                15.6      HIT\n",
      "[316]  L=3         |(22.8 ) - (7.5  ))|                15.3      HIT\n",
      "[317]  L=3         |(22.8 ) - (10.4 ))|                12.4      HIT\n",
      "[318]  L=3         |(22.8 ) - (8.8  ))|                14.0      HIT\n",
      "[319]  L=3         |(22.8 ) - (8.4  ))|                14.4      HIT\n",
      "[320]  L=3         |(22.8 ) - (16.7 ))|                 6.1      HIT\n",
      "[321]  L=3         |(22.8 ) - (14.2 ))|                 8.6      HIT\n",
      "[322]  L=3         |(22.8 ) - (20.8 ))|                 2.0      HIT\n",
      "[323]  L=3         |(22.8 ) - (13.4 ))|                 9.4      HIT\n",
      "[324]  L=3         |(22.8 ) - (11.7 ))|                11.1      HIT\n",
      "[325]  L=3         |(22.8 ) - (8.3  ))|                14.5      HIT\n",
      "[326]  L=3         |(22.8 ) - (10.2 ))|                12.6      HIT\n",
      "[327]  L=3         |(22.8 ) - (10.9 ))|                11.9      HIT\n",
      "[328]  L=3         |(22.8 ) - (11.0 ))|                11.8      HIT\n",
      "[329]  L=3         |(22.8 ) - (9.5  ))|                13.3      HIT\n",
      "[330]  L=3         |(22.8 ) - (14.5 ))|                 8.3      HIT\n",
      "[331]  L=3         |(22.8 ) - (14.1 ))|                 8.7      HIT\n",
      "[332]  L=3         |(22.8 ) - (16.1 ))|                 6.7      HIT\n",
      "[333]  L=3         |(22.8 ) - (14.3 ))|                 8.5      HIT\n",
      "[334]  L=3         |(22.8 ) - (11.7 ))|                11.1      HIT\n",
      "[335]  L=3         |(22.8 ) - (13.4 ))|                 9.4      HIT\n",
      "[336]  L=3         |(22.8 ) - (9.6  ))|                13.2      HIT\n",
      "[337]  L=3         |(22.8 ) - (8.7  ))|                14.1      HIT\n",
      "[338]  L=3         |(22.8 ) - (8.4  ))|                14.4      HIT\n",
      "[339]  L=3         |(22.8 ) - (12.8 ))|                10.0      HIT\n",
      "[340]  L=3         |(22.8 ) - (10.5 ))|                12.3      HIT\n",
      "[341]  L=3         |(22.8 ) - (17.1 ))|                 5.7      HIT\n",
      "[342]  L=3         |(22.8 ) - (18.4 ))|                 4.4      HIT\n",
      "[343]  L=3         |(22.8 ) - (15.4 ))|                 7.4      HIT\n",
      "[344]  L=3         |(22.8 ) - (10.8 ))|                12.0      HIT\n",
      "[345]  L=3         |(22.8 ) - (11.8 ))|                11.0      HIT\n",
      "[346]  L=3         |(22.8 ) - (14.9 ))|                 7.9      HIT\n",
      "[347]  L=3         |(22.8 ) - (12.6 ))|                10.2      HIT\n",
      "[348]  L=3         |(22.8 ) - (14.1 ))|                 8.7      HIT\n",
      "[349]  L=3         |(22.8 ) - (13.0 ))|                 9.8      HIT\n",
      "[350]  L=3         |(22.8 ) - (13.4 ))|                 9.4      HIT\n",
      "[351]  L=3         |(22.8 ) - (15.2 ))|                 7.6      HIT\n",
      "[352]  L=3         |(22.8 ) - (16.1 ))|                 6.7      HIT\n",
      "[353]  L=3         |(22.8 ) - (17.8 ))|                 5.0      HIT\n",
      "[354]  L=3         |(22.8 ) - (14.9 ))|                 7.9      HIT\n",
      "[355]  L=3         |(22.8 ) - (14.1 ))|                 8.7      HIT\n",
      "[356]  L=3         |(22.8 ) - (12.7 ))|                10.1      HIT\n",
      "[357]  L=3         |(22.8 ) - (13.5 ))|                 9.3      HIT\n",
      "[358]  L=3         |(22.8 ) - (14.9 ))|                 7.9      HIT\n",
      "[359]  L=3         |(22.8 ) - (20.0 ))|                 2.8      HIT\n",
      "[360]  L=3         |(22.8 ) - (16.4 ))|                 6.4      HIT\n",
      "[361]  L=3         |(22.8 ) - (17.7 ))|                 5.1      HIT\n",
      "[362]  L=3         |(22.8 ) - (19.5 ))|                 3.3      HIT\n",
      "[363]  L=3         |(22.8 ) - (20.2 ))|                 2.6      HIT\n",
      "[364]  L=3         |(22.8 ) - (21.4 ))|                 1.4      HIT\n",
      "[365]  L=3         |(22.8 ) - (19.9 ))|                 2.9      HIT\n",
      "[366]  L=3         |(22.8 ) - (19.0 ))|                 3.8      HIT\n",
      "[367]  L=3         |(22.8 ) - (19.1 ))|                 3.7      HIT\n",
      "[368]  L=3         |(22.8 ) - (19.1 ))|                 3.7      HIT\n",
      "[369]  L=3         |(22.8 ) - (20.1 ))|                 2.7      HIT\n",
      "[370]  L=3         |(22.8 ) - (19.9 ))|                 2.9      HIT\n",
      "[371]  L=3         |(22.8 ) - (19.6 ))|                 3.2      HIT\n",
      "[372]  L=3         |(22.8 ) - (23.2 ))|                 0.4      HIT\n",
      "[373]  L=3         |(22.8 ) - (29.8 ))|                 7.0      HIT\n",
      "[374]  L=3         |(22.8 ) - (13.8 ))|                 9.0      HIT\n",
      "[375]  L=3         |(22.8 ) - (13.3 ))|                 9.5      HIT\n",
      "[376]  L=3         |(22.8 ) - (16.7 ))|                 6.1      HIT\n",
      "[377]  L=3         |(22.8 ) - (12.0 ))|                10.8      HIT\n",
      "[378]  L=3         |(22.8 ) - (14.6 ))|                 8.2      HIT\n",
      "[379]  L=3         |(22.8 ) - (21.4 ))|                 1.4      HIT\n",
      "[380]  L=3         |(22.8 ) - (23.0 ))|                 0.2      HIT\n",
      "[381]  L=3         |(22.8 ) - (23.7 ))|                 0.9      HIT\n",
      "[382]  L=3         |(22.8 ) - (25.0 ))|                 2.2      HIT\n",
      "[383]  L=3         |(22.8 ) - (21.8 ))|                 1.0      HIT\n",
      "[384]  L=3         |(22.8 ) - (20.6 ))|                 2.2      HIT\n",
      "[385]  L=3         |(22.8 ) - (21.2 ))|                 1.6      HIT\n",
      "[386]  L=3         |(22.8 ) - (19.1 ))|                 3.7      HIT\n",
      "[387]  L=3         |(22.8 ) - (20.6 ))|                 2.2      HIT\n",
      "[388]  L=3         |(22.8 ) - (15.2 ))|                 7.6      HIT\n",
      "[389]  L=3         |(22.8 ) - (7.0  ))|                15.8      HIT\n",
      "[390]  L=3         |(22.8 ) - (8.1  ))|                14.7      HIT\n",
      "[391]  L=3         |(22.8 ) - (13.6 ))|                 9.2      HIT\n",
      "[392]  L=3         |(22.8 ) - (20.1 ))|                 2.7      HIT\n",
      "[393]  L=[5, 6]    |(19.48) - (21.8 ))|                2.32      INTERPOLATE\n",
      "[394]  L=[9, 6]    |(18.429) - (24.5 ))|              6.071      INTERPOLATE\n",
      "[395]  L=3         |(22.8 ) - (23.1 ))|                 0.3      HIT\n",
      "[396]  L=[5, 5]    |(23.754) - (19.7 ))|              4.054      INTERPOLATE\n",
      "[397]  L=[3, 5]    |(20.311) - (18.3 ))|              2.011      INTERPOLATE\n",
      "[398]  L=[3, 7]    |(21.04) - (21.2 ))|                0.16      INTERPOLATE\n",
      "[399]  L=[3, 5]    |(20.318) - (17.5 ))|              2.818      INTERPOLATE\n",
      "[400]  L=[5, 9]    |(18.483) - (16.8 ))|              1.683      INTERPOLATE\n",
      "[401]  L=6         |(18.4 ) - (22.4 ))|                 4.0      HIT\n",
      "[402]  L=8         |(15.6 ) - (20.6 ))|                 5.0      HIT\n",
      "[403]  L=8         |(15.6 ) - (23.9 ))|                 8.3      HIT\n",
      "[404]  L=8         |(15.6 ) - (22.0 ))|                 6.4      HIT\n",
      "[405]  L=8         |(15.6 ) - (11.9 ))|                 3.7      HIT\n",
      "N_INTERPOLATED:102, N_large_error (>0.1):405\n",
      "avg error          : 7.37128, avg_frac_error          : 0.41081 \n",
      "avg exclusive error: 8.12763, avg exclusive frac error: 0.41081\n"
     ]
    }
   ],
   "source": [
    "standard_evaluation(X_test, Y_test, net, get_interp_indices=False)\n",
    "Y_pred = []\n",
    "for i in range(len(X_test)):\n",
    "    y, act, ACTIVATION_STATUS, info_ = net.SQANN_propagation(X_test[i,:], ALLOW_INTERPOLATION=True)\n",
    "    Y_pred.append(y)\n",
    "MSE['SQANN'] = compute_mse(np.array(Y_pred),Y_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cfd27889",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "linear                   : 36.4449\n",
      "Ridge                    : 7.9896\n",
      "Lasso                    : 9.8339\n",
      "LinSVR                   : 8.3577\n",
      "NuSVR                    : 8.8331\n",
      "SVR                      : 8.7116\n",
      "DecTree                  : 7.3563\n",
      "kneigh                   : 7.3933\n",
      "MLP                      : 12.7684\n",
      "SQANN                    : 9.8976\n"
     ]
    }
   ],
   "source": [
    "for model_name, mse_score in MSE.items():\n",
    "    print('%-24s : %s'%(str(model_name),str(np.round( mse_score,4))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "1b2c175a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from SQANN.utils import ood_searcher\n",
    "\n",
    "def integrate_ood_data(X_train, Y_train, X_test,Y_test,net, error_th=5):\n",
    "    print('error threshold:', error_th)\n",
    "    OOD_INDICES_COLLECTION = ood_searcher(X_test,Y_test,net , len(X_test),error_th=error_th)\n",
    "\n",
    "    X_train_new = list(X_train)\n",
    "    Y_train_new = list(Y_train)\n",
    "\n",
    "    for oi in OOD_INDICES_COLLECTION:\n",
    "        X_train_new.append(X_test[oi,:])\n",
    "        Y_train_new.append(Y_test[oi])\n",
    "    X_train_new = np.array(X_train_new)\n",
    "    Y_train_new = np.array(Y_train_new)\n",
    "\n",
    "    # print(OOD_INDICES_COLLECTION)\n",
    "    print('n total:', len(X))\n",
    "    print('n original training:', len(X_train))\n",
    "    print('n integrated:',len(OOD_INDICES_COLLECTION))\n",
    "    print('n training new:', len(X_train_new))\n",
    "    print('n test:', len(X_test))\n",
    "    print('new training fraction:',np.round(len(X_train_new)/len(X),3))\n",
    "\n",
    "    MSE_new = {}\n",
    "    # print('linear models...')\n",
    "    MSE_new = do_regress( LinearRegression(), X_train_new, Y_train_new, MSE_new, 'linear')\n",
    "    MSE_new = do_regress(Ridge(), X_train_new, Y_train_new, MSE_new,'Ridge')\n",
    "    MSE_new = do_regress(Lasso(), X_train_new, Y_train_new, MSE_new, 'Lasso')\n",
    "\n",
    "    # print('\\nSupport vector models...')\n",
    "    from sklearn.svm import LinearSVR, NuSVR, SVR\n",
    "    MSE_new = do_regress(LinearSVR(), X_train_new, Y_train_new, MSE_new,'LinSVR')\n",
    "    MSE_new = do_regress(NuSVR(), X_train_new, Y_train_new, MSE_new,'NuSVR')\n",
    "    MSE_new = do_regress(SVR(), X_train_new, Y_train_new, MSE_new,'SVR')\n",
    "\n",
    "    # print('\\nDecision Tree models...')\n",
    "    from sklearn.tree import DecisionTreeRegressor\n",
    "    MSE_new = do_regress(DecisionTreeRegressor(random_state=0), X_train_new, Y_train_new, MSE_new,'DecTree')\n",
    "\n",
    "    # print('\\nKNeighbors models...')\n",
    "    from sklearn.neighbors import KNeighborsRegressor\n",
    "    min_mse_new,n_min = np.inf,-1\n",
    "    for n in range(2,16+1):\n",
    "        temp_name = 'KNeighborsRegressor(n_neighbors=%s)'%(str(n))\n",
    "        dummy = do_regress(KNeighborsRegressor(n_neighbors=n), X_train_new, Y_train_new, {}, temp_name)\n",
    "        this_mse = dummy[temp_name]\n",
    "        if this_mse<min_mse_new:\n",
    "            # print(np.round(this_mse,4), 'n:%s'%(str(n)))\n",
    "            min_mse_new = this_mse\n",
    "            n_min = n\n",
    "    MSE_new['kneigh'] = min_mse_new\n",
    "\n",
    "    # print('\\nMLP models...')\n",
    "    from sklearn.neural_network import MLPRegressor\n",
    "    MSE_new = do_regress(MLPRegressor(hidden_layer_sizes=(64,64),random_state=1, max_iter=12000), X_train_new, Y_train_new, MSE_new, 'MLP')\n",
    "\n",
    "    net_new = SQANN(layer_settings, N=len(X_train_new))\n",
    "    net_new.fit_data(X_train_new,Y_train_new,verbose=0)\n",
    "\n",
    "    # standard_evaluation(X_test, Y_test, net_new, get_interp_indices=False)\n",
    "    Y_pred_new = []\n",
    "    for i in range(len(X_test)):\n",
    "        y1, act1, ACTIVATION_STATUS1, info1_ = net.SQANN_propagation(X_test[i,:], ALLOW_INTERPOLATION=True)\n",
    "        y2, act2, ACTIVATION_STATUS2, info2_ = net_new.SQANN_propagation(X_test[i,:], ALLOW_INTERPOLATION=True)\n",
    "\n",
    "        y = y1 if np.max(act1)>np.max(act2) else y2\n",
    "        Y_pred_new.append(y)\n",
    "    MSE_new['SQANN'] = compute_mse(np.array(Y_pred_new),Y_test)\n",
    "    return MSE_new"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4a0633ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "error threshold: 5\n",
      "n total: 506\n",
      "n original training: 100\n",
      "n integrated: 211\n",
      "n training new: 311\n",
      "n test: 406\n",
      "new training fraction: 0.615\n",
      "\n",
      "error threshold: 2\n",
      "n total: 506\n",
      "n original training: 100\n",
      "n integrated: 319\n",
      "n training new: 419\n",
      "n test: 406\n",
      "new training fraction: 0.828\n"
     ]
    }
   ],
   "source": [
    "MSE_new1 = integrate_ood_data(X_train, Y_train, X_test,Y_test,net, error_th=5)\n",
    "print()\n",
    "MSE_new2 = integrate_ood_data(X_train, Y_train, X_test,Y_test,net, error_th=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1f354ab5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       linear  Ridge  Lasso  LinSVR  NuSVR    SVR  DecTree  kneigh     MLP  SQANN\n",
      "orig.  36.445  7.990  9.834   8.358  8.833  8.712    7.356   7.393  12.768  9.898\n",
      "eth:5   5.139  5.135  7.068   5.967  6.295  6.068    5.026   4.798   3.481  7.998\n",
      "eth:2   4.993  5.028  7.882   5.835  6.121  5.895    2.072   3.025   3.846  3.076\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "pd.set_option('display.expand_frame_repr', False)\n",
    "\n",
    "results = {}\n",
    "for model_name in MSE:\n",
    "    results[model_name] = [MSE[model_name],MSE_new1[model_name],MSE_new2[model_name]]\n",
    "df = pd.DataFrame(results)\n",
    "df.index = ['orig.','eth:5','eth:2'] # eth: error threshold\n",
    "print(df.round(3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1dc2d31",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
