{
 "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 of ODE problem\n",
    "T = [0,1]\n",
    "M = 40\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": [],
   "source": [
    "train=np.load('../data/load_data/train_IC1.npz')\n",
    "test=np.load('../data/load_data/test_IC1.npz')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1000, 40, 40) (40, 40) (40, 40) (1000, 40, 40)\n"
     ]
    }
   ],
   "source": [
    "print(train[\"u\"].shape,train[\"x\"].shape,train[\"t\"].shape,train[\"u\"].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.51282054"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train[\"t\"][20][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "x=train[\"u\"][:,0,:]\n",
    "x_y=train[\"x\"][0]\n",
    "y=train[\"u\"][:,20,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1000, 40) (40,) (1000, 40)\n"
     ]
    }
   ],
   "source": [
    "print(x.shape, x_y.shape, y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "train_data_done\n"
     ]
    }
   ],
   "source": [
    "train_x = []\n",
    "train_y = []\n",
    "#Train data\n",
    "for i in range(N):\n",
    "    for j in x_y:\n",
    "        train_x.append(np.append(x[i], j))\n",
    "\n",
    "    for j in range(len(D)):\n",
    "        train_y.append(y[i][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')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "x=test[\"u\"][:,0,:]\n",
    "x_y=test[\"x\"][0]\n",
    "y=test[\"u\"][:,20,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test_data_done\n"
     ]
    }
   ],
   "source": [
    "test_x = []\n",
    "test_y = []\n",
    "#Test data\n",
    "for i in range(test_N):\n",
    "    for j in D:\n",
    "        test_x.append(np.append(x[i], j))\n",
    "\n",
    "    for j in range(len(D)):\n",
    "        test_y.append(y[i][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')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "make_data=False\n",
    "file_name='advection_N'+str(N)+'_M'+str(M)+'.pickle'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([40000, 41]) torch.Size([40000]) torch.Size([8000, 41]) torch.Size([8000])\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": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f3401e57d90>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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/fXX65xzztH111/f9jlm2r17t7Zv3974etu2bdq8eXPXnr8VC75iOedumuexJ7sbDlKvsYl3UcrPv4her01MkoQB7QpG+nA4kqb82G3ZskXnnnuuTjnllLZ+PkrCor0cZ/rSl76kgwcPvmI7oU7t3r1b4+PjuuSSSyRJGzZs0IYNG7r2/K1gnTC0JpruncK+sFK50nghAdCaoD6zuG9mSEY9YWjJZz/7WZ177rk699xz9bnPfU5SLVE699xzG8fcfPPN+sQnPqH77rtP4+PjuuKKK7R69Wq9/PLLWrZsmW644QaNjY1pbGxMe/fulSRdddVVuu+++xrPEQS1a3PjjTfq4Ycf1urVq1+1mv6GDRtUKpW0du1abd26dc7neOihh3TBBRdo48aNWr58ua644orGvo87d+7UunXrtGrVKo2Njemll17STTfdpK1btzZW09+yZYs2bdokSXr22We1fv16rVy5UuvXr9dzzz3XiP+6667TunXrdOaZZ74ijk7wioXWRO8sy+lKwpxzKk7SEwa0K/CHJR3b/ivzykXp+NOTjqJ9D94o/exH3X3O171JunjuYbddu3bpzjvv1GOPPSbnnNauXat3vvOdOuGE2ZcK3bhxo2699VbdfPPNWrPm2ILwixcv1uOPP6677rpLH//4x/XAAw/Mec7Nmzfr5ptvnvWYbdu2KQgC7d69W5L04IMPzvk83//+97Vnzx6dcsopetvb3qbvfve7Ghsb02WXXaatW7fqvPPO0+HDh7Vo0SJ96lOf0vj4uG699VZJtWpeZNOmTbryyiv1wQ9+UHfccYeuu+463X///ZKkF154QTt27NBTTz2lDRs2aOPGjXPG0ywqYWhN1GORsmUqwkpVlapjOBJoU7TGXv8MRxbpCWvRjh079J73vEejo6MKgkDvfe979fDDD7f8PJdffnnj4yOPPNLtMGc1NjampUuXKpfLafXq1dq3b5+efvppnXzyyTrvvPMk1ZJDz5v/NeKRRx5pDI1+4AMf0I4dOxqPvfvd71Yul9OKFSv085//vCtx84qF1vjpHI6MXjhIwoD2FOqVsL7ZxDucyPbsyHkqVnGZay9pz/NUrR5bP25ycnLe55m+pnv0+fTncM6pXC63HN98zzG9Z2xoaEiVSkXOOXW6vvz0n59+jm7tu00lDK2JesJStnVRkSQM6EhfVcKq1do9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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": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "N_train=1000\n",
    "N_test=200\n",
    "M=40\n",
    "\n",
    "data_name='advection'+'_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": 35,
   "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[::100, :], 'test_Y' : test_y[::100], 'M' : M}\n",
    "test_data = {'test_X' : test_x, 'test_Y' : test_y, 'M' : M}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "file_name='advection_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='advection_test'+'_N'+str(N_train)+'_M'+str(M)+'.pickle'\n",
    "with open(\"../data/\"+file_name,\"wb\") as fw:\n",
    "    pickle.dump(test_data, fw)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([40000, 41]),\n",
       " torch.Size([40000]),\n",
       " torch.Size([80, 41]),\n",
       " torch.Size([80]))"
      ]
     },
     "execution_count": 37,
     "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
}
