{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import sys\n",
    "import os\n",
    "import numpy as np \n",
    "import os.path as osp\n",
    "import pickle\n",
    "from scipy.integrate import odeint\n",
    "import shutil"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "## setting parameters\n",
    "T = 1\n",
    "M = 50\n",
    "D = np.linspace(-T, T, M)\n",
    "\n",
    "## parameters for data generator\n",
    "N = 1000\n",
    "test_N=200\n",
    "order = 20\n",
    "_range=0.25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def func(y, t, c):\n",
    "    return np.polynomial.chebyshev.Chebyshev(c)(t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train_data_done\n",
      "test_data_done\n"
     ]
    }
   ],
   "source": [
    "train_x = []\n",
    "train_y = []\n",
    "test_x = []\n",
    "test_y = []\n",
    "\n",
    "#Train data\n",
    "for i in range(N):\n",
    "\n",
    "    c = [2*_range*np.random.rand(order)-_range]\n",
    "    x = np.polynomial.chebyshev.Chebyshev(c[0])(D)\n",
    "    y = np.polynomial.chebyshev.Chebyshev(c[0])(D)\n",
    "    for j in D:\n",
    "        train_x.append(np.append(x, j))\n",
    "\n",
    "    for j in range(len(D)):\n",
    "        train_y.append(y[j])\n",
    "\n",
    "train_x = torch.as_tensor(train_x).reshape(N*len(D), len(D) + 1)\n",
    "train_y = torch.as_tensor(train_y).reshape(N*len(D))\n",
    "print('train_data_done')\n",
    "\n",
    "#Test data\n",
    "for i in range(test_N):\n",
    "    c = [2*_range*np.random.rand(order)-_range]\n",
    "    x = np.polynomial.chebyshev.Chebyshev(c[0])(D)\n",
    "    y = np.polynomial.chebyshev.Chebyshev(c[0])(D)\n",
    "    for j in D:\n",
    "        test_x.append(np.append(x, j))\n",
    "\n",
    "    for j in range(len(D)):\n",
    "        test_y.append(y[j])\n",
    "\n",
    "test_x = torch.as_tensor(test_x).reshape(test_N*len(D), len(D) + 1)\n",
    "test_y = torch.as_tensor(test_y).reshape(test_N*len(D))\n",
    "print('test_data_done')\n",
    "\n",
    "data = {'train_X' : train_x, 'train_Y' : train_y, 'test_X' : test_x, 'test_Y' : test_y, 'M' : len(D)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "make_data=False\n",
    "file_name='identity_N'+str(N)+'_M'+str(M)+'.pickle'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "if make_data:\n",
    "    with open(\"../data/\"+file_name,\"wb\") as fw:\n",
    "        pickle.dump(data, fw)\n",
    "    load_data=data\n",
    "else:\n",
    "    ## load dataset\n",
    "    with open(\"../data/\"+file_name,\"rb\") as fr:\n",
    "        load_data= pickle.load(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000, 51]) torch.Size([50000]) torch.Size([10000, 51]) torch.Size([10000])\n"
     ]
    }
   ],
   "source": [
    "print(load_data['train_X'].shape,load_data['train_Y'].shape,load_data['test_X'].shape,load_data['test_Y'].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fd9a8f806a0>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "idx=np.random.randint(0,N)\n",
    "\n",
    "x=load_data['train_X'][M*idx][:M]\n",
    "y=load_data['train_Y'][M*idx:M*idx+M]\n",
    "\n",
    "plt.figure(figsize=(10,5))\n",
    "plt.subplot(1, 1, 1)  \n",
    "plt.plot(D, x, label='input function')\n",
    "plt.plot(D, y, label='output function')\n",
    "#plt.xlim(0,1)\n",
    "#plt.ylim(0,2)\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('y')\n",
    "plt.title('input function')\n",
    "plt.legend()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "inr",
   "language": "python",
   "name": "inr"
  },
  "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
}
