{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys, copy\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import triangular_construction as tr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# X = np.array([1,0.5,0])\n",
    "# Y = np.array([1,2,3])\n",
    "\n",
    "%matplotlib inline\n",
    "N =48\n",
    "X = np.array(range(N))/N\n",
    "Y1 = np.exp(-X)\n",
    "Y2 = (1+0.1* np.sin(20*X))*np.exp(-X)\n",
    "Y3 = (1+0.1* np.sin(20*X)**2)*np.exp(-X)\n",
    "\n",
    "plt.figure(figsize=(8,4))\n",
    "for i,Y0 in enumerate([Y1,Y2,Y3]):\n",
    "    plt.gcf().add_subplot(131+i)\n",
    "    W, b, alpha = tr.setup_one_dim_triangular(X, Y0, a=5.,)\n",
    "    y = [tr.approx_function(x, W, b, alpha) for x in X]\n",
    "    plt.gca().scatter(X,Y0,marker='o',s=12, facecolor='none',edgecolor='g')\n",
    "    plt.gca().plot(X,y, linewidth=0.3,c='g')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = np.array([0.9,0.6,0.5,0.4,0.1])\n",
    "Y = np.array([1,0,0,0,1])\n",
    "\n",
    "x = np.linspace(0,1,100)\n",
    "plt.figure(figsize=(10,4))\n",
    "for i,a in enumerate([5,10, 50]):\n",
    "    plt.gcf().add_subplot(131+i)\n",
    "    W, b, alpha = tr.setup_one_dim_triangular(X, Y, a=a,)\n",
    "    y = [tr.approx_function(x1, W, b, alpha) for x1 in x]\n",
    "    \n",
    "    ax,_ = plt.gca().plot(x,y,3, c='orange',label='a=%s'%(str(a)))\n",
    "    plt.gca().scatter(X,Y)\n",
    "    plt.gca().set_ylim([-0.1,1.5])\n",
    "    plt.legend(handles=[ax])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
