{
 "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\n",
    "from scipy import io"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "## setting parameters of ODE problem\n",
    "T = [0,1]\n",
    "M = 128\n",
    "D = np.linspace(T[0], T[1], M)\n",
    "\n",
    "## parameters for data generator\n",
    "N = 1000\n",
    "test_N=200"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "tags": []
   },
   "source": [
    "## Load data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: '../data/load_data/burgers_data_R10.mat'",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[1;32m~\\anaconda3\\envs\\torch\\lib\\site-packages\\scipy\\io\\matlab\\mio.py\u001b[0m in \u001b[0;36m_open_file\u001b[1;34m(file_like, appendmat, mode)\u001b[0m\n\u001b[0;32m     38\u001b[0m     \u001b[1;32mtry\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m---> 39\u001b[1;33m         \u001b[1;32mreturn\u001b[0m \u001b[0mopen\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mfile_like\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;32mTrue\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m     40\u001b[0m     \u001b[1;32mexcept\u001b[0m \u001b[0mIOError\u001b[0m \u001b[1;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: '../data/load_data/burgers_data_R10.mat'",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[1;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[1;32mC:\\Users\\SWCHO9~1.DES\\AppData\\Local\\Temp/ipykernel_8024/2690575958.py\u001b[0m in \u001b[0;36m<module>\u001b[1;34m\u001b[0m\n\u001b[1;32m----> 1\u001b[1;33m \u001b[0mmat_file\u001b[0m\u001b[1;33m=\u001b[0m\u001b[0mio\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mloadmat\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;34m'../data/load_data/burgers_data_R10.mat'\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[1;32m~\\anaconda3\\envs\\torch\\lib\\site-packages\\scipy\\io\\matlab\\mio.py\u001b[0m in \u001b[0;36mloadmat\u001b[1;34m(file_name, mdict, appendmat, **kwargs)\u001b[0m\n\u001b[0;32m    222\u001b[0m     \"\"\"\n\u001b[0;32m    223\u001b[0m     \u001b[0mvariable_names\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mpop\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;34m'variable_names'\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;32mNone\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 224\u001b[1;33m     \u001b[1;32mwith\u001b[0m \u001b[0m_open_file_context\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mfile_name\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mappendmat\u001b[0m\u001b[1;33m)\u001b[0m \u001b[1;32mas\u001b[0m \u001b[0mf\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    225\u001b[0m         \u001b[0mMR\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0m_\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mmat_reader_factory\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mf\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;33m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    226\u001b[0m         \u001b[0mmatfile_dict\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0mMR\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mget_variables\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mvariable_names\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\torch\\lib\\contextlib.py\u001b[0m in \u001b[0;36m__enter__\u001b[1;34m(self)\u001b[0m\n\u001b[0;32m    117\u001b[0m         \u001b[1;32mdel\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0margs\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mkwds\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mfunc\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    118\u001b[0m         \u001b[1;32mtry\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m--> 119\u001b[1;33m             \u001b[1;32mreturn\u001b[0m \u001b[0mnext\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mself\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mgen\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m    120\u001b[0m         \u001b[1;32mexcept\u001b[0m \u001b[0mStopIteration\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m    121\u001b[0m             \u001b[1;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;34m\"generator didn't yield\"\u001b[0m\u001b[1;33m)\u001b[0m \u001b[1;32mfrom\u001b[0m \u001b[1;32mNone\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\torch\\lib\\site-packages\\scipy\\io\\matlab\\mio.py\u001b[0m in \u001b[0;36m_open_file_context\u001b[1;34m(file_like, appendmat, mode)\u001b[0m\n\u001b[0;32m     15\u001b[0m \u001b[1;33m@\u001b[0m\u001b[0mcontextmanager\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     16\u001b[0m \u001b[1;32mdef\u001b[0m \u001b[0m_open_file_context\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mfile_like\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mappendmat\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[1;33m=\u001b[0m\u001b[1;34m'rb'\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m---> 17\u001b[1;33m     \u001b[0mf\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mopened\u001b[0m \u001b[1;33m=\u001b[0m \u001b[0m_open_file\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mfile_like\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mappendmat\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m     18\u001b[0m     \u001b[1;32mtry\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     19\u001b[0m         \u001b[1;32myield\u001b[0m \u001b[0mf\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n",
      "\u001b[1;32m~\\anaconda3\\envs\\torch\\lib\\site-packages\\scipy\\io\\matlab\\mio.py\u001b[0m in \u001b[0;36m_open_file\u001b[1;34m(file_like, appendmat, mode)\u001b[0m\n\u001b[0;32m     43\u001b[0m             \u001b[1;32mif\u001b[0m \u001b[0mappendmat\u001b[0m \u001b[1;32mand\u001b[0m \u001b[1;32mnot\u001b[0m \u001b[0mfile_like\u001b[0m\u001b[1;33m.\u001b[0m\u001b[0mendswith\u001b[0m\u001b[1;33m(\u001b[0m\u001b[1;34m'.mat'\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     44\u001b[0m                 \u001b[0mfile_like\u001b[0m \u001b[1;33m+=\u001b[0m \u001b[1;34m'.mat'\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[1;32m---> 45\u001b[1;33m             \u001b[1;32mreturn\u001b[0m \u001b[0mopen\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mfile_like\u001b[0m\u001b[1;33m,\u001b[0m \u001b[0mmode\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m,\u001b[0m \u001b[1;32mTrue\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m     46\u001b[0m         \u001b[1;32melse\u001b[0m\u001b[1;33m:\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0;32m     47\u001b[0m             raise IOError(\n",
      "\u001b[1;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: '../data/load_data/burgers_data_R10.mat'"
     ]
    }
   ],
   "source": [
    "mat_file=io.loadmat('../data/load_data/burgers_data_R10.mat')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2048, 8192) (2048, 8192)\n"
     ]
    }
   ],
   "source": [
    "print(mat_file[\"a\"].shape,mat_file[\"u\"].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1000, 128) (1000, 128)\n"
     ]
    }
   ],
   "source": [
    "print(mat_file['a'][:N,::2**6].shape,mat_file['u'][:N,::2**6].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0015793580549558761"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.00157936, -0.01806123, -0.03623163, -0.05261846, -0.06697024,\n",
       "       -0.07909947, -0.0888814 , -0.09625036, -0.10119405, -0.10374658,\n",
       "       -0.10398067, -0.10199977, -0.09793042, -0.09191518, -0.08410646,\n",
       "       -0.0746613 , -0.06373721, -0.05148894, -0.03806623, -0.02361231,\n",
       "       -0.00826314,  0.00785288,  0.02461467,  0.041908  ,  0.05962471,\n",
       "        0.07766179,  0.09592045,  0.11430501,  0.13272194,  0.15107884,\n",
       "        0.16928355,  0.18724342,  0.20486462,  0.2220518 ,  0.2387079 ,\n",
       "        0.25473433,  0.27003149,  0.28449978,  0.29804102,  0.31056041,\n",
       "        0.32196891,  0.33218609,  0.34114306,  0.34878538,  0.35507544,\n",
       "        0.35999376,  0.36353857,  0.36572287,  0.36656827,  0.36609476,\n",
       "        0.36430585,  0.36116861,  0.3565884 ,  0.35037862,  0.34222638,\n",
       "        0.33165618,  0.31799589,  0.30035265,  0.27761154,  0.24847654,\n",
       "        0.21157869,  0.16567601,  0.10995371,  0.04439302, -0.02988455,\n",
       "       -0.1104461 , -0.1936944 , -0.27537446, -0.35131082, -0.41811879,\n",
       "       -0.47364801, -0.51706261, -0.5486266 , -0.56934726, -0.58061721,\n",
       "       -0.58393547, -0.58072862, -0.57225827, -0.55958893, -0.54359165,\n",
       "       -0.52496536, -0.5042645 , -0.48192667, -0.45829727, -0.43365018,\n",
       "       -0.40820443, -0.38213738, -0.35559494, -0.32869949, -0.30155598,\n",
       "       -0.27425659, -0.24688446, -0.21951653, -0.19222593, -0.1650838 ,\n",
       "       -0.138161  , -0.11152944, -0.0852634 , -0.05944065, -0.03414353,\n",
       "       -0.00946007,  0.01451513,  0.03767987,  0.05992356,  0.0811265 ,\n",
       "        0.10115934,  0.11988293,  0.13714849,  0.15279844,  0.16666788,\n",
       "        0.17858718,  0.18838551,  0.1958959 ,  0.20096157,  0.20344377,\n",
       "        0.20323091,  0.2002485 ,  0.19446951,  0.18592404,  0.17470748,\n",
       "        0.16098592,  0.14499781,  0.12705124,  0.10751645,  0.08681394,\n",
       "        0.06539902,  0.0437441 ,  0.02232022])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mat_file['u'][-test_N,::2**6]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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",
    "_input=mat_file['a'][:N,::2**6]\n",
    "_output=mat_file['u'][:N,::2**6]\n",
    "for x, y in zip(_input, _output):\n",
    "    for idx, j in enumerate(D):\n",
    "        train_x.append(np.append(x, j))\n",
    "        train_y.append(y[idx])\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",
    "\n",
    "_input=mat_file['a'][-test_N:,::2**6]\n",
    "_output=mat_file['u'][-test_N:,::2**6]\n",
    "for x, y in zip(_input, _output):\n",
    "    for idx, j in enumerate(D):\n",
    "        test_x.append(np.append(x, j))\n",
    "        test_y.append(y[idx])\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')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "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": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "make_data=False\n",
    "file_name='burgers_N'+str(N)+'_M'+str(M)+'.pickle'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([128000, 129]) torch.Size([128000]) torch.Size([25600, 129]) torch.Size([25600])\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": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fe80595fdf0>"
      ]
     },
     "execution_count": 30,
     "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()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train/Test Split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_train=1000\n",
    "N_test=200\n",
    "M=128\n",
    "\n",
    "data_name='burgers'+'_N'+str(N_train)+'_M'+str(M)+'.pickle'\n",
    "\n",
    "## load dataset\n",
    "with open(\"../data/\"+data_name,\"rb\") as fr:\n",
    "    raw_set= pickle.load(fr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x, train_y, test_x, test_y = raw_set['train_X'], raw_set['train_Y'], raw_set['test_X'], raw_set['test_Y']\n",
    "train_data = {'train_X' : train_x, 'train_Y' : train_y, 'test_X' : test_x[:2560, :], 'test_Y' : test_y[:2560], 'M' : M}\n",
    "test_data = {'test_X' : test_x, 'test_Y' : test_y, 'M' : M}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "file_name='burgers_train'+'_N'+str(N_train)+'_M'+str(M)+'.pickle'\n",
    "with open(\"../data/\"+file_name,\"wb\") as fw:\n",
    "    pickle.dump(train_data, fw)\n",
    "    \n",
    "file_name='burgers_test'+'_N'+str(N_train)+'_M'+str(M)+'.pickle'\n",
    "with open(\"../data/\"+file_name,\"wb\") as fw:\n",
    "    pickle.dump(test_data, fw)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([128000, 129]),\n",
       " torch.Size([128000]),\n",
       " torch.Size([2560, 129]),\n",
       " torch.Size([2560]))"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_data['train_X'].shape, train_data['train_Y'].shape, train_data['test_X'].shape, train_data['test_Y'].shape"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch",
   "language": "python",
   "name": "torch"
  },
  "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
