{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import argparse\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "from rates.auxillary import (\n",
    "    training_and_error_computation,\n",
    ")\n",
    "from rates.config import LOG_DIR, AUTHOR\n",
    "from rates.targets import two_cos\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "parser = argparse.ArgumentParser(\n",
    "    prog=\"Rates\",\n",
    "    description=\"Experimental rates computation\",\n",
    "    epilog=f\"@ 2022, {AUTHOR}\",\n",
    "    formatter_class=argparse.ArgumentDefaultsHelpFormatter,\n",
    ")\n",
    "parser.add_argument(\n",
    "    \"-f\",\n",
    "    \"--name\",\n",
    "    default=\"smooth\",\n",
    "    nargs=\"?\",\n",
    "    help=\"Target function\",\n",
    "    type=str,\n",
    ")\n",
    "parser.add_argument(\n",
    "    \"-n\",\n",
    "    \"--n_train\",\n",
    "    default=1000,\n",
    "    nargs=\"?\",\n",
    "    help=\"Number of traning samples\",\n",
    "    type=int,\n",
    ")\n",
    "parser.add_argument(\n",
    "    \"-t\",\n",
    "    \"--root_n_test\",\n",
    "    default=100,\n",
    "    nargs=\"?\",\n",
    "    help=\"Root of the number of testing samples\",\n",
    "    type=int,\n",
    ")\n",
    "parser.add_argument(\n",
    "    \"-e\",\n",
    "    \"--nb_exp\",\n",
    "    default=100,\n",
    "    nargs=\"?\",\n",
    "    help=\"Number of experiment to estimate risk expectation\",\n",
    "    type=int,\n",
    ")\n",
    "parser.add_argument(\n",
    "    \"-s\",\n",
    "    \"--sigma\",\n",
    "    default=0.2,\n",
    "    nargs=\"?\",\n",
    "    help=\"Scale of regression kernel\",\n",
    "    type=float,\n",
    ")\n",
    "parser.add_argument(\n",
    "    \"--seed\",\n",
    "    default=0,\n",
    "    nargs=\"?\",\n",
    "    help=\"Random seed\",\n",
    "    type=int,\n",
    ")\n",
    "config = parser.parse_args(\"\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "config.name = \"two_cos\"\n",
    "func = two_cos\n",
    "lambd = 1e-6\n",
    "config.sigma = .1\n",
    "config.n_train = 300\n",
    "\n",
    "n_train = config.n_train\n",
    "sigma = config.sigma\n",
    "from rates.auxillary import rbf_kernel, rbf_periodic\n",
    "kernel = rbf_periodic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(config.seed)\n",
    "save_file = LOG_DIR / (config.name + \".bitfile\")\n",
    "\n",
    "# testing set\n",
    "lin = np.linspace(-1, 1, num=config.root_n_test)\n",
    "X1, X2 = np.meshgrid(lin, lin)\n",
    "x_test = np.vstack((X1.reshape(-1), X2.reshape(-1))).T\n",
    "y_test = func(x_test)\n",
    "\n",
    "x_train = 2 * np.random.rand(n_train, 2) - 1\n",
    "y_train = func(x_train)\n",
    "# kernels\n",
    "K = kernel(x_train, x_train, sigma=sigma)\n",
    "K += lambd * np.eye(n_train)\n",
    "K_test = kernel(x_test, x_train, sigma=sigma)\n",
    "alpha = np.linalg.solve(K, y_train)\n",
    "y_pred = K_test @ alpha"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "offset = 1.5\n",
    "fig, ax = plt.subplots(1, 1, figsize=(3, 3))\n",
    "ax.contourf(\n",
    "    X1,\n",
    "    X2,\n",
    "    y_test.reshape(config.root_n_test, config.root_n_test),\n",
    "    cmap=\"RdBu\",\n",
    "    levels=20,\n",
    "    vmin=-offset,\n",
    "    vmax=offset,\n",
    ")\n",
    "ax.set_axis_off()\n",
    "fig.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000,)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_test.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.cos(omeega_1)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.4 ('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
}
