{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 22,
   "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": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "## setting parameters\n",
    "T = 1\n",
    "M = 100\n",
    "x0 = 0\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": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "def func(y, t, c):\n",
    "    return np.polynomial.chebyshev.Chebyshev(c)(t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "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",
    "    y = np.polynomial.chebyshev.Chebyshev(c[0])(D)\n",
    "    x = odeint(func, x0, D, args = tuple(c))\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",
    "    y = np.polynomial.chebyshev.Chebyshev(c[0])(D)\n",
    "    x = odeint(func, x0, D, args = tuple(c))\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": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "make_data=False\n",
    "file_name='diff_N'+str(N)+'_M'+str(M)+'.pickle'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "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": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([100000, 101]) torch.Size([100000]) torch.Size([20000, 101]) torch.Size([20000])\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": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fdbaa4a4a30>"
      ]
     },
     "execution_count": 29,
     "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
}
