{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6c51b7ed-1200-44e1-a8b6-732c1e0539b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "983220d6-1de0-48ab-8dc1-9aee3436060c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from torch.optim import Adam\n",
    "\n",
    "from ic_surrogates_abm.models import sirs_ode, sirs_spatial\n",
    "from ic_surrogates_abm import training_ode_grid_sirs\n",
    "from ic_surrogates_abm.networks import MLP, RNN, count_pars\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "82b04d62-39b1-412e-8d1f-762861a13272",
   "metadata": {},
   "source": [
    "# Simulation setup"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67969056-693c-492a-9215-b638677f04ea",
   "metadata": {},
   "source": [
    "Move this cell to a `utils` folder or something?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "76d9178a-988a-4feb-8161-84adef156384",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Number of grid cells in horiz and vertical directions\n",
    "L = 50\n",
    "# Total number of agents\n",
    "N = L ** 2\n",
    "# Total number of time steps\n",
    "T = 50\n",
    "\n",
    "def run_spatial_intervention(params, i, i0, T):\n",
    "\n",
    "    # TODO: change kwarg N to L here\n",
    "    model = sirs_spatial.SIRS(n_timesteps=T, i0=i0, N=L)\n",
    "    x_grid = model.initialize(params)\n",
    "    true_i0 = (x_grid == 1).sum() / N\n",
    "    x = torch.tensor([1. - true_i0, true_i0, 0.]).unsqueeze(0)\n",
    "    initial_state = x_grid.clone()\n",
    "    for t in range(T):\n",
    "        if (i > 0) and (t >= 5 + i - 1) and (t <= 10 + i - 1):\n",
    "            int_pars = params * torch.tensor([0., 1., 1.])\n",
    "            x_grid = model.step(int_pars, x_grid)\n",
    "        else:\n",
    "            x_grid = model.step(params, x_grid)\n",
    "        x_new = torch.tensor([(x_grid == 0).sum(), (x_grid == 1).sum(), (x_grid == 2).sum()]) / N\n",
    "        x = torch.cat((x, x_new.unsqueeze(0)), dim=0)\n",
    "    return initial_state, x"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e6c4ddb2-5032-4c43-a4d0-3727660e0f1e",
   "metadata": {},
   "source": [
    "## Collect data from ABM"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "edab7b74-9893-4336-9377-530eda2c7718",
   "metadata": {},
   "source": [
    "### First observational"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "aaa510ed-02a9-46f8-bd2d-959712a56360",
   "metadata": {},
   "outputs": [],
   "source": [
    "def collect_data(R=1000, intervene=False):\n",
    "\n",
    "    init_states = []\n",
    "    xs = []\n",
    "    this = []\n",
    "    \n",
    "    for i in range(R):\n",
    "        # Draw initial proportion of infected individuals from Uniform(0,1)\n",
    "        i0 = torch.rand(1)\n",
    "        # Same for the three parameters\n",
    "        alpha, beta, gamma = torch.rand(1), torch.rand(1), torch.rand(1)\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # Start a lockdown for 5 time steps at time t = intervention if intervention != 0, else no lockdown\n",
    "        if intervene:\n",
    "            intervention = torch.randint(0, 5, (1,)).item()\n",
    "        else:\n",
    "            intervention = 0\n",
    "        # Collect data points\n",
    "        init_state, x = run_spatial_intervention(params, intervention, i0, T)\n",
    "        init_states.append(init_state)\n",
    "        xs.append(x)\n",
    "        this.append(torch.cat((params, torch.tensor([intervention])), dim=-1))\n",
    "    \n",
    "    xs = torch.stack(xs)\n",
    "    init_states = torch.stack(init_states)\n",
    "    this = torch.stack(this)\n",
    "\n",
    "    return xs, init_states, this"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8e6c4aa7-a874-4851-aeea-ccdde5f9c2d8",
   "metadata": {},
   "source": [
    "#### Train data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e5667d01-76a4-4f79-a532-e3243ee372e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "xs_train_obs, init_states_train_obs, this_train_obs = collect_data()\n",
    "\n",
    "torch.save(xs_train_obs, \"./sirs_ode_spatial/aggregate_ts_OBS.pt\")\n",
    "torch.save(init_states_train_obs, \"./sirs_ode_spatial/initial_grids_OBS.pt\")\n",
    "torch.save(this_train_obs, \"./sirs_ode_spatial/par_intervention_OBS.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ed0ced4f-0853-4d9c-8d4c-394cdaa8407f",
   "metadata": {},
   "source": [
    "#### Test data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "37e117fd-0086-4b50-b71e-925bc45ea35e",
   "metadata": {},
   "outputs": [],
   "source": [
    "xs_test_obs, init_states_test_obs, this_test_obs = collect_data()\n",
    "\n",
    "torch.save(xs_test_obs, \"./sirs_ode_spatial/aggregate_ts_OBS_TEST.pt\")\n",
    "torch.save(init_states_test_obs, \"./sirs_ode_spatial/initial_grids_OBS_TEST.pt\")\n",
    "torch.save(this_test_obs, \"./sirs_ode_spatial/par_intervention_OBS_TEST.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cd5e7fe4-1766-4e99-9db8-a7f4362c2854",
   "metadata": {},
   "source": [
    "### Now interventional"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87318503-e815-41bd-b088-700b794cd5dc",
   "metadata": {},
   "source": [
    "#### Train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "7747057e-dfe7-4e34-9cd7-4597acf61e6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "xs_train_int, init_states_train_int, this_train_int = collect_data(intervene=True)\n",
    "\n",
    "torch.save(xs_train_int, \"./sirs_ode_spatial/aggregate_ts_INT.pt\")\n",
    "torch.save(init_states_train_int, \"./sirs_ode_spatial/initial_grids_INT.pt\")\n",
    "torch.save(this_train_int, \"./sirs_ode_spatial/par_intervention_INT.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0f87ad0b-63aa-498e-b6eb-de7ad9ca9912",
   "metadata": {},
   "source": [
    "#### Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "013dcf7a-80e3-4cb0-b1dd-495d81753235",
   "metadata": {},
   "outputs": [],
   "source": [
    "xs_test_int, init_states_test_int, this_test_int = collect_data(intervene=True)\n",
    "\n",
    "torch.save(xs_test_int, \"./sirs_ode_spatial/aggregate_ts_INT_TEST.pt\")\n",
    "torch.save(init_states_test_int, \"./sirs_ode_spatial/initial_grids_INT_TEST.pt\")\n",
    "torch.save(this_test_int, \"./sirs_ode_spatial/par_intervention_INT_TEST.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a8b52073-f233-41cf-a8be-fa4c2eea9625",
   "metadata": {},
   "source": [
    "## Visual comparison of ABM and ODE behaviour"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3ffc75fb-99e3-4923-943d-c1af0072777a",
   "metadata": {},
   "outputs": [],
   "source": [
    "t = torch.linspace(0., T, T + 1)\n",
    "model = sirs_ode.SIRSODE_naive_int(t)\n",
    "# For plotting\n",
    "eps = 1e-2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "e84b96c8-9019-4930-b742-888e4317377f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqgAAADdCAYAAAB3yIAHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB/rUlEQVR4nO3dd3gU1d7A8e/23fTeExJ6D01CUVCMBkUUEcVypXjtYMOKBcSGXSwoWMHXjldRaYIICNJ774GE9JBets/7xyRLQhJI301yPnnm2d2pZya7Z3975hSFJEkSgiAIgiAIguAilM5OgCAIgiAIgiBUJAJUQRAEQRAEwaWIAFUQBEEQBEFwKSJAFQRBEARBEFyKCFAFQRAEQRAElyICVEEQBEEQBMGliABVEARBEARBcCkiQBUEQRAEQRBcighQBUEQBEEQBJciAlRBEARBEATBpYgAVRAEQRAEQXApIkAVmk1RURFKpZL33nvP2UkRhEYlSRLvvPMOnTp1QqvVEh4ezowZM5AkydlJE4RaE3m04EpEgCo0m/379yNJEr179wbAZDLx9NNPExYWhsFgIC4ujlWrVjVLWhrj2Dt37uT666/Hz88PNzc3evbsyQcffFBpnaKiImbOnMnIkSPx8/NDoVCwYMGCKvuq7XotTWP+j1999VUUCgU9e/asNP/AgQPcfPPNtG/fHjc3NwICAhg2bBh//PFHlX1s27aNqVOn0qNHD9zd3YmKiuKWW27h6NGj9UpTuSeffJInn3ySyy67jA8//JDBgwfz8ssvs2jRogbt92Iacn3rct3Wrl2LQqGodtq8ebNjvdb4Pna1vOJ8NX0u6uP8PLqx1eU9JwhIgtBMbDabVFpaKtntdkmSJOnWW2+V1Gq19MQTT0jz58+XBg8eLKnVamn9+vVNnpaGHvvPP/+UtFqtFBcXJ7377rvSp59+Kj399NPSk08+WWm9xMRECZCioqKkyy+/XAKkr776qsr+arteS9NY/+Pk5GTJzc1Ncnd3l3r06FFp2dKlS6WEhATpxRdflD799FNpzpw50mWXXSYB0vz58yute9NNN0khISHSQw89JH322WfSyy+/LAUHB0vu7u7Svn376nWOJ0+elFQqlfTCCy845pnNZsnDw0N67LHH6rXP2mrI9a3LdVuzZo0ESA8//LD0f//3f5WmrKwsx3qt8X3sanlFRRf6XNTH+Xl0Y6vLe04QRIAqOMWWLVskQHrrrbcc80pLS6UOHTpIgwcPdulj5+fnS8HBwdKNN94o2Wy2C65rNBqltLQ0SZIkadu2bTV+6dR2vZakMf/H48ePl0aMGCENHz68Vl/EVqtVio2Nlbp06VJp/r///iuZTKZK844ePSrpdDrpjjvuqFOayr3zzjuSUqmUMjMzHfPsdrvk4eEhPfvss/XaZ200xWeoputWHqAuWrTogtu3tvexK+YVFdX1c+GKanrPCYK4xS80m6uuuoqhQ4cC8PPPP6NSqbj33nsdy/V6Pf/973/ZtGkTycnJTZaOhh77u+++IyMjg1dffRWlUklxcTF2u73adXU6HSEhIRdNU23XK3f48GGSkpJqvf6PP/5Iv379MBgMdOvWjb/++gtJkujRowevvvpqrfdTF431P/7nn3/4+eefmTNnTq2PrVKpiIyMJC8vr9L8IUOGoNVqK83r1KkTPXr04NChQ5Xm1/Yab9myha5duxIYGOiYt2fPHoqKiprsVik0zWeoputWUWFhIVartdplTfU+vvvuuwkICODHH3+ssmz58uUoFAqWLl1a6+PWlivmFeVq+7moS15RMY9uLrV5zwltkwhQhWazd+9exxf2rl276Ny5M15eXpXWGThwIAC7d++udh8Wi4Xs7OxaTTV9EdT32OX++usvvLy8SElJoUuXLnh4eODl5cUDDzyA0Wi82GVoFN26dWPChAm1Wvf555/n1ltvJTY2lrfffhubzcaECRNYtmwZZ86cYerUqVW2cYXrDGCz2XjooYe4++676dWr1wXXLS4uJjs7mxMnTvDee++xfPlyrrzyyoseQ5IkMjIyCAgIqDS/ttd43759xMbGVpr31ltvodfrueqqq6rdxlWuL9Ttuk2ePBkvLy/0ej1XXHEF27dvr9UxalLba3zzzTfj5+fHrFmzKs2XJInp06czbNgwRo0aVWmZK1zjpsor6vK5qEteUTGPPl9jXM9y9f2sCm2L2tkJENqGzMxMMjMzHZlfWloaoaGhVdYrn5eamlrtfv7991+uuOKKWh0zMTGR6OjoKvPre+xyx44dw2q1csMNN/Df//6X2bNns3btWj788EPy8vL4/vvva5W+5rB+/XpeffVVnn76aV5//XUAQkJCGDduHM888wwPPPAA3t7eVbZzhesMMG/ePE6fPs1f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SwcPHqy0bmO/jyu65557JEDy8fGRcnJyar1dQ7hiXnG+C3XUX5trXFMe3djq8p4TBBGgCk3up59+kgDpwIEDleaXlpZKTzzxhBQSEiLpdDrpkksukVasWNEsaartsWv60jGbzdKLL74otWvXTtJoNFLHjh2l9957r9pjtWvXzhHInD8lJibWeb3CwkIJkG699daLnueuXbukQYMGSTqdTvL19ZWee+45yW63S3fddZekVqulBQsW1OZy1VtDr/P5qvsi/v7776X4+HgpODhYUqvVkq+vrxQfHy/99ttv1W5f0zWu+Hu9Ntd4w4YNEiDdfffdUmRkpKTRaKSoqCjp5ptvlvbs2XORK9M4GnJ963Ld3n//fWngwIGSn5+fpFarpdDQUOk///mPdOzYsSrrNsX7uNzrr78uAdLrr79e620ayhXzivPVFKDW9hrXlEc3trq85wRBIUl16OdDEASnW7ZsGddddx179uy5aCfdQv3U5hrPmzePBx54gPz8/CZvINQa1ed9/N577zFt2jRycnLw9fVt4hS2fCKvEFoyMZKUILQwa9as4dZbbxVfOE2oNtd4//79hIeHi+C0nurzPt6/fz8REREiOK0lkVcILZkoQRUEQaiH4cOHo9PpWLlypbOT0mYMHDiQgIAAli1b5uykCILQxEQJqiAIQj3s379ftDpuRpIkcfDgQXr27OnspAiC0AxECaogCIIgCILgUupcgvrPP/8wevRowsLCUCgULF68+KLbrF27ln79+qHT6ejYsSMLFiyoss7cuXOJjo5Gr9cTFxfH1q1b65o0QRCEFkHko4IgCBdW5476i4uLiY2N5a677mLs2LEXXT8xMZFRo0Zx//338+2337J69WruvvtuQkNDSUhIAODHH39k2rRpjvGr58yZQ0JCAkeOHKnSqW917HY7qampeHp6inF8BUFoEpIkUVhYSFhYWIM7pnfFfBREXioIQtOqUz7akD6qAOnXX3+94DpPPfVUlf7Zxo8fLyUkJDheDxw4UJoyZYrjtc1mk8LCwqTZs2fXKh3JyckX7NtQTGISk5gaa0pOTq59JlkL4Br5qCSJvFRMYhJT80y1yUebfKjTTZs2ER8fX2leQkICjz76KCAPC7hjxw6mT5/uWK5UKomPj2fTpk3V7tNkMmEymRyvpbJqtMnJyaLLF0EQmkRBQQGRkZF4eno2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",
      "text/plain": [
       "<Figure size 800x200 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "i0 = torch.rand(1)\n",
    "alpha, beta, gamma = torch.rand(1), torch.rand(1), torch.rand(1)\n",
    "i = torch.randint(0,5,(1,)).item()\n",
    "\n",
    "y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "\n",
    "params = torch.tensor([alpha, beta, gamma])\n",
    "\n",
    "_, y_mic = run_spatial_intervention(params, i, i0, T)\n",
    "y_mac = training_ode_grid_sirs.simulate_and_intervene(model, params, i, y0, T)\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(8, 2))\n",
    "\n",
    "_ = plt.suptitle(r\"$i0 =$\" + \n",
    "                 f\"{i0.item():.3}\" + \n",
    "                 r\"; $\\alpha =$\" + \n",
    "                 f\"{alpha.item():.3}\" + \n",
    "                 r\"; $\\beta =$\" + \n",
    "                 f\"{beta.item():.3}\" + \n",
    "                 r\"; $\\gamma =$\" + \n",
    "                 f\"{gamma.item():.3}\" + \n",
    "                 r\"; $i=$\" + \n",
    "                 str(i),\n",
    "                 y = 1.)\n",
    "\n",
    "axes[0].plot(y_mac[:,0], label=\"S\")\n",
    "axes[0].plot(y_mac[:,1], label=\"I\")\n",
    "axes[0].plot(y_mac[:,2], label=\"R\")\n",
    "axes[0].legend()\n",
    "axes[0].set_ylim([-eps, 1+eps])\n",
    "axes[0].set_title(\"Mac\", y=0.5)\n",
    "\n",
    "axes[1].plot(y_mic[:, 0], label=\"S\")\n",
    "axes[1].plot(y_mic[:, 1], label=\"I\")\n",
    "axes[1].plot(y_mic[:, 2], label=\"R\")\n",
    "axes[1].set_ylim([-eps, 1+eps])\n",
    "_ = axes[1].set_title(\"Mic\", y=0.5)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81df1d21-400b-429b-b70f-2b4fa014dbcb",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb42d029-24a8-4421-854a-b1ffecb4b223",
   "metadata": {},
   "source": [
    "## Training ODE+RNN+Emission"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6382cbec-e4a1-4d5a-b986-82338ac9f036",
   "metadata": {},
   "source": [
    "### Code for initialising maps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "2f9c8f0a-6898-4106-87c0-ac7a4bd9d319",
   "metadata": {},
   "outputs": [],
   "source": [
    "identity_map = torch.nn.Identity()\n",
    "\n",
    "class Omega(torch.nn.Module):\n",
    "\n",
    "    def __init__(self, cnn, ffn):\n",
    "\n",
    "        super().__init__()\n",
    "        self.cnn = cnn\n",
    "        self.ffn = ffn\n",
    "\n",
    "    # def cnn_forward(self, grids):\n",
    "    #     return self.cnn(grids)\n",
    "\n",
    "    def forward(self, grids, pars):\n",
    "        # grid_embs = self.cnn(grids)\n",
    "        # x = torch.cat((grid_embs, pars), dim=-1)\n",
    "        x = pars\n",
    "        x = self.ffn(x)\n",
    "        return x\n",
    "    \n",
    "    # def forward(self, grids, pars):\n",
    "    #     grid_embs = self.cnn(grids)\n",
    "    #     x = torch.cat((grid_embs, pars), dim=-1)\n",
    "    #     return self.ffn(x)\n",
    "\n",
    "\n",
    "# Instantiates the ODE\n",
    "def instantiate_model(t):\n",
    "    model = sirs_ode.SIRSODE_naive_int(t)\n",
    "    return model\n",
    "    \n",
    "    \n",
    "# Helper function for initialising networks. Just makes below code cleaner for training different things\n",
    "def generate_networks():\n",
    "    # This is to map from hidden state of RNN to logits\n",
    "    mlp_net = MLP(input_dim=32, output_dim=3, hidden_dims=[32, 64, 32, 16], final_nonlinearity=torch.nn.Identity()).double()\n",
    "    # This is to map from ODE output to hidden state of RNN\n",
    "    rnn_net = RNN(input_size=3, final_ff=mlp_net, flavour='gru').double()\n",
    "    # This forms part of map from initial state of ABM to initial parameters of ODE\n",
    "    state_net = identity_map\n",
    "    cnn = torch.nn.Identity().double()\n",
    "    mlp = MLP(input_dim=3, output_dim=3, hidden_dims=[32, 64, 32], final_nonlinearity=torch.nn.Sigmoid()).double()\n",
    "    omega = Omega(cnn, mlp)\n",
    "    print(\"Total trainable parameters =\", \n",
    "          count_pars(omega) + \n",
    "          count_pars(state_net) + \n",
    "          count_pars(rnn_net)\n",
    "          )\n",
    "    return rnn_net, state_net, omega\n",
    "    \n",
    "\n",
    "# For defining the emission distribution\n",
    "def instantiate_emission(e_pars):\n",
    "    return torch.distributions.multinomial.Multinomial(total_count=N, logits=e_pars)\n",
    "\n",
    "\n",
    "# This is for computing negative log likelihood of observation x from ODE output y \n",
    "def negative_log_likelihood(x, y, rnn_net):\n",
    "    \"\"\"\n",
    "    x is (normalised) S, I, R from ABM, y from ODE, rnn_net is \n",
    "    \"\"\"\n",
    "    x, y = x[0], y[0]\n",
    "    x = (x * N).int()\n",
    "    emission_params = rnn_net(y)\n",
    "    emissions = [instantiate_emission(e_pars) for e_pars in emission_params]\n",
    "    lps = torch.stack([emissions[j].log_prob(x[j]) for j in range(x.shape[0])])\n",
    "    if lps.isnan().any():\n",
    "        print(\"nan\")\n",
    "    return -torch.sum(lps)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce78a259-2e77-45c4-a9e2-1469297e2b4f",
   "metadata": {},
   "source": [
    "### Train observationally"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "78171e6b-f204-4c61-a9f9-25c43028bf05",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters = 13798\n"
     ]
    }
   ],
   "source": [
    "rnn_net, state_net, omega = generate_networks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "4d8c8371-66b7-45a0-851f-776ca2b699ff",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fe74c2aeb34e46839245becefd1dc77c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "83bc0be79ea84348b939e8c063004b0d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "optimiser = Adam(list(rnn_net.parameters()) +\n",
    "                 list(omega.parameters()) +\n",
    "                 list(state_net.parameters()), \n",
    "                 lr=1e-2)\n",
    "scheduler = None\n",
    "# scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimiser, factor=0.5, patience=5)\n",
    "\n",
    "best_obs_omega, best_obs_rnn_net, loss_hist = training_ode_grid_sirs.train_epi(omega.double(),\n",
    "                                                       rnn_net.double(),\n",
    "                                                       torch.tensor([[0.]]).repeat(xs_train_obs.shape[0],1).double(),\n",
    "                                                       xs_train_obs.double(), \n",
    "                                                       this_train_obs.double(), \n",
    "                                                       instantiate_model, \n",
    "                                                       negative_log_likelihood, \n",
    "                                                       optimiser, \n",
    "                                                       scheduler=scheduler,\n",
    "                                                       batch_size=50, \n",
    "                                                       max_epochs_no_improve=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "e2e1df63-0195-4141-b92e-bc6a855a709e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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SYUei8Wi8EqIiIgoWNL37WA2bGIunEg3GvN2YiIiotjT1dUFk8kU8Dkx13PicrlQX1+PpKQkCIIQ0o9tsViQn5+P2tpa9rOEEF/X8OFrGz58bcODr2v4RPtrK4oiurq6kJOTA5UqcFdJzFVOVCoV8vLywvo5jEZjVP7Bxjq+ruHD1zZ8+NqGB1/X8Inm13akiomEDbFEREQUVRhOiIiIKKownHjR6/V4+OGHodfrlV7KuMLXNXz42oYPX9vw4OsaPuPptY25hlgiIiIa31g5ISIioqjCcEJERERRheGEiIiIogrDCREREUUVhhOP8vJyTJw4EQaDAYsXL8aOHTuUXlLMeeyxx1BWVoakpCRkZGTgqquuwtGjRwc9p7+/H2vXrkVaWhoSExPxla98BU1NTQqtODY9/vjjEAQB99xzj/w2vq5jV1dXh6997WtIS0tDXFwc5syZg507d8qPi6KIhx56CNnZ2YiLi8OqVatw/PhxBVccG5xOJ376059i0qRJiIuLQ1FRER555JFB96rwtQ3Opk2bcMUVVyAnJweCIOCtt94a9Hgwr2N7eztuvvlmGI1GJCcn4xvf+Aa6u7sj+LsYJZHEl19+WdTpdOJzzz0nHjp0SPzWt74lJicni01NTUovLaasXr1a/Mtf/iIePHhQ3Lt3r3jZZZeJBQUFYnd3t/yc7373u2J+fr64YcMGcefOneKSJUvEZcuWKbjq2LJjxw5x4sSJ4ty5c8W7775bfjtf17Fpb28XCwsLxa9//evi9u3bxVOnTokffviheOLECfk5jz/+uGgymcS33npL3Ldvn/jlL39ZnDRpktjX16fgyqPfo48+KqalpYnvvvuuWFVVJb722mtiYmKi+Lvf/U5+Dl/b4Lz33nvigw8+KL7xxhsiAPHNN98c9Hgwr+Mll1wilpSUiNu2bRM3b94sTpkyRbzpppsi/DsJHsOJKIqLFi0S165dK//a6XSKOTk54mOPPabgqmJfc3OzCED89NNPRVEURbPZLGq1WvG1116Tn3P48GERgLh161allhkzurq6xKlTp4rr168Xzz//fDmc8HUdux//+Mfieeed5/dxl8slZmVliU888YT8NrPZLOr1evGll16KxBJj1uWXXy7efvvtg952zTXXiDfffLMoinxtx2poOAnmdaysrBQBiBUVFfJz3n//fVEQBLGuri5iax+Nc35bx2azYdeuXVi1apX8NpVKhVWrVmHr1q0Kriz2dXZ2AgBSU1MBALt27YLdbh/0Ws+YMQMFBQV8rYOwdu1aXH755YNeP4Cv69l45513UFpaiuuuuw4ZGRmYP38+nn32WfnxqqoqNDY2DnptTSYTFi9ezNd2BMuWLcOGDRtw7NgxAMC+ffuwZcsWXHrppQD42oZKMK/j1q1bkZycjNLSUvk5q1atgkqlwvbt2yO+5mDE3MV/odba2gqn04nMzMxBb8/MzMSRI0cUWlXsc7lcuOeee7B8+XLMnj0bANDY2AidTofk5ORBz83MzERjY6MCq4wdL7/8Mnbv3o2Kiophj/F1HbtTp07hj3/8I9atW4ef/OQnqKiowF133QWdToc1a9bIr5+vrw98bQO7//77YbFYMGPGDKjVajidTjz66KO4+eabAYCvbYgE8zo2NjYiIyNj0OMajQapqalR+1qf8+GEwmPt2rU4ePAgtmzZovRSYl5tbS3uvvturF+/HgaDQenljCsulwulpaX4n//5HwDA/PnzcfDgQfzpT3/CmjVrFF5dbHv11Vfxj3/8Ay+++CJmzZqFvXv34p577kFOTg5fWxrROb+tk56eDrVaPexkQ1NTE7KyshRaVWy744478O677+Ljjz9GXl6e/PasrCzYbDaYzeZBz+drHdiuXbvQ3NyMBQsWQKPRQKPR4NNPP8VTTz0FjUaDzMxMvq5jlJ2djeLi4kFvmzlzJmpqagBAfv349WH07rvvPtx///248cYbMWfOHNxyyy2499578dhjjwHgaxsqwbyOWVlZaG5uHvS4w+FAe3t71L7W53w40el0WLhwITZs2CC/zeVyYcOGDVi6dKmCK4s9oijijjvuwJtvvomNGzdi0qRJgx5fuHAhtFrtoNf66NGjqKmp4WsdwMqVK3HgwAHs3btX/q+0tBQ333yz/P98Xcdm+fLlw467Hzt2DIWFhQCASZMmISsra9Bra7FYsH37dr62I+jt7YVKNfhbjFqthsvlAsDXNlSCeR2XLl0Ks9mMXbt2yc/ZuHEjXC4XFi9eHPE1B0Xpjtxo8PLLL4t6vV58/vnnxcrKSvHb3/62mJycLDY2Niq9tJjyve99TzSZTOInn3wiNjQ0yP/19vbKz/nud78rFhQUiBs3bhR37twpLl26VFy6dKmCq45N3qd1RJGv61jt2LFD1Gg04qOPPioeP35c/Mc//iHGx8eLL7zwgvycxx9/XExOThbffvttcf/+/eKVV17J465BWLNmjZibmysfJX7jjTfE9PR08Uc/+pH8HL62wenq6hL37Nkj7tmzRwQgPvnkk+KePXvE6upqURSDex0vueQScf78+eL27dvFLVu2iFOnTuVR4ljw+9//XiwoKBB1Op24aNEicdu2bUovKeYA8PnfX/7yF/k5fX194ve//30xJSVFjI+PF6+++mqxoaFBuUXHqKHhhK/r2P3rX/8SZ8+eLer1enHGjBniM888M+hxl8sl/vSnPxUzMzNFvV4vrly5Ujx69KhCq40dFotFvPvuu8WCggLRYDCIkydPFh988EHRarXKz+FrG5yPP/7Y59fWNWvWiKIY3OvY1tYm3nTTTWJiYqJoNBrF2267Tezq6lLgdxMcQRS9xvURERERKeyc7zkhIiKi6MJwQkRERFGF4YSIiIiiCsMJERERRRWGEyIiIooqDCdEREQUVRhOiIiIKKownBAREVFUYTghIiKiqMJwQkRERFGF4YSIiIiiCsMJERERRZX/D5f3flnqAU1HAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)\n",
    "plt.gca().set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b7ffc323-a439-44d3-9da7-7971f0a5db8d",
   "metadata": {},
   "source": [
    "### Train interventionally"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "2db432da-9c75-4870-a7c3-525427434c35",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters = 13798\n"
     ]
    }
   ],
   "source": [
    "rnn_net, state_net, omega = generate_networks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "9b76754d-d6cd-4c3d-ab47-26a2d9ab2421",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2c5570e96a3a4e1c9cebf7e8f5a8a1a1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "70d07505b61242f1a44abc0eaab67c0e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "optimiser = Adam(list(rnn_net.parameters()) +\n",
    "                 list(omega.parameters()) +\n",
    "                 list(state_net.parameters()), \n",
    "                 lr=1e-2)\n",
    "scheduler = None\n",
    "# scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimiser, factor=0.5, patience=5)\n",
    "\n",
    "best_int_omega, best_int_rnn_net, loss_hist = training_ode_grid_sirs.train_epi(omega.double(),\n",
    "                                                       rnn_net.double(),\n",
    "                                                       torch.tensor([[0.]]).repeat(xs_train_int.shape[0],1).double(),\n",
    "                                                       xs_train_int.double(), \n",
    "                                                       this_train_int.double(), \n",
    "                                                       instantiate_model, \n",
    "                                                       negative_log_likelihood, \n",
    "                                                       optimiser, \n",
    "                                                       scheduler=scheduler,\n",
    "                                                       batch_size=50, \n",
    "                                                       max_epochs_no_improve=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "3d5e896a-5e4e-4c64-862a-ae2471574902",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)\n",
    "plt.gca().set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2c0ea3ba-18d9-4460-af20-bbf1af8a0b03",
   "metadata": {},
   "source": [
    "## Compute metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "c2643c3e-ec05-4de3-8e64-42aa5ad611d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mse_loss(x, y):\n",
    "    return torch.pow(x - y, 2).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 564,
   "id": "8374ffb8-edd5-4155-97ea-3534c2e37a38",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_dists(omega, params, model, y0, i, rnn_net):\n",
    "\n",
    "    new_params = omega(torch.tensor([[0.]]).double(), params.unsqueeze(0).double())[0]\n",
    "    y_mac = model(torch.cat((y0, torch.tensor([i])), dim=-1), new_params)[:, :-1]\n",
    "    e_pars = rnn_net(y_mac.double())\n",
    "    e_dists = [instantiate_emission(e_par) for e_par in e_pars]\n",
    "    return e_dists\n",
    "\n",
    "def build_lnode_compute_metric(omega, params, model, y0, i, rnn_net, x):\n",
    "\n",
    "    e_dists = generate_dists(omega, params, model, y0, i, rnn_net)\n",
    "    y_mac_stoch = torch.cat([e_d.sample((1,)) for e_d in e_dists])\n",
    "    assert y_mac_stoch.shape[0] == 51, y_mac_stoch.shape[1] == 3\n",
    "    y_mac_stoch_mean = torch.stack([e_d.mean for e_d in e_dists])\n",
    "    # Stoch MSE\n",
    "    this_stoch_mse_loss = mse_loss(x, y_mac_stoch / N)   \n",
    "    # MSE\n",
    "    this_mse_loss = mse_loss(x, y_mac_stoch_mean / N)       \n",
    "    # MSE infections\n",
    "    # this_mseinf_loss = mse_loss(x[:, 1], y_mac_stoch[:, 1] / N) \n",
    "    max_inf_idx = torch.argmax(x[:, 1])\n",
    "    this_mseinf_loss = torch.abs(x[max_inf_idx, 1] - y_mac_stoch[max_inf_idx, 1] / N)\n",
    "    # Negative log-likelihood\n",
    "    ll = 0.\n",
    "    for t in range(T+1):\n",
    "        term = e_dists[t].log_prob((x[t] * N).int())\n",
    "        ll += term\n",
    "    return this_stoch_mse_loss, this_mse_loss, this_mseinf_loss, -ll"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "b942b260-1226-4d22-bbf3-a188b73d0521",
   "metadata": {},
   "outputs": [],
   "source": [
    "test_ts = torch.linspace(0,T,T+1)\n",
    "# Instantiate model\n",
    "model = instantiate_model(test_ts)   "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "13ce1a59-1a8d-4f33-8556-0fee68cf0836",
   "metadata": {},
   "source": [
    "### Observational test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 565,
   "id": "4960bc5a-82ca-4549-b6d8-e5ea38572161",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = xs_test_obs.shape[0]\n",
    "\n",
    "# Test observationally trained surrogate on observational data\n",
    "test_obs_msesstoch_obs = []\n",
    "test_obs_mses_obs = []\n",
    "test_obs_msesinf_obs = []\n",
    "test_obs_neg_log_probs_obs = []\n",
    "# Test interventionally trained surrogate on observational data\n",
    "test_obs_msesstoch_int = []\n",
    "test_obs_mses_int = []\n",
    "test_obs_msesinf_int = []\n",
    "test_obs_neg_log_probs_int = []\n",
    "# Test straight ODE\n",
    "test_obs_naive_mses = []     \n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        this_test_x, i0, (alpha, beta, gamma), i = xs_test_obs[r], xs_test_obs[r, 0, 1], this_test_obs[r, :3], this_test_obs[r, -1].item()\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # LNODE TRAINED OBSERVATIONALLY\n",
    "        this_obs_stoch_loss, this_obs_mse_loss, this_obs_mseinf_loss, this_obs_nll = build_lnode_compute_metric(best_obs_omega, \n",
    "                                                                                                                params, \n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_obs_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_obs_msesstoch_obs.append(this_obs_stoch_loss)\n",
    "        test_obs_mses_obs.append(this_obs_mse_loss)\n",
    "        test_obs_msesinf_obs.append(this_obs_mseinf_loss)\n",
    "        test_obs_neg_log_probs_obs.append(this_obs_nll)\n",
    "        # LNODE TRAINED INTERVENTIONALLY\n",
    "        this_int_stoch_loss, this_int_mse_loss, this_int_mseinf_loss, this_int_nll = build_lnode_compute_metric(best_int_omega, \n",
    "                                                                                                                params,\n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_int_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_obs_msesstoch_int.append(this_int_stoch_loss)\n",
    "        test_obs_mses_int.append(this_int_mse_loss)\n",
    "        test_obs_msesinf_int.append(this_int_mseinf_loss)\n",
    "        test_obs_neg_log_probs_int.append(this_int_nll)\n",
    "        # STRAIGHT ODE\n",
    "        y_mac_oracle = training_ode_grid_sirs.simulate_and_intervene(model, params, i, y0, T)\n",
    "        test_obs_naive_mses.append(mse_loss(this_test_x, y_mac_oracle)) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 566,
   "id": "26a1455e-6ad7-4560-a139-64143b04946a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg MSE to straight ODE = tensor(4.6363)\n",
      "\n",
      "Avg Stoch MSE to LNODE OBS = tensor(0.2310, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.0385, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(0.2220, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(1356.9209, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.3954, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.0271, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.3863, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(2062.6848, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg MSE to straight ODE =\", sum(test_int_naive_mses) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_obs_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_obs_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\", sum(test_obs_mses_obs) / R, \"; avg NLL for LNODE OBS =\", sum(test_obs_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_obs_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_obs_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\", sum(test_obs_mses_int) / R, \"; avg NLL for LNODE INT =\", sum(test_obs_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 321,
   "id": "01119709-fc9c-4574-9f19-952e5c8c523b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg MSE to straight ODE = tensor(4.6363)\n",
      "\n",
      "Avg Stoch MSE to LNODE OBS = tensor(0.2308, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.0314, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(0.2220, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(1356.9209, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.3948, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.0646, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.3863, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(2062.6848, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg MSE to straight ODE =\", sum(test_int_naive_mses) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_obs_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_obs_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\", sum(test_obs_mses_obs) / R, \"; avg NLL for LNODE OBS =\", sum(test_obs_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_obs_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_obs_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\", sum(test_obs_mses_int) / R, \"; avg NLL for LNODE INT =\", sum(test_obs_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc64f839-2760-42fb-8eea-bd070bebaee6",
   "metadata": {},
   "source": [
    "### Interventional test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 567,
   "id": "5aab072d-9c49-4564-8b1b-4d470ff58882",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = xs_test_int.shape[0]\n",
    "\n",
    "# Test observationally trained surrogate on observational data\n",
    "test_int_msesstoch_obs = []\n",
    "test_int_mses_obs = []\n",
    "test_int_msesinf_obs = []\n",
    "test_int_neg_log_probs_obs = []\n",
    "# Test interventionally trained surrogate on observational data\n",
    "test_int_msesstoch_int = []\n",
    "test_int_mses_int = []\n",
    "test_int_msesinf_int = []\n",
    "test_int_neg_log_probs_int = []\n",
    "# Test straight ODE\n",
    "test_int_naive_mses = []\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        this_test_x, i0, (alpha, beta, gamma), i = xs_test_int[r], xs_test_int[r, 0, 1], this_test_int[r, :3], this_test_int[r, -1].item()\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # LNODE TRAINED OBSERVATIONALLY\n",
    "        this_obs_stoch_loss, this_obs_mse_loss, this_obs_mseinf_loss, this_obs_nll = build_lnode_compute_metric(best_obs_omega, \n",
    "                                                                                                                params, \n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_obs_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_int_msesstoch_obs.append(this_obs_stoch_loss)\n",
    "        test_int_mses_obs.append(this_obs_mse_loss)\n",
    "        test_int_msesinf_obs.append(this_obs_mseinf_loss)\n",
    "        test_int_neg_log_probs_obs.append(this_obs_nll)\n",
    "        # LNODE TRAINED INTERVENTIONALLY\n",
    "        this_int_stoch_loss, this_int_mse_loss, this_int_mseinf_loss, this_int_nll = build_lnode_compute_metric(best_int_omega, \n",
    "                                                                                                                params, \n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_int_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_int_msesstoch_int.append(this_int_stoch_loss)\n",
    "        test_int_mses_int.append(this_int_mse_loss)\n",
    "        test_int_msesinf_int.append(this_int_mseinf_loss)\n",
    "        test_int_neg_log_probs_int.append(this_int_nll)\n",
    "        # STRAIGHT ODE\n",
    "        y_mac_oracle = training_ode_grid_sirs.simulate_and_intervene(model, params, i, y0, T)\n",
    "        test_int_naive_mses.append(mse_loss(this_test_x, y_mac_oracle))\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 568,
   "id": "965b44eb-342c-4214-be76-5199c75728bd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg MSE to straight ODE = tensor(4.6363)\n",
      "\n",
      "Avg Stoch MSE to LNODE OBS = tensor(1.9666, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.0405, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(1.9584, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(8807.8772, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.3517, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.0289, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.3439, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(2071.1537, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg MSE to straight ODE =\", sum(test_int_naive_mses) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_int_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_int_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\", sum(test_int_mses_obs) / R, \"; avg NLL for LNODE OBS =\", sum(test_int_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_int_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_int_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\", sum(test_int_mses_int) / R, \"; avg NLL for LNODE INT =\", sum(test_int_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 309,
   "id": "6332d15c-cef2-468c-b858-b41f17a8049b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg MSE to straight ODE = tensor(4.6363)\n",
      "\n",
      "Avg Stoch MSE to LNODE OBS = tensor(1.9661, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.2665, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(1.9584, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(8807.8772, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.3513, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.0744, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.3439, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(2071.1537, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg MSE to straight ODE =\", sum(test_int_naive_mses) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_int_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_int_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\", sum(test_int_mses_obs) / R, \"; avg NLL for LNODE OBS =\", sum(test_int_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_int_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_int_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\", sum(test_int_mses_int) / R, \"; avg NLL for LNODE INT =\", sum(test_int_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 310,
   "id": "820d3abd-aa6d-4f58-8f6c-d37b8bd3e9b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3.5819892473118284"
      ]
     },
     "execution_count": 310,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "0.2665 / 0.0744"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 293,
   "id": "02c31e48-8ff8-4553-b6d5-2a27ec720643",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg MSE to straight ODE = tensor(4.6363)\n",
      "Avg MSE to LNODE OBS = tensor(4.1036, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(17643.6625, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.3439, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(2071.1537, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "# THIS IS WITH ODE INTERVENTION = 0 ALWAYS\n",
    "\n",
    "print(\"Avg MSE to straight ODE =\", sum(test_int_naive_mses) / R)\n",
    "\n",
    "print(\"Avg MSE to LNODE OBS =\", sum(test_int_mses_obs) / R, \"; avg NLL for LNODE OBS =\", sum(test_int_neg_log_probs_obs) / R)\n",
    "print(\"Avg MSE to LNODE INT =\", sum(test_int_mses_int) / R, \"; avg NLL for LNODE INT =\", sum(test_int_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74ce089c-2e73-464d-8abb-d36225ed5bce",
   "metadata": {},
   "source": [
    "## Plot example behaviours"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "df0d40ab-55aa-4fb4-af4e-ec46aa83e9de",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scienceplots\n",
    "plt.style.use('science')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 548,
   "id": "7581557e-3154-497c-94e9-6ae5b0f969e6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.9483, 0.9767, 0.4974]) 0.18 1\n"
     ]
    }
   ],
   "source": [
    "with torch.no_grad():\n",
    "\n",
    "    i0 = 0.18#torch.rand(1)\n",
    "    #alpha, beta, gamma = torch.rand(1), torch.rand(1), torch.rand(1)\n",
    "    i = 1#torch.randint(0,5,(1,)).item()    \n",
    "    y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "    params = torch.tensor([alpha, beta, gamma])\n",
    "    model = instantiate_model(test_ts)\n",
    "\n",
    "    # Simulate from ABM\n",
    "    _, y_mic_null = run_spatial_intervention(params, 0, i0, T)\n",
    "    _, y_mic = run_spatial_intervention(params, i, i0, T)\n",
    "\n",
    "    # Simulate from observationally trained LNODE\n",
    "    e_obs_dists_null = generate_dists(best_obs_omega, params, model, y0, 0, best_obs_rnn_net)\n",
    "    y_mac_obs_stoch_null = torch.stack([e_d.sample((1,)) for e_d in e_obs_dists_null])\n",
    "    e_obs_dists = generate_dists(best_obs_omega, params, model, y0, i, best_obs_rnn_net)\n",
    "    y_mac_obs_stoch = torch.stack([e_d.sample((1,)) for e_d in e_obs_dists])\n",
    "\n",
    "    # Simulate from interventionally trained LNODE\n",
    "    e_int_dists_null = generate_dists(best_int_omega, params, model, y0, 0, best_int_rnn_net)\n",
    "    y_mac_int_stoch_null = torch.stack([e_d.sample((1,)) for e_d in e_int_dists_null])\n",
    "    e_int_dists = generate_dists(best_int_omega, params, model, y0, i, best_int_rnn_net)\n",
    "    y_mac_int_stoch = torch.stack([e_d.sample((1,)) for e_d in e_int_dists])\n",
    "\n",
    "    print(params, i0, i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 553,
   "id": "c94ba28a-6ad8-4176-8351-a57caa382675",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([51, 3])\n",
      "torch.Size([51, 3])\n",
      "tensor(0.3296, dtype=torch.float64) tensor(13.0453, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1300x200 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 3, figsize=(13, 2), sharey=True)\n",
    "plt.subplots_adjust(wspace=0.05)\n",
    "\n",
    "y_name = 1.\n",
    "\n",
    "axes[1].plot(y_mic[..., 0], label=\"S\", c='b')\n",
    "axes[1].plot(y_mic[..., 1], label=\"I\", c='orange')\n",
    "axes[1].plot(y_mic[..., 2], label=\"R\", c='green')\n",
    "axes[1].plot(y_mic_null[..., 0], ls='-.', c='b')\n",
    "axes[1].plot(y_mic_null[..., 1], ls='-.', c='orange')\n",
    "axes[1].plot(y_mic_null[..., 2], ls='-.', c='green')\n",
    "axes[1].axvline(5 + i - 1, ls='--', c='black', alpha=0.5)\n",
    "\n",
    "axes[1].set_ylim([-eps, 1+eps])\n",
    "_ = axes[1].set_title(r\"$\\texttt{ABM}$\", y=y_name, fontsize=15)\n",
    "# axes[0].legend()\n",
    "\n",
    "axes[0].plot(y_mac_int_stoch[:,0,0] / N, label=\"S\", c='b')\n",
    "axes[0].plot(y_mac_int_stoch[:,0,1] / N, label=\"I\", c='orange')\n",
    "axes[0].plot(y_mac_int_stoch[:,0,2] / N, label=\"R\", c='green')\n",
    "axes[0].plot(y_mac_int_stoch_null[...,0,0] / N, ls='-.', c='b')\n",
    "axes[0].plot(y_mac_int_stoch_null[...,0,1] / N, ls='-.', c='orange')\n",
    "axes[0].plot(y_mac_int_stoch_null[...,0,2] / N, ls='-.', c='green')\n",
    "axes[0].axvline(5 + i - 1, ls='--', c='black', alpha=0.5)\n",
    "axes[1].legend(ncols=3, loc=0,#alignment='right', loc=9, \n",
    "               fontsize=12)\n",
    "eps = 1e-2\n",
    "axes[0].set_ylim([-eps, 1+eps])\n",
    "axes[0].set_title(r\"$\\texttt{LODE-RNN}\\,\\text{  ({\\bf I})}$\", y=y_name, fontsize=15)\n",
    "axes[1].set_xlabel(\"Time\", fontsize=15)\n",
    "\n",
    "axes[2].plot(y_mac_obs_stoch[:,0,0] / N, label=\"S\", c='b')\n",
    "axes[2].plot(y_mac_obs_stoch[:,0,1] / N, label=\"I\", c='orange')\n",
    "axes[2].plot(y_mac_obs_stoch[:,0,2] / N, label=\"R\", c='green')\n",
    "axes[2].plot(y_mac_obs_stoch_null[:,0,0] / N, label=\"S\", ls='-.', c='b')\n",
    "axes[2].plot(y_mac_obs_stoch_null[:,0,1] / N, label=\"I\", ls='-.', c='orange')\n",
    "axes[2].plot(y_mac_obs_stoch_null[:,0,2] / N, label=\"R\", ls='-.', c='green')\n",
    "axes[2].set_ylim([-eps, 1+eps])\n",
    "axes[2].axvline(5 + i - 1, ls='--', c='black', alpha=0.5)\n",
    "_ = axes[2].set_title(r\"$\\texttt{LODE-RNN}\\,\\text{  ({\\bf O})}$\", y=y_name, fontsize=15)\n",
    "\n",
    "print(y_mac_int_stoch[:, 0, :].shape)\n",
    "print(y_mic.shape)\n",
    "print(mse_loss(y_mic, y_mac_int_stoch[:, 0, :] / N), mse_loss(y_mic, y_mac_obs_stoch[:, 0, :] / N))\n",
    "\n",
    "plt.savefig(\"./plots/int_vs_obs_lnode/lnode_int_obs_example_095_098_050_018_1_and_0.pdf\", format='pdf', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cea36204-c5b5-4091-9a36-e0c9c7a1bbf7",
   "metadata": {},
   "source": [
    "## Training ODE+Emission"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5281d974-2910-41ee-8215-e5ef322551a0",
   "metadata": {},
   "source": [
    "### Code for initialising maps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 311,
   "id": "fd75c904-24b4-448c-8d36-7df65349a667",
   "metadata": {},
   "outputs": [],
   "source": [
    "identity_map = torch.nn.Identity()\n",
    "\n",
    "class Omega(torch.nn.Module):\n",
    "\n",
    "    def __init__(self, cnn, ffn):\n",
    "\n",
    "        super().__init__()\n",
    "        self.cnn = cnn\n",
    "        self.ffn = ffn\n",
    "\n",
    "    def forward(self, grids, pars):\n",
    "        # grid_embs = self.cnn(grids)\n",
    "        # x = torch.cat((grid_embs, pars), dim=-1)\n",
    "        x = pars\n",
    "        x = self.ffn(x)\n",
    "        return x\n",
    "\n",
    "\n",
    "# Instantiates the ODE\n",
    "def instantiate_model(t):\n",
    "    model = sirs_ode.SIRSODE_naive_int(t)\n",
    "    return model\n",
    "    \n",
    "    \n",
    "# Helper function for initialising networks. Just makes below code cleaner for training different things\n",
    "def generate_networks():\n",
    "    # This is to map from hidden state of RNN to logits\n",
    "    mlp_net = identity_map #MLP(input_dim=32, output_dim=3, hidden_dims=[32, 64, 32, 16], final_nonlinearity=torch.nn.Identity()).double()\n",
    "    # This is to map from ODE output to hidden state of RNN\n",
    "    rnn_net = identity_map #RNN(input_size=3, final_ff=mlp_net, flavour='gru').double()\n",
    "    # This forms part of map from initial state of ABM to initial parameters of ODE\n",
    "    state_net = identity_map\n",
    "    cnn = torch.nn.Identity().double()\n",
    "    mlp = MLP(input_dim=3, output_dim=3, hidden_dims=[32, 64, 32], final_nonlinearity=torch.nn.Sigmoid()).double()\n",
    "    omega = Omega(cnn, mlp)\n",
    "    print(\"Total trainable parameters =\", \n",
    "          count_pars(omega) + \n",
    "          count_pars(state_net) + \n",
    "          count_pars(rnn_net)\n",
    "          )\n",
    "    return rnn_net, state_net, omega\n",
    "    \n",
    "\n",
    "# For defining the emission distribution\n",
    "def instantiate_emission(e_pars):\n",
    "    return torch.distributions.multinomial.Multinomial(total_count=N, probs=e_pars)\n",
    "\n",
    "\n",
    "# This is for computing negative log likelihood of observation x from ODE output y \n",
    "def negative_log_likelihood(x, y, rnn_net):\n",
    "    \"\"\"\n",
    "    x is (normalised) S, I, R from ABM, y from ODE, rnn_net is \n",
    "    \"\"\"\n",
    "    x, y = x[0], y[0]\n",
    "    x = (x * N).int()\n",
    "    emission_params = rnn_net(y)\n",
    "    emissions = [instantiate_emission(e_pars) for e_pars in emission_params]\n",
    "    lps = torch.stack([emissions[j].log_prob(x[j]) for j in range(x.shape[0])])\n",
    "    if lps.isnan().any():\n",
    "        print(\"nan\")\n",
    "    return -torch.sum(lps)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2cc9ffa2-a953-42bd-b8e5-f5a05c3fa1b3",
   "metadata": {},
   "source": [
    "### Train observationally"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 312,
   "id": "2beb5335-baf1-4bc7-ab89-b82fe264b809",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters = 4419\n"
     ]
    }
   ],
   "source": [
    "rnn_net, state_net, omega = generate_networks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 313,
   "id": "054b4e9f-d1fa-4593-91d5-bd520fc7796a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "eceed2764d674db68603989aa0173e33",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "39bb0ce1781e4f5f9dfcc98d384591d2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "optimiser = Adam(list(rnn_net.parameters()) +\n",
    "                 list(omega.parameters()) +\n",
    "                 list(state_net.parameters()), \n",
    "                 lr=1e-2)\n",
    "scheduler = None\n",
    "# scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimiser, factor=0.5, patience=5)\n",
    "\n",
    "best_obs_ode_omega, best_obs_ode_rnn_net, loss_hist = training_ode_grid_sirs.train_epi(omega.double(),\n",
    "                                                       rnn_net.double(),\n",
    "                                                       torch.tensor([[0.]]).repeat(xs_train_obs.shape[0],1).double(),\n",
    "                                                       xs_train_obs.double(), \n",
    "                                                       this_train_obs.double(), \n",
    "                                                       instantiate_model, \n",
    "                                                       negative_log_likelihood, \n",
    "                                                       optimiser, \n",
    "                                                       scheduler=scheduler,\n",
    "                                                       batch_size=50, \n",
    "                                                       max_epochs_no_improve=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 314,
   "id": "2da3aee6-6738-4a40-b91b-9129a1b96392",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x262.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)\n",
    "plt.gca().set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63576d25-04a7-462d-88ec-344e596c2cbf",
   "metadata": {},
   "source": [
    "### Train interventionally"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 315,
   "id": "8be2d890-a417-4e63-8a49-5ef653d35fb2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters = 4419\n"
     ]
    }
   ],
   "source": [
    "rnn_net, state_net, omega = generate_networks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 316,
   "id": "76200abf-8d96-4660-84fa-3dd8a99dd1ea",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0e4f4d8f3d074c79ba13abb76438951a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f43a84e136254907880895f9d603fe9b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "optimiser = Adam(list(rnn_net.parameters()) +\n",
    "                 list(omega.parameters()) +\n",
    "                 list(state_net.parameters()), \n",
    "                 lr=1e-2)\n",
    "scheduler = None\n",
    "# scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimiser, factor=0.5, patience=5)\n",
    "\n",
    "best_int_ode_omega, best_int_ode_rnn_net, loss_hist = training_ode_grid_sirs.train_epi(omega.double(),\n",
    "                                                       rnn_net.double(),\n",
    "                                                       torch.tensor([[0.]]).repeat(xs_train_int.shape[0],1).double(),\n",
    "                                                       xs_train_int.double(), \n",
    "                                                       this_train_int.double(), \n",
    "                                                       instantiate_model, \n",
    "                                                       negative_log_likelihood, \n",
    "                                                       optimiser, \n",
    "                                                       scheduler=scheduler,\n",
    "                                                       batch_size=50, \n",
    "                                                       max_epochs_no_improve=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 317,
   "id": "e1545fa7-e558-4731-b89a-c84d5ebe4780",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x262.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)\n",
    "plt.gca().set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0c5a5f36-3f12-4230-afca-9a97362c6190",
   "metadata": {},
   "source": [
    "## Compute metrics"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "69a1e8e8-34dc-4b45-ad4f-13e4144bd7dc",
   "metadata": {},
   "source": [
    "### Observational test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 323,
   "id": "2eca97d8-9f8f-4cf9-90a3-341f195a3db5",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = xs_test_obs.shape[0]\n",
    "\n",
    "# Test observationally trained surrogate on observational data\n",
    "test_obs_ode_msesstoch_obs = []\n",
    "test_obs_ode_mses_obs = []\n",
    "test_obs_ode_msesinf_obs = []\n",
    "test_obs_ode_neg_log_probs_obs = []\n",
    "# Test interventionally trained surrogate on observational data\n",
    "test_obs_ode_msesstoch_int = []\n",
    "test_obs_ode_mses_int = []\n",
    "test_obs_ode_msesinf_int = []\n",
    "test_obs_ode_neg_log_probs_int = []\n",
    "# Test straight ODE\n",
    "test_obs_naive_mses = []     \n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        this_test_x, i0, (alpha, beta, gamma), i = xs_test_obs[r], xs_test_obs[r, 0, 1], this_test_obs[r, :3], this_test_obs[r, -1].item()\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # LNODE TRAINED OBSERVATIONALLY\n",
    "        this_obs_stoch_loss, this_obs_mse_loss, this_obs_mseinf_loss, this_obs_nll = build_lnode_compute_metric(best_obs_ode_omega, \n",
    "                                                                                                                params, \n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_obs_ode_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_obs_ode_msesstoch_obs.append(this_obs_stoch_loss)\n",
    "        test_obs_ode_mses_obs.append(this_obs_mse_loss)\n",
    "        test_obs_ode_msesinf_obs.append(this_obs_mseinf_loss)\n",
    "        test_obs_ode_neg_log_probs_obs.append(this_obs_nll)\n",
    "        # LNODE TRAINED INTERVENTIONALLY\n",
    "        this_int_stoch_loss, this_int_mse_loss, this_int_mseinf_loss, this_int_nll = build_lnode_compute_metric(best_int_ode_omega, \n",
    "                                                                                                                params,\n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_int_ode_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_obs_ode_msesstoch_int.append(this_int_stoch_loss)\n",
    "        test_obs_ode_mses_int.append(this_int_mse_loss)\n",
    "        test_obs_ode_msesinf_int.append(this_int_mseinf_loss)\n",
    "        test_obs_ode_neg_log_probs_int.append(this_int_nll)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 324,
   "id": "40786e86-7372-4f55-9e23-d850834674fa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg Stoch MSE to LNODE OBS = tensor(0.3900, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.0723, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(0.3816, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(1950.9221, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(1.4746, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.2012, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(1.4653, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(5936.1327, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_obs_ode_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_obs_ode_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\",       sum(test_obs_ode_mses_obs) / R,      \"; avg NLL for LNODE OBS =\",      sum(test_obs_ode_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_obs_ode_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_obs_ode_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\",       sum(test_obs_ode_mses_int) / R,      \"; avg NLL for LNODE INT =\",      sum(test_obs_ode_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b6a0d5ba-578e-4655-99a5-4b86d90c5cef",
   "metadata": {},
   "source": [
    "### Interventional test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 325,
   "id": "0d2c11e2-fc14-437a-9b30-98c5aeed667e",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = xs_test_int.shape[0]\n",
    "\n",
    "# Test observationally trained surrogate on observational data\n",
    "test_int_ode_msesstoch_obs = []\n",
    "test_int_ode_mses_obs = []\n",
    "test_int_ode_msesinf_obs = []\n",
    "test_int_ode_neg_log_probs_obs = []\n",
    "# Test interventionally trained surrogate on observational data\n",
    "test_int_ode_msesstoch_int = []\n",
    "test_int_ode_mses_int = []\n",
    "test_int_ode_msesinf_int = []\n",
    "test_int_ode_neg_log_probs_int = []\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        this_test_x, i0, (alpha, beta, gamma), i = xs_test_int[r], xs_test_int[r, 0, 1], this_test_int[r, :3], this_test_int[r, -1].item()\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # LNODE TRAINED OBSERVATIONALLY\n",
    "        this_obs_stoch_loss, this_obs_mse_loss, this_obs_mseinf_loss, this_obs_nll = build_lnode_compute_metric(best_obs_ode_omega, \n",
    "                                                                                                                params, \n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_obs_ode_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_int_ode_msesstoch_obs.append(this_obs_stoch_loss)\n",
    "        test_int_ode_mses_obs.append(this_obs_mse_loss)\n",
    "        test_int_ode_msesinf_obs.append(this_obs_mseinf_loss)\n",
    "        test_int_ode_neg_log_probs_obs.append(this_obs_nll)\n",
    "        # LNODE TRAINED INTERVENTIONALLY\n",
    "        this_int_stoch_loss, this_int_mse_loss, this_int_mseinf_loss, this_int_nll = build_lnode_compute_metric(best_int_ode_omega, \n",
    "                                                                                                                params, \n",
    "                                                                                                                model, \n",
    "                                                                                                                y0, \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_int_ode_rnn_net, \n",
    "                                                                                                                this_test_x)\n",
    "        test_int_ode_msesstoch_int.append(this_int_stoch_loss)\n",
    "        test_int_ode_mses_int.append(this_int_mse_loss)\n",
    "        test_int_ode_msesinf_int.append(this_int_mseinf_loss)\n",
    "        test_int_ode_neg_log_probs_int.append(this_int_nll)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 326,
   "id": "4ba7f073-a513-4169-bd44-f613c3038ee5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg Stoch MSE to LNODE OBS = tensor(2.0864, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.3420, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(2.0782, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(9412.2184, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.7725, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.1416, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.7646, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(3825.9348, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_int_ode_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_int_ode_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\",       sum(test_int_ode_mses_obs) / R,      \"; avg NLL for LNODE OBS =\",      sum(test_int_ode_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_int_ode_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_int_ode_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\",       sum(test_int_ode_mses_int) / R,      \"; avg NLL for LNODE INT =\",      sum(test_int_ode_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1140a672-67d7-42d5-88aa-73bd1859255b",
   "metadata": {},
   "source": [
    "## Training NODE+Emission"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6f959735-6cdb-4fe1-b265-57d76f5b5cdf",
   "metadata": {},
   "source": [
    "### Code for initialising maps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 474,
   "id": "eb443fbc-c1ea-4dc5-bc79-5eb3d00a1aa8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Instantiates the ODE\n",
    "def create_instantiate(net):\n",
    "    def instantiate_node(t):\n",
    "        model = sirs_ode.SIRSNODE_naive(t, net)\n",
    "        return model\n",
    "    return instantiate_node\n",
    "    \n",
    "# Helper function for initialising networks. Just makes below code cleaner for training different things\n",
    "def generate_node_networks():\n",
    "    # This is to map from hidden state of RNN to logits\n",
    "    mlp_net = MLP(input_dim=32, output_dim=3, hidden_dims=[16, 32, 32, 16], final_nonlinearity=torch.nn.Identity()).double()\n",
    "    # This is to map from ODE output to hidden state of RNN\n",
    "    rnn_net = identity_map#torch.nn.Sequential(identity_map, mlp_net) #RNN(input_size=3, final_ff=mlp_net, flavour='gru').double()\n",
    "    # Vector field network\n",
    "    vector_field = RNN(input_size=3, hidden_size=32, final_ff=mlp_net, flavour='gru').double()#MLP(input_dim=6, output_dim=3, hidden_dims=[16, 32, 32, 16], final_nonlinearity=torch.nn.Tanh()).double()\n",
    "    # This forms part of map from initial state of ABM to initial parameters of ODE\n",
    "    state_net = identity_map\n",
    "    cnn = torch.nn.Identity().double()\n",
    "    mlp = MLP(input_dim=3, output_dim=3, hidden_dims=[32, 64, 32], final_nonlinearity=torch.nn.Sigmoid()).double()\n",
    "    omega = Omega(cnn, mlp)\n",
    "    print(\"Total trainable parameters =\", \n",
    "          count_pars(omega) + \n",
    "          count_pars(state_net) + \n",
    "          count_pars(rnn_net) +\n",
    "          count_pars(vector_field)\n",
    "          )\n",
    "    return rnn_net, vector_field, state_net, omega\n",
    "    \n",
    "\n",
    "# For defining the emission distribution\n",
    "def instantiate_emission(e_pars):\n",
    "    return torch.distributions.multinomial.Multinomial(total_count=N, logits=e_pars)\n",
    "\n",
    "\n",
    "# This is for computing negative log likelihood of observation x from ODE output y \n",
    "def negative_log_likelihood(x, y, rnn_net):\n",
    "    \"\"\"\n",
    "    x is (normalised) S, I, R from ABM, y from ODE, rnn_net is \n",
    "    \"\"\"\n",
    "    x, y = x[0], y[0]\n",
    "    x = (x * N).int()\n",
    "    emission_params = rnn_net(y)\n",
    "    emissions = [instantiate_emission(e_pars) for e_pars in emission_params]\n",
    "    lps = torch.stack([emissions[j].log_prob(x[j]) for j in range(x.shape[0])])\n",
    "    if lps.isnan().any():\n",
    "        print(\"nan\")\n",
    "    return -torch.sum(lps)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "afa950ed-6792-43cd-9a3d-c2750caea0f7",
   "metadata": {},
   "source": [
    "### Train observationally"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 480,
   "id": "caa70459-3059-4e58-8a52-b7a687c04550",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters = 10678\n"
     ]
    }
   ],
   "source": [
    "rnn_net, vfield, state_net, omega = generate_node_networks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 481,
   "id": "76770931-fc3e-462f-9446-1ccb7c0ab2db",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1b63e8b5bb49452085454dcca21f6ad9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "059eaf8c4e28407182998c5cc85c69f1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "optimiser = Adam(list(rnn_net.parameters()) +\n",
    "                 list(omega.parameters()) +\n",
    "                 list(state_net.parameters()) +\n",
    "                 list(vfield.parameters()), \n",
    "                 lr=1e-2)\n",
    "scheduler = None\n",
    "# scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimiser, factor=0.5, patience=5)\n",
    "\n",
    "instantiate_node_obs = create_instantiate(vfield)\n",
    "\n",
    "best_obs_node_omega, best_obs_node_rnn_net, best_obs_node_model, loss_hist = training_ode_grid_sirs.train_epi(omega.double(),\n",
    "                                                       rnn_net.double(),\n",
    "                                                       torch.tensor([[0.]]).repeat(xs_train_obs.shape[0],1).double(),\n",
    "                                                       xs_train_obs.double(), \n",
    "                                                       this_train_obs.double(), \n",
    "                                                       instantiate_node_obs, \n",
    "                                                       negative_log_likelihood, \n",
    "                                                       optimiser, \n",
    "                                                       scheduler=scheduler,\n",
    "                                                       batch_size=50, \n",
    "                                                       max_epochs_no_improve=20,\n",
    "                                                       full_node=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 482,
   "id": "19b963f8-3eb3-4198-bd5b-fb3b45f1dda8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x262.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)\n",
    "plt.gca().set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "20817270-312d-4846-a2c8-731a24cc42c2",
   "metadata": {},
   "source": [
    "### Train interventionally"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 477,
   "id": "117d2057-527b-45b7-91b3-3ab5312f58ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total trainable parameters = 10678\n"
     ]
    }
   ],
   "source": [
    "rnn_net, vfield, state_net, omega = generate_node_networks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 478,
   "id": "f6d498de-32d7-4d42-b853-d8a82872e5c3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "260624873bfc49128c0796a9a66ee2db",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f7fb8026ac054d12976c2985e37da281",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "optimiser = Adam(list(rnn_net.parameters()) +\n",
    "                 list(omega.parameters()) +\n",
    "                 list(state_net.parameters()) +\n",
    "                 list(vfield.parameters()), \n",
    "                 lr=1e-2)\n",
    "scheduler = None\n",
    "# scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimiser, factor=0.5, patience=5)\n",
    "\n",
    "instantiate_node_int = create_instantiate(vfield)\n",
    "\n",
    "best_int_node_omega, best_int_node_rnn_net, best_int_node_model, loss_hist = training_ode_grid_sirs.train_epi(omega.double(),\n",
    "                                                       rnn_net.double(),\n",
    "                                                       torch.tensor([[0.]]).repeat(xs_train_obs.shape[0],1).double(),\n",
    "                                                       xs_train_int.double(), \n",
    "                                                       this_train_int.double(), \n",
    "                                                       instantiate_node_int, \n",
    "                                                       negative_log_likelihood, \n",
    "                                                       optimiser, \n",
    "                                                       scheduler=scheduler,\n",
    "                                                       batch_size=50, \n",
    "                                                       max_epochs_no_improve=20,\n",
    "                                                       full_node=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 479,
   "id": "f48e2c86-f886-44a5-83d2-9b12a09b55a0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 350x262.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)\n",
    "plt.gca().set_yscale('log')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "750ad645-d724-4930-bcaf-2c5f55f85e72",
   "metadata": {},
   "source": [
    "## Compute metrics"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0abce177-f64c-4bf8-8d37-5d7fc4c73194",
   "metadata": {},
   "source": [
    "### Observational test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 485,
   "id": "3e92efd9-a2d3-4abc-8e38-e123d140f371",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = xs_test_obs.shape[0]\n",
    "\n",
    "# Test observationally trained surrogate on observational data\n",
    "test_obs_node_msesstoch_obs = []\n",
    "test_obs_node_mses_obs = []\n",
    "test_obs_node_msesinf_obs = []\n",
    "test_obs_node_neg_log_probs_obs = []\n",
    "# Test interventionally trained surrogate on observational data\n",
    "test_obs_node_msesstoch_int = []\n",
    "test_obs_node_mses_int = []\n",
    "test_obs_node_msesinf_int = []\n",
    "test_obs_node_neg_log_probs_int = []\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        this_test_x, i0, (alpha, beta, gamma), i = xs_test_obs[r], xs_test_obs[r, 0, 1], this_test_obs[r, :3], this_test_obs[r, -1].item()\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # LNODE TRAINED OBSERVATIONALLY\n",
    "        this_obs_stoch_loss, this_obs_mse_loss, this_obs_mseinf_loss, this_obs_nll = build_lnode_compute_metric(best_obs_node_omega.double(), \n",
    "                                                                                                                params.double(), \n",
    "                                                                                                                best_obs_node_model.double(), \n",
    "                                                                                                                y0.double(), \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_obs_node_rnn_net.double(), \n",
    "                                                                                                                this_test_x)\n",
    "        test_obs_node_msesstoch_obs.append(this_obs_stoch_loss)\n",
    "        test_obs_node_mses_obs.append(this_obs_mse_loss)\n",
    "        test_obs_node_msesinf_obs.append(this_obs_mseinf_loss)\n",
    "        test_obs_node_neg_log_probs_obs.append(this_obs_nll)\n",
    "        # LNODE TRAINED INTERVENTIONALLY\n",
    "        this_int_stoch_loss, this_int_mse_loss, this_int_mseinf_loss, this_int_nll = build_lnode_compute_metric(best_int_node_omega.double(), \n",
    "                                                                                                                params.double(),\n",
    "                                                                                                                best_int_node_model.double(), \n",
    "                                                                                                                y0.double(), \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_int_node_rnn_net.double(), \n",
    "                                                                                                                this_test_x)\n",
    "        test_obs_node_msesstoch_int.append(this_int_stoch_loss)\n",
    "        test_obs_node_mses_int.append(this_int_mse_loss)\n",
    "        test_obs_node_msesinf_int.append(this_int_mseinf_loss)\n",
    "        test_obs_node_neg_log_probs_int.append(this_int_nll)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 486,
   "id": "0ee01675-b355-4bef-a7f8-e54363f27540",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg Stoch MSE to LNODE OBS = tensor(0.6391, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(0.1374, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(0.6301, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(3325.0542, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.6052, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.1553, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.5965, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(3214.1551, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_obs_node_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_obs_node_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\",       sum(test_obs_node_mses_obs) / R,      \"; avg NLL for LNODE OBS =\",      sum(test_obs_node_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_obs_node_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_obs_node_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\",       sum(test_obs_node_mses_int) / R,      \"; avg NLL for LNODE INT =\",      sum(test_obs_node_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aa21f344-44d9-46a1-acb9-75558e28c3fe",
   "metadata": {},
   "source": [
    "### Interventional test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 487,
   "id": "5eb94770-9b7b-4f7a-bf92-8e0f47a80d30",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "R = xs_test_int.shape[0]\n",
    "\n",
    "# Test observationally trained surrogate on observational data\n",
    "test_int_node_msesstoch_obs = []\n",
    "test_int_node_mses_obs = []\n",
    "test_int_node_msesinf_obs = []\n",
    "test_int_node_neg_log_probs_obs = []\n",
    "# Test innterventionally trained surrogate on observational data\n",
    "test_int_node_msesstoch_int = []\n",
    "test_int_node_mses_int = []\n",
    "test_int_node_msesinf_int = []\n",
    "test_int_node_neg_log_probs_int = []\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        this_test_x, i0, (alpha, beta, gamma), i = xs_test_int[r], xs_test_int[r, 0, 1], this_test_int[r, :3], int(this_test_int[r, -1].item())\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        # LNODE TRAINED OBSERVATIONALLY\n",
    "        this_obs_stoch_loss, this_obs_mse_loss, this_obs_mseinf_loss, this_obs_nll = build_lnode_compute_metric(best_obs_node_omega.double(), \n",
    "                                                                                                                params.double(), \n",
    "                                                                                                                best_obs_node_model.double(), \n",
    "                                                                                                                y0.double(), \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_obs_node_rnn_net.double(), \n",
    "                                                                                                                this_test_x)\n",
    "        test_int_node_msesstoch_obs.append(this_obs_stoch_loss)\n",
    "        test_int_node_mses_obs.append(this_obs_mse_loss)\n",
    "        test_int_node_msesinf_obs.append(this_obs_mseinf_loss)\n",
    "        test_int_node_neg_log_probs_obs.append(this_obs_nll)\n",
    "        # LNODE TRAINED INTERVENTIONALLY\n",
    "        this_int_stoch_loss, this_int_mse_loss, this_int_mseinf_loss, this_int_nll = build_lnode_compute_metric(best_int_node_omega.double(), \n",
    "                                                                                                                params.double(), \n",
    "                                                                                                                best_int_node_model.double(), \n",
    "                                                                                                                y0.double(), \n",
    "                                                                                                                i, \n",
    "                                                                                                                best_int_node_rnn_net.double(), \n",
    "                                                                                                                this_test_x)\n",
    "        test_int_node_msesstoch_int.append(this_int_stoch_loss)\n",
    "        test_int_node_mses_int.append(this_int_mse_loss)\n",
    "        test_int_node_msesinf_int.append(this_int_mseinf_loss)\n",
    "        test_int_node_neg_log_probs_int.append(this_int_nll)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 488,
   "id": "8e704dc8-1d1d-4276-863f-8ad7a45e510e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Avg Stoch MSE to LNODE OBS = tensor(4.7094, dtype=torch.float64) ; avg MSE Infs for LNODE OBS = tensor(1.0499, dtype=torch.float64)\n",
      "Avg MSE to LNODE OBS = tensor(4.7006, dtype=torch.float64) ; avg NLL for LNODE OBS = tensor(20177.3198, dtype=torch.float64)\n",
      "\n",
      "Avg Stoch MSE to LNODE INT = tensor(0.5793, dtype=torch.float64) ; avg MSE Infs for LNODE INT = tensor(0.1392, dtype=torch.float64)\n",
      "Avg MSE to LNODE INT = tensor(0.5725, dtype=torch.float64) ; avg NLL for LNODE INT = tensor(3165.9421, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(\"Avg Stoch MSE to LNODE OBS =\", sum(test_int_node_msesstoch_obs) / R, \"; avg MSE Infs for LNODE OBS =\", sum(test_int_node_msesinf_obs) / R)\n",
    "print(\"Avg MSE to LNODE OBS =\",       sum(test_int_node_mses_obs) / R,      \"; avg NLL for LNODE OBS =\",      sum(test_int_node_neg_log_probs_obs) / R)\n",
    "print()\n",
    "print(\"Avg Stoch MSE to LNODE INT =\", sum(test_int_node_msesstoch_int) / R, \"; avg MSE Infs for LNODE INT =\", sum(test_int_node_msesinf_int) / R)\n",
    "print(\"Avg MSE to LNODE INT =\",       sum(test_int_node_mses_int) / R,      \"; avg NLL for LNODE INT =\",      sum(test_int_node_neg_log_probs_int) / R)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 407,
   "id": "560d127e-8020-416c-bd38-fccbd3dbfc47",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_node_dists(omega, params, model, y0, i, rnn_net):\n",
    "\n",
    "    new_params = omega(torch.tensor([[0.]]).double(), params.unsqueeze(0).double())[0]\n",
    "    y_mac = model(torch.cat((y0, torch.tensor([i])), dim=-1), new_params)[:, :-1]\n",
    "    e_pars = rnn_net(y_mac.double())\n",
    "    e_dists = [instantiate_emission(e_par) for e_par in e_pars]\n",
    "    return e_dists"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 408,
   "id": "8e0f80d2-4573-46e2-ab04-2d0093d3ef20",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([0.1756, 0.8244, 0.0000]), tensor([0.5679, 0.2080, 0.2644]), 0)"
      ]
     },
     "execution_count": 408,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y0, params, i"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 415,
   "id": "c0fc0c81-fe1b-4293-b917-090de160b887",
   "metadata": {},
   "outputs": [],
   "source": [
    "with torch.no_grad():\n",
    "\n",
    "    # Simulate from ABM\n",
    "    i_ = 2\n",
    "    _, y_mic = run_spatial_intervention(params, i_, y0[..., 1, ...], T)\n",
    "\n",
    "    # Simulate from observationally trained LNODE\n",
    "    dists = generate_node_dists(best_int_node_omega, params, best_int_node_model, y0, i_, best_int_node_rnn_net)\n",
    "    y_mac_int_stoch = torch.stack([e_d.sample((1,)) for e_d in dists])\n",
    "    y_mac_int_stoch_mean = torch.stack([e_d.mean for e_d in dists])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 416,
   "id": "af7af402-c379-45e3-b16a-eae88f00525f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(2.7445, dtype=torch.float64) tensor(9.2368, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1300x200 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 2, figsize=(13, 2), sharey=True)\n",
    "plt.subplots_adjust(wspace=0.05)\n",
    "\n",
    "y_name = 1.\n",
    "\n",
    "axes[1].plot(y_mic[..., 0], label=\"S\")\n",
    "axes[1].plot(y_mic[..., 1], label=\"I\")\n",
    "axes[1].plot(y_mic[..., 2], label=\"R\")\n",
    "\n",
    "axes[1].set_ylim([-eps, 1+eps])\n",
    "_ = axes[1].set_title(\"ABM\", y=y_name, fontsize=15)\n",
    "# axes[0].legend()\n",
    "\n",
    "axes[0].plot(y_mac_int_stoch[:,0,0] / N, label=\"S\")\n",
    "axes[0].plot(y_mac_int_stoch[:,0,1] / N, label=\"I\")\n",
    "axes[0].plot(y_mac_int_stoch[:,0,2] / N, label=\"R\")\n",
    "# axes[1].plot(y_mac_learn_stoch_mean[...,0], ls='--')#, c='b')\n",
    "# axes[1].plot(y_mac_learn_stoch_mean[...,1], ls='--')#, c='orange')\n",
    "# axes[1].plot(y_mac_learn_stoch_mean[...,2], ls='--')#, c='green')\n",
    "axes[1].legend(ncols=3, alignment='center', loc=9, fontsize=12)\n",
    "eps = 1e-2\n",
    "axes[0].set_ylim([-eps, 1+eps])\n",
    "axes[0].set_title(\"LNODE Int.\", y=y_name, fontsize=15)\n",
    "axes[1].set_xlabel(\"Time\", fontsize=15)\n",
    "\n",
    "# axes[2].plot(y_mac_obs_stoch[:,0,0] / N, label=\"S\")\n",
    "# axes[2].plot(y_mac_obs_stoch[:,0,1] / N, label=\"I\")\n",
    "# axes[2].plot(y_mac_obs_stoch[:,0,2] / N, label=\"R\")\n",
    "# axes[2].set_ylim([-eps, 1+eps])\n",
    "# _ = axes[2].set_title(\"LNODE Obs.\", y=y_name, fontsize=15)\n",
    "\n",
    "print(mse_loss(y_mic, y_mac_int_stoch[:,0,:] / N), mse_loss(y_mic, y_mac_obs_stoch[:, 0, :] / N))\n",
    "\n",
    "# plt.savefig(\"./plots/int_vs_obs_lnode/lnode_int_obs_example6.pdf\", format='pdf', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b003d94e-639e-4fcd-92c1-6de83e471c80",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "causal",
   "language": "python",
   "name": "causal"
  },
  "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
