{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_folder = 'data'\n",
    "os.makedirs(save_folder, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 128\n",
    "ts = np.linspace(0, 3, N)\n",
    "dt = ts[1] - ts[0]\n",
    "xs = np.linspace(-4, 4, N)\n",
    "dx = xs[1] - xs[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen(ux0, u_x0) -> np.ndarray:\n",
    "    us = [ux0(xs)]\n",
    "    us.append(us[-1] + dt * (- us[-1] * u_x0(xs)))\n",
    "\n",
    "    for _ in range(2, len(ts)):\n",
    "        u_x = np.diff(us[-1]) / dx\n",
    "        u_x = np.concatenate([u_x[0].reshape(-1), u_x])\n",
    "        us.append(us[-1] + dt * (- us[-1] * u_x))\n",
    "    return np.stack(us)\n",
    "\n",
    "def pde_loss(u: np.ndarray, dx: np.ndarray, dt: np.ndarray) -> np.ndarray:\n",
    "    assert u.ndim == 3\n",
    "    u_t = np.diff(u, axis=1) / dt\n",
    "    u_x = np.diff(u, axis=2) / dx\n",
    "    return np.sqrt(np.square(u_t[:, :, :-1] + u[:, :-1, :-1] * u_x[:, :-1]).mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10000/10000 [00:17<00:00, 586.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pde loss: 0.15950947872635568\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(10000, 128, 128)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_samples = int(1e4)\n",
    "samples = []\n",
    "for _ in tqdm(range(n_samples)):\n",
    "    d = np.random.uniform(1, 6)\n",
    "    ux0 = lambda x: np.exp(-np.square(x) / d)\n",
    "    u_x0 = lambda x: - ux0(x) * x * 2 / d\n",
    "\n",
    "    samples.append(gen(ux0, u_x0))\n",
    "samples = np.stack(samples)\n",
    "print('pde loss:', pde_loss(samples, dx, dt))\n",
    "np.save(os.path.join(save_folder, 'train.npy'), samples)\n",
    "samples.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:06<00:00, 166.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pde loss: 0.15591565844515068\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(1000, 128, 128)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_samples = int(1e3)\n",
    "samples = []\n",
    "for _ in tqdm(range(n_samples)):\n",
    "    d = np.random.uniform(1, 6)\n",
    "    ux0 = lambda x: np.exp(-np.square(x) / d)\n",
    "    u_x0 = lambda x: - ux0(x) * x * 2 / d\n",
    "\n",
    "    samples.append(gen(ux0, u_x0))\n",
    "samples = np.stack(samples)\n",
    "print('pde loss:', pde_loss(samples, dx, dt))\n",
    "np.save(os.path.join(save_folder, 'val.npy'), samples)\n",
    "samples.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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zon8vAHghhtuwLhx4zB37lzLG+W7774bM2bMYPtPmDABycnJOHr0KHbs2KGNXV1dHfF92lafd0uOfdlll2HKlClYtmwZBg4cqJ375z//ialTp2LUqFFsfwB44oknkJ6eDr/fj71792rnIt0EtOSNeks+b8E9EuYGAjj2hr/66qtx9OhRfP/99wCATp06NbnLef78+dpj8+77V199FT/60Y/Y/tF+wQDN/5JJTk7GkiVLcP/992Pjxo3abuVBgwZZroocZ82aNRHndO2112LChAns+Za6eaHPecOGDaipqQEA5Obm4uyzz474nAH+eav/zcJorc8bABYsWIB27drhN7/5DW655ZbQjadSCnl5eZgzZw5mz55t2Xf8+PGh8ujRo3Ho0CHt/J/+9CcMGDBAnncrGvvRRx/Ftddei0GDBqFjx46hzKJvv/0W+/btw4gRI/Doo4+y/bt27YonnngCwLHPzYcffoihQ4eGzr/99tvo1auXZd9o/t5AdH/zlnzegnskTBpnS3P//ffjt7/9Laqrqxt9wcycOZP9ggGAiRMnao9HjhyprZbMnj0bmzdvxqpVq2Iz+SjZv3+/45uXpvjiiy/g9/tx8skn2+7j9/vxr3/9C3369GnWmE77t/Tz3rFjhzb28bBXc6mrq4PX60VKSkrEdvv379du3NrK827JsT/77DOsW7euUSpl7969oxp/3bp1SE5ObvQrnxKL9zlg72/eks9biB65gXCI218wQNNfMj/88AM2btyIrKwsnH766dq5w4cP48UXX8S4ceNc7wuEP+DHP9Sff/45fvvb3+LIkSP4+c9/josuuqjJvoMHD0avXr1s9y0rK7Os/+1vf4uf//znoXDTQw89FJP+ZqhuSEFBAcaMGWNbNySRNEdmzJiBq666KuJqXCz6tgZ2796NJUuW4N1338Xu3bvh8Xhwyimn4IorrsCECRPg9Xpj0lcQEpoW2755AlFVVaUmTpwYk/5btmwJ5WV7PB41dOhQ9c0334TOV1dXK4/HY7vvrl27bPVVSqnXX39d+f1+lZWVpVJSUtTrr7+uOnfurEpKStRFF12kvF6vqqiocL2vYRhqwIABatiwYdphGIY655xz1LBhw9SFF17Izjva/tHohpj7duvWzZHmyMaNG7XzTz/9tBo8eLA6+eST1fnnn6+ee+65mPRVSoXeJ6eeeqq677771O7duyO2d6vvcX73u9+p6667LjTPp59+WvXp00f16tVLlZeXq6NHj8ak7wcffKAyMzPVoEGD1JAhQ5TX61XXXXeduvrqq1WHDh3U4MGD1f79+13ve5xoNWbc1KihVFdXqzvvvDOm/b/66itLrYj6+nq1du3aJseItr8QHXID4QKbNm2K+B9xNP2vuOIK9ZOf/ER99913auvWreonP/mJKiwsVF9++aVSKvJNQDR9lVKquLhY/dd//ZdSSqnnnntOdezYUd12222h87feeqv68Y9/7HrfhQsXqsLCwkY3GD6fT33yySfsfN3qH41uSLSaI/3791dvvvmmUkqpJ554QqWmpqqbbrpJLVmyRM2cOVOlp6erZcuWud73+NxXr16tbr75ZtWpUyeVlJSkLr/8cvXqq6+qQCAQ6SWLqq9SSt11112qffv2qrS0VOXl5an77rtPZWdnq7vvvlvde++9qnPnzmrevHmu91VKqfPPP1/dcccdocd/+MMfVFFRkVJKqb1796oBAwaom266yfW+SkWvMRNt/0jE8ntt165d6pxzzlEejyd000VvBJr6boq2v+AOcgNhg7/85S8Rj4cffjjimzWa/jk5OWrz5s2hx8FgUN14442qa9euavv27RE/KNH0VUqpjIyM0JdPIBBQPp9Pyxv/6KOPVG5urut9lVLq/fffV6eddpq65ZZbQopydm8Aou0fjW5ItJojqampaufOnUqpY/ntjz/+uHb+2WefVaeffrrrfc1zr6+vVy+88IIaMWKE8nq9qqCgQN12223sf0bR9FVKqR49eqg//elPSqlj//F4vV71zDPPhM6vXLlS9ezZ0/W+Sh173bZv3x56HAgEVFJSkqqurlZKKfX3v/9dFRQUuN5Xqeg1ZqLp/69//Svi8cILL0T8foim/7hx41RRUZH64IMP1JtvvqkGDRqkzj77bLV3716l1LEbAMMw2LGj7S+4g9xA2OD48qxhGOwR6YMWTf/27durTz/9tFH9tGnT1Mknn6zeeeedmPRV6thNwLZt20KP09PTtS/LnTt3suqf0fQ9zoEDB9S4ceNU//791UcffaSSkpJs30BE058KURUUFDQSGYo092j6KnVMRGvDhg1KqWM3gJs2bdLOb9u2jRU1iqbv8blbSRd/+eWXav78+apbt27s+yWavkod+4/4+MqYUkolJSVpAmA7d+5UaWlprvdVSqlu3bqpd999N/R4165dyjCMkFTyjh072L9ZNH2Pz725IlbR9o/0vUQlqTmi6V9QUKDWr18fenz48GE1atQoNWDAALVnz54mf9xE219wB7HztkF+fj5WrlyJYDBoeXz44Ycx69+7d29s2LChUf2jjz6K0aNH4/LLL49JXwDo3r07tm7dGnpcWVmJrl27hh5XVVU1EuVyo+9x0tPTsXz5cpSXl6OkpCSk/WGXaPoPHz4cZ511Vkg3hNKUbkg0fUeOHIklS5YAAC644AL88Y9/1M6/+OKL6Nmzp+t9I9G1a1fccccd2LFjh+NMIbt98/Ly8OmnnwIAtm7dikAgEHoMAJ988glrnhZNXwC44oorcOONN2LVqlV4++23MXbsWFxwwQVITU0FAGzZsgUnnXSS632BsMYMR1MaM9H0z8rKwhNPPIEdO3Y0Or744gv89a9/Za8bbf/a2lp07Ngx9Dg5ORkrV65E9+7dceGFF+Lbb7+NOHa0/QV3SCgdiJZi0KBB2LhxI0aPHm153jAMqAjJLNH0/z//5//gueeew3XXXdfo3KOPPopgMIilS5e63hcApk6dqv2naxbSev3119lMimj6mhkzZgyGDBmCjRs3olu3brb6RNM/Gt2QaDVH7r//fpx//vm44IILcPbZZ+O///u/sWbNGvTp0wdbtmzBunXr8Oc//9n1vgDQrVu3iBkDhmHgxz/+set9AWDs2LEYN24cRo8ejYqKCsyePRu/+tWvsGfPHhiGgXvuuQc//elPXe8LAHfffTd2796NUaNGIRAIoLi4GM8884w294ULF7reF4heYyaa/oMGDcKuXbvYz8S+ffua/F5rbv9TTjkFmzdvxqmnnhqq8/l8eOmll/Czn/0Ml112GTuuG/0Fl2jZBZDE4J133lGvv/46e/7gwYMRvRui7S+0Lf7zn/+oOXPmqNNPP12lpKQov9+vunXrpq699lr1wQcfxKxvSxIIBNQ999yjLrvsMnXvvfeqYDConnvuOdWlSxeVnZ2tJkyYoA4ePOh6X8oPP/wQ0TE0Vn3vu+8+lZ+fH1ryP778n5+fb8sQqrn9V65cqf7whz+w5/fu3aueeuqpmPSfPXs2uzfj6NGj6vLLL4+4hyHa/oI7iA6EIAhCKyBajZlYaNTEioaGBhw6dIgVq2poaMA333zDrm5E219wB9kDIQiC0AooLCxEcXExiouLQ//5f/XVV7j++uvj0t9MNH2b6u/z+SIqXe7evRt33nknez7a/oI7yAqEIAhCK+Vf//oXzjrrLMcbiN3o31bHFuwjmygFQRBaiFdeeSXi+S+++CJm/dvq2IJ7yAqEIAhCC+HxeJrM4jIMg/0lHU3/tjq24B6yB0IQBKGFaEmNmbY6tuAecgMhCILQQhzXiOGwqzHTnP5tdWzBPWQPhCAIQgvx61//GnV1dez5nj174u23345J/7Y6tuAesgdCEARBEATHSAhDEARBEATHyA2EIAiCIAiOkRsIQRAEQRAcIzcQgiAIgiA4Rm4gBEEQBEFwjNxACIIgCILgGLmBEARBEATBMXIDIQiCIAiCY/4/W2bl/Qy6Bq8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.heatmap(data=samples[0])"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch",
   "language": "python",
   "name": "python3"
  },
  "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.11.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
