{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "from torchdiffeq import odeint\n",
    "import sys; sys.path.append(2*'../')\n",
    "from src import *\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "device = torch.device('cpu') # for second gpu"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "source": [
    "class SpringMass(nn.Module):\n",
    "    \"\"\"\n",
    "    Spring-mass system\n",
    "    \"\"\"\n",
    "    def __init__(self, u, m=1., k=.5):\n",
    "        super().__init__()\n",
    "        self.u = u # controller (nn.Module)\n",
    "        self.nfe = 0 # number of function evaluations\n",
    "        self.cur_f = None # current function evaluation\n",
    "        self.cur_u = None # current controller evaluation \n",
    "        self.m, self.k = m, k # physics\n",
    "        \n",
    "    def forward(self, t, x):\n",
    "        self.nfe += 1\n",
    "        q, p = x[..., :1], x[..., 1:]\n",
    "        self.cur_u = self.u(t, x)\n",
    "        dq = p/self.m\n",
    "        dp = -self.k*q + self.cur_u\n",
    "        self.cur_f = torch.cat([dq, dp], -1)\n",
    "        return self.cur_f\n",
    "\n",
    "ControlledSystem = SpringMass\n",
    "def R(X, u, Δt, method, hypereuler=None):\n",
    "    system = ControlledSystem(RandConstController((1,1), -1, 1))\n",
    "    system.u.u0 = u\n",
    "    t_span = torch.tensor([0, Δt]).to(device)\n",
    "    with torch.no_grad():\n",
    "        x_fine = odeint(system, X, t_span, method='dopri5')[-1]\n",
    "        if hypereuler:\n",
    "            xfu = torch.cat([X, system(0, X), u], -1)\n",
    "            x_coarse =  X + Δt*system(0, X) + (Δt**2)*hypereuler(xfu)\n",
    "        else:\n",
    "            x_coarse = odeint(system, X, t_span, method=method)[-1]\n",
    "        return torch.norm(x_fine - x_coarse, p=2, dim=-1)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Compare multiple $\\Delta t$"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "source": [
    "def residual_loss(g, X, u, Δt, method, order=1):\n",
    "    system = ControlledSystem(RandConstController((1,1), -1, 1))\n",
    "    system.u.u0 = u    \n",
    "    t_span = torch.tensor([0, Δt]).to(device)\n",
    "    x_fine = odeint(system, X, t_span, method='dopri5')[-1]\n",
    "    x_coarse = odeint(system, X, t_span, method=method)[-1]\n",
    "    xfu = torch.cat([X, system(0, X), u], -1)\n",
    "    return torch.norm(x_fine - x_coarse - (Δt**(order+1))*g(xfu), p=2, dim=-1)/(Δt**(order+1))"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "Δt_test = [0.01, 0.03, 0.1, 0.3, 1.0]\n",
    "hs_list = []\n",
    "\n",
    "x_min_train, x_max_train = -5, 5\n",
    "u_lim = 20\n",
    "bs_hs = 1000\n",
    "n_grid = 100\n",
    "megalosses = []"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "source": [
    "\n",
    "# Train HyperEuler on multiple delta t\n",
    "for Δt in Δt_test:\n",
    "    print('Training HyperEuler with Δt = ',Δt, '...')\n",
    "    hdim = 32\n",
    "    hs = nn.Sequential(nn.Linear(5, 32), nn.Softplus(), nn.Linear(32, 32), nn.Tanh(), nn.Linear(32, 2)).to(device)\n",
    "    losses = []\n",
    "    opt_hs = torch.optim.Adam(hs.parameters(), lr=1e-3)\n",
    "    '''Hypersolver training loop with given Δt_test'''\n",
    "    for epoch in tqdm(range(10000)):\n",
    "        opt_hs.zero_grad()\n",
    "        # Randomize state and controller values\n",
    "        x = torch.Tensor(bs_hs, 2).uniform_(x_min_train, x_max_train).to(device)\n",
    "        #_grid = x.repeat(n_grid, 1, 1).detach()\n",
    "        u_rand = torch.Tensor(bs_hs, 1).uniform_(-u_lim, u_lim).to(device)\n",
    "        loss = residual_loss(hs, x[:, None, :], u_rand[:, None, :],  Δt, 'euler').mean()\n",
    "        # Optimization step\n",
    "        loss.backward()\n",
    "        opt_hs.step()\n",
    "        losses.append(loss.detach().cpu().item())\n",
    "        # print(f'Step: {epoch}, Residual loss: {loss:.3f}')\n",
    "    print(f'Residual loss: {loss:.3f}')\n",
    "    megalosses.append(losses)\n",
    "    torch.save(hs, f'saved_models/hs{Δt}.pt')\n",
    "    hs_list.append(hs)"
   ],
   "outputs": [
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "  0%|          | 20/10000 [00:00<00:51, 193.83it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "Training HyperEuler with Δt =  0.01 ...\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|██████████| 10000/10000 [00:50<00:00, 198.66it/s]\n",
      "  0%|          | 17/10000 [00:00<00:59, 168.39it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "Residual loss: 0.022\n",
      "Training HyperEuler with Δt =  0.03 ...\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|██████████| 10000/10000 [00:57<00:00, 173.40it/s]\n",
      "  0%|          | 15/10000 [00:00<01:09, 143.47it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "Residual loss: 0.013\n",
      "Training HyperEuler with Δt =  0.1 ...\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|██████████| 10000/10000 [01:02<00:00, 161.05it/s]\n",
      "  0%|          | 15/10000 [00:00<01:06, 149.31it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "Residual loss: 0.012\n",
      "Training HyperEuler with Δt =  0.3 ...\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|██████████| 10000/10000 [01:09<00:00, 143.18it/s]\n",
      "  0%|          | 10/10000 [00:00<01:46, 94.03it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "Residual loss: 0.025\n",
      "Training HyperEuler with Δt =  1.0 ...\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|██████████| 10000/10000 [01:59<00:00, 83.86it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "Residual loss: 0.009\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "\n"
     ]
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Comparison plot"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "source": [
    "hs_list = []\n",
    "for t in Δt_test:\n",
    "    hs_list.append(torch.load(f'saved_models/hs{t}.pt'))"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "n_x, n_u = 10000, 100\n",
    "x = torch.Tensor(n_x, 2).uniform_(-2, 2).to(device)\n",
    "qp = torch.linspace(x_min_train, x_max_train, 100) ; Q, P = torch.meshgrid(qp, qp) ; x = torch.cat([Q.reshape(-1, 1), P.reshape(-1, 1)], -1).to(device)\n",
    "u = torch.linspace(-u_lim, u_lim, n_u)[:,None].to(device)\n",
    "\n",
    "X = x.repeat(n_u, 1, 1)\n",
    "U = u.repeat(n_x, 1, 1).permute(1, 0, 2)\n",
    "X = X.cpu()\n",
    "U = U.cpu()\n",
    "res_eu, res_he, res_mp, res_rk, res_dp = [], [], [], [], []\n",
    "\n",
    "for Δt, i in zip(Δt_test, range(len(Δt_test))):\n",
    "    res_eu.append(R(X, U, Δt, 'euler').cpu()) \n",
    "    res_he.append(R(X, U, Δt, 'euler', hypereuler=hs_list[i].cpu()).cpu())\n",
    "    res_mp.append(R(X, U, Δt, 'midpoint').cpu())\n",
    "    res_rk.append(R(X, U, Δt, 'rk4').cpu())\n",
    "    res_dp.append(R(X, U, Δt, 'dopri5').cpu())\n",
    "u = u.cpu().squeeze()\n"
   ],
   "outputs": [
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "/home/botu/anaconda3/lib/python3.8/site-packages/torch/functional.py:445: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at  ../aten/src/ATen/native/TensorShape.cpp:2157.)\n",
      "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n"
     ]
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "source": [
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Palatino\"],\n",
    "})"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "source": [
    "\n",
    "\n",
    "alpha = .1\n",
    "\n",
    "fig, ax = plt.subplots(1, len(hs_list), figsize=(10, 2))\n",
    "# plt.tight_layout()\n",
    "\n",
    "for Δt, i in zip(Δt_test, range(len(Δt_test))):\n",
    "        # HyperEuler\n",
    "    ax[i].plot(u, res_he[i].mean(1), label='HyperEuler', color='tab:orange')\n",
    "    # ax[i].fill_between(u, res_he[i].mean(1) - res_he[i].std(1),\n",
    "    #                 res_he[i].mean(1) + res_he[i].std(1), alpha=alpha, color='tab:orange')\n",
    "    ax[i].plot(u, res_eu[i].mean(1), label='Euler', color='tab:red')\n",
    "    # ax[i].fill_between(u, res_eu[i].mean(1) - res_eu[i].std(1),\n",
    "    #                 res_eu[i].mean(1) + res_eu[i].std(1), alpha=alpha, color='tab:red')\n",
    "\n",
    "    ax[i].plot(u, res_mp[i].mean(1), label='Midpoint', color='tab:green')\n",
    "    # ax[i].fill_between(u, res_mp[i].mean(1) - res_mp[i].std(1),\n",
    "    #                 res_mp[i].mean(1) + res_mp[i].std(1), alpha=alpha, color='tab:green')\n",
    "    ax[i].plot(u, res_rk[i].mean(1), label='RK4', color='tab:purple')\n",
    "    # ax[i].fill_between(u, res_rk[i].mean(1) - res_rk[i].std(1),\n",
    "    #                 res_rk[i].mean(1) + res_rk[i].std(1), alpha=alpha, color='tab:purple')\n",
    "#     ax[i].plot(u, res_dp[i].mean(1), label='Dopri5', color='purple')\n",
    "#     ax[i].fill_between(u, res_dp[i].mean(1) - res_dp[i].std(1),\n",
    "#                     res_dp[i].mean(1) + res_dp[i].std(1), alpha=alpha, color='purple')\n",
    "    \n",
    "    ax[i].set_title(r'$\\epsilon = {}~[s]$'.format(Δt))\n",
    "    ax[i].set_xlabel(r'$u~[N]$')\n",
    "#     ax[i].legend()\n",
    "    ax[i].set_yscale('log')\n",
    "    ax[i].label_outer()\n",
    "    ax[i].set_ylim([1e-8, 1e2])\n",
    "    ax[i].set_yticks([1e-8, 1e-5, 1e-2, 1e01])\n",
    "#     ax[i].yaxis.set_major_locator(plt.MaxNLocator(5))\n",
    "    \n",
    "ax[0].set_ylabel(r'Mean Residual $R$')\n",
    "plt.legend(loc='lower center', ncol=1, bbox_to_anchor=(1.53, 0.15), fancybox=True)\n",
    "# plt.suptitle('Solver residuals with different step sizes',fontsize=14, weight='semibold', y=1.04)\n",
    "\n",
    "# ## Saving\n",
    "import tikzplotlib\n",
    "fig.savefig('media/residuals_spring_mass_multi_epsilon.pdf',  bbox_inches = 'tight')\n",
    "tikzplotlib.save(\"media/residuals_spring_mass_multi_epsilon.tex\")"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x144 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  }
 ],
 "metadata": {
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3.8.5 64-bit ('base': conda)"
  },
  "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"
  },
  "interpreter": {
   "hash": "d77f8d9122331bf0c813f643ab906d6086736a1197fa074182ffff0b1ac62f18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}