{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "431427e8",
   "metadata": {},
   "source": [
    "# Plot: Statistical vs Deep Learning Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "91b4f5cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import defaultdict\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import scipy.stats as st\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from tsbench.config import DATASET_REGISTRY\n",
    "from tsbench.experiments.tracking import Tracker\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as mtick\n",
    "%matplotlib inline\n",
    "\n",
    "plt.style.use('seaborn-notebook')\n",
    "plt.rcParams['figure.dpi'] = 150\n",
    "plt.rcParams['font.family'] = 'Times New Roman'\n",
    "plt.rcParams['text.usetex'] = False"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "60d8e73e",
   "metadata": {},
   "source": [
    "## Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "59e5b2c4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "166618eb004d41c8aca78887ed923dfa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/4708 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "acd027b69bd341ce856e071ab8a414a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/2420 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "tracker_ungrouped = Tracker.for_experiment(\"ts-bench\", group_seeds=False)\n",
    "tracker_grouped = Tracker.for_experiment(\"ts-bench\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7c1a3a7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = tracker_ungrouped.get_results()\n",
    "grouped_data = tracker_grouped.get_results()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0f27809c",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasets = {c.dataset for c in data.configurations}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0de0aeb9",
   "metadata": {},
   "source": [
    "## Get Dataset Performances"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7f6d2e82",
   "metadata": {},
   "outputs": [],
   "source": [
    "statistical_models = {\n",
    "    \"arima\",\n",
    "    \"ets\",\n",
    "    \"seasonal_naive\",\n",
    "    \"theta\",\n",
    "    \"npts\",\n",
    "    \"prophet\",\n",
    "    \"stlar\"\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7170ffde",
   "metadata": {},
   "outputs": [],
   "source": [
    "statistical_results = defaultdict(list)\n",
    "deep_results = defaultdict(list)\n",
    "\n",
    "for config, performance in zip(data.configurations, data.performances):\n",
    "    if config.model.name() in statistical_models:\n",
    "        statistical_results[config.dataset.name].append(performance.mean_weighted_quantile_loss.mean)\n",
    "    elif config.model.training_fraction == 1:\n",
    "        deep_results[config.dataset.name].append(performance.mean_weighted_quantile_loss.mean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4316dffe",
   "metadata": {},
   "outputs": [],
   "source": [
    "statistical_results_grouped = defaultdict(list)\n",
    "deep_results_grouped = defaultdict(list)\n",
    "\n",
    "for config, performance in zip(data.configurations, data.performances):\n",
    "    if config.model.name() in statistical_models:\n",
    "        statistical_results_grouped[config.dataset.name].append(performance.mean_weighted_quantile_loss.mean)\n",
    "    elif config.model.training_fraction == 1:\n",
    "        deep_results_grouped[config.dataset.name].append(performance.mean_weighted_quantile_loss.mean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "c8f95c34",
   "metadata": {},
   "outputs": [],
   "source": [
    "statistical_results_latency_grouped = defaultdict(list)\n",
    "deep_results_latency_grouped = defaultdict(list)\n",
    "\n",
    "for config, performance in zip(data.configurations, data.performances):\n",
    "    if config.model.name() in statistical_models:\n",
    "        if config.model.name() != \"seasonal_naive\":\n",
    "            statistical_results_latency_grouped[config.dataset.name].append(performance.latency.mean)\n",
    "    elif config.model.training_fraction == 1:\n",
    "        deep_results_latency_grouped[config.dataset.name].append(performance.latency.mean)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4aa8ff07",
   "metadata": {},
   "source": [
    "## Evaluation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6f48614b",
   "metadata": {},
   "source": [
    "### p-Values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "ef3e987f",
   "metadata": {},
   "outputs": [],
   "source": [
    "pvalues = {}\n",
    "for dataset in datasets:\n",
    "    result = st.ks_2samp(statistical_results[dataset.name], deep_results[dataset.name], alternative=\"less\").pvalue\n",
    "    pvalues[dataset.name] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "b11f6012",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "30"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len({k: v for k, v in pvalues.items() if v < 0.05})"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9cad1203",
   "metadata": {},
   "source": [
    "### Percentage Improvement"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "3289a22b",
   "metadata": {},
   "outputs": [],
   "source": [
    "improvements = {}\n",
    "for dataset in datasets:\n",
    "    result = min(deep_results_grouped[dataset.name]) / min(statistical_results_grouped[dataset.name])\n",
    "    improvements[dataset.name] = result"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3f212bb5",
   "metadata": {},
   "source": [
    "### Improvement in Latency"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "19fb63d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "latency_improvements = {}\n",
    "for dataset in datasets:\n",
    "    result = (\n",
    "        np.median(deep_results_latency_grouped[dataset.name]) / \n",
    "        min(statistical_results_latency_grouped[dataset.name])\n",
    "    )\n",
    "    latency_improvements[dataset.name] = result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "cf781151",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.051119040803858366"
      ]
     },
     "execution_count": 99,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "min(latency_improvements.values())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "fbc04b30",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.49788626603346653"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max(latency_improvements.values())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c956d35a",
   "metadata": {},
   "source": [
    "## Plot with Dataset Size"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f14a9d94",
   "metadata": {},
   "source": [
    "### Get Dataset Stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "8cb84f42",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_observations = {\n",
    "    dataset.name: dataset.stats()[\"num_time_observations\"]\n",
    "    for dataset in datasets\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ef45db08",
   "metadata": {},
   "source": [
    "### Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "13000ea3",
   "metadata": {},
   "outputs": [],
   "source": [
    "mapping = {\n",
    "    obs: pvalues[dataset] for dataset, obs in num_observations.items()\n",
    "}\n",
    "x = np.array(list(mapping.keys()))\n",
    "y = np.array(list(mapping.values()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "876d4b42",
   "metadata": {},
   "outputs": [],
   "source": [
    "ordering = np.argsort(x)\n",
    "x = x[ordering]\n",
    "y = y[ordering]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "614d11fe",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 900x450 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 3))\n",
    "plt.scatter(x, y, marker='x', s=25, linewidth=1.5, color='forestgreen')\n",
    "plt.hlines(0.05, 0, x.max() * 2, linewidth=1, color='firebrick')\n",
    "plt.xscale(\"log\")\n",
    "plt.xlim((x.min() / 1.5, x.max() * 1.5))\n",
    "plt.xlabel(\"Number of Observations\", fontsize=15)\n",
    "plt.ylabel(\"p-Value\", fontsize=15)\n",
    "for tick in plt.gca().xaxis.get_major_ticks():\n",
    "    tick.label.set_fontsize(13)\n",
    "for tick in plt.gca().yaxis.get_major_ticks():\n",
    "    tick.label.set_fontsize(13)\n",
    "plt.tight_layout()\n",
    "plt.savefig(Path.home() / \"figures\" / \"pvalues.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d82c7746",
   "metadata": {},
   "source": [
    "### Percentage Improvement"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "6a69c476",
   "metadata": {},
   "outputs": [],
   "source": [
    "mapping = {\n",
    "    obs: improvements[dataset] for dataset, obs in num_observations.items()\n",
    "}\n",
    "x = np.array(list(mapping.keys()))\n",
    "y = np.array(list(mapping.values()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "e85746aa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'kdd_2018', 'm3_yearly', 'm4_quarterly', 'taxi'}"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{dataset for dataset, greater in zip(num_observations, y > 1) if greater}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "b1358246",
   "metadata": {},
   "outputs": [],
   "source": [
    "ordering = np.argsort(x)\n",
    "x = x[ordering]\n",
    "y = y[ordering]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "6a9ab7ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = np.log(x)[:, None]\n",
    "m = LinearRegression().fit(X, y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "4aed8c3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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c1YANwFfcPeXsxT7HdAO7BtZl5q/7q5evEQREQm1tDpzF6yL3TZ3wbqs0x2IiIgUEwV1EWEL3c3ABOAZYE1kWU0wfu4W4FV3XxXZ9RLgT8D3zOydZlZuZp8Avgb81N1/0MNTzwGed/esrXlh5s2rgMPM7FgzGwvMDut1RW9fq4jIUJeZ5TJTZlZMERGRYqWgLmRmUwiSlOTyniyMPnD3ZuAEgq6YtxIEgWcAJ7r7Z3p43ncStAp+Nofn/QJBK+J84FmCwPPQjABTRER6EBfQTZ5UxZ3zdojNiqnATkREipnFD98SCZjZ8gkTJkxYvnx5oasiItJvrl1Uz6J7GtOPo0lR4gK+6VOqOWt6XSGqKiIiQ8DEiRNZsWLFCnef2Jf91VInIiJDzoypNYwfVwl0zXKZmRVz/LhKZkytKVhdRUREelJR6AqIiIgMtLrqcuadP5aFSxqYNa22S5bLVGA3f/F6Zkytoa66vEA1FRER6ZmCOhERGZLqqsu77VJZWWHqcikiIiVB3S9FRERERERKmII6ERERERGREqagTkREREREpIQpqBMRERERESlhCupERERERERKmII6ERERERGREqagTkREREREpIQpqBMRERERESlhCupERERERERKmII6ERERERGREqagTkREREREpIQpqBMRERERESlhCupERERERERKmII6ERERERGREqagTkREREREpIQpqBMRERERESlhCupERERERERKmII6ERERERGREqagTkREREREpIQpqBMRERERESlhCupERERERERKWCJBnZnV5FhumJm9M4k6iIiIiIiIDAVJtdTVm1kux24BTjSz+TmWFxERERERkYiKhI5ruRRydzezOcAq4CXgGwnVR0REREREZFBKqnXMwyUXOwE1wKyE6iIiJaq+sY1rF9XT0hr/ddLS6ly7qJ76xrYBrpmIiIhI8ci7pc7M3gdcSNfWuXvMrKfArhqYCIwAqvKti4gMHvWNbcy+ejUrV7Xw6tpWLj59NJUVHV8zLa3OpdetZemyTTz0RBPzzh9LXXV5AWssIiIiUhh5B3Xu/kczewH4JnAiQQudAUf08lDz862LiAweC5c0sHJVCwBLl23i0uvWpgO7aEAHsHJVCwuXNHDW9LpCVllERESkIPplTJ27PwFMN7PTgJ8QdOu8n567YLYCbwB/Bq7vj7qIyOAw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DQQtiRbZf2lk++sE0wccHW4bBkwm+PEiVebzQE1GHSoIxk86QXfir4afQw3wEYK/31uALTL2qw0/x9Sxnw/f52GRv4vDwnqnviOmAVXh9vPp+Bu/giCIrwHeC7xK8De6Q6G+Q7Vo0dJ1KXgFtGjRomWoLeHFbrYL2NdyPEYNwQTQO2fZ/kmCFrsmgjEwX41c0N0bXnB+EhgRrpvZTZ2+FV4EZtvu4UXkt7rZ/vGM+h0D3EAwkXkzQTBwP8EYpxE5vP4jCAKU1QQByHPA1cA2GeXu6KZOsYFJju//zsD3CebT20jQ+vVAeDG8VZZ9HuimLg5cl+d5dTRBkLwsrM9mgnFzD4WfTZdAs5tjjQe+QRDUNITn0dMESUN27Wa/9TGv602C4HdKN/tVE3QN/Q9BwPVmeJ6emFHund28fxt68fp+Bnw5h3LbEEzwvTZ8bbcBe4XbJhAEo68TzKFXlrHv2wjGxW0MP4NjItvu6uZ1bBtTjxOA34WfZ3P4vL8BpmY5N7Md+4GwTFOW7S+H28+P2dYK/I9g2oqant47LVq0DOxi7o6IiIiIiIiUJo2pExERERERKWEK6kREREREREqYgjoREREREZESpqBORERERESkhCmoExERERERKWEK6kREREREREqYgjoREREREZESpqBORERERESkhCmoExERERERKWEK6kREREREREqYgjoREREREZESpqBORERERESkhCmoExERERERKWEK6kREREREREqYgjoREREREZESpqBORERERESkhCmoExERERERKWEK6kREREREREqYgjoREREREZES9v8AxL1CgZ4XMAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 900x450 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 3)) # [8, 2]\n",
    "\n",
    "# Line at 0\n",
    "plt.hlines(0, 0, x.max() * 2, linewidth=0.5, color='black', linestyles='solid')\n",
    "plt.xlim((x.min() / 1.5, x.max() * 1.5))\n",
    "\n",
    "# Add linear regression line\n",
    "x_vals = np.array(plt.gca().get_xlim())\n",
    "y_vals = (m.intercept_ + m.coef_[0] * np.log(x_vals) - 1) * 100\n",
    "plt.plot(x_vals, y_vals, linestyle='dashed', linewidth=1, color='firebrick')\n",
    "\n",
    "plt.scatter(x, (y - 1) * 100, marker='x', s=25, linewidth=1.5, color='royalblue', zorder=1)\n",
    "plt.xscale(\"log\")\n",
    "plt.xlabel(\"Number of Observations\", fontsize=15)\n",
    "plt.ylabel(\"Rel. Improvement\", fontsize=15)\n",
    "plt.gca().yaxis.set_major_formatter(mtick.PercentFormatter())\n",
    "\n",
    "for tick in plt.gca().xaxis.get_major_ticks():\n",
    "    tick.label.set_fontsize(13)\n",
    "for tick in plt.gca().yaxis.get_major_ticks():\n",
    "    tick.label.set_fontsize(13)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(Path.home() / \"figures\" / \"relative-improvement.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b9c9a63",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
