{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from get_online_results import EvaluatorOnline\n",
    "from get_offline_results import EvaluatorOffline\n",
    "\n",
    "XSMALL_SIZE = 14\n",
    "SMALL_SIZE = 14\n",
    "MEDIUM_SIZE = 14\n",
    "BIGGER_SIZE = 18\n",
    "\n",
    "plt.rc(\"font\", size=SMALL_SIZE)  # controls default text sizes\n",
    "plt.rc(\"axes\", titlesize=MEDIUM_SIZE)  # fontsize of the axes title\n",
    "plt.rc(\"axes\", labelsize=MEDIUM_SIZE)  # fontsize of the x and y labels\n",
    "plt.rc(\"xtick\", labelsize=MEDIUM_SIZE)  # fontsize of the tick labels\n",
    "plt.rc(\"ytick\", labelsize=MEDIUM_SIZE)  # fontsize of the tick labels\n",
    "plt.rc(\"legend\", fontsize=SMALL_SIZE)  # legend fontsize\n",
    "plt.rc(\"figure\", titlesize=BIGGER_SIZE)  # fontsize of the figure title"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "mycolors = [\"#759AD5\", \"#F99963\", \"#95C460\", \"#E85D58\", \"#ACA9D9\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BNG_wisconsin\n",
      "model, n, h, loss, time = cats, 4.0, 1.0, 0.240446, 5.6\n",
      "model, n, h, loss, time = cats, 8.0, 1.0, 0.198868, 6.57\n",
      "model, n, h, loss, time = cats, 8.0, 2.0, 0.222735, 5.89\n",
      "model, n, h, loss, time = cats, 16.0, 1.0, 0.192508, 8.18\n",
      "model, n, h, loss, time = cats, 16.0, 2.0, 0.197387, 10.69\n",
      "model, n, h, loss, time = cats, 16.0, 4.0, 0.215877, 8.51\n",
      "model, n, h, loss, time = cats, 32.0, 1.0, 0.201209, 11.09\n",
      "model, n, h, loss, time = cats, 32.0, 2.0, 0.188503, 12.85\n",
      "model, n, h, loss, time = cats, 32.0, 4.0, 0.192799, 15.68\n",
      "model, n, h, loss, time = cats, 32.0, 8.0, 0.211517, 9.33\n",
      "model, n, h, loss, time = cats, 64.0, 1.0, 0.202885, 14.92\n",
      "model, n, h, loss, time = cats, 64.0, 2.0, 0.188466, 19.56\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.185859, 16.4\n",
      "model, n, h, loss, time = cats, 64.0, 8.0, 0.188952, 20.58\n",
      "model, n, h, loss, time = cats, 64.0, 16.0, 0.208764, 11.79\n",
      "model, n, h, loss, time = cats, 128.0, 1.0, 0.205108, 17.07\n",
      "model, n, h, loss, time = cats, 128.0, 2.0, 0.1881, 17.34\n",
      "model, n, h, loss, time = cats, 128.0, 4.0, 0.18548, 18.73\n",
      "model, n, h, loss, time = cats, 128.0, 8.0, 0.183081, 19.32\n",
      "model, n, h, loss, time = cats, 128.0, 16.0, 0.186112, 16.0\n",
      "model, n, h, loss, time = cats, 128.0, 32.0, 0.206733, 13.95\n",
      "model, n, h, loss, time = cats, 256.0, 1.0, 0.200743, 16.72\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.1916, 17.07\n",
      "model, n, h, loss, time = cats, 256.0, 4.0, 0.182435, 17.43\n",
      "model, n, h, loss, time = cats, 256.0, 8.0, 0.182346, 16.66\n",
      "model, n, h, loss, time = cats, 256.0, 16.0, 0.179137, 18.81\n",
      "model, n, h, loss, time = cats, 256.0, 32.0, 0.184601, 17.04\n",
      "model, n, h, loss, time = cats, 256.0, 64.0, 0.205301, 13.98\n",
      "model, n, h, loss, time = cats, 512.0, 1.0, 0.213181, 17.51\n",
      "model, n, h, loss, time = cats, 512.0, 2.0, 0.203591, 17.9\n",
      "model, n, h, loss, time = cats, 512.0, 4.0, 0.182473, 16.67\n",
      "model, n, h, loss, time = cats, 512.0, 8.0, 0.182438, 20.66\n",
      "model, n, h, loss, time = cats, 512.0, 16.0, 0.178852, 19.91\n",
      "model, n, h, loss, time = cats, 512.0, 32.0, 0.178174, 18.52\n",
      "model, n, h, loss, time = cats, 512.0, 64.0, 0.182425, 20.18\n",
      "model, n, h, loss, time = cats, 512.0, 128.0, 0.204084, 14.97\n",
      "model, n, h, loss, time = cats, 1024.0, 1.0, 0.229247, 20.54\n",
      "model, n, h, loss, time = cats, 1024.0, 2.0, 0.21274, 16.69\n",
      "model, n, h, loss, time = cats, 1024.0, 4.0, 0.200845, 16.9\n",
      "model, n, h, loss, time = cats, 1024.0, 8.0, 0.18514, 18.29\n",
      "model, n, h, loss, time = cats, 1024.0, 16.0, 0.178227, 18.96\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.175696, 18.95\n",
      "model, n, h, loss, time = cats, 1024.0, 64.0, 0.176849, 17.61\n",
      "model, n, h, loss, time = cats, 1024.0, 128.0, 0.181235, 18.53\n",
      "model, n, h, loss, time = cats, 1024.0, 256.0, 0.203249, 17.07\n",
      "model, n, h, loss, time = cats, 2048.0, 1.0, 0.253936, 16.37\n",
      "model, n, h, loss, time = cats, 2048.0, 2.0, 0.221458, 17.67\n",
      "model, n, h, loss, time = cats, 2048.0, 4.0, 0.204751, 18.31\n",
      "model, n, h, loss, time = cats, 2048.0, 8.0, 0.186803, 16.13\n",
      "model, n, h, loss, time = cats, 2048.0, 16.0, 0.181781, 15.52\n",
      "model, n, h, loss, time = cats, 2048.0, 32.0, 0.178034, 16.08\n",
      "model, n, h, loss, time = cats, 2048.0, 64.0, 0.175347, 16.47\n",
      "model, n, h, loss, time = cats, 2048.0, 128.0, 0.175334, 14.92\n",
      "model, n, h, loss, time = cats, 2048.0, 256.0, 0.180162, 13.06\n",
      "model, n, h, loss, time = cats, 2048.0, 512.0, 0.202825, 13.08\n",
      "model, n, h, loss, time = cats, 4096.0, 1.0, 0.26139, 14.88\n",
      "model, n, h, loss, time = cats, 4096.0, 2.0, 0.246596, 16.5\n",
      "model, n, h, loss, time = cats, 4096.0, 4.0, 0.217244, 17.01\n",
      "model, n, h, loss, time = cats, 4096.0, 8.0, 0.203082, 17.37\n",
      "model, n, h, loss, time = cats, 4096.0, 16.0, 0.188951, 20.88\n",
      "model, n, h, loss, time = cats, 4096.0, 32.0, 0.182972, 15.66\n",
      "model, n, h, loss, time = cats, 4096.0, 64.0, 0.178553, 13.73\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.173245, 14.71\n",
      "model, n, h, loss, time = cats, 4096.0, 256.0, 0.175282, 13.95\n",
      "model, n, h, loss, time = cats, 4096.0, 512.0, 0.179426, 12.87\n",
      "model, n, h, loss, time = cats, 4096.0, 1024.0, 0.202763, 12.39\n",
      "model, n, h, loss, time = cats, 8192.0, 1.0, 0.259286, 11.66\n",
      "model, n, h, loss, time = cats, 8192.0, 2.0, 0.246893, 13.38\n",
      "model, n, h, loss, time = cats, 8192.0, 4.0, 0.24539, 13.88\n",
      "model, n, h, loss, time = cats, 8192.0, 8.0, 0.21525, 14.95\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.200583, 14.91\n",
      "model, n, h, loss, time = cats, 8192.0, 32.0, 0.188759, 14.3\n",
      "model, n, h, loss, time = cats, 8192.0, 64.0, 0.17826, 15.78\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.175398, 15.99\n",
      "model, n, h, loss, time = cats, 8192.0, 256.0, 0.173745, 15.19\n",
      "model, n, h, loss, time = cats, 8192.0, 512.0, 0.174696, 16.44\n",
      "model, n, h, loss, time = cats, 8192.0, 1024.0, 0.179361, 15.42\n",
      "model, n, h, loss, time = cats, 8192.0, 2048.0, 0.202282, 13.81\n",
      "model, n, h, loss, time = disc_tree, 2.0, 0, 0.247959, 1.94\n",
      "model, n, h, loss, time = disc_tree, 4.0, 0, 0.198006, 2.58\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.194564, 4.0\n",
      "model, n, h, loss, time = disc_tree, 16.0, 0, 0.200192, 6.43\n",
      "model, n, h, loss, time = disc_tree, 32.0, 0, 0.206654, 8.26\n",
      "model, n, h, loss, time = disc_tree, 64.0, 0, 0.225218, 8.87\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.217926, 10.89\n",
      "model, n, h, loss, time = disc_tree, 256.0, 0, 0.22144, 12.33\n",
      "model, n, h, loss, time = disc_tree, 512.0, 0, 0.246328, 13.13\n",
      "model, n, h, loss, time = disc_tree, 1024.0, 0, 0.278912, 15.32\n",
      "model, n, h, loss, time = disc_tree, 2048.0, 0, 0.271191, 19.42\n",
      "model, n, h, loss, time = disc_tree, 4096.0, 0, 0.26584, 28.59\n",
      "model, n, h, loss, time = disc_tree, 8192.0, 0, 0.259087, 43.49\n",
      "model, n, h, loss, time = disc_linear, 2.0, 0, 0.320468, 3.49\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.172323, 7.15\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.228959, 9.94\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.18036, 14.59\n",
      "model, n, h, loss, time = disc_linear, 32.0, 0, 0.18811, 23.27\n",
      "model, n, h, loss, time = disc_linear, 64.0, 0, 0.21606, 41.5\n",
      "model, n, h, loss, time = disc_linear, 128.0, 0, 0.24207, 79.01\n",
      "model, n, h, loss, time = disc_linear, 256.0, 0, 0.203918, 154.45\n",
      "model, n, h, loss, time = disc_linear, 512.0, 0, 0.223586, 309.2\n",
      "model, n, h, loss, time = disc_linear, 1024.0, 0, 0.232631, 543.8\n",
      "model, n, h, loss, time = disc_linear, 2048.0, 0, 0.232948, 1139.52\n",
      "model, n, h, loss, time = disc_linear, 4096.0, 0, 0.271221, 2114.1\n",
      "model, n, h, loss, time = disc_linear, 8192.0, 0, 0.263182, 3842.07\n",
      "max_time =  5000.0\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.173245, 14.71\n",
      "C.I. = 0.17252435550541706, 0.1739680546281629\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.194564, 4.0\n",
      "C.I. = 0.19382057178429749, 0.19530961873323882\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.172323, 7.15\n",
      "C.I. = 0.1716256530841535, 0.173022619483447\n",
      "0.000723054628163\n",
      "0.000745618733239\n",
      "0.000699619483447\n",
      "black_friday\n",
      "model, n, h, loss, time = cats, 4.0, 1.0, 0.244163, 0.76\n",
      "model, n, h, loss, time = cats, 8.0, 1.0, 0.191747, 0.93\n",
      "model, n, h, loss, time = cats, 8.0, 2.0, 0.218026, 0.83\n",
      "model, n, h, loss, time = cats, 16.0, 1.0, 0.188085, 1.01\n",
      "model, n, h, loss, time = cats, 16.0, 2.0, 0.192191, 0.92\n",
      "model, n, h, loss, time = cats, 16.0, 4.0, 0.214603, 0.9\n",
      "model, n, h, loss, time = cats, 32.0, 1.0, 0.189662, 1.07\n",
      "model, n, h, loss, time = cats, 32.0, 2.0, 0.186827, 1.09\n",
      "model, n, h, loss, time = cats, 32.0, 4.0, 0.189867, 1.11\n",
      "model, n, h, loss, time = cats, 32.0, 8.0, 0.213034, 0.97\n",
      "model, n, h, loss, time = cats, 64.0, 1.0, 0.198452, 1.14\n",
      "model, n, h, loss, time = cats, 64.0, 2.0, 0.187626, 1.16\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.185229, 1.17\n",
      "model, n, h, loss, time = cats, 64.0, 8.0, 0.188232, 1.15\n",
      "model, n, h, loss, time = cats, 64.0, 16.0, 0.212099, 0.99\n",
      "model, n, h, loss, time = cats, 128.0, 1.0, 0.203882, 1.19\n",
      "model, n, h, loss, time = cats, 128.0, 2.0, 0.193601, 1.22\n",
      "model, n, h, loss, time = cats, 128.0, 4.0, 0.187629, 1.26\n",
      "model, n, h, loss, time = cats, 128.0, 8.0, 0.185462, 1.24\n",
      "model, n, h, loss, time = cats, 128.0, 16.0, 0.190106, 1.23\n",
      "model, n, h, loss, time = cats, 128.0, 32.0, 0.211117, 1.05\n",
      "model, n, h, loss, time = cats, 256.0, 1.0, 0.222255, 1.14\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.196399, 1.25\n",
      "model, n, h, loss, time = cats, 256.0, 4.0, 0.194193, 1.34\n",
      "model, n, h, loss, time = cats, 256.0, 8.0, 0.185687, 1.32\n",
      "model, n, h, loss, time = cats, 256.0, 16.0, 0.185766, 1.32\n",
      "model, n, h, loss, time = cats, 256.0, 32.0, 0.189698, 1.3\n",
      "model, n, h, loss, time = cats, 256.0, 64.0, 0.209799, 1.04\n",
      "model, n, h, loss, time = cats, 512.0, 1.0, 0.240506, 1.25\n",
      "model, n, h, loss, time = cats, 512.0, 2.0, 0.233138, 1.24\n",
      "model, n, h, loss, time = cats, 512.0, 4.0, 0.214072, 1.29\n",
      "model, n, h, loss, time = cats, 512.0, 8.0, 0.191674, 1.31\n",
      "model, n, h, loss, time = cats, 512.0, 16.0, 0.189015, 1.41\n",
      "model, n, h, loss, time = cats, 512.0, 32.0, 0.185833, 1.39\n",
      "model, n, h, loss, time = cats, 512.0, 64.0, 0.188063, 1.37\n",
      "model, n, h, loss, time = cats, 512.0, 128.0, 0.210047, 1.19\n",
      "model, n, h, loss, time = cats, 1024.0, 1.0, 0.248652, 1.27\n",
      "model, n, h, loss, time = cats, 1024.0, 2.0, 0.21561, 1.34\n",
      "model, n, h, loss, time = cats, 1024.0, 4.0, 0.221264, 1.39\n",
      "model, n, h, loss, time = cats, 1024.0, 8.0, 0.204735, 1.35\n",
      "model, n, h, loss, time = cats, 1024.0, 16.0, 0.19196, 1.4\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.188482, 1.41\n",
      "model, n, h, loss, time = cats, 1024.0, 64.0, 0.186325, 1.29\n",
      "model, n, h, loss, time = cats, 1024.0, 128.0, 0.188991, 1.23\n",
      "model, n, h, loss, time = cats, 1024.0, 256.0, 0.210382, 1.27\n",
      "model, n, h, loss, time = cats, 2048.0, 1.0, 0.258944, 1.13\n",
      "model, n, h, loss, time = cats, 2048.0, 2.0, 0.272592, 1.36\n",
      "model, n, h, loss, time = cats, 2048.0, 4.0, 0.248633, 1.44\n",
      "model, n, h, loss, time = cats, 2048.0, 8.0, 0.221808, 1.5\n",
      "model, n, h, loss, time = cats, 2048.0, 16.0, 0.209754, 1.51\n",
      "model, n, h, loss, time = cats, 2048.0, 32.0, 0.198167, 1.48\n",
      "model, n, h, loss, time = cats, 2048.0, 64.0, 0.191572, 1.57\n",
      "model, n, h, loss, time = cats, 2048.0, 128.0, 0.18806, 1.53\n",
      "model, n, h, loss, time = cats, 2048.0, 256.0, 0.186854, 1.53\n",
      "model, n, h, loss, time = cats, 2048.0, 512.0, 0.21034, 1.32\n",
      "model, n, h, loss, time = cats, 4096.0, 1.0, 0.273347, 1.3\n",
      "model, n, h, loss, time = cats, 4096.0, 2.0, 0.269281, 1.32\n",
      "model, n, h, loss, time = cats, 4096.0, 4.0, 0.272125, 1.47\n",
      "model, n, h, loss, time = cats, 4096.0, 8.0, 0.236485, 1.49\n",
      "model, n, h, loss, time = cats, 4096.0, 16.0, 0.212304, 1.57\n",
      "model, n, h, loss, time = cats, 4096.0, 32.0, 0.203944, 1.59\n",
      "model, n, h, loss, time = cats, 4096.0, 64.0, 0.189562, 1.63\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.190344, 1.61\n",
      "model, n, h, loss, time = cats, 4096.0, 256.0, 0.187859, 1.61\n",
      "model, n, h, loss, time = cats, 4096.0, 512.0, 0.188089, 1.63\n",
      "model, n, h, loss, time = cats, 4096.0, 1024.0, 0.211581, 1.33\n",
      "model, n, h, loss, time = cats, 8192.0, 1.0, 0.268766, 1.36\n",
      "model, n, h, loss, time = cats, 8192.0, 2.0, 0.266139, 1.42\n",
      "model, n, h, loss, time = cats, 8192.0, 4.0, 0.267808, 1.48\n",
      "model, n, h, loss, time = cats, 8192.0, 8.0, 0.256014, 1.56\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.231251, 1.38\n",
      "model, n, h, loss, time = cats, 8192.0, 32.0, 0.219135, 1.64\n",
      "model, n, h, loss, time = cats, 8192.0, 64.0, 0.207553, 1.67\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.196994, 1.69\n",
      "model, n, h, loss, time = cats, 8192.0, 256.0, 0.190436, 1.46\n",
      "model, n, h, loss, time = cats, 8192.0, 512.0, 0.186677, 1.7\n",
      "model, n, h, loss, time = cats, 8192.0, 1024.0, 0.188211, 1.7\n",
      "model, n, h, loss, time = cats, 8192.0, 2048.0, 0.210707, 1.5\n",
      "model, n, h, loss, time = disc_tree, 2.0, 0, 0.185978, 0.24\n",
      "model, n, h, loss, time = disc_tree, 4.0, 0, 0.183968, 0.26\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.180672, 0.33\n",
      "model, n, h, loss, time = disc_tree, 16.0, 0, 0.191013, 0.38\n",
      "model, n, h, loss, time = disc_tree, 32.0, 0, 0.191449, 0.5\n",
      "model, n, h, loss, time = disc_tree, 64.0, 0, 0.199072, 0.58\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.209897, 0.68\n",
      "model, n, h, loss, time = disc_tree, 256.0, 0, 0.242329, 0.76\n",
      "model, n, h, loss, time = disc_tree, 512.0, 0, 0.245583, 0.96\n",
      "model, n, h, loss, time = disc_tree, 1024.0, 0, 0.272348, 1.34\n",
      "model, n, h, loss, time = disc_tree, 2048.0, 0, 0.265271, 2.0\n",
      "model, n, h, loss, time = disc_tree, 4096.0, 0, 0.268162, 3.24\n",
      "model, n, h, loss, time = disc_tree, 8192.0, 0, 0.273753, 5.85\n",
      "model, n, h, loss, time = disc_linear, 2.0, 0, 0.185966, 0.28\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.185129, 0.43\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.187305, 0.6\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.192786, 0.95\n",
      "model, n, h, loss, time = disc_linear, 32.0, 0, 0.215205, 1.37\n",
      "model, n, h, loss, time = disc_linear, 64.0, 0, 0.222692, 2.71\n",
      "model, n, h, loss, time = disc_linear, 128.0, 0, 0.231619, 4.89\n",
      "model, n, h, loss, time = disc_linear, 256.0, 0, 0.252989, 9.46\n",
      "model, n, h, loss, time = disc_linear, 512.0, 0, 0.271028, 18.29\n",
      "model, n, h, loss, time = disc_linear, 1024.0, 0, 0.282785, 41.15\n",
      "model, n, h, loss, time = disc_linear, 2048.0, 0, 0.285385, 89.39\n",
      "model, n, h, loss, time = disc_linear, 4096.0, 0, 0.277951, 180.89\n",
      "model, n, h, loss, time = disc_linear, 8192.0, 0, 0.338563, 339.99\n",
      "max_time =  5000.0\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.185229, 1.17\n",
      "C.I. = 0.18339626667679604, 0.18707604839899872\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.180672, 0.33\n",
      "C.I. = 0.17883831238075984, 0.18252051287523674\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.185129, 0.43\n",
      "C.I. = 0.1832743253515882, 0.18699834677064053\n",
      "0.001847048399\n",
      "0.00184851287524\n",
      "0.00186934677064\n",
      "BNG_auto_price\n",
      "model, n, h, loss, time = cats, 4.0, 1.0, 0.227856, 5.27\n",
      "model, n, h, loss, time = cats, 8.0, 1.0, 0.15558, 6.38\n",
      "model, n, h, loss, time = cats, 8.0, 2.0, 0.198822, 4.86\n",
      "model, n, h, loss, time = cats, 16.0, 1.0, 0.137396, 7.83\n",
      "model, n, h, loss, time = cats, 16.0, 2.0, 0.143968, 6.75\n",
      "model, n, h, loss, time = cats, 16.0, 4.0, 0.184512, 6.5\n",
      "model, n, h, loss, time = cats, 32.0, 1.0, 0.135322, 9.96\n",
      "model, n, h, loss, time = cats, 32.0, 2.0, 0.127437, 10.9\n",
      "model, n, h, loss, time = cats, 32.0, 4.0, 0.135986, 7.86\n",
      "model, n, h, loss, time = cats, 32.0, 8.0, 0.177577, 6.82\n",
      "model, n, h, loss, time = cats, 64.0, 1.0, 0.139824, 11.23\n",
      "model, n, h, loss, time = cats, 64.0, 2.0, 0.125018, 9.72\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.121683, 9.84\n",
      "model, n, h, loss, time = cats, 64.0, 8.0, 0.131132, 11.08\n",
      "model, n, h, loss, time = cats, 64.0, 16.0, 0.173974, 10.56\n",
      "model, n, h, loss, time = cats, 128.0, 1.0, 0.145404, 11.11\n",
      "model, n, h, loss, time = cats, 128.0, 2.0, 0.133031, 14.16\n",
      "model, n, h, loss, time = cats, 128.0, 4.0, 0.118347, 12.7\n",
      "model, n, h, loss, time = cats, 128.0, 8.0, 0.11683, 13.23\n",
      "model, n, h, loss, time = cats, 128.0, 16.0, 0.128045, 11.4\n",
      "model, n, h, loss, time = cats, 128.0, 32.0, 0.171215, 8.29\n",
      "model, n, h, loss, time = cats, 256.0, 1.0, 0.149598, 12.24\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.129981, 12.11\n",
      "model, n, h, loss, time = cats, 256.0, 4.0, 0.1205, 11.96\n",
      "model, n, h, loss, time = cats, 256.0, 8.0, 0.11544, 11.8\n",
      "model, n, h, loss, time = cats, 256.0, 16.0, 0.114091, 12.61\n",
      "model, n, h, loss, time = cats, 256.0, 32.0, 0.126318, 10.6\n",
      "model, n, h, loss, time = cats, 256.0, 64.0, 0.169645, 10.31\n",
      "model, n, h, loss, time = cats, 512.0, 1.0, 0.161347, 11.72\n",
      "model, n, h, loss, time = cats, 512.0, 2.0, 0.135344, 12.5\n",
      "model, n, h, loss, time = cats, 512.0, 4.0, 0.123178, 13.13\n",
      "model, n, h, loss, time = cats, 512.0, 8.0, 0.113959, 12.94\n",
      "model, n, h, loss, time = cats, 512.0, 16.0, 0.111062, 12.29\n",
      "model, n, h, loss, time = cats, 512.0, 32.0, 0.112446, 11.43\n",
      "model, n, h, loss, time = cats, 512.0, 64.0, 0.125318, 12.04\n",
      "model, n, h, loss, time = cats, 512.0, 128.0, 0.168575, 10.37\n",
      "model, n, h, loss, time = cats, 1024.0, 1.0, 0.185128, 13.5\n",
      "model, n, h, loss, time = cats, 1024.0, 2.0, 0.151012, 11.42\n",
      "model, n, h, loss, time = cats, 1024.0, 4.0, 0.126424, 12.12\n",
      "model, n, h, loss, time = cats, 1024.0, 8.0, 0.120037, 13.57\n",
      "model, n, h, loss, time = cats, 1024.0, 16.0, 0.114187, 13.57\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.10946, 15.27\n",
      "model, n, h, loss, time = cats, 1024.0, 64.0, 0.111758, 13.03\n",
      "model, n, h, loss, time = cats, 1024.0, 128.0, 0.125036, 11.48\n",
      "model, n, h, loss, time = cats, 1024.0, 256.0, 0.168226, 10.89\n",
      "model, n, h, loss, time = cats, 2048.0, 1.0, 0.186948, 11.52\n",
      "model, n, h, loss, time = cats, 2048.0, 2.0, 0.169631, 13.33\n",
      "model, n, h, loss, time = cats, 2048.0, 4.0, 0.1417, 13.12\n",
      "model, n, h, loss, time = cats, 2048.0, 8.0, 0.126592, 12.97\n",
      "model, n, h, loss, time = cats, 2048.0, 16.0, 0.116661, 13.24\n",
      "model, n, h, loss, time = cats, 2048.0, 32.0, 0.11214, 16.72\n",
      "model, n, h, loss, time = cats, 2048.0, 64.0, 0.110518, 13.26\n",
      "model, n, h, loss, time = cats, 2048.0, 128.0, 0.11174, 18.01\n",
      "model, n, h, loss, time = cats, 2048.0, 256.0, 0.125732, 12.9\n",
      "model, n, h, loss, time = cats, 2048.0, 512.0, 0.168212, 11.28\n",
      "model, n, h, loss, time = cats, 4096.0, 1.0, 0.249439, 15.06\n",
      "model, n, h, loss, time = cats, 4096.0, 2.0, 0.196637, 12.44\n",
      "model, n, h, loss, time = cats, 4096.0, 4.0, 0.150748, 12.81\n",
      "model, n, h, loss, time = cats, 4096.0, 8.0, 0.131379, 13.04\n",
      "model, n, h, loss, time = cats, 4096.0, 16.0, 0.119087, 12.67\n",
      "model, n, h, loss, time = cats, 4096.0, 32.0, 0.113891, 12.3\n",
      "model, n, h, loss, time = cats, 4096.0, 64.0, 0.110113, 14.06\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.111562, 17.23\n",
      "model, n, h, loss, time = cats, 4096.0, 256.0, 0.113433, 14.48\n",
      "model, n, h, loss, time = cats, 4096.0, 512.0, 0.126571, 12.65\n",
      "model, n, h, loss, time = cats, 4096.0, 1024.0, 0.168888, 12.49\n",
      "model, n, h, loss, time = cats, 8192.0, 1.0, 0.246705, 11.75\n",
      "model, n, h, loss, time = cats, 8192.0, 2.0, 0.227589, 10.59\n",
      "model, n, h, loss, time = cats, 8192.0, 4.0, 0.17851, 10.59\n",
      "model, n, h, loss, time = cats, 8192.0, 8.0, 0.151106, 12.32\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.128263, 13.47\n",
      "model, n, h, loss, time = cats, 8192.0, 32.0, 0.120995, 13.44\n",
      "model, n, h, loss, time = cats, 8192.0, 64.0, 0.115314, 13.49\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.111626, 13.99\n",
      "model, n, h, loss, time = cats, 8192.0, 256.0, 0.111754, 13.45\n",
      "model, n, h, loss, time = cats, 8192.0, 512.0, 0.114228, 14.3\n",
      "model, n, h, loss, time = cats, 8192.0, 1024.0, 0.127063, 13.49\n",
      "model, n, h, loss, time = cats, 8192.0, 2048.0, 0.168634, 11.17\n",
      "model, n, h, loss, time = disc_tree, 2.0, 0, 0.223604, 1.22\n",
      "model, n, h, loss, time = disc_tree, 4.0, 0, 0.1542, 2.0\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.14226, 3.23\n",
      "model, n, h, loss, time = disc_tree, 16.0, 0, 0.147215, 3.59\n",
      "model, n, h, loss, time = disc_tree, 32.0, 0, 0.157947, 3.82\n",
      "model, n, h, loss, time = disc_tree, 64.0, 0, 0.16348, 4.09\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.166922, 5.46\n",
      "model, n, h, loss, time = disc_tree, 256.0, 0, 0.18112, 5.6\n",
      "model, n, h, loss, time = disc_tree, 512.0, 0, 0.212975, 7.31\n",
      "model, n, h, loss, time = disc_tree, 1024.0, 0, 0.234863, 8.69\n",
      "model, n, h, loss, time = disc_tree, 2048.0, 0, 0.237621, 12.91\n",
      "model, n, h, loss, time = disc_tree, 4096.0, 0, 0.260849, 21.1\n",
      "model, n, h, loss, time = disc_tree, 8192.0, 0, 0.255752, 38.74\n",
      "model, n, h, loss, time = disc_linear, 2.0, 0, 0.258158, 1.73\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.114013, 2.73\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.108524, 4.48\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.149116, 7.74\n",
      "model, n, h, loss, time = disc_linear, 32.0, 0, 0.193875, 11.82\n",
      "model, n, h, loss, time = disc_linear, 64.0, 0, 0.188934, 22.43\n",
      "model, n, h, loss, time = disc_linear, 128.0, 0, 0.171021, 45.26\n",
      "model, n, h, loss, time = disc_linear, 256.0, 0, 0.190798, 82.4\n",
      "model, n, h, loss, time = disc_linear, 512.0, 0, 0.14617, 180.86\n",
      "model, n, h, loss, time = disc_linear, 1024.0, 0, 0.160917, 333.78\n",
      "model, n, h, loss, time = disc_linear, 2048.0, 0, 0.180748, 654.98\n",
      "model, n, h, loss, time = disc_linear, 4096.0, 0, 0.208421, 1287.82\n",
      "model, n, h, loss, time = disc_linear, 8192.0, 0, 0.189124, 2463.04\n",
      "max_time =  5000.0\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.10946, 15.27\n",
      "C.I. = 0.10888329817985999, 0.11003941615193658\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.14226, 3.23\n",
      "C.I. = 0.14160645988354242, 0.14291608887229634\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.108524, 4.48\n",
      "C.I. = 0.1079569726138683, 0.10909367751607058\n",
      "0.000579416151937\n",
      "0.000656088872296\n",
      "0.000569677516071\n",
      "BNG_cpu_act\n",
      "model, n, h, loss, time = cats, 4.0, 1.0, 0.198576, 4.65\n",
      "model, n, h, loss, time = cats, 8.0, 1.0, 0.124724, 5.5\n",
      "model, n, h, loss, time = cats, 8.0, 2.0, 0.169552, 5.9\n",
      "model, n, h, loss, time = cats, 16.0, 1.0, 0.089076, 9.61\n",
      "model, n, h, loss, time = cats, 16.0, 2.0, 0.109923, 8.07\n",
      "model, n, h, loss, time = cats, 16.0, 4.0, 0.158783, 11.45\n",
      "model, n, h, loss, time = cats, 32.0, 1.0, 0.079961, 8.87\n",
      "model, n, h, loss, time = cats, 32.0, 2.0, 0.080495, 9.26\n",
      "model, n, h, loss, time = cats, 32.0, 4.0, 0.103426, 9.95\n",
      "model, n, h, loss, time = cats, 32.0, 8.0, 0.154324, 11.12\n",
      "model, n, h, loss, time = cats, 64.0, 1.0, 0.08113, 12.36\n",
      "model, n, h, loss, time = cats, 64.0, 2.0, 0.072381, 10.81\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.076279, 11.32\n",
      "model, n, h, loss, time = cats, 64.0, 8.0, 0.098659, 11.34\n",
      "model, n, h, loss, time = cats, 64.0, 16.0, 0.150249, 8.69\n",
      "model, n, h, loss, time = cats, 128.0, 1.0, 0.084113, 12.94\n",
      "model, n, h, loss, time = cats, 128.0, 2.0, 0.070826, 12.54\n",
      "model, n, h, loss, time = cats, 128.0, 4.0, 0.066515, 15.26\n",
      "model, n, h, loss, time = cats, 128.0, 8.0, 0.073323, 14.41\n",
      "model, n, h, loss, time = cats, 128.0, 16.0, 0.09589, 12.74\n",
      "model, n, h, loss, time = cats, 128.0, 32.0, 0.147292, 12.2\n",
      "model, n, h, loss, time = cats, 256.0, 1.0, 0.090495, 12.67\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.072715, 13.07\n",
      "model, n, h, loss, time = cats, 256.0, 4.0, 0.065047, 14.31\n",
      "model, n, h, loss, time = cats, 256.0, 8.0, 0.062671, 14.0\n",
      "model, n, h, loss, time = cats, 256.0, 16.0, 0.070496, 14.59\n",
      "model, n, h, loss, time = cats, 256.0, 32.0, 0.093193, 15.12\n",
      "model, n, h, loss, time = cats, 256.0, 64.0, 0.145428, 11.65\n",
      "model, n, h, loss, time = cats, 512.0, 1.0, 0.103431, 12.99\n",
      "model, n, h, loss, time = cats, 512.0, 2.0, 0.078482, 15.97\n",
      "model, n, h, loss, time = cats, 512.0, 4.0, 0.066975, 15.69\n",
      "model, n, h, loss, time = cats, 512.0, 8.0, 0.060653, 20.69\n",
      "model, n, h, loss, time = cats, 512.0, 16.0, 0.060436, 14.57\n",
      "model, n, h, loss, time = cats, 512.0, 32.0, 0.068727, 16.48\n",
      "model, n, h, loss, time = cats, 512.0, 64.0, 0.091374, 14.82\n",
      "model, n, h, loss, time = cats, 512.0, 128.0, 0.144102, 13.61\n",
      "model, n, h, loss, time = cats, 1024.0, 1.0, 0.131408, 13.09\n",
      "model, n, h, loss, time = cats, 1024.0, 2.0, 0.08968, 15.91\n",
      "model, n, h, loss, time = cats, 1024.0, 4.0, 0.070877, 13.83\n",
      "model, n, h, loss, time = cats, 1024.0, 8.0, 0.062911, 14.4\n",
      "model, n, h, loss, time = cats, 1024.0, 16.0, 0.058227, 14.56\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.058646, 16.22\n",
      "model, n, h, loss, time = cats, 1024.0, 64.0, 0.067012, 15.65\n",
      "model, n, h, loss, time = cats, 1024.0, 128.0, 0.090217, 16.39\n",
      "model, n, h, loss, time = cats, 1024.0, 256.0, 0.143049, 13.16\n",
      "model, n, h, loss, time = cats, 2048.0, 1.0, 0.163584, 16.18\n",
      "model, n, h, loss, time = cats, 2048.0, 2.0, 0.105099, 14.82\n",
      "model, n, h, loss, time = cats, 2048.0, 4.0, 0.077722, 14.16\n",
      "model, n, h, loss, time = cats, 2048.0, 8.0, 0.066402, 13.11\n",
      "model, n, h, loss, time = cats, 2048.0, 16.0, 0.060144, 15.74\n",
      "model, n, h, loss, time = cats, 2048.0, 32.0, 0.056747, 15.02\n",
      "model, n, h, loss, time = cats, 2048.0, 64.0, 0.057628, 14.97\n",
      "model, n, h, loss, time = cats, 2048.0, 128.0, 0.066339, 14.62\n",
      "model, n, h, loss, time = cats, 2048.0, 256.0, 0.089536, 16.23\n",
      "model, n, h, loss, time = cats, 2048.0, 512.0, 0.14236, 14.88\n",
      "model, n, h, loss, time = cats, 4096.0, 1.0, 0.182366, 14.66\n",
      "model, n, h, loss, time = cats, 4096.0, 2.0, 0.13273, 13.0\n",
      "model, n, h, loss, time = cats, 4096.0, 4.0, 0.099553, 13.83\n",
      "model, n, h, loss, time = cats, 4096.0, 8.0, 0.073588, 14.29\n",
      "model, n, h, loss, time = cats, 4096.0, 16.0, 0.063389, 14.9\n",
      "model, n, h, loss, time = cats, 4096.0, 32.0, 0.058597, 13.27\n",
      "model, n, h, loss, time = cats, 4096.0, 64.0, 0.055962, 11.26\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.056888, 12.62\n",
      "model, n, h, loss, time = cats, 4096.0, 256.0, 0.066043, 14.25\n",
      "model, n, h, loss, time = cats, 4096.0, 512.0, 0.089314, 12.73\n",
      "model, n, h, loss, time = cats, 4096.0, 1024.0, 0.142135, 11.68\n",
      "model, n, h, loss, time = cats, 8192.0, 1.0, 0.175221, 13.38\n",
      "model, n, h, loss, time = cats, 8192.0, 2.0, 0.168166, 12.87\n",
      "model, n, h, loss, time = cats, 8192.0, 4.0, 0.119018, 13.57\n",
      "model, n, h, loss, time = cats, 8192.0, 8.0, 0.085853, 13.2\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.068236, 14.2\n",
      "model, n, h, loss, time = cats, 8192.0, 32.0, 0.061411, 13.27\n",
      "model, n, h, loss, time = cats, 8192.0, 64.0, 0.057425, 12.66\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.055658, 13.32\n",
      "model, n, h, loss, time = cats, 8192.0, 256.0, 0.056918, 12.96\n",
      "model, n, h, loss, time = cats, 8192.0, 512.0, 0.066096, 12.53\n",
      "model, n, h, loss, time = cats, 8192.0, 1024.0, 0.089357, 12.72\n",
      "model, n, h, loss, time = cats, 8192.0, 2048.0, 0.142039, 10.88\n",
      "model, n, h, loss, time = disc_tree, 2.0, 0, 0.173195, 2.24\n",
      "model, n, h, loss, time = disc_tree, 4.0, 0, 0.153387, 2.72\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.088844, 3.22\n",
      "model, n, h, loss, time = disc_tree, 16.0, 0, 0.090434, 3.19\n",
      "model, n, h, loss, time = disc_tree, 32.0, 0, 0.092061, 4.8\n",
      "model, n, h, loss, time = disc_tree, 64.0, 0, 0.09993, 5.01\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.112167, 6.34\n",
      "model, n, h, loss, time = disc_tree, 256.0, 0, 0.125396, 6.42\n",
      "model, n, h, loss, time = disc_tree, 512.0, 0, 0.140644, 8.56\n",
      "model, n, h, loss, time = disc_tree, 1024.0, 0, 0.154795, 9.92\n",
      "model, n, h, loss, time = disc_tree, 2048.0, 0, 0.195238, 14.97\n",
      "model, n, h, loss, time = disc_tree, 4096.0, 0, 0.186998, 24.18\n",
      "model, n, h, loss, time = disc_tree, 8192.0, 0, 0.176405, 40.97\n",
      "model, n, h, loss, time = disc_linear, 2.0, 0, 0.121694, 2.72\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.119886, 3.72\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.057062, 5.57\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.141814, 8.51\n",
      "model, n, h, loss, time = disc_linear, 32.0, 0, 0.149214, 16.78\n",
      "model, n, h, loss, time = disc_linear, 64.0, 0, 0.154396, 29.01\n",
      "model, n, h, loss, time = disc_linear, 128.0, 0, 0.206425, 54.5\n",
      "model, n, h, loss, time = disc_linear, 256.0, 0, 0.229317, 103.21\n",
      "model, n, h, loss, time = disc_linear, 512.0, 0, 0.199751, 209.07\n",
      "model, n, h, loss, time = disc_linear, 1024.0, 0, 0.168046, 412.31\n",
      "model, n, h, loss, time = disc_linear, 2048.0, 0, 0.155285, 795.43\n",
      "model, n, h, loss, time = disc_linear, 4096.0, 0, 0.2362, 1560.03\n",
      "model, n, h, loss, time = disc_linear, 8192.0, 0, 0.413412, 2990.43\n",
      "max_time =  5000.0\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.055658, 13.32\n",
      "C.I. = 0.05524042158523795, 0.056078588792391026\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.088844, 3.22\n",
      "C.I. = 0.08833314935758924, 0.08935755229090125\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.057062, 5.57\n",
      "C.I. = 0.05665478026994569, 0.05747200647377715\n",
      "0.000420588792391\n",
      "0.000513552290901\n",
      "0.000410006473777\n",
      "ds_5\n",
      "model, n, h, loss, time = cats, 4.0, 1.0, 0.211929, 5.07\n",
      "model, n, h, loss, time = cats, 8.0, 1.0, 0.12117, 4.41\n",
      "model, n, h, loss, time = cats, 8.0, 2.0, 0.172621, 4.5\n",
      "model, n, h, loss, time = cats, 16.0, 1.0, 0.10027, 6.81\n",
      "model, n, h, loss, time = cats, 16.0, 2.0, 0.114551, 9.05\n",
      "model, n, h, loss, time = cats, 16.0, 4.0, 0.160677, 4.78\n",
      "model, n, h, loss, time = cats, 32.0, 1.0, 0.095847, 6.17\n",
      "model, n, h, loss, time = cats, 32.0, 2.0, 0.09925, 6.19\n",
      "model, n, h, loss, time = cats, 32.0, 4.0, 0.112758, 5.24\n",
      "model, n, h, loss, time = cats, 32.0, 8.0, 0.156963, 5.53\n",
      "model, n, h, loss, time = cats, 64.0, 1.0, 0.095152, 6.38\n",
      "model, n, h, loss, time = cats, 64.0, 2.0, 0.095965, 6.84\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.099292, 6.69\n",
      "model, n, h, loss, time = cats, 64.0, 8.0, 0.112114, 6.89\n",
      "model, n, h, loss, time = cats, 64.0, 16.0, 0.155549, 5.11\n",
      "model, n, h, loss, time = cats, 128.0, 1.0, 0.095629, 6.7\n",
      "model, n, h, loss, time = cats, 128.0, 2.0, 0.095937, 6.23\n",
      "model, n, h, loss, time = cats, 128.0, 4.0, 0.096955, 6.56\n",
      "model, n, h, loss, time = cats, 128.0, 8.0, 0.099571, 9.06\n",
      "model, n, h, loss, time = cats, 128.0, 16.0, 0.111799, 6.94\n",
      "model, n, h, loss, time = cats, 128.0, 32.0, 0.154482, 5.65\n",
      "model, n, h, loss, time = cats, 256.0, 1.0, 0.1003, 7.14\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.094689, 7.51\n",
      "model, n, h, loss, time = cats, 256.0, 4.0, 0.096739, 6.66\n",
      "model, n, h, loss, time = cats, 256.0, 8.0, 0.096212, 8.5\n",
      "model, n, h, loss, time = cats, 256.0, 16.0, 0.0991, 9.0\n",
      "model, n, h, loss, time = cats, 256.0, 32.0, 0.111624, 8.07\n",
      "model, n, h, loss, time = cats, 256.0, 64.0, 0.153992, 8.03\n",
      "model, n, h, loss, time = cats, 512.0, 1.0, 0.097613, 8.74\n",
      "model, n, h, loss, time = cats, 512.0, 2.0, 0.096591, 9.41\n",
      "model, n, h, loss, time = cats, 512.0, 4.0, 0.095321, 7.89\n",
      "model, n, h, loss, time = cats, 512.0, 8.0, 0.09505, 7.29\n",
      "model, n, h, loss, time = cats, 512.0, 16.0, 0.097483, 6.92\n",
      "model, n, h, loss, time = cats, 512.0, 32.0, 0.098845, 10.2\n",
      "model, n, h, loss, time = cats, 512.0, 64.0, 0.111576, 7.56\n",
      "model, n, h, loss, time = cats, 512.0, 128.0, 0.153833, 5.94\n",
      "model, n, h, loss, time = cats, 1024.0, 1.0, 0.097527, 7.24\n",
      "model, n, h, loss, time = cats, 1024.0, 2.0, 0.105245, 16.78\n",
      "model, n, h, loss, time = cats, 1024.0, 4.0, 0.094817, 7.47\n",
      "model, n, h, loss, time = cats, 1024.0, 8.0, 0.09577, 6.9\n",
      "model, n, h, loss, time = cats, 1024.0, 16.0, 0.096491, 9.23\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.0973, 9.8\n",
      "model, n, h, loss, time = cats, 1024.0, 64.0, 0.098894, 7.25\n",
      "model, n, h, loss, time = cats, 1024.0, 128.0, 0.111734, 12.62\n",
      "model, n, h, loss, time = cats, 1024.0, 256.0, 0.153817, 5.86\n",
      "model, n, h, loss, time = cats, 2048.0, 1.0, 0.107643, 8.78\n",
      "model, n, h, loss, time = cats, 2048.0, 2.0, 0.107806, 8.47\n",
      "model, n, h, loss, time = cats, 2048.0, 4.0, 0.100488, 11.43\n",
      "model, n, h, loss, time = cats, 2048.0, 8.0, 0.094942, 9.65\n",
      "model, n, h, loss, time = cats, 2048.0, 16.0, 0.098368, 7.73\n",
      "model, n, h, loss, time = cats, 2048.0, 32.0, 0.096029, 8.77\n",
      "model, n, h, loss, time = cats, 2048.0, 64.0, 0.097318, 10.82\n",
      "model, n, h, loss, time = cats, 2048.0, 128.0, 0.099079, 8.67\n",
      "model, n, h, loss, time = cats, 2048.0, 256.0, 0.111669, 11.62\n",
      "model, n, h, loss, time = cats, 2048.0, 512.0, 0.153919, 9.87\n",
      "model, n, h, loss, time = cats, 4096.0, 1.0, 0.10281, 7.83\n",
      "model, n, h, loss, time = cats, 4096.0, 2.0, 0.106885, 8.65\n",
      "model, n, h, loss, time = cats, 4096.0, 4.0, 0.099068, 8.91\n",
      "model, n, h, loss, time = cats, 4096.0, 8.0, 0.101352, 7.91\n",
      "model, n, h, loss, time = cats, 4096.0, 16.0, 0.095591, 11.25\n",
      "model, n, h, loss, time = cats, 4096.0, 32.0, 0.098273, 8.54\n",
      "model, n, h, loss, time = cats, 4096.0, 64.0, 0.096498, 9.06\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.095895, 9.64\n",
      "model, n, h, loss, time = cats, 4096.0, 256.0, 0.099131, 8.14\n",
      "model, n, h, loss, time = cats, 4096.0, 512.0, 0.111315, 8.4\n",
      "model, n, h, loss, time = cats, 4096.0, 1024.0, 0.153463, 8.04\n",
      "model, n, h, loss, time = cats, 8192.0, 1.0, 0.116917, 8.65\n",
      "model, n, h, loss, time = cats, 8192.0, 2.0, 0.103073, 8.68\n",
      "model, n, h, loss, time = cats, 8192.0, 4.0, 0.106194, 8.26\n",
      "model, n, h, loss, time = cats, 8192.0, 8.0, 0.103421, 8.62\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.107578, 12.51\n",
      "model, n, h, loss, time = cats, 8192.0, 32.0, 0.100316, 9.45\n",
      "model, n, h, loss, time = cats, 8192.0, 64.0, 0.095057, 10.07\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.095789, 10.99\n",
      "model, n, h, loss, time = cats, 8192.0, 256.0, 0.097016, 10.4\n",
      "model, n, h, loss, time = cats, 8192.0, 512.0, 0.099219, 9.4\n",
      "model, n, h, loss, time = cats, 8192.0, 1024.0, 0.111825, 11.5\n",
      "model, n, h, loss, time = cats, 8192.0, 2048.0, 0.15392, 8.17\n",
      "model, n, h, loss, time = disc_tree, 2.0, 0, 0.097429, 2.01\n",
      "model, n, h, loss, time = disc_tree, 4.0, 0, 0.096198, 2.05\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.095645, 2.15\n",
      "model, n, h, loss, time = disc_tree, 16.0, 0, 0.096678, 5.45\n",
      "model, n, h, loss, time = disc_tree, 32.0, 0, 0.096824, 2.51\n",
      "model, n, h, loss, time = disc_tree, 64.0, 0, 0.098853, 2.9\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.096837, 4.07\n",
      "model, n, h, loss, time = disc_tree, 256.0, 0, 0.099477, 4.24\n",
      "model, n, h, loss, time = disc_tree, 512.0, 0, 0.099336, 6.28\n",
      "model, n, h, loss, time = disc_tree, 1024.0, 0, 0.135662, 9.47\n",
      "model, n, h, loss, time = disc_tree, 2048.0, 0, 0.124573, 15.59\n",
      "model, n, h, loss, time = disc_tree, 4096.0, 0, 0.179867, 24.99\n",
      "model, n, h, loss, time = disc_tree, 8192.0, 0, 0.115517, 39.09\n",
      "model, n, h, loss, time = disc_linear, 2.0, 0, 0.097429, 2.02\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.093489, 2.38\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.097233, 2.94\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.097094, 5.4\n",
      "model, n, h, loss, time = disc_linear, 32.0, 0, 0.114393, 8.31\n",
      "model, n, h, loss, time = disc_linear, 64.0, 0, 0.137581, 13.99\n",
      "model, n, h, loss, time = disc_linear, 128.0, 0, 0.118183, 25.38\n",
      "model, n, h, loss, time = disc_linear, 256.0, 0, 0.10967, 48.51\n",
      "model, n, h, loss, time = disc_linear, 512.0, 0, 0.115574, 95.88\n",
      "model, n, h, loss, time = disc_linear, 1024.0, 0, 0.139535, 182.83\n",
      "model, n, h, loss, time = disc_linear, 2048.0, 0, 0.187663, 364.66\n",
      "model, n, h, loss, time = disc_linear, 4096.0, 0, 0.314053, 730.35\n",
      "model, n, h, loss, time = disc_linear, 8192.0, 0, 0.437097, 1494.48\n",
      "max_time =  5000.0\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.094689, 7.51\n",
      "C.I. = 0.0941487322086408, 0.09523208052629706\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.095645, 2.15\n",
      "C.I. = 0.09510046785518435, 0.09619235715723706\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.093489, 2.38\n",
      "C.I. = 0.09292600922691212, 0.09405509026259984\n",
      "0.000543080526297\n",
      "0.000547357157237\n",
      "0.0005660902626\n",
      "zurich\n",
      "model, n, h, loss, time = cats, 4.0, 1.0, 0.291308, 23.19\n",
      "model, n, h, loss, time = cats, 8.0, 1.0, 0.11753, 26.76\n",
      "model, n, h, loss, time = cats, 8.0, 2.0, 0.247187, 26.17\n",
      "model, n, h, loss, time = cats, 16.0, 1.0, 0.058579, 30.62\n",
      "model, n, h, loss, time = cats, 16.0, 2.0, 0.109576, 28.49\n",
      "model, n, h, loss, time = cats, 16.0, 4.0, 0.229655, 29.5\n",
      "model, n, h, loss, time = cats, 32.0, 1.0, 0.045113, 36.9\n",
      "model, n, h, loss, time = cats, 32.0, 2.0, 0.057373, 38.47\n",
      "model, n, h, loss, time = cats, 32.0, 4.0, 0.106088, 31.67\n",
      "model, n, h, loss, time = cats, 32.0, 8.0, 0.22186, 30.89\n",
      "model, n, h, loss, time = cats, 64.0, 1.0, 0.042036, 50.86\n",
      "model, n, h, loss, time = cats, 64.0, 2.0, 0.043562, 38.46\n",
      "model, n, h, loss, time = cats, 64.0, 4.0, 0.056458, 43.67\n",
      "model, n, h, loss, time = cats, 64.0, 8.0, 0.10423, 34.23\n",
      "model, n, h, loss, time = cats, 64.0, 16.0, 0.218109, 36.28\n",
      "model, n, h, loss, time = cats, 128.0, 1.0, 0.040316, 46.87\n",
      "model, n, h, loss, time = cats, 128.0, 2.0, 0.037897, 45.21\n",
      "model, n, h, loss, time = cats, 128.0, 4.0, 0.041619, 44.31\n",
      "model, n, h, loss, time = cats, 128.0, 8.0, 0.055586, 40.21\n",
      "model, n, h, loss, time = cats, 128.0, 16.0, 0.103065, 41.01\n",
      "model, n, h, loss, time = cats, 128.0, 32.0, 0.216158, 36.67\n",
      "model, n, h, loss, time = cats, 256.0, 1.0, 0.038836, 45.42\n",
      "model, n, h, loss, time = cats, 256.0, 2.0, 0.035832, 47.84\n",
      "model, n, h, loss, time = cats, 256.0, 4.0, 0.034681, 46.18\n",
      "model, n, h, loss, time = cats, 256.0, 8.0, 0.04013, 44.92\n",
      "model, n, h, loss, time = cats, 256.0, 16.0, 0.054439, 35.47\n",
      "model, n, h, loss, time = cats, 256.0, 32.0, 0.102025, 41.35\n",
      "model, n, h, loss, time = cats, 256.0, 64.0, 0.214888, 40.69\n",
      "model, n, h, loss, time = cats, 512.0, 1.0, 0.039078, 45.9\n",
      "model, n, h, loss, time = cats, 512.0, 2.0, 0.033426, 48.07\n",
      "model, n, h, loss, time = cats, 512.0, 4.0, 0.031474, 51.01\n",
      "model, n, h, loss, time = cats, 512.0, 8.0, 0.032522, 57.27\n",
      "model, n, h, loss, time = cats, 512.0, 16.0, 0.038829, 47.58\n",
      "model, n, h, loss, time = cats, 512.0, 32.0, 0.053587, 48.8\n",
      "model, n, h, loss, time = cats, 512.0, 64.0, 0.101217, 48.04\n",
      "model, n, h, loss, time = cats, 512.0, 128.0, 0.214077, 44.8\n",
      "model, n, h, loss, time = cats, 1024.0, 1.0, 0.036729, 53.96\n",
      "model, n, h, loss, time = cats, 1024.0, 2.0, 0.030717, 55.05\n",
      "model, n, h, loss, time = cats, 1024.0, 4.0, 0.028686, 56.51\n",
      "model, n, h, loss, time = cats, 1024.0, 8.0, 0.028768, 57.1\n",
      "model, n, h, loss, time = cats, 1024.0, 16.0, 0.031118, 58.91\n",
      "model, n, h, loss, time = cats, 1024.0, 32.0, 0.038128, 50.29\n",
      "model, n, h, loss, time = cats, 1024.0, 64.0, 0.053082, 51.97\n",
      "model, n, h, loss, time = cats, 1024.0, 128.0, 0.100738, 46.81\n",
      "model, n, h, loss, time = cats, 1024.0, 256.0, 0.213624, 57.47\n",
      "model, n, h, loss, time = cats, 2048.0, 1.0, 0.041179, 57.16\n",
      "model, n, h, loss, time = cats, 2048.0, 2.0, 0.031146, 55.95\n",
      "model, n, h, loss, time = cats, 2048.0, 4.0, 0.027545, 54.06\n",
      "model, n, h, loss, time = cats, 2048.0, 8.0, 0.026539, 60.06\n",
      "model, n, h, loss, time = cats, 2048.0, 16.0, 0.027441, 60.93\n",
      "model, n, h, loss, time = cats, 2048.0, 32.0, 0.030552, 58.25\n",
      "model, n, h, loss, time = cats, 2048.0, 64.0, 0.037725, 51.91\n",
      "model, n, h, loss, time = cats, 2048.0, 128.0, 0.052877, 51.41\n",
      "model, n, h, loss, time = cats, 2048.0, 256.0, 0.100497, 46.61\n",
      "model, n, h, loss, time = cats, 2048.0, 512.0, 0.21339, 41.74\n",
      "model, n, h, loss, time = cats, 4096.0, 1.0, 0.045194, 55.89\n",
      "model, n, h, loss, time = cats, 4096.0, 2.0, 0.032827, 56.73\n",
      "model, n, h, loss, time = cats, 4096.0, 4.0, 0.027915, 58.07\n",
      "model, n, h, loss, time = cats, 4096.0, 8.0, 0.02568, 58.28\n",
      "model, n, h, loss, time = cats, 4096.0, 16.0, 0.025605, 59.51\n",
      "model, n, h, loss, time = cats, 4096.0, 32.0, 0.026911, 59.64\n",
      "model, n, h, loss, time = cats, 4096.0, 64.0, 0.030271, 59.23\n",
      "model, n, h, loss, time = cats, 4096.0, 128.0, 0.037571, 59.61\n",
      "model, n, h, loss, time = cats, 4096.0, 256.0, 0.052768, 55.67\n",
      "model, n, h, loss, time = cats, 4096.0, 512.0, 0.100376, 57.33\n",
      "model, n, h, loss, time = cats, 4096.0, 1024.0, 0.213275, 55.14\n",
      "model, n, h, loss, time = cats, 8192.0, 1.0, 0.048269, 57.96\n",
      "model, n, h, loss, time = cats, 8192.0, 2.0, 0.037049, 58.72\n",
      "model, n, h, loss, time = cats, 8192.0, 4.0, 0.030853, 56.91\n",
      "model, n, h, loss, time = cats, 8192.0, 8.0, 0.025967, 55.1\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.024919, 60.07\n",
      "model, n, h, loss, time = cats, 8192.0, 32.0, 0.025127, 66.77\n",
      "model, n, h, loss, time = cats, 8192.0, 64.0, 0.026649, 61.85\n",
      "model, n, h, loss, time = cats, 8192.0, 128.0, 0.030165, 60.76\n",
      "model, n, h, loss, time = cats, 8192.0, 256.0, 0.037439, 55.92\n",
      "model, n, h, loss, time = cats, 8192.0, 512.0, 0.052679, 55.75\n",
      "model, n, h, loss, time = cats, 8192.0, 1024.0, 0.10031, 55.35\n",
      "model, n, h, loss, time = cats, 8192.0, 2048.0, 0.213228, 57.59\n",
      "model, n, h, loss, time = disc_tree, 2.0, 0, 0.458471, 7.79\n",
      "model, n, h, loss, time = disc_tree, 4.0, 0, 0.216342, 9.91\n",
      "model, n, h, loss, time = disc_tree, 8.0, 0, 0.096663, 11.39\n",
      "model, n, h, loss, time = disc_tree, 16.0, 0, 0.038298, 16.66\n",
      "model, n, h, loss, time = disc_tree, 32.0, 0, 0.043337, 18.55\n",
      "model, n, h, loss, time = disc_tree, 64.0, 0, 0.048256, 22.97\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.033597, 27.63\n",
      "model, n, h, loss, time = disc_tree, 256.0, 0, 0.041431, 31.42\n",
      "model, n, h, loss, time = disc_tree, 512.0, 0, 0.047426, 44.03\n",
      "model, n, h, loss, time = disc_tree, 1024.0, 0, 0.049744, 57.41\n",
      "model, n, h, loss, time = disc_tree, 2048.0, 0, 0.052419, 88.64\n",
      "model, n, h, loss, time = disc_tree, 4096.0, 0, 0.056695, 137.17\n",
      "model, n, h, loss, time = disc_tree, 8192.0, 0, 0.069202, 236.19\n",
      "model, n, h, loss, time = disc_linear, 2.0, 0, 0.932173, 11.51\n",
      "model, n, h, loss, time = disc_linear, 4.0, 0, 0.213452, 13.32\n",
      "model, n, h, loss, time = disc_linear, 8.0, 0, 0.091619, 18.46\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.030744, 32.56\n",
      "model, n, h, loss, time = disc_linear, 32.0, 0, 0.03622, 59.61\n",
      "model, n, h, loss, time = disc_linear, 64.0, 0, 0.034955, 114.66\n",
      "model, n, h, loss, time = disc_linear, 128.0, 0, 0.056589, 211.91\n",
      "model, n, h, loss, time = disc_linear, 256.0, 0, 0.04209, 413.61\n",
      "model, n, h, loss, time = disc_linear, 512.0, 0, 0.279946, 807.41\n",
      "model, n, h, loss, time = disc_linear, 1024.0, 0, 0.06261, 1599.48\n",
      "model, n, h, loss, time = disc_linear, 2048.0, 0, 0.085192, 3086.37\n",
      "model, n, h, loss, time = disc_linear, 4096.0, 0, 0.131863, 6184.27\n",
      "model, n, h, loss, time = disc_linear, 8192.0, 0, 0.33107, 12045.22\n",
      "max_time =  50000.0\n",
      "model, n, h, loss, time = cats, 8192.0, 16.0, 0.024919, 60.07\n",
      "C.I. = 0.024791943192186666, 0.025046700012950063\n",
      "model, n, h, loss, time = disc_tree, 128.0, 0, 0.033597, 27.63\n",
      "C.I. = 0.033449476565627, 0.03374516002286532\n",
      "model, n, h, loss, time = disc_linear, 16.0, 0, 0.030744, 32.56\n",
      "C.I. = 0.030602467996980014, 0.0308861744709229\n",
      "0.00012770001295\n",
      "0.000148160022865\n",
      "0.000142174470923\n"
     ]
    }
   ],
   "source": [
    "# online\n",
    "dir_ = \"../../results/\"\n",
    "data_names = [\n",
    "    \"BNG_wisconsin\",\n",
    "    \"black_friday\",\n",
    "    \"BNG_auto_price\",\n",
    "    \"BNG_cpu_act\",\n",
    "    \"ds_5\",\n",
    "    \"zurich\",\n",
    "]\n",
    "# data_names = [\"black_friday\"]\n",
    "\n",
    "bars_cats = [0] * len(data_names)\n",
    "bars_tree = [0] * len(data_names)\n",
    "bars_lin = [0] * len(data_names)\n",
    "y_cats = [[0] * len(data_names) for i in range(2)]\n",
    "y_tree = [[0] * len(data_names) for i in range(2)]\n",
    "y_lin = [[0] * len(data_names) for i in range(2)]\n",
    "\n",
    "for i, name in enumerate(data_names):\n",
    "    print(name)\n",
    "    data_file = dir_ + name + \"_online_validation.txt\"\n",
    "    online_results = EvaluatorOnline(data_file, 0.05, False)\n",
    "    online_results.eval()\n",
    "    bars_cats[i], y_cats[0][i], y_cats[1][i] = online_results.return_loss(\"cats\")\n",
    "    print(max(bars_cats[i] - y_cats[0][i], y_cats[1][i] - bars_cats[i]))\n",
    "    bars_tree[i], y_tree[0][i], y_tree[1][i] = online_results.return_loss(\"disc_tree\")\n",
    "    print(max(bars_tree[i] - y_tree[0][i], y_tree[1][i] - bars_tree[i]))\n",
    "    bars_lin[i], y_lin[0][i], y_lin[1][i] = online_results.return_loss(\"disc_linear\")\n",
    "    print(max(bars_lin[i] - y_lin[0][i], y_lin[1][i] - bars_lin[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# online\n",
    "# width of the bars\n",
    "barWidth = 0.2\n",
    "\n",
    "yer_cats = (\n",
    "    list(np.subtract(bars_cats, y_cats[0]).transpose()),\n",
    "    list(np.subtract(y_cats[1], bars_cats).transpose()),\n",
    ")\n",
    "yer_tree = (\n",
    "    list(np.subtract(bars_tree, y_tree[0]).transpose()),\n",
    "    list(np.subtract(y_tree[1], bars_tree).transpose()),\n",
    ")\n",
    "yer_lin = (\n",
    "    list(np.subtract(bars_lin, y_lin[0]).transpose()),\n",
    "    list(np.subtract(y_lin[1], bars_lin).transpose()),\n",
    ")\n",
    "\n",
    "# The x position of bars\n",
    "r1 = np.arange(len(bars_cats))\n",
    "r2 = [x + barWidth for x in r1]\n",
    "r3 = [x + 2 * barWidth for x in r1]\n",
    "\n",
    "# Create blue bars\n",
    "plt.bar(\n",
    "    r1,\n",
    "    bars_cats,\n",
    "    width=barWidth,\n",
    "    color=mycolors[0],\n",
    "    edgecolor=\"black\",\n",
    "    yerr=yer_cats,\n",
    "    capsize=5,\n",
    "    label=\"$\\mathtt{CATS}$\",\n",
    ")\n",
    "\n",
    "# Create cyan bars\n",
    "plt.bar(\n",
    "    r2,\n",
    "    bars_lin,\n",
    "    width=barWidth,\n",
    "    color=mycolors[1],\n",
    "    edgecolor=\"black\",\n",
    "    yerr=yer_lin,\n",
    "    capsize=5,\n",
    "    label=\"$\\mathtt{dLinear}$\",\n",
    ")\n",
    "\n",
    "# Create red bars\n",
    "plt.bar(\n",
    "    r3,\n",
    "    bars_tree,\n",
    "    width=barWidth,\n",
    "    color=mycolors[2],\n",
    "    edgecolor=\"black\",\n",
    "    yerr=yer_tree,\n",
    "    capsize=5,\n",
    "    label=\"$\\mathtt{dTree}$\",\n",
    ")\n",
    "\n",
    "# general layout\n",
    "plt.xticks(\n",
    "    [r + barWidth for r in range(len(bars_cats))],\n",
    "    [\"Wis\", \"Friday\", \"Price\", \"Cpu\", \"Ds\", \"Zurich\"],\n",
    ")\n",
    "plt.ylabel(\"Absolute Loss\")\n",
    "plt.xlabel(\"Datasets\")\n",
    "plt.legend(loc=\"upper center\", bbox_to_anchor=(0.81, 1.0))\n",
    "\n",
    "# plt.grid()\n",
    "# Show graphic\n",
    "fig = plt.gcf()\n",
    "plt.show()\n",
    "fig.savefig(dir_ + \"abs_online.png\", format=\"pdf\", dpi=100, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BNG_wisconsin\n",
      "0.2346804867838879\n",
      "0.0018086906435\n",
      "0.17291528372268655\n",
      "0.0016156357445\n",
      "black_friday\n",
      "0.2402975106878043\n",
      "0.00458302349663\n",
      "0.17830500708561633\n",
      "0.00409187987299\n",
      "BNG_auto_price\n",
      "0.2263923567637802\n",
      "0.00174944411875\n",
      "0.10870415038260625\n",
      "0.00129123141747\n",
      "BNG_cpu_act\n",
      "0.19217566998475297\n",
      "0.00163678645887\n",
      "0.05281622603481378\n",
      "0.000925296331242\n",
      "ds_5\n",
      "0.2070609617415339\n",
      "0.00168803475657\n",
      "0.08526858097278117\n",
      "0.00116720210195\n",
      "zurich\n",
      "0.2907520532601073\n",
      "0.000834665790403\n",
      "0.024476349538704794\n",
      "0.000285403200433\n"
     ]
    }
   ],
   "source": [
    "# offline\n",
    "dir_ = \"../../results/\"\n",
    "data_names = [\n",
    "    \"BNG_wisconsin\",\n",
    "    \"black_friday\",\n",
    "    \"BNG_auto_price\",\n",
    "    \"BNG_cpu_act\",\n",
    "    \"ds_5\",\n",
    "    \"zurich\",\n",
    "]\n",
    "# data_names = [\"black_friday\"]\n",
    "\n",
    "bars_init = [0] * len(data_names)\n",
    "bars_opt = [0] * len(data_names)\n",
    "y_init = [[0] * len(data_names) for i in range(2)]\n",
    "y_opt = [[0] * len(data_names) for i in range(2)]\n",
    "\n",
    "for i, name in enumerate(data_names):\n",
    "    print(name)\n",
    "    srm_file = dir_ + name + \"_offline_srm.txt\"\n",
    "    test_file = dir_ + name + \"_offline_test.txt\"\n",
    "    offline_results = EvaluatorOffline(srm_file, test_file, 0.1, 0.05, True)\n",
    "    offline_results.eval()\n",
    "    bars_init[i], y_init[0][i], y_init[1][i] = offline_results.return_loss(\"init\")\n",
    "    bars_opt[i], y_opt[0][i], y_opt[1][i] = offline_results.return_loss(\"opt\")\n",
    "    print(bars_init[i])\n",
    "    print(max(bars_init[i] - y_init[0][i], y_init[1][i] - bars_init[i]))\n",
    "    print(bars_opt[i])\n",
    "    print(max(bars_opt[i] - y_opt[0][i], y_opt[1][i] - bars_opt[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# offline\n",
    "# width of the bars\n",
    "barWidth = 0.2\n",
    "\n",
    "yer_init = (\n",
    "    list(np.subtract(bars_init, y_init[0]).transpose()),\n",
    "    list(np.subtract(y_init[1], bars_init).transpose()),\n",
    ")\n",
    "yer_opt = (\n",
    "    list(np.subtract(bars_opt, y_opt[0]).transpose()),\n",
    "    list(np.subtract(y_opt[1], bars_opt).transpose()),\n",
    ")\n",
    "\n",
    "# The x position of bars\n",
    "r1 = np.arange(len(bars_init))\n",
    "r2 = [x + 1.5 * barWidth for x in r1]\n",
    "\n",
    "# Create blue bars\n",
    "plt.bar(\n",
    "    r1,\n",
    "    bars_init,\n",
    "    width=barWidth,\n",
    "    color=mycolors[3],\n",
    "    edgecolor=\"black\",\n",
    "    yerr=yer_init,\n",
    "    capsize=5,\n",
    "    label=\"Initial model\",\n",
    ")\n",
    "\n",
    "# Create cyan bars\n",
    "plt.bar(\n",
    "    r2,\n",
    "    bars_opt,\n",
    "    width=barWidth,\n",
    "    color=mycolors[4],\n",
    "    edgecolor=\"black\",\n",
    "    yerr=yer_opt,\n",
    "    capsize=5,\n",
    "    label=\"$\\mathtt{CATS\\_Off}$ optimized model\",\n",
    ")\n",
    "\n",
    "\n",
    "# general layout\n",
    "plt.xticks(\n",
    "    [r + barWidth for r in range(len(bars_init))],\n",
    "    [\"Wis\", \"Friday\", \"Price\", \"Cpu\", \"Ds\", \"Zurich\"],\n",
    ")\n",
    "plt.ylabel(\"Absolute Loss\")\n",
    "plt.xlabel(\"Datasets\")\n",
    "plt.legend(loc=\"upper center\", bbox_to_anchor=(0.49, 1.07))\n",
    "\n",
    "# plt.grid()\n",
    "# Show graphic\n",
    "fig = plt.gcf()\n",
    "plt.show()\n",
    "fig.savefig(dir_ + \"abs_offline_srm.png\", format=\"pdf\", dpi=100, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[4.0, 8.0, 16.0, 32.0, 64.0, 128.0, 256.0, 512.0, 1024.0, 2048.0, 4096.0, 8192.0]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# time 1\n",
    "# width of the bars\n",
    "barWidth = 0.4\n",
    "\n",
    "name = \"zurich\"\n",
    "n = 0\n",
    "hp = 1\n",
    "h = 1 / 4\n",
    "data_file = dir_ + name + \"_online_validation.txt\"\n",
    "online_results = EvaluatorOnline(data_file, 0.05, True)\n",
    "online_results.eval()\n",
    "bars1, k_ = online_results.getTime(\"cats\", n, hp, h, \"h\")\n",
    "print(k_)\n",
    "\n",
    "bars1 = bars1[:9]\n",
    "# The x position of bars\n",
    "r1 = np.arange(len(bars1))\n",
    "\n",
    "# Create blue bars\n",
    "plt.bar(\n",
    "    r1 + barWidth,\n",
    "    bars1,\n",
    "    width=barWidth,\n",
    "    color=\"indigo\",\n",
    "    edgecolor=\"black\",\n",
    "    label=\"Time(s)\",\n",
    ")\n",
    "\n",
    "\n",
    "# general layout\n",
    "plt.xticks(\n",
    "    [r + barWidth for r in range(len(bars1))],\n",
    "    [\n",
    "        \"$\\dfrac{1}{2^2}$\",\n",
    "        \"$\\dfrac{1}{2^3}$\",\n",
    "        \"$\\dfrac{1}{2^4}$\",\n",
    "        \"$\\dfrac{1}{2^5}$\",\n",
    "        \"$\\dfrac{1}{2^6}$\",\n",
    "        \"$\\dfrac{1}{2^7}$\",\n",
    "        \"$\\dfrac{1}{2^8}$\",\n",
    "        \"$\\dfrac{1}{2^9}$\",\n",
    "        \"$\\dfrac{1}{2^{10}}$\",\n",
    "        \"$\\dfrac{1}{2^{11}}$\",\n",
    "        \"$\\dfrac{1}{2^{12}}$\",\n",
    "        \"$\\dfrac{1}{2^{13}}$\",\n",
    "    ],\n",
    ")\n",
    "plt.ylabel(\"Training time (s)\")\n",
    "plt.xlabel(\"Discretization scale ($\\dfrac{1}{K}$)\")\n",
    "# plt.legend(loc='upper center', bbox_to_anchor= (0.5, 1.18))\n",
    "\n",
    "# plt.grid()\n",
    "# Show graphic\n",
    "fig = plt.gcf()\n",
    "plt.show()\n",
    "fig.savefig(dir_ + \"timen.png\", format=\"pdf\", dpi=100, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# time 2\n",
    "# width of the bars\n",
    "barWidth = 0.4\n",
    "\n",
    "name = \"zurich\"\n",
    "n = 8192\n",
    "hp = 0\n",
    "h = 0\n",
    "data_file = dir_ + name + \"_online_validation.txt\"\n",
    "online_results = EvaluatorOnline(data_file, 0.05, True)\n",
    "online_results.eval()\n",
    "bars1, h_ = online_results.getTime(\"cats\", n, hp, h, \"n\")\n",
    "print(h_ / (np.ones(len(h_)) * n))\n",
    "\n",
    "# The x position of bars\n",
    "bars1 = bars1[2:11]\n",
    "r1 = np.arange(len(bars1))\n",
    "\n",
    "# Create blue bars\n",
    "plt.bar(\n",
    "    r1 + barWidth,\n",
    "    bars1,\n",
    "    width=barWidth,\n",
    "    color=\"indigo\",\n",
    "    edgecolor=\"black\",\n",
    "    label=\"Time(s)\",\n",
    ")\n",
    "\n",
    "\n",
    "# general layout\n",
    "plt.xticks(\n",
    "    [r + barWidth for r in range(len(bars1))],\n",
    "    [\n",
    "        \"$\\dfrac{1}{2^{11}}$\",\n",
    "        \"$\\dfrac{1}{2^{10}}$\",\n",
    "        \"$\\dfrac{1}{2^{9}}$\",\n",
    "        \"$\\dfrac{1}{2^{8}}$\",\n",
    "        \"$\\dfrac{1}{2^{7}}$\",\n",
    "        \"$\\dfrac{1}{2^{6}}$\",\n",
    "        \"$\\dfrac{1}{2^{5}}$\",\n",
    "        \"$\\dfrac{1}{2^{4}}$\",\n",
    "        \"$\\dfrac{1}{2^{3}}$\",\n",
    "        \"$\\dfrac{1}{2^{2}}$\",\n",
    "    ],\n",
    ")\n",
    "plt.ylabel(\"Training time (s)\")\n",
    "plt.xlabel(\"Bandwidth ($h$)\")\n",
    "# plt.legend(loc='upper center', bbox_to_anchor= (0.5, 1))\n",
    "\n",
    "# plt.grid()\n",
    "# Show graphic\n",
    "fig = plt.gcf()\n",
    "plt.show()\n",
    "fig.savefig(dir_ + \"timeh.png\", format=\"pdf\", dpi=100, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# time 3\n",
    "# width of the bars\n",
    "barWidth = 0.4\n",
    "\n",
    "name = \"zurich\"\n",
    "n = 0\n",
    "hp = 0\n",
    "h = 1 / 4\n",
    "data_file = dir_ + name + \"_online_validation.txt\"\n",
    "online_results = EvaluatorOnline(data_file, 0.05, True)\n",
    "online_results.eval()\n",
    "bars1, k_ = online_results.getTime(\"cats\", n, hp, h, \"h\")\n",
    "print(k_)\n",
    "n = 0\n",
    "hp = 0\n",
    "h = 0\n",
    "bars2, k_2 = online_results.getTime(\"disc_linear\", n, hp, h, \"hp\")\n",
    "print(k_2)\n",
    "\n",
    "\n",
    "bars1 = bars1[0:9]\n",
    "bars2 = bars2[1:10]\n",
    "k_2 = k_2[1:10]\n",
    "\n",
    "\n",
    "# The x position of bars\n",
    "r1 = np.arange(len(bars1))\n",
    "r2 = [x + barWidth for x in r1]\n",
    "\n",
    "# Create blue bars\n",
    "plt.bar(r1, bars1, width=barWidth, color=\"indigo\", edgecolor=\"black\", label=\"CATS\")\n",
    "\n",
    "# Create cyan bars\n",
    "plt.bar(\n",
    "    r2,\n",
    "    bars2,\n",
    "    width=barWidth,\n",
    "    color=\"chocolate\",\n",
    "    edgecolor=\"black\",\n",
    "    label=\"Discretized Linear\",\n",
    ")\n",
    "\n",
    "\n",
    "# general layout\n",
    "plt.xticks(\n",
    "    [r + barWidth for r in range(len(bars1))],\n",
    "    [\n",
    "        \"$\\dfrac{1}{2^2}$\",\n",
    "        \"$\\dfrac{1}{2^3}$\",\n",
    "        \"$\\dfrac{1}{2^4}$\",\n",
    "        \"$\\dfrac{1}{2^5}$\",\n",
    "        \"$\\dfrac{1}{2^6}$\",\n",
    "        \"$\\dfrac{1}{2^7}$\",\n",
    "        \"$\\dfrac{1}{2^8}$\",\n",
    "        \"$\\dfrac{1}{2^9}$\",\n",
    "        \"$\\dfrac{1}{2^{10}}$\",\n",
    "        \"$\\dfrac{1}{2^{11}}$\",\n",
    "        \"$\\dfrac{1}{2^{12}}$\",\n",
    "        \"$\\dfrac{1}{2^{13}}$\",\n",
    "    ],\n",
    ")\n",
    "plt.ylabel(\"Training time (s)\")\n",
    "plt.xlabel(\"Discretization scale ($\\dfrac{1}{K}$)\")\n",
    "plt.legend(loc=\"upper center\", bbox_to_anchor=(0.5, 1.28))\n",
    "\n",
    "# plt.grid()\n",
    "# Show graphic\n",
    "fig = plt.gcf()\n",
    "plt.show()\n",
    "fig.savefig(dir_ + \"timenn.png\", format=\"pdf\", dpi=100, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
