{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0d760f78",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(\"..\")\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from rbf_layer import RBFLayer, l_norm, rbf_gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d55e97be",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define an RBF layer where the dimensionality of the input feature is 2,\n",
    "# the number of kernels is 3, and 2 output features\n",
    "\n",
    "rbf = RBFLayer(in_features_dim=2,\n",
    "               num_kernels=3,\n",
    "               out_features_dim=2,\n",
    "               radial_function=rbf_gaussian,\n",
    "               norm_function=l_norm,\n",
    "               normalization=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0487cad3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Uniformly sample 100 points from the 2D plane\n",
    "x = torch.rand((100, 2))\n",
    "y = rbf(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "978920b9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot results\n",
    "x_orig, y_orig = x[:, 0].detach().numpy(), x[:, 1].detach().numpy()\n",
    "x_new, y_new = y[:, 0].detach().numpy(), y[:, 1].detach().numpy()\n",
    "\n",
    "fig, ax = plt.subplots(nrows=1, ncols=2)\n",
    "ax[0].scatter(x_orig, y_orig)\n",
    "ax[1].scatter(x_new, y_new)\n",
    "ax[0].set_title('Original input space')\n",
    "ax[1].set_title('Feature space')\n",
    "ax[0].grid()\n",
    "ax[1].grid()\n",
    "plt.plot()\n",
    "plt.savefig('img.png', bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
