{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4dca7433",
   "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": 13,
   "id": "5a1929fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define an RBF layer where the dimensionality of the input feature is 2,\n",
    "# the number of kernels is 3, and 1 output feature\n",
    "\n",
    "rbf = RBFLayer(in_features_dim=1,\n",
    "               num_kernels=3,\n",
    "               out_features_dim=1,\n",
    "               radial_function=rbf_gaussian,\n",
    "               norm_function=l_norm,\n",
    "               normalization=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "84d49e6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Uniformly sample 100 points from the 2D plane\n",
    "x = torch.rand((100, 1))\n",
    "y = rbf(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "9866fedf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot results\n",
    "x_orig = x.detach().numpy()\n",
    "y_new = y.detach().numpy()\n",
    "\n",
    "\n",
    "plt.plot(x_orig, y_new)\n",
    "plt.xlabel('Input space')\n",
    "plt.ylabel('Output space')\n",
    "plt.grid()\n",
    "plt.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb66c77e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
