{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c6f388b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:48:56.879832Z",
     "start_time": "2025-09-24T22:48:56.878056Z"
    }
   },
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cdb1a303",
   "metadata": {},
   "source": [
    "# Load & Prepare Data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b4d5f58b",
   "metadata": {},
   "source": [
    "## LSCI Coverages & Bandwith"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "24c62ae61603ab0b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:48:58.684622Z",
     "start_time": "2025-09-24T22:48:58.681751Z"
    }
   },
   "outputs": [],
   "source": [
    "data_path = Path(\"xxx\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd0222b6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:48:59.393228Z",
     "start_time": "2025-09-24T22:48:59.251760Z"
    }
   },
   "outputs": [],
   "source": [
    "# Load Raw Coverages and Sample Residuals\n",
    "results_lsci_antidiff = np.load(data_path / 'fd_antidiff_large' / 'lsci_coverages.npz', allow_pickle=True)\n",
    "results_lsci_bwheat = np.load(data_path / 'fd_bwheat_large' / 'lsci_coverages.npz', allow_pickle=True)\n",
    "results_lsci_reaction = np.load(data_path / 'fd_reaction_large' / 'lsci_coverages.npz', allow_pickle=True)\n",
    "\n",
    "# Compute Mean Coverages\n",
    "coverages_lsci_antidiff = [np.mean(np.array(timestep)) for timestep in results_lsci_antidiff['coverages']]\n",
    "coverages_lsci_bwheat = [np.mean(np.array(timestep)) for timestep in results_lsci_bwheat['coverages']]\n",
    "coverages_lsci_reaction = [np.mean(np.array(timestep)) for timestep in results_lsci_reaction['coverages']]\n",
    "\n",
    "# Compute Confidence Ensembles\n",
    "# Minumum and Maximum over the sample-residual axis (axis=2)\n",
    "lo_antidiff, hi_antidiff = np.min(results_lsci_antidiff['conf_ens'], axis=2), np.max(results_lsci_antidiff['conf_ens'],\n",
    "                                                                                     axis=2)\n",
    "mean_bandwidths_antidiff = (hi_antidiff - lo_antidiff).mean(axis=-1)\n",
    "bandwidths_lsci_antidiff = mean_bandwidths_antidiff.mean(axis=1)\n",
    "\n",
    "lo_bwheat, hi_bwheat = np.min(results_lsci_bwheat['conf_ens'], axis=2), np.max(results_lsci_bwheat['conf_ens'], axis=2)\n",
    "mean_bandwidths_bwheat = (hi_bwheat - lo_bwheat).mean(axis=-1)\n",
    "bandwidths_lsci_bwheat = mean_bandwidths_bwheat.mean(axis=1)\n",
    "\n",
    "lo_reaction, hi_reaction = np.min(results_lsci_reaction['conf_ens'], axis=2), np.max(results_lsci_reaction['conf_ens'],\n",
    "                                                                                     axis=2)\n",
    "mean_bandwidths_reaction = (hi_reaction - lo_reaction).mean(axis=-1)\n",
    "bandwidths_lsci_reaction = mean_bandwidths_reaction.mean(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81ed2741",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:00.012718Z",
     "start_time": "2025-09-24T22:49:00.007893Z"
    }
   },
   "outputs": [],
   "source": [
    "coverages_lsci_antidiff[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "63a1a45f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:00.594154Z",
     "start_time": "2025-09-24T22:49:00.591097Z"
    }
   },
   "outputs": [],
   "source": [
    "bandwidths_lsci_antidiff[:5]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8ac3ac5f",
   "metadata": {},
   "source": [
    "## Weighted CP Coverage, Bandwidths & Infinity Values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "604c5c11",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:01.552506Z",
     "start_time": "2025-09-24T22:49:01.548630Z"
    }
   },
   "outputs": [],
   "source": [
    "weighted_cp_antidiff = np.load(data_path / 'fd_antidiff_large' / 'fd_antidiff_large_weighted_results.npz',\n",
    "                               allow_pickle=True)\n",
    "weighted_cp_bwheat = np.load(data_path / 'fd_bwheat_large' / 'fd_bwheat_large_weighted_results.npz', allow_pickle=True)\n",
    "weighted_cp_reaction = np.load(data_path / 'fd_reaction_large' / 'fd_reaction_large_weighted_results.npz',\n",
    "                               allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f65e4d1e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:02.051259Z",
     "start_time": "2025-09-24T22:49:02.048682Z"
    }
   },
   "outputs": [],
   "source": [
    "weighted_antidiff_coverages = weighted_cp_antidiff['coverages']\n",
    "weighted_antidiff_bandwidths = weighted_cp_antidiff['mean_bandwidths']\n",
    "weighted_antidiff_num_infinite = weighted_cp_antidiff['num_infinite']\n",
    "\n",
    "weighted_bwheat_coverages = weighted_cp_bwheat['coverages']\n",
    "weighted_bwheat_bandwidths = weighted_cp_bwheat['mean_bandwidths']\n",
    "weighted_bwheat_num_infinite = weighted_cp_bwheat['num_infinite']\n",
    "\n",
    "weighted_reaction_coverages = weighted_cp_reaction['coverages']\n",
    "weighted_reaction_bandwidths = weighted_cp_reaction['mean_bandwidths']\n",
    "weighted_reaction_num_infinite = weighted_cp_reaction['num_infinite']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "87136947",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:02.827919Z",
     "start_time": "2025-09-24T22:49:02.826043Z"
    }
   },
   "outputs": [],
   "source": [
    "weighted_antidiff_coverages[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02de410f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:03.201300Z",
     "start_time": "2025-09-24T22:49:03.198074Z"
    }
   },
   "outputs": [],
   "source": [
    "weighted_antidiff_bandwidths[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "529ea766",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:03.542929Z",
     "start_time": "2025-09-24T22:49:03.539078Z"
    }
   },
   "outputs": [],
   "source": [
    "weighted_antidiff_num_infinite[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "16b127b5",
   "metadata": {},
   "source": [
    "## Unweighted CP Coverage, Bandwidths & Infinity Values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7bc3e876",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:04.947698Z",
     "start_time": "2025-09-24T22:49:04.944252Z"
    }
   },
   "outputs": [],
   "source": [
    "unweighted_cp_antidiff = np.load(data_path / 'fd_antidiff_large' / 'fd_antidiff_large_unweighted_results.npz',\n",
    "                                 allow_pickle=True)\n",
    "unweighted_cp_bwheat = np.load(data_path / 'fd_bwheat_large' / 'fd_bwheat_large_unweighted_results.npz',\n",
    "                               allow_pickle=True)\n",
    "unweighted_cp_reaction = np.load(data_path / 'fd_reaction_large' / 'fd_reaction_large_unweighted_results.npz',\n",
    "                                 allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3038875",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:05.584904Z",
     "start_time": "2025-09-24T22:49:05.580683Z"
    }
   },
   "outputs": [],
   "source": [
    "unweighted_antidiff_coverages = unweighted_cp_antidiff['coverages']\n",
    "unweighted_antidiff_bandwidths = unweighted_cp_antidiff['mean_bandwidths']\n",
    "unweighted_antidiff_num_infinite = unweighted_cp_antidiff['num_infinite']\n",
    "\n",
    "unweighted_bwheat_coverages = unweighted_cp_bwheat['coverages']\n",
    "unweighted_bwheat_bandwidths = unweighted_cp_bwheat['mean_bandwidths']\n",
    "unweighted_bwheat_num_infinite = unweighted_cp_bwheat['num_infinite']\n",
    "\n",
    "unweighted_reaction_coverages = unweighted_cp_reaction['coverages']\n",
    "unweighted_reaction_bandwidths = unweighted_cp_reaction['mean_bandwidths']\n",
    "unweighted_reaction_num_infinite = unweighted_cp_reaction['num_infinite']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d59e228",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:06.300Z",
     "start_time": "2025-09-24T22:49:06.297359Z"
    }
   },
   "outputs": [],
   "source": [
    "unweighted_antidiff_coverages[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f2ca4b0",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:06.807728Z",
     "start_time": "2025-09-24T22:49:06.805061Z"
    }
   },
   "outputs": [],
   "source": [
    "unweighted_antidiff_bandwidths[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9b3ac03",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:49:07.302761Z",
     "start_time": "2025-09-24T22:49:07.299565Z"
    }
   },
   "outputs": [],
   "source": [
    "unweighted_antidiff_num_infinite[:5]  # First 5 timesteps"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b07c3a9",
   "metadata": {},
   "source": [
    "# Result Table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73049546",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:10.106838Z",
     "start_time": "2025-09-24T22:52:10.099556Z"
    }
   },
   "outputs": [],
   "source": [
    "print(\"COVERAGES F-DIFF\")\n",
    "print(\n",
    "    f\"{np.round(unweighted_antidiff_coverages[4], 2)} & {np.round(unweighted_antidiff_coverages[14], 2)} & {np.round(unweighted_antidiff_coverages[24], 2)} & {np.round(unweighted_antidiff_coverages[34], 2)} & {np.round(unweighted_antidiff_coverages[44], 2)}\")\n",
    "print(\n",
    "    f\"{np.round(coverages_lsci_antidiff[4], 2)} & {np.round(coverages_lsci_antidiff[14], 2)} & {np.round(coverages_lsci_antidiff[24], 2)} & {np.round(coverages_lsci_antidiff[34], 2)} & {np.round(coverages_lsci_antidiff[44], 2)}\")\n",
    "print(\n",
    "    f\"{np.round(weighted_antidiff_coverages[4], 2)} & {np.round(weighted_antidiff_coverages[14], 2)} & {np.round(weighted_antidiff_coverages[24], 2)} & {np.round(weighted_antidiff_coverages[34], 2)} & {np.round(weighted_antidiff_coverages[44], 2)}\")\n",
    "print(\"COVERAGES B-HEAT\")\n",
    "print(\n",
    "    f\"{np.round(unweighted_bwheat_coverages[4], 2)} & {np.round(unweighted_bwheat_coverages[14], 2)} & {np.round(unweighted_bwheat_coverages[24], 2)} & {np.round(unweighted_bwheat_coverages[34], 2)} & {np.round(unweighted_bwheat_coverages[44], 2)}\")\n",
    "print(\n",
    "    f\"{np.round(coverages_lsci_bwheat[4], 2)} & {np.round(coverages_lsci_bwheat[14], 2)} & {np.round(coverages_lsci_bwheat[24], 2)} & {np.round(coverages_lsci_bwheat[34], 2)} & {np.round(coverages_lsci_bwheat[44], 2)}\")\n",
    "print(\n",
    "    f\"{np.round(weighted_bwheat_coverages[4], 2)} & {np.round(weighted_bwheat_coverages[14], 2)} & {np.round(weighted_bwheat_coverages[24], 2)} & {np.round(weighted_bwheat_coverages[34], 2)} & {np.round(weighted_bwheat_coverages[44], 2)}\")\n",
    "print(\"COVERAGES R-DIFF\")\n",
    "print(\n",
    "    f\"{np.round(unweighted_reaction_coverages[4], 2)} & {np.round(unweighted_reaction_coverages[14], 2)} & {np.round(unweighted_reaction_coverages[24], 2)} & {np.round(unweighted_reaction_coverages[34], 2)} & {np.round(unweighted_reaction_coverages[44], 2)}\")\n",
    "print(\n",
    "    f\"{np.round(coverages_lsci_reaction[4], 2)} & {np.round(coverages_lsci_reaction[14], 2)} & {np.round(coverages_lsci_reaction[24], 2)} & {np.round(coverages_lsci_reaction[34], 2)} & {np.round(coverages_lsci_reaction[44], 2)}\")\n",
    "print(\n",
    "    f\"{np.round(weighted_reaction_coverages[4], 2)} & {np.round(weighted_reaction_coverages[14], 2)} & {np.round(weighted_reaction_coverages[24], 2)} & {np.round(weighted_reaction_coverages[34], 2)} & {np.round(weighted_reaction_coverages[44], 2)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d284868",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:10.519991Z",
     "start_time": "2025-09-24T22:52:10.510935Z"
    }
   },
   "outputs": [],
   "source": [
    "print(\"BANDWIDTH F-DIFF\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(unweighted_antidiff_bandwidths[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_antidiff_bandwidths[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_antidiff_bandwidths[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_antidiff_bandwidths[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_antidiff_bandwidths[44], 2)}}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_antidiff[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_antidiff[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_antidiff[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_antidiff[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_antidiff[44], 2)}}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(weighted_antidiff_bandwidths[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_antidiff_bandwidths[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_antidiff_bandwidths[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_antidiff_bandwidths[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_antidiff_bandwidths[44], 2)}}}\")\n",
    "print(\"BANDWIDTH B-HEAT\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(unweighted_bwheat_bandwidths[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_bwheat_bandwidths[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_bwheat_bandwidths[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_bwheat_bandwidths[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_bwheat_bandwidths[44], 2)}}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_bwheat[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_bwheat[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_bwheat[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_bwheat[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_bwheat[44], 2)}}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(weighted_bwheat_bandwidths[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_bwheat_bandwidths[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_bwheat_bandwidths[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_bwheat_bandwidths[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_bwheat_bandwidths[44], 2)}}}\")\n",
    "print(\"BANDWIDTH R-DIFF\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(unweighted_reaction_bandwidths[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_reaction_bandwidths[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_reaction_bandwidths[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_reaction_bandwidths[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(unweighted_reaction_bandwidths[44], 2)}}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_reaction[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_reaction[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_reaction[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_reaction[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(bandwidths_lsci_reaction[44], 2)}}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{np.round(weighted_reaction_bandwidths[4], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_reaction_bandwidths[14], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_reaction_bandwidths[24], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_reaction_bandwidths[34], 2)}}} & \\\\textcolor{{gray}}{{{np.round(weighted_reaction_bandwidths[44], 2)}}}\")\n",
    "print(\"N-INFS\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{int(weighted_antidiff_num_infinite[4] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_antidiff_num_infinite[14] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_antidiff_num_infinite[24] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_antidiff_num_infinite[34] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_antidiff_num_infinite[44] / 5)}\\\\%}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{int(weighted_bwheat_num_infinite[4] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_bwheat_num_infinite[14] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_bwheat_num_infinite[24] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_bwheat_num_infinite[34] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_bwheat_num_infinite[44] / 5)}\\\\%}}\")\n",
    "print(\n",
    "    f\"\\\\textcolor{{gray}}{{{int(weighted_reaction_num_infinite[4] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_reaction_num_infinite[14] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_reaction_num_infinite[24] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_reaction_num_infinite[34] / 5)}\\\\%}} & \\\\textcolor{{gray}}{{{int(weighted_reaction_num_infinite[44] / 5)}\\\\%}}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3aff5e3b",
   "metadata": {},
   "source": [
    "# Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d892b6b25da1a9db",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:11.316333Z",
     "start_time": "2025-09-24T22:52:11.314380Z"
    }
   },
   "outputs": [],
   "source": [
    "# In the coverage data of our model, we have default 0 if every sample is reported with trivial bands. As we want to distinguish this case from the other models that try to predict bands, but fail for all samples (leading to 0 coverage), we replace 0 coverages with NaN for better visualization.\n",
    "weighted_antidiff_coverages = np.array(weighted_antidiff_coverages)\n",
    "weighted_antidiff_coverages[weighted_antidiff_coverages == 0] = np.nan\n",
    "\n",
    "weighted_bwheat_coverages = np.array(weighted_bwheat_coverages)\n",
    "weighted_bwheat_coverages[weighted_bwheat_coverages == 0] = np.nan\n",
    "\n",
    "weighted_reaction_coverages = np.array(weighted_reaction_coverages)\n",
    "weighted_reaction_coverages[weighted_reaction_coverages == 0] = np.nan"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c602031",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:11.843179Z",
     "start_time": "2025-09-24T22:52:11.732897Z"
    }
   },
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(18, 5))\n",
    "\n",
    "axs[0].plot(unweighted_antidiff_coverages, label=\"Plain CP\")\n",
    "axs[0].plot(coverages_lsci_antidiff, label=\"LSCI\")\n",
    "axs[0].plot(weighted_antidiff_coverages, label=\"Weighted CP\")\n",
    "axs[0].set_xlabel('Timestep')\n",
    "axs[0].set_ylabel('Coverage')\n",
    "axs[0].set_title('Antidiffusion')\n",
    "\n",
    "axs[1].plot(unweighted_bwheat_coverages, label=\"Plain CP\")\n",
    "axs[1].plot(coverages_lsci_bwheat, label=\"LSCI\")\n",
    "axs[1].plot(weighted_bwheat_coverages, label=\"Weighted CP\")\n",
    "axs[1].set_xlabel('Timestep')\n",
    "axs[1].set_ylabel('Coverage')\n",
    "axs[1].set_title('Backward Heat Equation')\n",
    "\n",
    "axs[2].plot(unweighted_reaction_coverages, label=\"Plain CP\")\n",
    "axs[2].plot(coverages_lsci_reaction, label=\"LSCI\")\n",
    "axs[2].plot(weighted_reaction_coverages, label=\"Weighted CP\")\n",
    "axs[2].set_xlabel('Timestep')\n",
    "axs[2].set_ylabel('Coverage')\n",
    "axs[2].set_title('Reaction-Diffusion')\n",
    "# Force all y-axes to [0,1]\n",
    "for ax in axs.flat:\n",
    "    ax.set_ylim(-0.03, 1.03)\n",
    "    ax.axhline(0.9, color='black', linestyle='--', label='Target Coverage')\n",
    "    # add legend for all subplots\n",
    "    ax.legend()\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa6058c4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:12.150145Z",
     "start_time": "2025-09-24T22:52:12.038247Z"
    }
   },
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(18, 5))\n",
    "\n",
    "axs[0].plot(unweighted_antidiff_bandwidths, label=\"Plain CP\")\n",
    "axs[0].plot(bandwidths_lsci_antidiff, label=\"LSCI\")\n",
    "axs[0].plot(weighted_antidiff_bandwidths, label=\"Weighted CP\")\n",
    "axs[0].legend()\n",
    "axs[0].set_xlabel('Timestep')\n",
    "axs[0].set_ylabel('Bandwidth')\n",
    "axs[0].set_title('Antidiffusion')\n",
    "\n",
    "axs[1].plot(unweighted_bwheat_bandwidths, label=\"Plain CP\")\n",
    "axs[1].plot(bandwidths_lsci_bwheat, label=\"LSCI\")\n",
    "axs[1].plot(weighted_bwheat_bandwidths, label=\"Weighted CP\")\n",
    "axs[1].legend()\n",
    "axs[1].set_xlabel('Timestep')\n",
    "axs[1].set_ylabel('Bandwidth')\n",
    "axs[1].set_title('Backward Heat Equation')\n",
    "\n",
    "axs[2].plot(unweighted_reaction_bandwidths, label=\"Plain CP\")\n",
    "axs[2].plot(bandwidths_lsci_reaction, label=\"LSCI\")\n",
    "axs[2].plot(weighted_reaction_bandwidths, label=\"Weighted CP\")\n",
    "axs[2].legend()\n",
    "axs[2].set_xlabel('Timestep')\n",
    "axs[2].set_ylabel('Bandwidth')\n",
    "axs[2].set_title('Reaction-Diffusion')\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9972202",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:12.649289Z",
     "start_time": "2025-09-24T22:52:12.551735Z"
    }
   },
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(18, 5))\n",
    "\n",
    "axs[0].plot(unweighted_antidiff_num_infinite, label=\"Plain CP\")\n",
    "axs[0].plot(weighted_antidiff_num_infinite, label=\"Weighted CP\")\n",
    "axs[0].legend()\n",
    "axs[0].set_xlabel('Timestep')\n",
    "axs[0].set_ylabel('Number of Infinite Bands')\n",
    "axs[0].set_title('Antidiffusion')\n",
    "\n",
    "axs[1].plot(unweighted_bwheat_num_infinite, label=\"Plain CP\")\n",
    "axs[1].plot(weighted_bwheat_num_infinite, label=\"Weighted CP\")\n",
    "axs[1].legend()\n",
    "axs[1].set_xlabel('Timestep')\n",
    "axs[1].set_ylabel('Number of Infinite Bands')\n",
    "axs[1].set_title('Backward Heat Equation')\n",
    "\n",
    "axs[2].plot(unweighted_reaction_num_infinite, label=\"Plain CP\")\n",
    "axs[2].plot(weighted_reaction_num_infinite, label=\"Weighted CP\")\n",
    "axs[2].legend()\n",
    "axs[2].set_xlabel('Timestep')\n",
    "axs[2].set_ylabel('Number of Infinite Bands')\n",
    "axs[2].set_title('Reaction-Diffusion')\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "01acc2da",
   "metadata": {},
   "source": [
    "# EXPORT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "053445dc",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:15.066277Z",
     "start_time": "2025-09-24T22:52:14.280869Z"
    }
   },
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(18, 5))\n",
    "\n",
    "# Set global font sizes\n",
    "plt.rcParams.update({\n",
    "    'font.size': 14,  # base font size\n",
    "    'axes.titlesize': 16,  # title size\n",
    "    'axes.labelsize': 14,  # x/y label size\n",
    "    'xtick.labelsize': 12,  # x tick label size\n",
    "    'ytick.labelsize': 12,  # y tick label size\n",
    "    'legend.fontsize': 12,  # legend size\n",
    "})\n",
    "\n",
    "axs[0].plot(unweighted_antidiff_coverages, label=\"Naïve CP\")\n",
    "axs[0].plot(coverages_lsci_antidiff, label=\"LSCI\")\n",
    "axs[0].plot(weighted_antidiff_coverages, label=\"WCP (Ours)\")\n",
    "axs[0].set_xlabel('Timestep')\n",
    "axs[0].set_ylabel('Coverage')\n",
    "axs[0].set_title('Fractional Diffusion')\n",
    "\n",
    "axs[1].plot(unweighted_bwheat_coverages, label=\"Naïve CP\")\n",
    "axs[1].plot(coverages_lsci_bwheat, label=\"LSCI\")\n",
    "axs[1].plot(weighted_bwheat_coverages, label=\"WCP (Ours)\")\n",
    "axs[1].set_xlabel('Timestep')\n",
    "axs[1].set_ylabel('Coverage')\n",
    "axs[1].set_title('Backwards Heat')\n",
    "\n",
    "axs[2].plot(unweighted_reaction_coverages, label=\"Naïve CP\")\n",
    "axs[2].plot(coverages_lsci_reaction, label=\"LSCI\")\n",
    "axs[2].plot(weighted_reaction_coverages, label=\"WCP (Ours)\")\n",
    "axs[2].set_xlabel('Timestep')\n",
    "axs[2].set_ylabel('Coverage')\n",
    "axs[2].set_title('Reaction-Diffusion')\n",
    "\n",
    "for ax in axs.flat:\n",
    "    ax.set_ylim(-0.03, 1.03)\n",
    "    ax.axhline(0.9, color='red', linestyle='--', label='Target')\n",
    "    ax.legend(frameon=False)\n",
    "\n",
    "#plt.tight_layout()\n",
    "\n",
    "# Export to PDF (best for LaTeX)\n",
    "fig.savefig(\"coverages.pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "# Optional: high-res PNG fallback\n",
    "fig.savefig(\"coverages.png\", dpi=600, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25eb41b6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:15.281203Z",
     "start_time": "2025-09-24T22:52:15.232596Z"
    }
   },
   "outputs": [],
   "source": [
    "fig2data1 = np.load(data_path / \"raw_data_start_1.npz\", allow_pickle=True)\n",
    "label1 = fig2data1[\"label\"]\n",
    "x_grid1 = fig2data1[\"x\"]\n",
    "lower_band1 = fig2data1[\"lower_band\"]\n",
    "upper_band1 = fig2data1[\"upper_band\"]\n",
    "bands1 = (lower_band1, upper_band1)\n",
    "\n",
    "fig2data2 = np.load(\"raw_data_start_3.npz\", allow_pickle=True)\n",
    "label2 = fig2data2[\"label\"]\n",
    "x_grid2 = fig2data2[\"x\"]\n",
    "lower_band2 = fig2data2[\"lower_band\"]\n",
    "upper_band2 = fig2data2[\"upper_band\"]\n",
    "bands2 = (lower_band2, upper_band2)\n",
    "\n",
    "figdata3 = np.load(\"raw_data_start_4.npz\", allow_pickle=True)\n",
    "label3 = figdata3[\"label\"]\n",
    "x_grid3 = figdata3[\"x\"]\n",
    "lower_band3 = figdata3[\"lower_band\"]\n",
    "upper_band3 = figdata3[\"upper_band\"]\n",
    "bands3 = (lower_band3, upper_band3)\n",
    "\n",
    "fig, axs = plt.subplots(1, 3, figsize=(18, 5))\n",
    "\n",
    "# Set global font sizes\n",
    "plt.rcParams.update({\n",
    "    'font.size': 14,  # base font size\n",
    "    'axes.titlesize': 16,  # title size\n",
    "    'axes.labelsize': 14,  # x/y label size\n",
    "    'xtick.labelsize': 12,  # x tick label size\n",
    "    'ytick.labelsize': 12,  # y tick label size\n",
    "    'legend.fontsize': 12,  # legend size\n",
    "})\n",
    "axs[0].plot(x_grid1.squeeze(), label1.squeeze(), 'k-', label='Ground truth', linewidth=2)\n",
    "axs[0].fill_between(x_grid1.squeeze(), bands1[0], bands1[1],\n",
    "                    color='orange', edgecolor=\"red\", alpha=0.5, zorder=3,\n",
    "                    label='Conformal band')\n",
    "axs[0].set_xlabel('x')\n",
    "axs[0].set_ylabel('u(x, t)')\n",
    "axs[0].set_title('t = 1δ')\n",
    "axs[0].legend(frameon=False, loc='lower left')\n",
    "\n",
    "axs[1].plot(x_grid2.squeeze(), label2.squeeze(), 'k-', label='Ground truth', linewidth=2)\n",
    "axs[1].fill_between(x_grid2.squeeze(), bands2[0], bands2[1],\n",
    "                    color='orange', edgecolor=\"red\", alpha=0.5, zorder=3,\n",
    "                    label='Conformal band')\n",
    "axs[1].set_xlabel('x')\n",
    "#axs[1].set_ylabel('u(x, t)')\n",
    "axs[1].set_title('t = 3δ')\n",
    "axs[1].legend(frameon=False, loc='lower left')\n",
    "\n",
    "axs[2].plot(x_grid3.squeeze(), label3.squeeze(), 'k-', label='Ground truth', linewidth=2)\n",
    "axs[2].fill_between(x_grid3.squeeze(), bands3[0], bands3[1],\n",
    "                    color='orange', edgecolor=\"red\", alpha=0.5, zorder=3,\n",
    "                    label='Conformal band')\n",
    "axs[2].set_xlabel('x')\n",
    "#axs[2].set_ylabel('u(x, t)')\n",
    "axs[2].set_title('t = 4δ')\n",
    "axs[2].legend(frameon=False, loc='lower left')\n",
    "\n",
    "for ax in axs.flat:\n",
    "    ax.set_ylim(-.9, 1.4)\n",
    "\n",
    "# Export to PDF (best for LaTeX)\n",
    "fig.savefig(\"calib_bands.pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "# Optional: high-res PNG fallback\n",
    "fig.savefig(\"calib_bands.png\", dpi=600, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "baf5cd8d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-24T22:52:15.396147Z",
     "start_time": "2025-09-24T22:52:15.367201Z"
    }
   },
   "outputs": [],
   "source": [
    "fig2data4 = np.load(data_path / \"raw_data_end_4.npz\", allow_pickle=True)\n",
    "label4 = fig2data4[\"label\"]\n",
    "x_grid4 = fig2data4[\"x\"]\n",
    "lower_band4 = fig2data4[\"lower_band\"]\n",
    "upper_band4 = fig2data4[\"upper_band\"]\n",
    "bands4 = (lower_band4, upper_band4)\n",
    "\n",
    "fig2data5 = np.load(\"raw_data_end_5.npz\", allow_pickle=True)\n",
    "label5 = fig2data5[\"label\"]\n",
    "x_grid5 = fig2data5[\"x\"]\n",
    "lower_band5 = fig2data5[\"lower_band\"]\n",
    "upper_band5 = fig2data5[\"upper_band\"]\n",
    "bands5 = (lower_band5, upper_band5)\n",
    "\n",
    "figdata6 = np.load(\"raw_data_end_6.npz\", allow_pickle=True)\n",
    "label6 = figdata6[\"label\"]\n",
    "x_grid6 = figdata6[\"x\"]\n",
    "lower_band6 = figdata6[\"lower_band\"]\n",
    "upper_band6 = figdata6[\"upper_band\"]\n",
    "bands6 = (lower_band6, upper_band6)\n",
    "\n",
    "fig, axs = plt.subplots(1, 3, figsize=(18, 5))\n",
    "\n",
    "# Set global font sizes\n",
    "plt.rcParams.update({\n",
    "    'font.size': 14,  # base font size\n",
    "    'axes.titlesize': 16,  # title size\n",
    "    'axes.labelsize': 14,  # x/y label size\n",
    "    'xtick.labelsize': 12,  # x tick label size\n",
    "    'ytick.labelsize': 12,  # y tick label size\n",
    "    'legend.fontsize': 12,  # legend size\n",
    "})\n",
    "axs[0].plot(x_grid4.squeeze(), label4.squeeze(), 'k-', label='Ground truth', linewidth=2)\n",
    "axs[0].fill_between(x_grid4.squeeze(), bands4[0], bands4[1],\n",
    "                    color='orange', edgecolor=\"red\", alpha=0.5, zorder=3,\n",
    "                    label='Conformal band')\n",
    "axs[0].set_xlabel('x')\n",
    "axs[0].set_ylabel('u(x, t)')\n",
    "axs[0].set_title('t = 4δ')\n",
    "axs[0].legend(frameon=False, loc='lower left')\n",
    "\n",
    "axs[1].plot(x_grid5.squeeze(), label5.squeeze(), 'k-', label='Ground truth', linewidth=2)\n",
    "axs[1].fill_between(x_grid5.squeeze(), bands5[0], bands5[1],\n",
    "                    color='orange', edgecolor=\"red\", alpha=0.5, zorder=3,\n",
    "                    label='Conformal band')\n",
    "axs[1].set_xlabel('x')\n",
    "#axs[1].set_ylabel('u(x, t)')\n",
    "axs[1].set_title('t = 5δ')\n",
    "axs[1].legend(frameon=False, loc='lower left')\n",
    "\n",
    "axs[2].plot(x_grid6.squeeze(), label6.squeeze(), 'k-', label='Ground truth', linewidth=2)\n",
    "axs[2].fill_between(x_grid6.squeeze(), bands6[0], bands6[1],\n",
    "                    color='orange', edgecolor=\"red\", alpha=0.5, zorder=3,\n",
    "                    label='Conformal band')\n",
    "axs[2].set_xlabel('x')\n",
    "#axs[2].set_ylabel('u(x, t)')\n",
    "axs[2].set_title('t = 6δ')\n",
    "# put legend to the bottom left\n",
    "axs[2].legend(frameon=False, loc='lower left')\n",
    "#axs[2].legend(frameon=False)\n",
    "\n",
    "for ax in axs.flat:\n",
    "    ax.set_ylim(-3.9, 4.9)\n",
    "\n",
    "# Export to PDF (best for LaTeX)\n",
    "fig.savefig(\"calib_bands_2.pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "# Optional: high-res PNG fallback\n",
    "fig.savefig(\"calib_bands_2.png\", dpi=600, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a1cda48a1de4d80",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "temp-no-plots",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
