{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import fnmatch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import scienceplots\n",
    "plt.style.use('science')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "resources = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "path_svi = \"../benchmark/store/9457192\"\n",
    "\n",
    "df_svi_rel = pd.read_csv(f\"{path_svi}/rel.csv\")\n",
    "df_svi_fit = pd.read_csv(f\"{path_svi}/fit.csv\")\n",
    "df_svi = pd.merge(df_svi_rel, df_svi_fit, suffixes=('_rel', '_fit'), on='quote_datetime')\n",
    "\n",
    "def load_csv(path, error):\n",
    "    return pd.concat([pd.read_csv(f\"{path}/{f}\") for f in os.listdir(path) if fnmatch.fnmatch(f, f'{error}_*.csv')])\n",
    "\n",
    "path_opds = \"../eval/store/9456890 (raw)\"\n",
    "path_opds = \"../eval/store/9456890 (finetune)\"\n",
    "\n",
    "df_opds_rel = load_csv(path_opds, 'rel')\n",
    "df_opds_fit = load_csv(path_opds, 'fit')\n",
    "df_opds_val = load_csv(path_opds, 'val')\n",
    "df_opds = pd.merge(df_opds_rel, df_opds_fit, suffixes=('_rel', '_fit'), on='quote_datetime')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def resample(df):\n",
    "    df['quote_datetime'] = pd.to_datetime(df['quote_datetime'])\n",
    "    df = df.set_index('quote_datetime').sort_index()\n",
    "\n",
    "    df_train = df.loc[:'2020'].resample('ME').mean() #.agg(agg).dropna()\n",
    "\n",
    "    df_test = df.loc['2021':].resample('2D').mean()\n",
    "    df = pd.concat((df_train, df_test)).dropna()\n",
    "\n",
    "    df_test.iloc[0] = df_train.iloc[-1]\n",
    " \n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_svi_rs = resample(df_svi)\n",
    "df_opds_rs = resample(df_opds)\n",
    "spread = resample(df_opds_val)['spread']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def plot_series_shaded(data: pd.Series, lower: pd.Series = None, upper: pd.Series = None, ax=None, figsize=(10, 1.5), prop_train={}, prop_test={}):\n",
    "    n_train = len(data[data.index.year < 2021])\n",
    "    n_test = len(data) - n_train\n",
    "\n",
    "    indices2 = np.linspace(0.5, 1, n_test)  # Second half of the plot\n",
    "    indices1 = np.linspace(0, 0.5, n_train)  # First half of the plot\n",
    "\n",
    "    # Plotting\n",
    "    if ax is None:\n",
    "        fig, ax = plt.subplots(figsize=figsize)\n",
    "\n",
    "    line1 = ax.plot(indices1, data.iloc[:n_train], **prop_train)\n",
    "    line2 = ax.plot(indices2, data.iloc[n_train:], **prop_test)\n",
    "\n",
    "    prop_test.pop('label')\n",
    "\n",
    "\n",
    "    if lower is not None:\n",
    "        ax.fill_between(indices1, lower.iloc[:n_train], upper.iloc[:n_train], alpha=0.2, **prop_train)\n",
    "    \n",
    "    if upper is not None:\n",
    "        ax.fill_between(indices2, lower.iloc[n_train:], upper.iloc[n_train:], alpha=0.2, **prop_test)\n",
    "\n",
    "    # Set x-axis major labels for the first segment\n",
    "    years = np.arange(2012, 2022)\n",
    "    year_positions = list(np.linspace(0, 0.5, len(years))) + [1]\n",
    "\n",
    "    ax.set_xticks(year_positions)\n",
    "    ax.set_xticklabels([str(year) for year in years] + [''])\n",
    "\n",
    "    months = ['Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec', \"\"]\n",
    "    month_positions = np.linspace(0.5 + 1/24, 1, 12)  # Starts from 0.5 + 1 month interval, ends at 1\n",
    "    ax.set_xticks(month_positions, minor=True)\n",
    "    ax.set_xticklabels(months, minor=True)\n",
    "\n",
    "    # Minor ticks visual style\n",
    "    ax.tick_params(axis='x', which='minor', length=4, color='blue')  # Make minor ticks distinct\n",
    "\n",
    "    ax.grid(visible=True)\n",
    "    legend = ax.legend(loc='upper left', facecolor='white', framealpha=1, frameon=True, prop={'size': 9})\n",
    "\n",
    "    return ax\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "color_names = ['blue', 'green', 'orange', 'red', 'purple', 'gray', 'lightgray']\n",
    "color_codes = ['#0C5DA5', '#00B945', '#FF9500', '#FF2C00', '#845B97', '#474747', '#9e9e9e']\n",
    "\n",
    "colors = dict(zip(color_names, color_codes))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create a subplot mosaic for the following plots, using the plt.subplot_mosaic method\n",
    "def setup_plot():\n",
    "\n",
    "    fig, axs = plt.subplot_mosaic([\n",
    "        ['rel'],\n",
    "        ['fit'],\n",
    "        #['freq'],\n",
    "        ['spr']\n",
    "    ],\n",
    "    figsize=(8, 3.5), sharex=True)\n",
    "\n",
    "    #axs['mean'].set_yticks([0., 1., 2., 3., 4])\n",
    "    #axs['mean'].yaxis.set_major_formatter(ticker.FormatStrFormatter('%0.3f'))\n",
    "\n",
    "    axs['rel'].set_ylabel(r\"$\\delta_\\text{abs}$\")\n",
    "    axs['rel'].set_yticks([0.01, 0.02, 0.03])\n",
    "\n",
    "\n",
    "    \n",
    "\n",
    "    axs['fit'].set_ylabel(r\"$\\delta_\\text{spr}$\")\n",
    "    axs['fit'].set_yticks([1., 2., 3., 4])\n",
    "    axs['fit'].set_ylim(0., 5.)\n",
    "    #axs['fit'].yaxis.set_major_formatter(ticker.FormatStrFormatter('%0.3f'))\n",
    "\n",
    "    axs['spr'].set_xlabel(r\"$T_0$\")\n",
    "\n",
    "    for ax in axs:\n",
    "        axs[ax].yaxis.tick_right()\n",
    "    \n",
    "    #axs['fit'].grid(True, which='both')\n",
    "\n",
    "\n",
    "    return fig, axs\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "fig, axs = setup_plot()\n",
    "\n",
    "\n",
    "plot_series_shaded(df_svi_rs['mean_rel'], ax=axs['rel'], \n",
    "                   prop_train={'color': colors['orange']}, \n",
    "                   prop_test={'color': colors['orange'], 'label': 'SVI'})\n",
    "\n",
    "plot_series_shaded(df_svi_rs['mean_fit'], ax=axs['fit'], \n",
    "                   prop_train={'color': colors['orange']}, \n",
    "                   prop_test={'color': colors['orange'], 'label': 'SVI'})\n",
    "\n",
    "plot_series_shaded(df_opds_rs['mean_rel'], ax=axs['rel'], \n",
    "                    prop_test={'label': 'OpDS'})\n",
    "\n",
    "plot_series_shaded(df_opds_rs['mean_fit'], ax=axs['fit'], \n",
    "                    prop_test={'label': 'OpDS'})\n",
    "\n",
    "prop_spread = {'color': 'purple'}\n",
    "plot_series_shaded(spread, ax=axs['spr'], prop_train=prop_spread, prop_test=prop_spread | {'label': r\"$s$\"})\n",
    "\n",
    "fig.savefig(f\"{resources}/benchmark_lines.png\", dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create a subplot mosaic for the following plots, using the plt.subplot_mosaic method\n",
    "fig, axs = setup_plot()\n",
    "\n",
    "\n",
    "plot_series_shaded(df_svi_rs['mean_rel'], df_svi_rs['%25_rel'], df_svi_rs['%75_rel'], ax=axs['rel'], \n",
    "                   prop_train={'color': colors['orange']}, \n",
    "                   prop_test={'color': colors['orange'], 'label': 'SVI'})\n",
    "\n",
    "plot_series_shaded(df_svi_rs['mean_fit'], df_svi_rs['%25_fit'], df_svi_rs['%75_fit'], ax=axs['fit'], \n",
    "                   prop_train={'color': colors['orange']}, \n",
    "                   prop_test={'color': colors['orange'], 'label': 'SVI'})\n",
    "\n",
    "plot_series_shaded(df_opds_rs['mean_rel'], df_opds_rs['%25_rel'], df_opds_rs['%75_rel'], ax=axs['rel'], \n",
    "                    prop_test={'label': 'OpDS'})\n",
    "\n",
    "plot_series_shaded(df_opds_rs['mean_fit'], df_opds_rs['%25_fit'], df_opds_rs['%75_fit'], ax=axs['fit'], \n",
    "                    prop_test={'label': 'OpDS'})\n",
    "\n",
    "prop_spread = {'color': 'purple'}\n",
    "plot_series_shaded(spread, ax=axs['spr'], prop_train=prop_spread, prop_test=prop_spread | {'label': r\"$s$\"})\n",
    "\n",
    "fig.savefig(f\"{resources}/benchmark_quantiles.png\", dpi=300, bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "op-ds-cqZ6S183-py3.11",
   "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.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
