{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# TODO\n",
    "Make a plot in 2d of the convergence rates as a function of (n, lambda)\n",
    "show on the plot on optimal value of lambda for each n."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "from rates.targets import absolute_value\n",
    "from rates.architectures.kernels import rbf_kernel\n",
    "from rates.config import SAVE_DIR\n",
    "\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{mathtools}')\n",
    "plt.rc('font', size=8, family='serif', serif='cm')\n",
    "plt.rc('figure', figsize=(1.5, 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_train = 10000\n",
    "n_test = 1000\n",
    "clip = 1\n",
    "\n",
    "np.random.seed(0)\n",
    "x_train = np.random.randn(n_train, 1)\n",
    "y_train = absolute_value(x_train)\n",
    "\n",
    "x_test = np.linspace(-2, 2, n_test)[:, np.newaxis]\n",
    "y_test = absolute_value(x_test)\n",
    "\n",
    "sigma = 1\n",
    "K = rbf_kernel(x_train, x_train, sigma)\n",
    "K_test = rbf_kernel(x_test, x_train, sigma)\n",
    "\n",
    "K_reg = K + 2e-3 * np.eye(n_train)\n",
    "pred_full = K_test @ np.linalg.solve(K_reg, y_train)\n",
    "n = 100\n",
    "pred_small = K_test[..., :n] @ np.linalg.solve(K_reg[:n, :n], y_train[:n])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.25, 0.25)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Ground truth\n",
    "fig, ax = plt.subplots()\n",
    "a, = ax.plot(x_test[:, 0], y_test[:])\n",
    "\n",
    "# Estimation after 1000 samples\n",
    "b, = ax.plot(x_test[:, 0], pred_full)\n",
    "\n",
    "# Estimation after 200 samples\n",
    "c, = ax.plot(x_test[:, 0], pred_small, linestyle=\"--\")\n",
    "# fig.savefig(SAVE_DIR / \"fast_slow_reconstruction.pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "ax.legend([a, b, c], [r\"Ground truth\", r\"$10^4$ samples\", r\"$10^2$ samples\"])\n",
    "# remove axis frame\n",
    "ax.axis('off')\n",
    "# fig.savefig(SAVE_DIR / \"fast_slow_reconstruction_legend.pdf\")\n",
    "\n",
    "# Ground truth\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(x_test[:, 0], y_test[:])\n",
    "\n",
    "# Estimation after 1000 samples\n",
    "ax.plot(x_test[:, 0], pred_full)\n",
    "\n",
    "# Estimation after 200 samples\n",
    "ax.plot(x_test[:, 0], pred_small, linestyle=\"--\")\n",
    "ax.set_ylim(-0.1, 0.3)\n",
    "ax.set_xlim(-.25, .25)\n",
    "# fig.savefig(SAVE_DIR / \"fast_slow_reconstruction_zoom.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dev",
   "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.4"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "eeb90ca8861134173ea2edb6120d403a551dc71a17254f2d5d4c5ae7c0686c83"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
