{
 "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": "markdown",
   "metadata": {},
   "source": [
    "## Identity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "## load dataset\n",
    "N_train=1000\n",
    "N_test=200\n",
    "num_sensor=50\n",
    "D=torch.linspace(-1,1,num_sensor)\n",
    "\n",
    "data_name='id'+'_N'+str(N_train)+'_M'+str(num_sensor)+'.pickle'\n",
    "with open(\"../data/\"+data_name,\"rb\") as fr:\n",
    "    raw_set= pickle.load(fr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'train_X': tensor([[ 1.3521, -0.6524, -0.1991,  ..., -0.6846, -0.4245, -1.0000],\n",
       "         [ 1.3521, -0.6524, -0.1991,  ..., -0.6846, -0.4245, -0.9592],\n",
       "         [ 1.3521, -0.6524, -0.1991,  ..., -0.6846, -0.4245, -0.9184],\n",
       "         ...,\n",
       "         [ 0.1485, -0.4007, -0.3985,  ...,  0.1865, -1.6206,  0.9184],\n",
       "         [ 0.1485, -0.4007, -0.3985,  ...,  0.1865, -1.6206,  0.9592],\n",
       "         [ 0.1485, -0.4007, -0.3985,  ...,  0.1865, -1.6206,  1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'train_Y': tensor([ 1.3521, -0.6524, -0.1991,  ..., -0.6283,  0.1865, -1.6206],\n",
       "        dtype=torch.float64),\n",
       " 'test_X': tensor([[-1.1728,  0.8030,  0.2777,  ...,  0.1532, -0.0067, -1.0000],\n",
       "         [-1.1728,  0.8030,  0.2777,  ...,  0.1532, -0.0067, -0.9592],\n",
       "         [-1.1728,  0.8030,  0.2777,  ...,  0.1532, -0.0067, -0.9184],\n",
       "         ...,\n",
       "         [ 0.0132, -0.1927,  0.1315,  ..., -0.7111,  0.8183,  0.9184],\n",
       "         [ 0.0132, -0.1927,  0.1315,  ..., -0.7111,  0.8183,  0.9592],\n",
       "         [ 0.0132, -0.1927,  0.1315,  ..., -0.7111,  0.8183,  1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'test_Y': tensor([-1.1728,  0.8030,  0.2777,  ...,  0.4259, -0.7111,  0.8183],\n",
       "        dtype=torch.float64),\n",
       " 'M': 50}"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 1.3521, -0.6524, -0.1991,  ..., -1.0088, -0.6846, -0.4245],\n",
       "        [ 0.4699, -0.0741, -0.6618,  ..., -0.4262, -0.3074, -0.0163],\n",
       "        [ 0.7252,  0.2546, -0.1409,  ..., -0.2196,  0.5358, -0.9360],\n",
       "        ...,\n",
       "        [-0.1959, -0.4476, -0.1594,  ..., -0.6530, -0.4281,  0.4177],\n",
       "        [ 0.5854, -0.7368, -0.1699,  ..., -0.1434,  0.5229, -0.7909],\n",
       "        [ 0.1485, -0.4007, -0.3985,  ..., -0.6283,  0.1865, -1.6206]],\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 1.3521, -0.6524, -0.1991,  ..., -1.0088, -0.6846, -0.4245],\n",
       "        [ 0.4699, -0.0741, -0.6618,  ..., -0.4262, -0.3074, -0.0163],\n",
       "        [ 0.7252,  0.2546, -0.1409,  ..., -0.2196,  0.5358, -0.9360],\n",
       "        ...,\n",
       "        [-0.1959, -0.4476, -0.1594,  ..., -0.6530, -0.4281,  0.4177],\n",
       "        [ 0.5854, -0.7368, -0.1699,  ..., -0.1434,  0.5229, -0.7909],\n",
       "        [ 0.1485, -0.4007, -0.3985,  ..., -0.6283,  0.1865, -1.6206]],\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 50])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 50])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x=raw_set['train_X'][::num_sensor][:,:-1]\n",
    "train_y=raw_set['train_Y'].reshape(N_train,num_sensor)\n",
    "test_x=raw_set['test_X'][::num_sensor][:,:-1]\n",
    "test_y=raw_set['test_Y'].reshape(N_test,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../data/fno_data/\"+'fno_'+data_name,\"wb\") as fw:\n",
    "    pickle.dump(data, fw)\n",
    "load_data=data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f4fbff81880>"
      ]
     },
     "execution_count": 11,
     "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_train)\n",
    "\n",
    "x=load_data['train_X'][idx]\n",
    "y=load_data['train_Y'][idx]\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": [
    "## Differentiation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "## load dataset\n",
    "N_train=1000\n",
    "N_test=200\n",
    "num_sensor=100\n",
    "D=torch.linspace(-1,1,num_sensor)\n",
    "\n",
    "data_name='diff'+'_N'+str(N_train)+'_M'+str(num_sensor)+'.pickle'\n",
    "with open(\"../data/\"+data_name,\"rb\") as fr:\n",
    "    raw_set= pickle.load(fr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'train_X': tensor([[ 0.0000, -0.0157, -0.0400,  ..., -0.3931, -0.4019, -1.0000],\n",
       "         [ 0.0000, -0.0157, -0.0400,  ..., -0.3931, -0.4019, -0.9798],\n",
       "         [ 0.0000, -0.0157, -0.0400,  ..., -0.3931, -0.4019, -0.9596],\n",
       "         ...,\n",
       "         [ 0.0000, -0.0072, -0.0258,  ..., -0.2025, -0.2023,  0.9596],\n",
       "         [ 0.0000, -0.0072, -0.0258,  ..., -0.2025, -0.2023,  0.9798],\n",
       "         [ 0.0000, -0.0072, -0.0258,  ..., -0.2025, -0.2023,  1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'train_Y': tensor([ 0.5404, -1.3619, -0.9050,  ...,  0.4790, -0.0153,  0.4410],\n",
       "        dtype=torch.float64),\n",
       " 'test_X': tensor([[ 0.0000,  0.0126,  0.0149,  ...,  0.0906,  0.1012, -1.0000],\n",
       "         [ 0.0000,  0.0126,  0.0149,  ...,  0.0906,  0.1012, -0.9798],\n",
       "         [ 0.0000,  0.0126,  0.0149,  ...,  0.0906,  0.1012, -0.9596],\n",
       "         ...,\n",
       "         [ 0.0000,  0.0036,  0.0031,  ..., -0.1140, -0.1146,  0.9596],\n",
       "         [ 0.0000,  0.0036,  0.0031,  ..., -0.1140, -0.1146,  0.9798],\n",
       "         [ 0.0000,  0.0036,  0.0031,  ..., -0.1140, -0.1146,  1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'test_Y': tensor([ 0.9928,  0.3123, -0.0325,  ..., -0.4229, -0.5702,  1.0223],\n",
       "        dtype=torch.float64),\n",
       " 'M': 100}"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 0.0000e+00, -1.5685e-02, -3.9966e-02,  ..., -3.8235e-01,\n",
       "         -3.9311e-01, -4.0190e-01],\n",
       "        [ 0.0000e+00, -3.8325e-04,  5.3749e-03,  ...,  2.4198e-01,\n",
       "          2.5353e-01,  2.7113e-01],\n",
       "        [ 0.0000e+00, -2.8646e-03, -3.1887e-03,  ...,  4.0737e-02,\n",
       "          4.5497e-02,  5.6447e-02],\n",
       "        ...,\n",
       "        [ 0.0000e+00,  9.7046e-04,  3.6308e-03,  ...,  1.3001e-01,\n",
       "          1.3189e-01,  1.4273e-01],\n",
       "        [ 0.0000e+00,  7.7772e-03,  8.3598e-03,  ..., -1.8670e-01,\n",
       "         -1.7937e-01, -1.8236e-01],\n",
       "        [ 0.0000e+00, -7.1927e-03, -2.5800e-02,  ..., -2.0735e-01,\n",
       "         -2.0248e-01, -2.0230e-01]], dtype=torch.float64)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 0.5404, -1.3619, -0.9050,  ..., -0.4581, -0.5299, -0.3798],\n",
       "        [-0.0748,  0.1022,  0.4696,  ...,  0.3423,  0.7832,  0.8326],\n",
       "        [-0.1739, -0.0475, -0.0513,  ...,  0.0064,  0.4862,  0.2971],\n",
       "        ...,\n",
       "        [ 0.7624, -0.1236,  0.4009,  ..., -0.3048,  0.4946,  0.1007],\n",
       "        [ 0.5389,  0.1945, -0.0996,  ...,  0.4916,  0.1313, -0.2870],\n",
       "        [ 0.8383, -0.9841, -0.6820,  ...,  0.4790, -0.0153,  0.4410]],\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 100])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 100])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x=raw_set['train_X'][::num_sensor][:,:-1]\n",
    "train_y=raw_set['train_Y'].reshape(N_train,num_sensor)\n",
    "test_x=raw_set['test_X'][::num_sensor][:,:-1]\n",
    "test_y=raw_set['test_Y'].reshape(N_test,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../data/fno_data/\"+'fno_'+data_name,\"wb\") as fw:\n",
    "    pickle.dump(data, fw)\n",
    "load_data=data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f4fbfe50b50>"
      ]
     },
     "execution_count": 21,
     "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_train)\n",
    "\n",
    "x=load_data['train_X'][idx]\n",
    "y=load_data['train_Y'][idx]\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": [
    "## Advection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "## load dataset\n",
    "N_train=1000\n",
    "N_test=200\n",
    "num_sensor=40\n",
    "D=torch.linspace(-1,1,num_sensor)\n",
    "\n",
    "data_name='advection'+'_N'+str(N_train)+'_M'+str(num_sensor)+'.pickle'\n",
    "with open(\"../data/\"+data_name,\"rb\") as fr:\n",
    "    raw_set= pickle.load(fr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'train_X': tensor([[0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0000],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0256],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0513],\n",
       "         ...,\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.9487],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.9744],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 1.0000]]),\n",
       " 'train_Y': tensor([1.6517, 0.0000, 0.0000,  ..., 1.1660, 1.1660, 1.1660]),\n",
       " 'test_X': tensor([[0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0000],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0256],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0513],\n",
       "         ...,\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.9487],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.9744],\n",
       "         [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'test_Y': tensor([1.8125, 1.8125, 1.8125,  ..., 1.0283, 1.0283, 1.0283]),\n",
       " 'M': 40}"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        ...,\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.],\n",
       "        [0., 0., 0.,  ..., 0., 0., 0.]])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.6517, 0.0000, 0.0000,  ..., 1.6517, 1.6517, 1.6517],\n",
       "        [1.2201, 1.2201, 1.2201,  ..., 1.2201, 1.2201, 1.2201],\n",
       "        [1.3061, 1.3061, 1.3061,  ..., 1.3061, 1.3061, 1.3061],\n",
       "        ...,\n",
       "        [1.5362, 0.0000, 0.0000,  ..., 1.5362, 1.5362, 1.5362],\n",
       "        [1.9259, 1.9259, 1.9259,  ..., 0.0000, 1.9259, 1.9259],\n",
       "        [1.1660, 1.1660, 1.1660,  ..., 1.1660, 1.1660, 1.1660]])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 40])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 40])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x=raw_set['train_X'][::num_sensor][:,:-1]\n",
    "train_y=raw_set['train_Y'].reshape(N_train,num_sensor)\n",
    "test_x=raw_set['test_X'][::num_sensor][:,:-1]\n",
    "test_y=raw_set['test_Y'].reshape(N_test,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "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": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../data/fno_data/\"+'fno_'+data_name,\"wb\") as fw:\n",
    "    pickle.dump(data, fw)\n",
    "load_data=data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f4fbfde7d60>"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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jiwBDmpV/+cSkfmptb94d6ikICyT2gnDlwDvds79jnPu/3HOjQI0a7f+/UwPcs7Vgc3A14HHgb91zu02syvN7Mrmbh8H1prZj4B/Aq5zzv1yAdfTMbZs2cL+/VMTg+3bu3cvd95554zbr732Ws466yyuvfbaeZ9jql27drF9+/aJv7dt28aNN944yyMk1MiE5fyfKHxjV12YSHoF5UbWeg7CIEzdkdly1K/mzrkbZtn2+FEeux3YPuW+W1pu7wf+3dGbmT1btmzh7LPP5sQTT5zX48MgLFzLcaovfOELHDhw4GXLCS3Url27GB4e5sILLwRgw4YNbNiwIbLjZ1k1GGPFkl7/JwqDsKAMA6/xfz4RmbugMudMWNgdqRGS2aIZ8yPyqU99irPPPpuzzz6bT3/600AjUDr77LMn9rnpppv46Ec/yt13383w8DCXXHIJq1ev5vDhwyxfvpzrrruOoaEhhoaG2LNnDwCbNm3i7rvvnjhGqdT49nT99dfzrW99i9WrVx8xm/6GDRuoVqusWbOGrVu3zniMBx54gHXr1nHxxRdz+umnc8kll0ys+7hjxw7Wrl3LqlWrGBoa4sUXX+SGG25g69atE7Ppb9myhc2bNwPw1FNPsX79elauXMn69et5+umnJ9p/9dVXs3btWk499dSXtaOblEfqlOLMhKk4XyS9gvKcivKhsYA3KBOWNZlbwJv7r4d//VG0x3zNb8IFM3e77dy5k9tvv51HH30U5xxr1qzhbW97G8cdN/30ahdffDE333wzN910E4ODk5PoLl68mO9+97vccccdXHPNNdx3330znvPGG2/kpptumnafbdu2USqV2LVrFwD333//jMf5/ve/z+7duznxxBN5y1vewre//W2GhoZ4z3vew9atWznnnHM4dOgQxxxzDB/72McYHh7m5ptvBhrZvNDmzZu57LLLeP/7389tt93G1VdfzT333APAs88+y0MPPcRPfvITNmzYwMUXXzxje7KqGtT9L1kEk2/sCsJE0qtWgWNfO6eHTBTma/3ITFEmLAIPPfQQ73rXu+jv76dUKvHud7+bb33rW3M+zsaNGyd+P/LII1E3c1pDQ0MsW7aMnp4eVq9ezd69e3niiSc44YQTOOecc4BGcJjPzx5APPLIIxNdo5deeikPPfTQxLZ3vvOd9PT0cOaZZ/Lcc8/5u5iUGht3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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_train)\n",
    "\n",
    "x=load_data['train_X'][idx]\n",
    "y=load_data['train_Y'][idx]\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": [
    "## Burgers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "## load dataset\n",
    "N_train=1000\n",
    "N_test=200\n",
    "num_sensor=128\n",
    "D=torch.linspace(-1,1,num_sensor)\n",
    "\n",
    "data_name='burgers'+'_N'+str(N_train)+'_M'+str(num_sensor)+'.pickle'\n",
    "with open(\"../data/\"+data_name,\"rb\") as fr:\n",
    "    raw_set= pickle.load(fr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'train_X': tensor([[ 0.8354,  0.8267,  0.8107,  ...,  0.8304,  0.8357,  0.0000],\n",
       "         [ 0.8354,  0.8267,  0.8107,  ...,  0.8304,  0.8357,  0.0079],\n",
       "         [ 0.8354,  0.8267,  0.8107,  ...,  0.8304,  0.8357,  0.0157],\n",
       "         ...,\n",
       "         [-0.5274, -0.5399, -0.5536,  ..., -0.4987, -0.5146,  0.9843],\n",
       "         [-0.5274, -0.5399, -0.5536,  ..., -0.4987, -0.5146,  0.9921],\n",
       "         [-0.5274, -0.5399, -0.5536,  ..., -0.4987, -0.5146,  1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'train_Y': tensor([ 0.6835,  0.6958,  0.7070,  ..., -0.3977, -0.3885, -0.3775],\n",
       "        dtype=torch.float64),\n",
       " 'test_X': tensor([[0.0283, 0.0331, 0.0233,  ..., 0.0080, 0.0172, 0.0000],\n",
       "         [0.0283, 0.0331, 0.0233,  ..., 0.0080, 0.0172, 0.0079],\n",
       "         [0.0283, 0.0331, 0.0233,  ..., 0.0080, 0.0172, 0.0157],\n",
       "         ...,\n",
       "         [1.4525, 1.3956, 1.3158,  ..., 1.4978, 1.4842, 0.9843],\n",
       "         [1.4525, 1.3956, 1.3158,  ..., 1.4978, 1.4842, 0.9921],\n",
       "         [1.4525, 1.3956, 1.3158,  ..., 1.4978, 1.4842, 1.0000]],\n",
       "        dtype=torch.float64),\n",
       " 'test_Y': tensor([ 0.0016, -0.0181, -0.0362,  ...,  0.9517,  0.9802,  1.0084],\n",
       "        dtype=torch.float64),\n",
       " 'M': 128}"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 0.8354,  0.8267,  0.8107,  ...,  0.8252,  0.8304,  0.8357],\n",
       "        [ 0.4741,  0.4643,  0.4621,  ...,  0.5591,  0.5243,  0.4944],\n",
       "        [-0.3802, -0.4201, -0.4563,  ..., -0.3420, -0.3369, -0.3495],\n",
       "        ...,\n",
       "        [ 0.0938,  0.1235,  0.1648,  ...,  0.0505,  0.0621,  0.0747],\n",
       "        [ 0.4329,  0.4355,  0.4356,  ...,  0.3607,  0.3990,  0.4224],\n",
       "        [-0.5274, -0.5399, -0.5536,  ..., -0.4784, -0.4987, -0.5146]],\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 0.6835,  0.6958,  0.7070,  ...,  0.6417,  0.6563,  0.6702],\n",
       "        [ 0.7511,  0.7437,  0.7341,  ...,  0.7584,  0.7585,  0.7560],\n",
       "        [-0.4153, -0.4185, -0.4197,  ..., -0.3925, -0.4025, -0.4101],\n",
       "        ...,\n",
       "        [ 0.1056,  0.1260,  0.1468,  ...,  0.0465,  0.0659,  0.0856],\n",
       "        [ 0.1920,  0.2072,  0.2212,  ...,  0.1410,  0.1587,  0.1758],\n",
       "        [-0.3649, -0.3507, -0.3353,  ..., -0.3977, -0.3885, -0.3775]],\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 128])"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_X'][::num_sensor][:,:-1].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 128])"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "raw_set['train_Y'].reshape(N_train,num_sensor).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x=raw_set['train_X'][::num_sensor][:,:-1]\n",
    "train_y=raw_set['train_Y'].reshape(N_train,num_sensor)\n",
    "test_x=raw_set['test_X'][::num_sensor][:,:-1]\n",
    "test_y=raw_set['test_Y'].reshape(N_test,num_sensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "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": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../data/fno_data/\"+'fno_'+data_name,\"wb\") as fw:\n",
    "    pickle.dump(data, fw)\n",
    "load_data=data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f4fbffc3fa0>"
      ]
     },
     "execution_count": 41,
     "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_train)\n",
    "\n",
    "x=load_data['train_X'][idx]\n",
    "y=load_data['train_Y'][idx]\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
}
