{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "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')\n",
    "import torch\n",
    "from volatility_smoothing.utils.errors import spread_error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "resources = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_path = \"../eval/store/9456890 (raw)/data\"\n",
    "\n",
    "datafile_2012 = f\"{data_path}/data_2012-07-20-10-50-00.pt\"\n",
    "datafile_2012 = f\"{data_path}/data_2012-08-13-12-30-00.pt\"\n",
    "datafile_2013 = f\"{data_path}/data_2013-01-31-10-50-00.pt\"\n",
    "datafile_2014 = f\"{data_path}/data_2014-01-07-14-10-00.pt\"\n",
    "datafile_2016 = f\"{data_path}/data_2016-10-21-13-10-00.pt\"\n",
    "datafile_2017 = f\"{data_path}/data_2017-06-08-10-50-00.pt\"\n",
    "datafile_2021 = f\"{data_path}/data_2021-01-04-10-50-00.pt\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = torch.load(datafile_2021)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "xs = data['time_to_maturity']\n",
    "ys = data['log_moneyness']\n",
    "zs = data['implied_volatility'] * np.sqrt(xs)\n",
    "\n",
    "mask = (-1.5 <= ys) & (ys <= 0.5)\n",
    "\n",
    "xs = xs[mask]\n",
    "ys = ys[mask]\n",
    "zs = zs[mask]\n",
    "\n",
    "ecolor = \"#408DBF\"\n",
    "\n",
    "figsize = (4, 3)\n",
    "fig = plt.figure(figsize=figsize)\n",
    "ax = fig.add_subplot(projection='3d')\n",
    "#ax.view_init(elev=30, azim=-45)\n",
    "ax.scatter(ys, xs, zs, c=ecolor, cmap='viridis', label=r'$v(\\tau_i, k_i)$', s=1, alpha=1., zorder=2)\n",
    "#ax.scatter(ys, xs, zs, label=r'$v(\\tau_i, k_i)$', color=ecolor, s=4)\n",
    "ax.set_xlabel('$k$')\n",
    "ax.set_ylabel(r'$\\tau$')\n",
    "\n",
    "\n",
    "from matplotlib.cm import coolwarm\n",
    "from matplotlib.cm import Blues, Purples_r, RdPu_r\n",
    "\n",
    "grid = data.grid\n",
    "X = grid['r'] ** 2\n",
    "Y = grid['z'] * grid['r']\n",
    "Z = data.iv_surface * grid['r']\n",
    "\n",
    "ax.plot_surface(Y, X, Z - 5e-3, cmap=RdPu_r, label='$\\\\hat{v}(\\\\tau, k)$', zorder=-1, alpha=1.)\n",
    "\n",
    "#ax.legend()#loc='upper left')\n",
    "\n",
    "\n",
    "fig.savefig(f\"{resources}/op_deep_smoothing_surface.png\", bbox_inches='tight', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print('spread_error:', np.mean(spread_error(data['iv_predict'], data)).item())\n",
    "print('abs_error:', torch.mean(torch.abs((data['iv_predict'] - data['implied_volatility']) / data['implied_volatility'])).item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch.nn.functional as F\n",
    "print(F.relu(-data.calendar_error + 1e-3).mean().item())\n",
    "F.relu(-data.butterfly_error + 1e-3).mean().item()"
   ]
  }
 ],
 "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
