{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "from typing import List\n",
    "import scipy.stats as stats\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_data(path: str) -> pd.DataFrame:\n",
    "    return pd.read_json(path)\n",
    "\n",
    "def metric(data: pd.DataFrame) -> np.ndarray:\n",
    "    data = data[data['step'] > 0]\n",
    "    data['miscoverage'] = 1\n",
    "    lower_ids = data['y_real'] < data['pi_low']\n",
    "    data.loc[lower_ids, 'miscoverage'] = (data['pi_low'] - data['y_real']).iloc[lower_ids]\n",
    "\n",
    "    upper_ids = data['y_real'] > data['pi_high']\n",
    "    data.loc[upper_ids, 'miscoverage'] = (data['y_real'] - data['pi_high']).iloc[upper_ids]\n",
    "\n",
    "    results = (data['miscoverage'] * (data['pi_high'] - data['pi_low'])).values\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def agg_metric_values(data_paths: List[List[str]]) -> List[np.ndarray]:\n",
    "    metrics = []\n",
    "    for paths in data_paths:\n",
    "        cur_metrics = []\n",
    "        for path in paths:\n",
    "            data = load_data(path)\n",
    "            cur_metric = metric(data)\n",
    "            cur_metrics.append(cur_metric)\n",
    "        metrics.append(np.concatenate(cur_metrics))\n",
    "    return metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_statistics(data: List[np.ndarray]) -> list:\n",
    "    return [\n",
    "        stats.wilcoxon(data[0, :], data[i, :]).pvalue for i in range(1, data.shape[1])\n",
    "    ]\n",
    "\n",
    "\n",
    "def format_statistics(data: np.ndarray) -> list:\n",
    "    return [round(datum, 2) for datum in data]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ALPHA_0_05_PATHS = [\n",
    "    [\"path1\", \"path2\", \"path3\"] # DIST_MATCH_PATHS,\n",
    "    [\"path1\", \"path2\", \"path3\"] # HOP_CPT_PATHS,\n",
    "]\n",
    "ALPHA_0_10_PATHS = [\n",
    "    [\"path1\", \"path2\", \"path3\"] # DIST_MATCH_PATHS,\n",
    "    [\"path1\", \"path2\", \"path3\"] # HOP_CPT_PATHS,\n",
    "]\n",
    "ALPHA_0_15_PATHS = [\n",
    "    [\"path1\", \"path2\", \"path3\"] # DIST_MATCH_PATHS,\n",
    "    [\"path1\", \"path2\", \"path3\"] # HOP_CPT_PATHS,\n",
    "]\n",
    "\n",
    "alpha_0_05 = agg_metric_values(ALPHA_0_05_PATHS)\n",
    "alpha_0_10 = agg_metric_values(ALPHA_0_10_PATHS)\n",
    "alpha_0_15 = agg_metric_values(ALPHA_0_15_PATHS)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Alpha = 0.05:  [0.81, 0.81, 0.02, 0.3, 0.16, 0.22]\n",
      "Alpha = 0.10:  [0.47, 0.38, 0.05, 0.31, 0.05, 0.08]\n",
      "Alpha = 0.15:  [0.72, 0.38, 0.02, 0.3, 0.03, 0.03]\n"
     ]
    }
   ],
   "source": [
    "print(\"Alpha = 0.05: \",format_statistics(compute_statistics(alpha_0_05)))\n",
    "print(\"Alpha = 0.10: \",format_statistics(compute_statistics(alpha_0_10)))\n",
    "print(\"Alpha = 0.15: \",format_statistics(compute_statistics(alpha_0_15)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "METHODS = ['HopCPT', 'SPCI', 'EnbPI', 'NexCP', 'CP', 'Copula']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_statistics(data_map: np.ndarray, categories: list):\n",
    "    n_data = len(data_map)\n",
    "    fig, axes = plt.subplots(ncols=n_data, figsize=(3 * n_data, 2))\n",
    "    for idx, (title, data) in enumerate(data_map.items()):\n",
    "        axes[idx].bar(categories, data)\n",
    "        axes[idx].axhline(y=0.05, linewidth=2, color=\"red\", ls=\"--\")\n",
    "        axes[idx].set_title(title)\n",
    "        if idx != 0:\n",
    "            axes[idx].set_yticklabels([])\n",
    "        else:\n",
    "            axes[idx].set_ylabel('P-value')\n",
    "    fig.tight_layout()\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA4AAAAC+CAYAAABkrGEXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA2OklEQVR4nO3deVxUVf8H8M+wzbArgiyCiHu4pOECmFq54JaS5h6K4ZY+qdnySJupmUulqLmWgeYSmftaaO5QLoF7ao8apMPjo5iACgic3x/+GL3MwFyGwRmYz/v1uq+6Z86553vnDl/n3HvnXIUQQoCIiIiIiIiqPCtTB0BERERERERPBweAREREREREFoIDQCIiIiIiIgvBASAREREREZGF4ACQiIiIiIjIQnAASEREREREZCE4ACQiIiIiIrIQHAASERERERFZCA4AiYiIiIiILAQHgPRULFy4EAqFAk2bNtX5ukKhwCeffGLQtl944YUSt2sK33//PVq0aAGVSgUfHx9MmjQJ2dnZstsvWrQIjRs3hlKpREBAAKZNm4aHDx9K6sTFxUGhUOhc0tPTjb1LRGaLuUVebomJiUHfvn0REBAAhUKBF154ocS6N2/eRGRkJNzd3eHg4ICQkBDs27fPSHtBVHkwvxg3v/C7i/ngAJCeim+//RYAcO7cOfz2228mjqbirF27FoMHD0br1q2xe/duTJ06FXFxcejbt6+s9jNnzsTEiRPRt29f/PTTTxg3bhw+++wzjB8/Xmf92NhYJCUlSZYaNWoYc5eIzBpzi7zcsmzZMvz111946aWX4OHhUWK93NxcdOrUCfv27cOCBQuwdetWeHp6olu3bjh48KCxdoeoUmB+MW5+KcLvLmZAEFWw48ePCwCiZ8+eAoAYNWqUVh0AYurUqQZtv2PHjqJJkybljLL88vPzhbe3t+jataukfO3atQKA2LVrV6ntb926JVQqlRg9erSkfObMmUKhUIhz585pymJjYwUAcfz4cePtAFElw9wiL7cIIURBQYHm/5s0aSI6duyos97ixYsFAJGYmKgpe/jwoQgMDBRt2rQxbAeIKiHmF+PnF353MR+8AkgVbuXKlQCA2bNnIzQ0FN9//z3u379fapui2wQSEhIwYsQIuLm5wdHRES+//DKuXLmis83x48fRvn17ODg4oG7dupg9ezYKCws1r+fk5ODt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6e1HCIGUlBR4e3uXWEepVMLFxUWyEBERERERVTUm+w0gAEyePBkRERFo1aoVQkJCsGLFCqSmpmLs2LEAHl2Zu379OlavXi1pt3LlSrRt2xZNmzbV2ua0adMQHByMBg0aIDMzEwsXLkRKSgoWL178VPaJiIiIiIjIXJl0ADhw4EDcvn0b06dPh1qtRtOmTbFr1y7NrJ5qtVrrmYB3797Fxo0bsWDBAp3b/OeffzB69Gikp6fD1dUVLVu2xKFDh9CmTZsK3x8iIiIiIiJzZtIBIACMGzcO48aN0/laXFycVpmrqyvu379f4vbmz5+P+fPnGys8IiIiIiKiKsPks4ASERERERHR02HyK4BERFUZnzNKRERE5oRXAImIKhCfM0pERETmhANAIqIKxOeMElFFyM3NRWZmpmQhIpKDA0AiogrE54wSUUXg3QVEZCgOAImIiIgqGd5dQESG4iQwRERERJWMUqmEUqk0dRhEVAnxCiAREREREZGF4BVAIiIqlzpTdpq0/2uze5q0fyIiosqEVwCJiIiIiIgsBAeAREREREREFoIDQCIiIiIiIgvBASAREREREZGF4ACQiIiIiIjIQnAASEREREREZCE4ACQiIiIiIrIQHAASERERERFZCA4AiYiIiIiILAQHgERERERERBai3APAnJwcY8RBREREREREFcygAWBhYSFmzJiBWrVqwcnJCVeuXAEAfPTRR1i5cqVRAyQiIiIiIiLjMGgA+OmnnyIuLg5z586FnZ2dprxZs2b45ptvjBYcERERERERGY9BA8DVq1djxYoVGDp0KKytrTXlzZs3xx9//GG04IiIiIiIiMh4DBoAXr9+HfXr19cqLywsxMOHD8sdFBERERERERmfjSGNmjRpgsOHD8Pf319SvmHDBrRs2dIogREREVmKOlN2mrT/a7N7mrR/IiJ6egwaAE6dOhURERG4fv06CgsLsWnTJly8eBGrV6/Gjh07jB0jERERERERGYFBt4C+/PLLiI+Px65du6BQKPDxxx/jwoUL2L59O7p06VKmbS1ZsgQBAQFQqVQICgrC4cOHS6x74MABKBQKraX47w43btyIwMBAKJVKBAYGYvPmzYbsJhERERERUZVi0BVAAAgLC0NYWFi5Oo+Pj8ekSZOwZMkStGvXDsuXL0f37t1x/vx51K5du8R2Fy9ehIuLi2bdw8ND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",
      "text/plain": [
       "<Figure size 900x200 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plot_statistics(\n",
    "    {\n",
    "        \"Alpha=0.05\": compute_statistics(alpha_0_05),\n",
    "        \"Alpha=0.10\": compute_statistics(alpha_0_10),\n",
    "        \"Alpha=0.15\": compute_statistics(alpha_0_15),\n",
    "    },\n",
    "    METHODS,\n",
    ")\n",
    "fig.savefig('wilcoxon_test.pdf')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch_env",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
