{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6c51b7ed-1200-44e1-a8b6-732c1e0539b2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "983220d6-1de0-48ab-8dc1-9aee3436060c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\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\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "82b04d62-39b1-412e-8d1f-762861a13272",
   "metadata": {},
   "source": [
    "# Simulation setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "76d9178a-988a-4feb-8161-84adef156384",
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 50\n",
    "\n",
    "def run_spatial_intervention(params, i, i0, T):\n",
    "\n",
    "    model = sirs_spatial.SIRS(n_timesteps=T, i0=i0, N=N)\n",
    "    x_grid = model.initialize(params)\n",
    "    true_i0 = (x_grid == 1).sum() / N**2\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**2\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 observational data from ABM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "aaa510ed-02a9-46f8-bd2d-959712a56360",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 50\n",
    "\n",
    "init_states = []\n",
    "xs = []\n",
    "this = []\n",
    "\n",
    "for i in range(1000):\n",
    "    i0 = torch.rand(1)\n",
    "    alpha, beta, gamma = torch.rand(1), torch.rand(1), torch.rand(1)\n",
    "    params = torch.tensor([alpha, beta, gamma])\n",
    "    init_state, x = run_spatial_intervention(params, 0, i0, T)\n",
    "    init_states.append(init_state)\n",
    "    xs.append(x)\n",
    "    this.append(torch.cat((params, torch.tensor([0.])), dim=-1))\n",
    "\n",
    "xs = torch.stack(xs)\n",
    "init_states = torch.stack(init_states)\n",
    "this = torch.stack(this)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e5667d01-76a4-4f79-a532-e3243ee372e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(xs, \"./sirs_ode_spatial/aggregate_ts_OBS.pt\")\n",
    "torch.save(init_states, \"./sirs_ode_spatial/initial_grids_OBS.pt\")\n",
    "torch.save(this, \"./sirs_ode_spatial/par_intervention_OBS.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cd5e7fe4-1766-4e99-9db8-a7f4362c2854",
   "metadata": {},
   "source": [
    "### Also collect test set of interventional data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "88269c47-a24c-45b9-aa33-4101bc7266d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "init_states = []\n",
    "xs = []\n",
    "this = []\n",
    "\n",
    "for i in range(1000):\n",
    "    i0 = torch.rand(1)\n",
    "    alpha, beta, gamma = torch.rand(1), torch.rand(1), torch.rand(1)\n",
    "    params = torch.tensor([alpha, beta, gamma])\n",
    "    intervention = torch.randint(0, 5, (1,)).item()\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "f56c3b80-1e08-4d67-b5ad-43a652ec5773",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.9712, 0.6523, 0.2413, 2.0000],\n",
       "        [0.5629, 0.1299, 0.5374, 2.0000],\n",
       "        [0.1702, 0.8845, 0.6040, 2.0000],\n",
       "        ...,\n",
       "        [0.4241, 0.0157, 0.3265, 0.0000],\n",
       "        [0.7515, 0.4438, 0.1929, 1.0000],\n",
       "        [0.1005, 0.2562, 0.2096, 4.0000]])"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "this"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "013dcf7a-80e3-4cb0-b1dd-495d81753235",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(xs, \"./sirs_ode_spatial/aggregate_ts_INT_TEST.pt\")\n",
    "torch.save(init_states, \"./sirs_ode_spatial/initial_grids_INT_TEST.pt\")\n",
    "torch.save(this, \"./sirs_ode_spatial/par_intervention_INT_TEST.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "89d05a1d-d801-47ef-812e-74ade01e878e",
   "metadata": {},
   "source": [
    "## And of observational data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "0573ee0f-0066-4294-9e09-bbe7f44889a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "init_states = []\n",
    "xs = []\n",
    "this = []\n",
    "\n",
    "for i in range(1000):\n",
    "    i0 = torch.rand(1)\n",
    "    alpha, beta, gamma = torch.rand(1), torch.rand(1), torch.rand(1)\n",
    "    params = torch.tensor([alpha, beta, gamma])\n",
    "    intervention = 0\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "1ae24631-771a-45cf-a8bc-6190a2bf6fb8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.6285, 0.8545, 0.7787, 0.0000],\n",
       "        [0.9396, 0.0755, 0.3874, 0.0000],\n",
       "        [0.5678, 0.9123, 0.4715, 0.0000],\n",
       "        ...,\n",
       "        [0.8600, 0.1710, 0.1596, 0.0000],\n",
       "        [0.7551, 0.6485, 0.6280, 0.0000],\n",
       "        [0.0286, 0.8117, 0.6103, 0.0000]])"
      ]
     },
     "execution_count": 109,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "this"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "37e117fd-0086-4b50-b71e-925bc45ea35e",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(xs, \"./sirs_ode_spatial/aggregate_ts_OBS_TEST.pt\")\n",
    "torch.save(init_states, \"./sirs_ode_spatial/initial_grids_OBS_TEST.pt\")\n",
    "torch.save(this, \"./sirs_ode_spatial/par_intervention_OBS_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": 24,
   "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",
    "eps = 1e-2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "e84b96c8-9019-4930-b742-888e4317377f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": "3d2eedfe-fbb4-4839-bb12-a7f3ef4c5809",
   "metadata": {},
   "source": [
    "#### Or load if already saved"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "13d5e198-ca36-4f85-b462-a44c7b0c579f",
   "metadata": {},
   "outputs": [],
   "source": [
    "xs = torch.load(\"./sirs_ode_spatial/aggregate_ts_OBS.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "3ce6145c-a2ef-41b9-b1a1-1bf0782c4c4f",
   "metadata": {},
   "outputs": [],
   "source": [
    "iss = torch.load(\"./sirs_ode_spatial/initial_grids_OBS.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "282113e1-d4dd-45e0-8f3a-53a308216373",
   "metadata": {},
   "outputs": [],
   "source": [
    "this = torch.load(\"./sirs_ode_spatial/par_intervention_OBS.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "052ac5c4-6901-4e35-b8f0-60cb7d6c2c92",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.2815, 0.9626, 0.6774, 2.0000],\n",
       "        [0.7957, 0.8877, 0.2414, 1.0000],\n",
       "        [0.1517, 0.2960, 0.2373, 3.0000],\n",
       "        ...,\n",
       "        [0.4757, 0.9985, 0.5534, 2.0000],\n",
       "        [0.9921, 0.4016, 0.3151, 3.0000],\n",
       "        [0.7698, 0.3944, 0.2280, 3.0000]])"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "this"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "81df1d21-400b-429b-b70f-2b4fa014dbcb",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6382cbec-e4a1-4d5a-b986-82338ac9f036",
   "metadata": {},
   "source": [
    "### Initialise CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2f9c8f0a-6898-4106-87c0-ac7a4bd9d319",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Tau(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)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce78a259-2e77-45c4-a9e2-1469297e2b4f",
   "metadata": {},
   "source": [
    "### Train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "8215f4ba-3bf5-4a79-b4a5-fbaec024c698",
   "metadata": {},
   "outputs": [],
   "source": [
    "def instantiate_emission(e_pars):\n",
    "    return torch.distributions.dirichlet.Dirichlet(e_pars)\n",
    "\n",
    "mlp_net = MLP(input_dim=32, output_dim=3, hidden_dims=[32, 64, 32, 16], final_nonlinearity=torch.nn.Softplus()).double()\n",
    "# net = mlp_net\n",
    "net = RNN(input_size=3, final_ff=mlp_net, flavour='gru').double()\n",
    "# state_net = MLP(input_dim=6, output_dim=3, hidden_dims=[32, 64, 32, 16], final_nonlinearity=torch.nn.Sigmoid()\n",
    "               # ).double()\n",
    "state_net = torch.nn.Identity()\n",
    "\n",
    "kl_div = sirs_ode.create_kl_divergence(net, instantiate_emission)\n",
    "instantiate_model = sirs_ode.create_latent_ode(state_net)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "818ad811-c466-4816-a8d4-c1a9a7e2a8cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "final_ff_layers = [1]#\n",
    "# final_ff_layers = [16]\n",
    "# cnn = CNN(N=50, \n",
    "#           n_channels=2, \n",
    "#           hidden_layer_channels=1, \n",
    "#           conv_kernel_size=5, \n",
    "#           pool_kernel_size=32, \n",
    "#           final_ff=final_ff_layers).double()\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()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "1d81c6c8-6e0a-4f89-b76a-6184d62522b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4419\n",
      "13798\n"
     ]
    }
   ],
   "source": [
    "tau = Tau(cnn, mlp)\n",
    "print(sum(p.numel() for p in tau.parameters() if p.requires_grad))\n",
    "print(sum(p.numel() for p in cnn.parameters() if p.requires_grad) + sum(p.numel() for p in mlp.parameters() if p.requires_grad)\n",
    "      + sum(p.numel() for p in net.parameters() if p.requires_grad) + sum(p.numel() for p in state_net.parameters() if p.requires_grad))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "4d8c8371-66b7-45a0-851f-776ca2b699ff",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f8d076f23bf14c83b0a9a40545a4ac21",
       "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": "1afc138f35754382971b1bb28577dce9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from torch.optim import Adam\n",
    "\n",
    "optimiser = Adam(list(net.parameters()) + list(tau.parameters()) + 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_tau, loss_hist = training_ode_grid_sirs.train_epi(tau.double(), torch.tensor([[0.]]).repeat(1000,1).double(),\n",
    "                                                       # iss[:, :-1, ...].double(), \n",
    "                                                       xs.double(), this.double(), instantiate_model, kl_div, \n",
    "                                                       optimiser, scheduler=scheduler,\n",
    "                                                       batch_size=50, max_epochs_no_improve=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "e2e1df63-0195-4141-b92e-bc6a855a709e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x17709a7d0>]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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IiIiCgsMPSPwt7/9DZMmTYLFYkF+fj6++uqrYA8p4NatW4dFixYhOjoaycnJWL16NYqKityuWbZsGSRJcvv66U9/GqQRB84DDzzQ53VOnz5dvb+rqws33HADEhISEBUVhUsvvRTV1dVBHHHgTJo0qc/vQpIk3HDDDQDG93vi888/x7e+9S2kp6dDkiSsX7/e7X5ZlnHfffchLS0NERERWLFiBY4ePep2TUNDA6644grExMQgLi4Oa9euRVtb2yi+Cv/o73dhs9lw5513Yvbs2bBarUhPT8dVV12FiooKt+fw9l76wx/+MMqvZOQGel9cffXVfV7nqlWr3K4Jh/cFAK//dkiShIceeki9xl/vC4aeYXr55Zdx66234v7778euXbswd+5crFy5EjU1NcEeWkB99tlnuOGGG7B161Zs2LABNpsN559/Ptrb292uu/baa1FZWal+/elPfwrSiANr5syZbq9z8+bN6n233HIL3n77bbz66qv47LPPUFFRgUsuuSSIow2c7du3u/0eNmzYAAC47LLL1GvG63uivb0dc+fOxd/+9jev9//pT3/CX/7yFzz55JPYtm0brFYrVq5cia6uLvWaK664AgcOHMCGDRvwzjvv4PPPP8d11103Wi/Bb/r7XXR0dGDXrl349a9/jV27duH1119HUVERLrrooj7X/va3v3V7r/z85z8fjeH71UDvCwBYtWqV2+t88cUX3e4Ph/cFALffQWVlJZ555hlIkoRLL73U7Tq/vC9kGpbFixfLN9xwg/pnu90up6eny+vWrQviqEZfTU2NDED+7LPP1NvOOecc+aabbgreoEbJ/fffL8+dO9frfU1NTbLRaJRfffVV9bZDhw7JAOTCwsJRGmHw3HTTTXJeXp7scDhkWQ6f9wQA+Y033lD/7HA45NTUVPmhhx5Sb2tqapLNZrP84osvyrIsywcPHpQByNu3b1evef/992VJkuTy8vJRG7u/ef4uvPnqq69kAHJpaal6W3Z2tvzoo48GdnCjzNvv4oc//KF88cUX+3xMOL8vLr74Yvncc891u81f7wtWeoahp6cHO3fuxIoVK9TbdDodVqxYgcLCwiCObPQ1NzcDAOLj491u//e//43ExETMmjULd999Nzo6OoIxvIA7evQo0tPTkZubiyuuuAJlZWUAgJ07d8Jms7m9R6ZPn46srKxx/x7p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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_hist)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74ce089c-2e73-464d-8abb-d36225ed5bce",
   "metadata": {},
   "source": [
    "#### Plot behaviours after training to check they are doing well"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "3ced4872-deaf-44a0-9eea-d2fa88e04574",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.9329, 0.4014, 0.6381], dtype=torch.float64)\n",
      "tensor(7.5140, dtype=torch.float64) tensor(2.9263, dtype=torch.float64) tensor(3.8994)\n"
     ]
    },
    {
     "data": {
      "image/png": "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ejoAd999d43HtvR1ru91++WXXygqKqoyBcTmhRde4MEHH2Tv3r34+PjQu3dvHnvsMUC9c18fe/bswd/fn4iICCIiIujVqxdXXnklffr0Ydq0aWzatIlRo0ZVOa6lr/GZTJ06ldtvv51Dhw7RtWtX+/7c3FwmT55MTk4Oa9eubdR/K7Xp1KkTWq2Ww4cPk5+fzwsvvMCMGTPo3r17jce0lmvcUtft9H73dI1xfYQQQjQdCVYIIUQzOD3JW79+/Vi9ejV5eXkOiets+QP69etXbT3r169v8Bzr+p67PlJTU/Hz86uy32w2A1BWVtZo5zqdLShxeiK/l156qdr9lbX0da7vdfvqq6/w9PTkkksuqbFuPz8/zjvvPPvPK1asICIiwj6yoK52795d7Z1ri8UCUG2+A2j5a3wmtqkNubm59n0lJSVcfPHFHDp0iBUrVtCjR4961V1fRqOR8PBwDh8+zGuvvUZ+fj5PP/30GY9pDde4Ja/bmZJrQuNcHyGEEE1HghVCCNHELBYL+/btY9KkSfZ9U6dOZc6cOXz44Yc8+OCDgLpaw6effsqQIUOIjIystq7GmGNdl3MXFRWRkJBAYGBgvbL3x8XFsWzZMvvQdZuFCxei1WqbdFlL293UyqtcfP311/z9999AxTD26rT0da7PdUtPT2fFihVcc801uLu7O9X2b7/9ls2bNzNnzhy02votELZ7927c3d0xmUz23AalpaW899579OvXr8YRGy19jUFNwBgcHOxQp9ls5vPPP8fNzc3+xdpisXDVVVexYcMGfv311xpzRDS12NhY1q9fz5EjR7j33nurjLw5XXNe4+qub0tet+r63dNJzgohhGjdJFghhBBN7PDhw5SUlDjcfR4yZAhXXHEFs2bNIi0tjdjYWD777DOOHz/Oxx9/XGNdjTHHui7n3rRpE2PGjOGpp55yuIv77rvvkpOTY18J4PfffycpKQmAe++91x4oeOihh1iyZAkjRozgnnvuISAggD/++IMlS5Zwyy23OAwHd7ZOAI1Gw6hRo1izZk2N77N79+7ExMTwv//9D3d3d7RaLS+//DJXXnkl3333HU8//TQzZ86sdlRAS1/nulw3m2+//ZaysrIap4D8/fffPPvss5x//vkEBATw77//8umnnzJp0qRqE2E6c41zc3NJTEwEYNSoUUyfPp3i4mK++uor9u3b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",
      "text/plain": [
       "<Figure size 1300x200 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "N = 50\n",
    "\n",
    "def mse_loss(x, y):\n",
    "    return torch.pow(x - y, 2).sum()\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    learned_model = sirs_ode.SIRSODE_naive_int_lat(torch.linspace(0,T,T+1), state_net)\n",
    "    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",
    "    init_state, y_mic = run_spatial_intervention(params, i, i0, T)\n",
    "    # z = torch.zeros(1, 2, N, N)\n",
    "    # z[0, 0, ...] = init_state == 0\n",
    "    # z[0, 1, ...] = init_state == 1\n",
    "\n",
    "    # print(best_tau.cnn(z.double()))\n",
    "    # emb = best_tau.cnn_forward(z.double())\n",
    "    # print(emb)\n",
    "    # new_params = best_tau(emb, params.unsqueeze(0))[0]\n",
    "    new_params = best_tau(torch.tensor([[0.]]).double(), params.unsqueeze(0).double())[0]\n",
    "    print(new_params)\n",
    "    \n",
    "    y_mac_oracle = training_ode_grid_sirs.__simulate_and_intervene(model, params, i, y0, T)\n",
    "    y_mac_learn = learned_model(torch.cat((y0, torch.tensor([i])), dim=-1), new_params)[:, :-1]\n",
    "    e_pars = net(y_mac_learn.clamp_(min=1e-8).double())\n",
    "    # print(e_pars)\n",
    "    e_dists = [instantiate_emission(e_par) for e_par in e_pars]\n",
    "    y_mac_learn_stoch = torch.stack([e_d.sample((1,)) for e_d in e_dists])\n",
    "    y_mac_learn_stoch_mean = torch.stack([e_d.mean for e_d in e_dists])\n",
    "    \n",
    "    fig, axes = plt.subplots(1, 3, figsize=(13, 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",
    "    \n",
    "    axes[0].plot(y_mic[..., 0], label=\"S\")\n",
    "    axes[0].plot(y_mic[..., 1], label=\"I\")\n",
    "    axes[0].plot(y_mic[..., 2], label=\"R\")\n",
    "    \n",
    "    axes[0].set_ylim([-eps, 1+eps])\n",
    "    _ = axes[0].set_title(\"ABM\", y=0.5)\n",
    "    axes[0].legend()\n",
    "    \n",
    "    # axes[1].plot(y_mac_learn[...,0])\n",
    "    # axes[1].plot(y_mac_learn[...,1])\n",
    "    # axes[1].plot(y_mac_learn[...,2])\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[0].legend()\n",
    "    eps = 1e-2\n",
    "    axes[1].set_ylim([-eps, 1+eps])\n",
    "    axes[1].set_title(\"LNODE\", y=0.5)\n",
    "\n",
    "    axes[2].plot(y_mac_oracle[..., 0], label=\"S\")\n",
    "    axes[2].plot(y_mac_oracle[..., 1], label=\"I\")\n",
    "    axes[2].plot(y_mac_oracle[..., 2], label=\"R\")\n",
    "    axes[2].set_ylim([-eps, 1+eps])\n",
    "    _ = axes[2].set_title(\"SIRS ODE\", y=0.5)\n",
    "    \n",
    "    print(mse_loss(y_mic, y_mac_learn), mse_loss(y_mic, y_mac_learn_stoch_mean), mse_loss(y_mic, y_mac_oracle))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "955bde90-f1be-45b7-9aee-b95f08a3bae6",
   "metadata": {},
   "source": [
    "### Test set MSE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a25c08d5-ba9b-48ac-9d9b-016d1ad9e77f",
   "metadata": {},
   "source": [
    "#### Load test set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "8898c919-fa47-4b57-9197-3e9340c0b3e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "test_xs = torch.load(\"./sirs_ode_spatial/aggregate_ts_INT_TEST.pt\")\n",
    "test_iss = torch.load(\"./sirs_ode_spatial/initial_grids_INT_TEST.pt\")\n",
    "test_this = torch.load(\"./sirs_ode_spatial/par_intervention_INT_TEST.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8ef40e15-cdc3-4ed7-b183-5e154c6c8093",
   "metadata": {},
   "source": [
    "#### Compute test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "6095a62b-375a-442c-a44d-9a160d102ec9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.9884)"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_xs[0, 0, 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "32d62ce4-1ffc-4d5c-ad9d-00d1209baca5",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = test_xs.shape[0]\n",
    "\n",
    "test_mses = []\n",
    "test_naive_mses = []\n",
    "test_neg_log_probs = []\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        # Instantiate model\n",
    "        learned_model = sirs_ode.SIRSODE_naive_int_lat(torch.linspace(0,T,T+1), state_net)\n",
    "        this_test_x = test_xs[r]\n",
    "        i0 = test_xs[r, 0, 1]\n",
    "        alpha, beta, gamma = test_this[r, :3]\n",
    "        i = test_this[r, -1].item()\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        new_params = best_tau(torch.tensor([[0.]]).double(), params.unsqueeze(0).double())[0]\n",
    "        y_mac_oracle = training_ode_grid_sirs.__simulate_and_intervene(model, params, i, y0, T)\n",
    "        y_mac_learn = learned_model(torch.cat((y0, torch.tensor([i])), dim=-1), new_params)[:, :-1]\n",
    "        e_pars = net(y_mac_learn.clamp_(min=1e-8).double())\n",
    "        e_dists = [instantiate_emission(e_par) for e_par in e_pars]\n",
    "        y_mac_learn_stoch_mean = torch.stack([e_d.mean for e_d in e_dists])\n",
    "        test_mses.append(mse_loss(this_test_x, y_mac_learn_stoch_mean))\n",
    "        test_naive_mses.append(mse_loss(this_test_x, y_mac_oracle))\n",
    "        ll = 0.\n",
    "        for t in range(T+1):\n",
    "            term = e_dists[t].log_prob(this_test_x[t].clamp_(min=1e-8))\n",
    "            ll += term\n",
    "        test_neg_log_probs.append(-ll)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "803fca97-f2df-4396-b540-b4d9a7e9f915",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(4.8082, dtype=torch.float64) tensor(4.4317) tensor(12444.9193, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(sum(test_mses) / R, sum(test_naive_mses) / R, sum(test_neg_log_probs) / R)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "35446f5d-496a-4699-a7c8-412e708269bc",
   "metadata": {},
   "source": [
    "### Visualise some examples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "id": "02b06ba5-befe-4018-b1f9-5b4ddde023a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "633\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.5, 'LNODE OBS')"
      ]
     },
     "execution_count": 254,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAloAAADdCAYAAABjcdyjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAA9hAAAPYQGoP6dpAABSj0lEQVR4nO3deXhTVfrA8W+WNt13utFCgbKvA0JBREQqRVFBBEGcAdxFZHQYEHEUEGSKiD+ZUVRcEJxhU1RUVEYsgiirIPsuW4EuFOi+J+f3R2ggXWhSmqbL+3mePCQ377333ENz8ubcc8/VKKUUQgghhBCi2mmdXQAhhBBCiPpKEi0hhBBCCAeRREsIIYQQwkEk0RJCCCGEcBBJtIQQQgghHEQSLSGEEEIIB5FESwghhBDCQSTREkIIIYRwEEm0hBBCCCEcRBItIYQQQggHkURLCCGEEMJBJNGqR7Kzs9Fqtbz55pvOLooQ1U4pxRtvvEHLli1xdXWlcePGTJs2Dbldq3AmaXdFZSTRqkf279+PUopOnToBUFBQwJQpUwgPD8fd3Z2YmBjWrVtXI2W5kX0fOHCA4cOH07x5czw8PAgKCuLWW2/lm2++KRObnZ3N9OnTGThwIAEBAWg0GhYvXlzpPmbPno1Go6FDhw72HlqtciP1bGvdVaWOd+3axb333ktAQAAeHh506NCBf//731U4wqsmT57M5MmT6dOnD2+99Ra9evVi1qxZfPbZZze03cpUx+fI1vo4duwYI0eOJCIiAg8PD9q0acPMmTPJzc21itu5cycDBw7Ex8cHb29vBgwYwO7du2/kMJ3qRuvYlvrYsWMHzzzzDO3bt8fT05MmTZrwwAMPcPTo0Rsqe+l219Gq0nY587tAAErUG0ajUeXl5SmTyaSUUmrkyJFKr9erSZMmqYULF6pevXopvV6vNm3a5PCy3Mi+v/32WxUXF6dmzJih3n//fTV//nzVp08fBaiFCxdaxZ48eVIBqkmTJuq2225TgPr444+vu/3ExETl4eGhPD09Vfv27W/kMJ3uRurZ1rqzt47/97//KVdXVxUTE6P+7//+T73//vtqypQpavLkyVU+zhMnTiidTqdefvlly7LCwkLl5eWl/va3v1V5u7a40c+RrfVx5swZ5efnp5o2bari4+PVwoUL1dixYxWg7r33Xkvczp07lZubm2rZsqWaN2+emjt3roqKilI+Pj7q8OHD1XrsNeVG6tjW+rj//vtVaGiomjBhgvrggw/UrFmzVEhIiPL09FT79u2rctlLt7uOVNW2y5nfBUIpSbTqqW3btilAvf7665ZleXl5qkWLFqpXr151bt/FxcWqc+fOqnXr1lbL8/PzVVJSklJKqR07dtiUaI0YMULdfvvtqm/fvnU60brRera17uyp44yMDBUSEqLuu+8+ZTQa7T+oCrzxxhtKq9Wq1NRUyzKTyaS8vLzUiy++WG37Ke1G69ie+pg9e7YC1P79+62Wjx49WgHq0qVLSiml7rrrLuXv76/S0tIsMefPn1deXl5q6NCh9hxerXCjdWxrffz666+qoKDAat2jR48qg8GgHnrooWo4EserStvlzO8CYSanDuuRO+64g969ewOwatUqdDodTzzxhOV9Nzc3Hn30UbZs2UJiYqLDyuGIfet0OiIjI0lPT7dabjAYCA0NtXk7P//8M6tWrWL+/PnXjTt8+DBnzpyxebsrV66ka9euuLu707ZtW3788UeUUrRv357Zs2fbvB173Gg921p39tTxsmXLSElJYfbs2Wi1WnJycjCZTBXG21rP27Zto02bNjRq1MiybM+ePWRnZzv0lM2N1rE99ZGZmQlASEiI1fKwsDC0Wi2urq4AbNq0idjYWAIDA61i+vbty5o1a8jOzrZa39Y6fuyxxwgKCmLlypVl3vv+++/RaDR8++23lW7HXjdax7bWx80332ypwxItW7akffv2HDp0yGq5PZ//a9tdR7K17SrNmd8FwkwSrXpk7969li+d33//nVatWuHj42MV06NHD4AKx3MUFRWRlpZm06OiL4yq7ru0nJwc0tLS+OOPP3jzzTf5/vvv6d+/v03rlsdoNDJhwgQee+wxOnbseN3Ytm3bMnr0aJu2+9JLLzFy5Eg6d+7MvHnzMBqNjB49mu+++46zZ8/yzDPPlFmnNtVzdfrxxx/x8fHh3LlztG7dGi8vL3x8fBg3bhz5+fll4m2t53379tG5c2erZa+//jpubm7ccccd5a5TG+rYnvq47bbbAHj00UfZvXs3iYmJrFy5knfffZe//vWveHp6AubxNu7u7mX25eHhQWFhIfv377dabmsdDx8+nICAAF555RWr5Uoppk6dyq233sqgQYOs3qsNdWxvfZQ+tpSUFIKCgqyW2/P5v7bd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",
      "text/plain": [
       "<Figure size 700x200 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with torch.no_grad():\n",
    "\n",
    "    # r = 4\n",
    "    r = torch.randint(0,R,(1,)).item()\n",
    "    print(r)\n",
    "    # Instantiate model\n",
    "    learned_model = sirs_ode.SIRSODE_naive_int_lat(torch.linspace(0,T,T+1), state_net)\n",
    "    this_test_x = test_xs[r]\n",
    "    i0 = test_xs[r, 0, 1]\n",
    "    alpha, beta, gamma = test_this[r, :3]\n",
    "    i = test_this[r, -1].item()\n",
    "    y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "    params = torch.tensor([alpha, beta, gamma])\n",
    "    new_params = best_tau(torch.tensor([[0.]]).double(), params.unsqueeze(0).double())[0]\n",
    "    y_mac_oracle = training_ode_grid_sirs.__simulate_and_intervene(model, params, i, y0, T)\n",
    "    y_mac_learn = learned_model(torch.cat((y0, torch.tensor([i])), dim=-1), new_params)[:, :-1]\n",
    "    e_pars = net(y_mac_learn.clamp_(min=1e-8).double())\n",
    "    e_dists = [instantiate_emission(e_par) for e_par in e_pars]\n",
    "    y_mac_learn_stoch_mean = torch.stack([e_d.mean for e_d in e_dists])\n",
    "    init_state, y_mic = run_spatial_intervention(params, i, i0, T)\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(7, 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",
    "\n",
    "axes[0].plot(y_mic[..., 0], label=\"S\")\n",
    "axes[0].plot(y_mic[..., 1], label=\"I\")\n",
    "axes[0].plot(y_mic[..., 2], label=\"R\")\n",
    "\n",
    "axes[0].set_ylim([-eps, 1+eps])\n",
    "_ = axes[0].set_title(\"ABM\", y=0.5)\n",
    "axes[0].legend()\n",
    "\n",
    "# axes[1].plot(y_mac_learn[...,0])\n",
    "# axes[1].plot(y_mac_learn[...,1])\n",
    "# axes[1].plot(y_mac_learn[...,2])\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[0].legend()\n",
    "eps = 1e-2\n",
    "axes[1].set_ylim([-eps, 1+eps])\n",
    "axes[1].set_title(\"LNODE OBS\", y=0.5)\n",
    "\n",
    "# plt.savefig(\"./plots/int_vs_obs_lnode/lnode_obs_example.pdf\", format='pdf', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c6a0800f-b655-4708-99d8-ced768ced5c7",
   "metadata": {},
   "source": [
    "### Observational test set error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "077ac6cd-c45f-41cd-9f08-b70c11e8add2",
   "metadata": {},
   "outputs": [],
   "source": [
    "test_xs = torch.load(\"./sirs_ode_spatial/aggregate_ts_OBS_TEST.pt\")\n",
    "test_iss = torch.load(\"./sirs_ode_spatial/initial_grids_OBS_TEST.pt\")\n",
    "test_this = torch.load(\"./sirs_ode_spatial/par_intervention_OBS_TEST.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "46fa4130-bab7-44ce-855b-db2c3e066821",
   "metadata": {},
   "outputs": [],
   "source": [
    "R = test_xs.shape[0]\n",
    "\n",
    "test_mses = []\n",
    "test_naive_mses = []\n",
    "test_neg_log_probs = []\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    for r in range(R):\n",
    "        # Instantiate model\n",
    "        learned_model = sirs_ode.SIRSODE_naive_int_lat(torch.linspace(0,T,T+1), state_net)\n",
    "        this_test_x = test_xs[r]\n",
    "        i0 = test_xs[r, 0, 1]\n",
    "        alpha, beta, gamma = test_this[r, :3]\n",
    "        i = test_this[r, -1].item()\n",
    "        assert i == 0, \"Not observational\"\n",
    "        y0 = torch.tensor([1 - i0, i0, 0.])\n",
    "        params = torch.tensor([alpha, beta, gamma])\n",
    "        new_params = best_tau(torch.tensor([[0.]]).double(), params.unsqueeze(0).double())[0]\n",
    "        y_mac_oracle = training_ode_grid_sirs.__simulate_and_intervene(model, params, i, y0, T)\n",
    "        y_mac_learn = learned_model(torch.cat((y0, torch.tensor([i])), dim=-1), new_params)[:, :-1]\n",
    "        e_pars = net(y_mac_learn.clamp_(min=1e-8).double())\n",
    "        e_dists = [instantiate_emission(e_par) for e_par in e_pars]\n",
    "        y_mac_learn_stoch_mean = torch.stack([e_d.mean for e_d in e_dists])\n",
    "        test_mses.append(mse_loss(this_test_x, y_mac_learn_stoch_mean))\n",
    "        test_naive_mses.append(mse_loss(this_test_x, y_mac_oracle))\n",
    "        ll = 0.\n",
    "        for t in range(T+1):\n",
    "            term = e_dists[t].log_prob(this_test_x[t].clamp_(min=1e-8))\n",
    "            ll += term\n",
    "        test_neg_log_probs.append(-ll)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "3a6e30a3-367d-41db-bb80-22ff02659f4b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.4767, dtype=torch.float64) tensor(7.4040) tensor(-390.9909, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(sum(test_mses) / R, sum(test_naive_mses) / R, sum(test_neg_log_probs) / R)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2c57a90-e7c0-4c3e-a295-b3d2815033d8",
   "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
}
